:root,[data-theme="light"]{
  --bg-start:#0f1419;--bg-end:#1a2332;
  --card-bg:rgba(255,255,255,0.03);--card-border:rgba(255,255,255,0.1);
  --primary:#4a90e2;--primary-light:rgba(74,144,226,0.12);
  --accent:#4a90e2;--accent-soft:rgba(74,144,226,0.15);--accent-line:rgba(74,144,226,0.35);
  --accent-green:#10b981;--accent-green-soft:rgba(16,185,129,0.15);--accent-green-line:rgba(16,185,129,0.35);
  --text-main:#ffffff;--text-sub:#b8c5d6;--text-hint:#6b7d93;
  --nav-bg:rgba(15,20,25,0.96);--nav-border:rgba(255,255,255,0.08);
  --input-bg:rgba(255,255,255,0.04);--input-border:rgba(255,255,255,0.12);
  --table-stripe:rgba(255,255,255,0.02);--table-hover:rgba(74,144,226,0.08);
  --success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#4a90e2;
  --shadow:none;
  --shadow-lg:none;
  --rarity-common:#94a3b8;--rarity-uncommon:#10b981;--rarity-rare:#4a90e2;--rarity-epic:#a855f7;--rarity-legendary:#f59e0b;
  --modal-bg:rgba(15,20,25,0.94);--surface:rgba(255,255,255,0.03);--surface-soft:rgba(255,255,255,0.05);--surface-strong:rgba(255,255,255,0.08);--select-menu-bg:#16202b;--select-menu-text:#f3f7fb;
  --radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;
}
[data-theme="dark"]{
  --bg-start:#0f1419;--bg-end:#1a2332;
  --card-bg:rgba(255,255,255,0.03);--card-border:rgba(255,255,255,0.1);
  --primary:#4a90e2;--primary-light:rgba(74,144,226,0.12);
  --accent:#4a90e2;--accent-soft:rgba(74,144,226,0.15);--accent-line:rgba(74,144,226,0.35);
  --accent-green:#10b981;--accent-green-soft:rgba(16,185,129,0.15);--accent-green-line:rgba(16,185,129,0.35);
  --text-main:#ffffff;--text-sub:#b8c5d6;--text-hint:#6b7d93;
  --nav-bg:rgba(15,20,25,0.96);--nav-border:rgba(255,255,255,0.08);
  --input-bg:rgba(255,255,255,0.04);--input-border:rgba(255,255,255,0.12);
  --table-stripe:rgba(255,255,255,0.02);--table-hover:rgba(74,144,226,0.08);
  --shadow:none;
  --shadow-lg:none;
  --modal-bg:rgba(15,20,25,0.94);--surface:rgba(255,255,255,0.03);--surface-soft:rgba(255,255,255,0.05);--surface-strong:rgba(255,255,255,0.08);--select-menu-bg:#16202b;--select-menu-text:#f3f7fb;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:linear-gradient(180deg,var(--bg-start),var(--bg-end));color:var(--text-main);min-height:100vh;display:flex;flex-direction:column;}
.noscript-message{display:block;padding:2rem;text-align:center;background:var(--surface);border-radius:var(--radius-lg);margin:2rem;}
a{color:var(--primary);text-decoration:none;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:rgba(255,255,255,0.02);border-radius:3px;}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px;}

.nav{position:fixed;top:0;left:0;right:0;z-index:10000;height:60px;background:var(--nav-bg);border-bottom:1px solid var(--nav-border);display:flex;align-items:center;padding:0 24px;}
.nav-logo{margin-right:32px;cursor:pointer;display:flex;align-items:center;line-height:0;flex-shrink:0;}
.nav-logo-image{display:block;height:34px;width:auto;max-width:min(44vw,220px);object-fit:contain;}
.nav-links{display:flex;gap:4px;flex:1 0 auto;overflow-x:visible;min-width:0;align-items:center;}
.nav-links a{padding:8px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:600;color:var(--text-sub);white-space:nowrap;cursor:pointer;border:1px solid transparent;background:transparent;flex-shrink:0;}
.nav-links a:hover,.nav-links a.active{color:var(--primary);background:var(--accent-soft);border-color:var(--accent-line);}
.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0;}
.lang-switch{display:flex;align-items:center;border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--surface-soft);overflow:hidden;}
.lang-btn{min-width:40px;height:36px;padding:0 10px;border:0;border-right:1px solid var(--card-border);background:transparent;color:var(--text-sub);font-size:12px;font-weight:700;cursor:pointer;}
.lang-btn:last-child{border-right:0;}
.lang-btn:hover,.lang-btn.active{color:var(--primary);background:var(--accent-soft);}
.nav-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--surface-soft);color:var(--text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;}
.nav-btn:hover{color:var(--primary);border-color:var(--accent-line);}
.nav-right #themeBtn{display:none;}
.hamburger{display:none;}

.main{margin-top:60px;padding:28px 24px 40px;max-width:1440px;width:100%;margin-left:auto;margin-right:auto;flex:1 0 auto;}
.page{display:none;}
.page.active{display:block;position:relative;}
.site-footer{border-top:1px solid var(--card-border);margin-top:auto;padding:12px 24px 14px;width:100%;background:var(--surface);}
.site-footer-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.site-footer-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.site-footer-link-btn{display:inline-flex;align-items:center;gap:6px;min-height:34px;padding:8px 14px;font-size:12px;font-weight:700;letter-spacing:0.03em;text-transform:none;}
.site-footer-link-btn i{font-size:12px;}
.site-footer-meta{display:flex;align-items:center;gap:8px;min-width:0;flex:1 1 560px;}
.site-footer-copy{font-size:12px;color:var(--text-main);white-space:nowrap;font-weight:500;}
.site-footer-sep{font-size:12px;color:var(--text-hint);}
.site-footer-note{font-size:12px;line-height:1.6;color:var(--text-hint);}

.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:22px;}
.card-title{font-size:16px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px;color:var(--text-main);}
.card-title i{color:var(--primary);font-size:16px;}

.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:700;border:1px solid var(--accent);cursor:pointer;background:var(--accent);color:#fff;letter-spacing:0.02em;text-transform:uppercase;}
.btn:hover{background:var(--accent-soft);color:var(--primary);}
.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none;}
.btn-outline{background:transparent;border:1px solid var(--accent-line);color:var(--primary);}
.btn-outline:hover{background:var(--accent-soft);border-color:var(--accent);}
.btn-sm{padding:6px 14px;font-size:13px;border-radius:var(--radius-sm);}
.btn-danger{background:var(--danger);border-color:var(--danger);}
.btn-danger:hover{background:rgba(239,68,68,0.1);color:var(--danger);}
.btn-success{background:var(--success);border-color:var(--success);}
.btn-success:hover{background:rgba(16,185,129,0.1);color:var(--success);}
.btn-warning{background:var(--warning);color:#1a1a2e;border-color:var(--warning);}
.btn-warning:hover{background:rgba(245,158,11,0.1);color:var(--warning);}
.btn-link{padding:0;border:0;background:none;color:var(--primary);cursor:pointer;font:inherit;text-align:left;}
.btn-link:hover{color:#fff;}

.input-group{position:relative;display:flex;align-items:center;}
.input-group input,.input-group select{width:100%;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);font-size:14px;outline:none}
.input-group select option{background:#1a1f2e;color:var(--text-main)}
.input-group input:focus,.input-group select:focus{border-color:var(--accent);background:var(--accent-soft);}
.input-group select,
.lb-controls select,
.season-selector select,
.replay-filter-group select{
  color-scheme:dark;
}
.input-group select option,
.input-group select optgroup,
.lb-controls select option,
.lb-controls select optgroup,
.season-selector select option,
.season-selector select optgroup,
.replay-filter-group select option,
.replay-filter-group select optgroup{
  background:var(--select-menu-bg);
  background-color:var(--select-menu-bg);
  color:var(--select-menu-text);
}
.input-group i{position:absolute;left:14px;color:var(--text-hint);font-size:14px;pointer-events:none;}
.input-group.has-icon input{padding-left:40px;}

.tabs{display:flex;gap:4px;margin-bottom:20px;flex-wrap:wrap;}
.tab-btn{padding:8px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:700;background:transparent;color:var(--text-sub);border:1px solid transparent;cursor:pointer;text-transform:uppercase;}
.tab-btn:hover{color:var(--primary);background:var(--accent-soft);border-color:var(--accent-line);}
.tab-btn.active{color:var(--primary);background:var(--accent-soft);border-color:var(--accent);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

.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;}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;}

.stat-card{text-align:center;padding:20px 12px;border-radius:var(--radius-lg);background:var(--accent-soft);border:1px solid var(--accent-line);}
.stat-card .stat-value{font-size:28px;font-weight:800;color:var(--primary);line-height:1.2;}
.stat-card .stat-label{font-size:12px;color:var(--text-hint);margin-top:4px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;}
.stat-card .stat-label i{color:var(--primary);font-size:14px;}
.stat-card.green{background:var(--accent-green-soft);border-color:var(--accent-green-line);}
.stat-card.green .stat-value{color:var(--accent-green);}
.stat-card.green .stat-label i{color:var(--accent-green);}

.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--surface);}
table{width:100%;border-collapse:collapse;font-size:13px;}
th{text-align:left;padding:12px 14px;font-weight:600;color:var(--text-sub);border-bottom:1px solid var(--card-border);white-space:nowrap;background:var(--surface-soft);}
td{padding:10px 14px;border-bottom:1px solid var(--card-border);white-space:nowrap;}
tr:nth-child(even){background:var(--table-stripe);}
tr:hover{background:var(--table-hover);}
.mobile-data-list{display:none}
.mobile-data-card{border-top:1px solid var(--card-border);background:var(--surface)}
.mobile-data-card:first-child{border-top:0}
.mobile-data-card.is-highlighted{background:var(--accent-soft)}
.mobile-data-main{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer}
.mobile-data-badge{display:inline-flex;align-items:center;justify-content:center;min-width:34px;padding:4px 8px;border-radius:var(--radius-sm);background:var(--surface-soft);color:var(--text-main);font-weight:700;flex-shrink:0}
.mobile-data-content{min-width:0;flex:1}
.mobile-data-title{min-width:0}
.mobile-data-title strong,.mobile-data-title button{font-size:14px}
.mobile-data-title .lb-player-cell{display:flex;align-items:center;gap:10px;min-width:0}
.mobile-data-title .lb-player-meta{min-width:0;display:flex;flex-direction:column;gap:3px}
.mobile-data-title .lb-player-name{display:inline-flex;justify-content:flex-start}
.mobile-data-title .lb-player-tier{font-size:11px;color:var(--text-sub)}
.mobile-data-title .match-detail-team-player-name{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.mobile-data-primary{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.mobile-inline-stat,.mobile-extra-stat{display:flex;flex-direction:column;gap:3px}
.mobile-inline-stat{text-align:right;min-width:58px}
.mobile-stat-label{font-size:11px;color:var(--text-hint);line-height:1.2}
.mobile-stat-value{font-size:13px;font-weight:700;color:var(--text-main);line-height:1.25}
.mobile-expand-icon{font-size:12px;color:var(--text-sub);transition:transform .2s ease;flex-shrink:0}
.mobile-row-extra{display:none;padding:0 14px 14px 60px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.mobile-data-card.is-expanded .mobile-row-extra{display:grid}
.mobile-data-card.is-expanded .mobile-expand-icon{transform:rotate(180deg)}
.mobile-row-extra .btn-link{justify-content:flex-start;padding:0;color:var(--primary)}
.lb-special-list{display:flex;flex-direction:column;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}
.lb-special-card{border-top:1px solid var(--card-border)}
.lb-special-card:first-child{border-top:0}
.lb-special-main .mobile-data-primary{margin-left:auto}
.lb-special-main .mobile-inline-stat{min-width:84px}
.lb-special-table{display:block}
.lb-special-cards{display:none}
@media(max-width:900px){
  .lb-special-table{display:none}
  .lb-special-cards{display:flex}
}

.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-xl);font-size:11px;font-weight:600;}
.badge-success{background:rgba(16,185,129,0.15);color:var(--success);border:1px solid rgba(16,185,129,0.3);}
.badge-danger{background:rgba(239,68,68,0.15);color:var(--danger);border:1px solid rgba(239,68,68,0.3);}
.badge-warning{background:rgba(245,158,11,0.15);color:var(--warning);border:1px solid rgba(245,158,11,0.3);}
.badge-info{background:rgba(74,144,226,0.15);color:var(--info);border:1px solid rgba(74,144,226,0.3);}
.badge-gold{background:rgba(251,191,36,0.15);color:#fbbf24;border:1px solid rgba(251,191,36,0.3);}
.badge-purple{background:rgba(168,85,247,0.15);color:#a855f7;border:1px solid rgba(168,85,247,0.3);}

.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--card-border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-overlay{display:flex;align-items:center;justify-content:center;padding:28px;gap:10px;color:var(--text-hint);position:relative;overflow:hidden;min-height:96px;background:var(--surface);border-radius:var(--radius-lg);}
.loading-overlay::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent);animation:loadingSweep 1.4s linear infinite;}
.compare-loading-panel{padding:20px 22px;min-height:120px;background:transparent;color:var(--text-hint);border-radius:var(--radius-lg)}
.compare-loading-stack{width:min(100%,560px);display:grid;gap:12px;position:relative;z-index:1}
.compare-loading-head{display:flex;align-items:flex-start;gap:12px}
.compare-loading-copy{display:grid;gap:4px;min-width:0}
.compare-loading-copy strong{font-size:14px;color:var(--text-main)}
.compare-loading-copy span{font-size:12px;line-height:1.5;color:var(--text-sub)}
.compare-loading-bar{height:8px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden;border:1px solid var(--card-border)}
.compare-loading-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--primary),#7dd3fc);min-width:2%}
.compare-cancel-btn{margin-top:8px;font-size:12px;padding:4px 14px;border-color:rgba(255,255,255,0.15);color:var(--text-sub)}
.compare-cancel-btn:hover{border-color:var(--primary);color:var(--primary)}
.has-global-loading{overflow:hidden}
.global-loading-mask{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at center,rgba(22,34,43,.36) 0,rgba(0,0,0,.42) 38%,rgba(0,0,0,.66) 100%);backdrop-filter:blur(5px);z-index:20000}
.global-loading-mask.is-visible{display:flex}
.global-loading-content{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;min-width:min(92vw,360px);max-width:min(96vw,720px);padding:28px 24px;text-align:center}
.global-loading-content::before{content:'';position:absolute;inset:auto 50% 56px;transform:translateX(-50%);width:min(72vw,520px);height:110px;border-radius:999px;background:radial-gradient(circle,rgba(123,168,160,.16) 0,rgba(123,168,160,.06) 40%,rgba(123,168,160,0) 72%);filter:blur(10px);pointer-events:none}
.global-loading-spinner{display:flex;justify-content:center;align-items:center;gap:2px;flex-wrap:wrap}
.global-loader{width:48px;height:54px;position:relative;display:inline-flex;align-items:center;justify-content:center;margin:0 2px;animation:globalLoaderFloat 2.8s ease-in-out infinite}
.global-loader-core{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:hidden;clip-path:polygon(18% 0,100% 0,82% 100%,0 100%)}
.global-loader-core::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(123,168,160,.22) 0,rgba(142,205,193,.95) 28%,rgba(232,243,247,.92) 50%,rgba(123,168,160,.38) 72%,rgba(123,168,160,.16) 100%);background-size:220% 100%;background-position:100% 50%;box-shadow:0 0 18px rgba(123,168,160,.18);animation:globalLoaderFrameShift 2.6s ease-in-out infinite}
.global-loader-core::after{content:'';position:absolute;inset:2px;background:linear-gradient(160deg,rgba(10,18,24,.98),rgba(15,28,36,.92));clip-path:polygon(18% 0,100% 0,82% 100%,0 100%);box-shadow:inset 0 0 0 1px rgba(196,227,232,.08)}
.global-loader-accent{position:absolute;inset:-10% auto -10% -35%;width:45%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);transform:skewX(-18deg);filter:blur(.5px);animation:globalLoaderAccentSweep 2.2s ease-in-out infinite}
.global-loader-letter{position:relative;font-size:20px;font-weight:700;color:rgba(232,243,247,.82);text-shadow:0 0 14px rgba(142,205,193,.16);z-index:1;pointer-events:none}
.global-loader:nth-child(1),.global-loader:nth-child(6){animation-delay:0s}
.global-loader:nth-child(2),.global-loader:nth-child(7){animation-delay:.12s}
.global-loader:nth-child(3),.global-loader:nth-child(8){animation-delay:.24s}
.global-loader:nth-child(4),.global-loader:nth-child(9){animation-delay:.36s}
.global-loader:nth-child(5){animation-delay:.18s}
.global-loading-dot{width:6px;height:6px;background:#8ecdc1;border-radius:50%;margin:0 6px;align-self:center;box-shadow:0 0 14px rgba(142,205,193,.65);animation:globalLoadingDotPulse 1.6s ease-in-out infinite}
.global-loading-divider{position:relative;overflow:hidden;width:min(260px,72vw);height:1px;background:linear-gradient(90deg,transparent 0,rgba(123,168,160,.18) 20%,rgba(206,232,240,.45) 50%,rgba(123,168,160,.18) 80%,transparent 100%);box-shadow:0 0 10px rgba(123,168,160,.14)}
.global-loading-divider::after{content:'';position:absolute;top:0;left:-28%;width:28%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);animation:globalLoadingDividerSweep 2.4s ease-in-out infinite}
.global-loading-title{font-size:15px;font-weight:500;line-height:1.5;color:rgba(236,244,247,.86);letter-spacing:1.5px;text-shadow:0 2px 10px rgba(0,0,0,.35)}
.global-loading-text{font-size:13px;line-height:1.6;color:rgba(214,226,231,.64);max-width:360px}
@keyframes globalLoaderFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.03)}}
@keyframes globalLoaderFrameShift{0%,100%{background-position:100% 50%;filter:saturate(.95) brightness(.96)}50%{background-position:0 50%;filter:saturate(1.15) brightness(1.08)}}
@keyframes globalLoaderAccentSweep{0%{left:-35%;opacity:0}18%{opacity:.9}55%{opacity:.45}100%{left:110%;opacity:0}}
@keyframes globalLoadingDotPulse{0%,100%{transform:scale(.78);opacity:.72}50%{transform:scale(1.25);opacity:1}}
@keyframes globalLoadingDividerSweep{0%{left:-28%;opacity:0}18%{opacity:1}100%{left:100%;opacity:0}}
@media (max-width: 768px){
  .global-loading-mask{padding:20px}
  .global-loading-content{min-width:min(92vw,320px);max-width:min(96vw,520px);padding:24px 18px;gap:14px}
  .global-loading-spinner{gap:1px;flex-wrap:nowrap}
  .global-loader{width:clamp(24px,7vw,30px);height:clamp(28px,8vw,36px);margin:0}
  .global-loader-letter{font-size:clamp(11px,3.6vw,14px)}
  .global-loading-dot{width:4px;height:4px;margin:0 2px;flex:0 0 auto}
  .global-loading-divider{width:min(220px,74vw)}
  .global-loading-title{font-size:14px}
  .global-loading-text{font-size:12px;max-width:280px}
}
.response-enter{animation:responseEnter .38s cubic-bezier(.22,1,.36,1);}
.response-stagger>*{animation:responseEnter .42s cubic-bezier(.22,1,.36,1);animation-fill-mode:both;}
.response-stagger>*:nth-child(1){animation-delay:.02s;}
.response-stagger>*:nth-child(2){animation-delay:.05s;}
.response-stagger>*:nth-child(3){animation-delay:.08s;}
.response-stagger>*:nth-child(4){animation-delay:.11s;}
.response-stagger>*:nth-child(5){animation-delay:.14s;}
.response-stagger>*:nth-child(6){animation-delay:.17s;}
.response-stagger>*:nth-child(n+7){animation-delay:.2s;}
.skeleton-wrap{display:grid;gap:12px;width:100%;}
.skeleton-grid{display:grid;gap:16px;}
.skeleton-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr));}
.skeleton-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.skeleton-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.skeleton-card,.skeleton-line,.skeleton-pill{position:relative;overflow:hidden;background:linear-gradient(90deg,var(--surface-soft),var(--accent-soft),var(--surface-soft));border-radius:var(--radius-md);}
.skeleton-card::after,.skeleton-line::after,.skeleton-pill::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);animation:loadingSweep 1.1s linear infinite;}
.skeleton-card{height:112px;border:1px solid var(--card-border);}
.skeleton-card.tall{height:160px;}
.skeleton-line{height:12px;border-radius:var(--radius-sm);}
.skeleton-pill{height:34px;}
.skeleton-line.w-30{width:30%;}
.skeleton-line.w-40{width:40%;}
.skeleton-line.w-50{width:50%;}
.skeleton-line.w-60{width:60%;}
.skeleton-line.w-70{width:70%;}
.skeleton-line.w-80{width:80%;}
.skeleton-line.w-100{width:100%;}
@keyframes loadingSweep{to{transform:translateX(100%);}}
@keyframes responseEnter{
  from{opacity:0;transform:translateY(10px);filter:blur(3px);}
  to{opacity:1;transform:translateY(0);filter:blur(0);}
}

.toast-container{position:fixed;top:72px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast{padding:12px 20px;border-radius:var(--radius-lg);font-size:13px;font-weight:500;background:var(--surface-strong);border:1px solid var(--accent-line);animation:fadeIn .2s ease;display:flex;align-items:center;gap:8px;max-width:360px;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.toast-success{border-color:rgba(16,185,129,0.4);background:rgba(16,185,129,0.1);}
.toast-success i{color:var(--success);}
.toast-error{border-color:rgba(239,68,68,0.4);background:rgba(239,68,68,0.1);}
.toast-error i{color:var(--danger);}
.toast-info{border-color:rgba(74,144,226,0.4);background:rgba(74,144,226,0.1);}
.toast-info i{color:var(--info);}
.page-restriction-notice{margin:0 0 20px;padding:16px 18px;border-radius:var(--radius-lg);border:1px solid rgba(239,68,68,0.45);background:rgba(239,68,68,0.12);}
.page-restriction-notice-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.page-restriction-notice-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:800;color:#fecaca;}
.page-restriction-notice-title i{color:#f87171;}
.page-restriction-notice-close{width:32px;height:32px;flex-shrink:0;border-radius:999px;border:1px solid rgba(255,255,255,0.14);background:rgba(255,255,255,0.06);color:var(--text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.page-restriction-notice-close:hover{color:#fff;border-color:rgba(248,113,113,0.5);background:rgba(248,113,113,0.16);}
.page-restriction-notice-body{font-size:14px;line-height:1.8;color:#fee2e2;white-space:pre-wrap;word-break:break-word;}

.hero-search{max-width:600px;margin:0 auto 32px;}
.hero-search h2{font-size:28px;font-weight:800;text-align:center;margin-bottom:8px;color:var(--text-main);}
.hero-search p{text-align:center;color:var(--text-hint);margin-bottom:20px;font-size:14px;}
.hero-search .input-group input{font-size:16px;padding:14px 20px 14px 44px;border-radius:0;background:transparent;}
#homeAnnouncementsCard{max-width:600px;margin:0 auto 24px;}
#homeAnnouncementsCard .card-title{justify-content:center;text-align:center;}
#homeAnnouncements{text-align:center;}
.home-platform-tabs{justify-content:center;margin-bottom:16px;}
.home-search-combo{display:flex;align-items:stretch;width:100%;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--card-border);background:var(--surface);}
.home-search-input-wrap{flex:1;min-width:0;}
.home-history-trigger{width:56px;min-width:56px;border-radius:0;border:0;border-right:1px solid var(--card-border);background:var(--surface-soft);color:var(--text-sub);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;}
.home-history-trigger i{font-size:14px;}
.home-history-trigger span{font-size:9px;font-weight:700;letter-spacing:.06em;line-height:1;text-transform:uppercase;}
.home-history-trigger:hover{color:var(--primary);background:var(--accent-soft);}
.home-history-trigger:focus-visible{outline:none;color:var(--primary);background:var(--accent-soft);}
.home-search-input-wrap input{height:100%;border:0;border-radius:0;background:transparent;}
.home-search-input-wrap input:focus{border-color:transparent;background:transparent;}
.home-search-submit{min-width:100px;border-radius:0;border:0;border-left:1px solid var(--card-border);padding:0 18px;justify-content:center;white-space:nowrap;background:var(--accent);color:#fff;}
.home-search-submit:hover{background:var(--accent-soft);color:var(--primary);}
.home-history-modal{max-width:760px;}
.home-history-title{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:800;margin-bottom:6px;padding-right:44px;}
.home-history-subtitle{font-size:13px;color:var(--text-hint);margin-bottom:18px;}
.home-history-list{display:flex;flex-direction:column;gap:12px;}
.home-history-item{width:100%;padding:16px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:rgba(255,255,255,.02);text-align:left;color:var(--text-main);cursor:pointer;}
.home-history-item:hover{border-color:var(--accent);background:var(--accent-soft);}
.home-history-item-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;}
.home-history-player{display:flex;align-items:center;gap:12px;min-width:0;}
.home-history-rank{width:42px;height:42px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--surface-soft);}
.home-history-rank img{width:100%;height:100%;object-fit:contain;}
.home-history-main{min-width:0;display:flex;flex-direction:column;gap:4px;}
.home-history-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.home-history-name{font-size:16px;font-weight:800;max-width:100%;word-break:break-all;}
.home-history-platform{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--card-border);font-size:12px;color:var(--text-sub);text-transform:uppercase;white-space:nowrap;background:var(--surface-soft);}
.home-history-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 14px;}
.home-history-meta-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-sub);min-width:0;}
.home-history-meta-item i{width:14px;text-align:center;color:var(--text-hint);flex-shrink:0;}
.home-history-meta-item .ban-status{font-size:13px;}
.home-history-meta-item span:last-child{min-width:0;word-break:break-word;}
.home-history-empty{padding:32px 16px;text-align:center;color:var(--text-hint);border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--surface);}
.home-history-empty i{display:block;font-size:32px;margin-bottom:10px;color:var(--primary);}

.player-header{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.player-rank-img{width:80px;height:80px;flex-shrink:0;border-radius:var(--radius-lg);background:var(--surface-soft);display:flex;align-items:center;justify-content:center;border:1px solid var(--card-border);}
.player-rank-img img{width:100%;height:100%;object-fit:contain;}
.player-info{flex:1;min-width:200px;}
.player-info h3{font-size:24px;font-weight:800;display:flex;align-items:center;gap:10px;}
.player-meta{display:flex;gap:14px;margin-top:8px;flex-wrap:wrap;align-items:center;}
.player-meta span{font-size:13px;color:var(--text-sub);display:flex;align-items:center;gap:4px;}
.player-meta .ban-status{font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px;}
.player-meta .ban-status.is-success{color:var(--success);}
.player-meta .ban-status.is-warning{color:var(--warning);}
.player-meta .ban-status.is-danger{color:var(--danger);}
.player-meta span strong{color:var(--text-main);}
.player-rank-bar{margin-top:16px;padding:16px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--card-border);}
.player-rank-bar .rank-title{font-size:15px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px;}
.player-rank-bar .rank-stats{display:flex;gap:20px;flex-wrap:wrap;font-size:13px;color:var(--text-sub);}
.player-rank-bar .rank-stats strong{color:var(--primary);}
.xp-bar{margin-top:10px;height:6px;border-radius:3px;background:var(--card-border);overflow:hidden;}
.xp-bar-fill{height:100%;border-radius:3px;background:var(--primary);transition:width .5s;}

.weapon-card{padding:16px 10px;text-align:center;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--surface);}
.weapon-card .weapon-icon{width:48px;height:48px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--surface-soft);}
.weapon-card .weapon-icon img{max-width:100%;max-height:100%;object-fit:contain;}
.weapon-card .weapon-name{font-size:13px;font-weight:700;margin-bottom:4px;}
.weapon-card .weapon-level{font-size:11px;color:var(--text-hint);margin-bottom:6px;}
.weapon-card .weapon-stat{font-size:12px;color:var(--text-sub);}
.weapon-card .weapon-stat strong{color:var(--primary);}
.mastery-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;}
.mastery-tab{padding:6px 14px;border-radius:var(--radius-md);font-size:13px;cursor:pointer;border:1px solid var(--card-border);background:transparent;color:var(--text-sub);white-space:nowrap;}
.mastery-tab:hover{border-color:var(--accent);color:var(--primary);}
.mastery-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}

.replay-shell{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:16px;padding:14px;flex:1;min-height:0;align-items:stretch;font:13px/1.5 "Segoe UI","Microsoft YaHei",sans-serif;color:var(--text-main)}
.replay-main,.replay-sidebar{background:transparent;border:0;border-radius:0;overflow:visible}
.replay-main{display:flex;flex-direction:column;min-height:100%;height:100%}
.replay-topbar{display:flex;justify-content:space-between;gap:8px;padding:0 0 10px;flex-wrap:wrap}
.replay-badges,.replay-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.replay-badge{padding:4px 8px;border-radius:var(--radius-xl);background:var(--accent-soft);color:var(--primary);font-size:11px;font-weight:600;border:1px solid var(--accent-line)}
.replay-stage{position:relative;flex:1 1 auto;min-height:400px;overflow:hidden;border-radius:var(--radius-lg)}
.replay-canvas-stage{position:relative;height:100%;min-height:400px;border-radius:var(--radius-lg);background:linear-gradient(180deg,#0f1419,#1a2332);border:1px solid var(--card-border);overflow:hidden}
.replay-canvas-stage canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.replay-feed{position:absolute;top:12px;left:12px;z-index:50;pointer-events:none;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;align-items:flex-start;max-width:min(46vw,360px)}
.remaining-player-container{display:flex;font-size:12px;font-weight:500;line-height:22px;height:24px;list-style:none;margin:0 0 6px 0;padding:0;pointer-events:none;-webkit-user-select:none;user-select:none}
.remaining-player-container li{margin-right:8px;display:flex;align-items:center}
.remaining-player-container li .title,.remaining-player-container li .value{display:inline-block;text-align:center;padding:0 6px;border-radius:var(--radius-sm)}
.remaining-player-container li .title{color:#9ea0a6;background-color:rgba(17,17,17,0.8)}
.remaining-player-container li .value{color:#ededf2;min-width:28px;background-color:rgba(27,27,27,0.6)}
#kill-feed-list-container{max-height:min(40vh,360px);max-width:100%;overflow:hidden;pointer-events:none}
.kill-feed-list{display:flex;flex-direction:column;align-items:flex-start;list-style:none;margin:0;padding:0;font-size:clamp(11px,1.2vw,12px)}
.kill-feed-list .kill-feed{display:flex;align-items:center;height:22px;padding:0 2px;background:rgba(0,0,0,0.55);color:#fff;margin-bottom:4px;max-width:100%;width:fit-content;border-radius:var(--radius-sm)}
.kill-feed-list .kill-feed.kill .victim .nickname{color:#ff3e3e}
.attacker,.victim{display:flex;align-items:center}
.attacker .team-id,.victim .team-id{display:flex;justify-content:center;align-items:center;width:22px;height:18px;font-size:12px;font-weight:700;text-align:center;white-space:nowrap;text-shadow:1px 0 1px rgba(0,0,0,0.5),0 1px 1px rgba(0,0,0,0.5),-1px 0 1px rgba(0,0,0,0.5),0 -1px 1px rgba(0,0,0,0.5)}
.attacker .team-id{margin-right:5px}
.attacker .nickname,.victim .nickname{font-size:12px;line-height:22px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;color:#fff;margin-right:5px;max-width:100px}
.victim .team-id{margin-left:5px;margin-right:0}
.victim .distance{font-size:11px;color:#9ea0a6;margin-right:5px;white-space:nowrap}
.feed-info{display:flex;align-items:center}
.feed-info>*{margin-right:5px}
.feed-info .weapon-silhouette{height:16px;object-fit:contain;transform:scaleX(-1)}
.feed-info .weapon-silhouette.unknown{height:18px}
.feed-info .head-shot-icon{height:16px;object-fit:contain}
.feed-info .dbno-icon{width:32px;height:16px;object-fit:contain}
.feed-item{display:grid;grid-template-columns:56px 1fr;gap:6px;padding:6px 8px;background:rgba(8,14,24,0.78);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius-md)}
.feed-time{color:var(--primary);font-weight:600;font-size:11px}
.feed-text{color:var(--text-main);font-size:12px}
.replay-controls{padding:12px 0 0;border-top:1px solid rgba(255,255,255,0.08);display:grid;gap:10px}
.replay-actions,.replay-speeds{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.replay-speeds{justify-content:space-between}
.replay-speed-range{display:flex;align-items:center;gap:10px;flex:1;min-width:180px}
.replay-speed-range input[type=range]{flex:1;accent-color:var(--primary);height:6px;border-radius:var(--radius-xl)}
.replay-speed-value{min-width:40px;text-align:right;color:var(--primary);font-size:12px;font-weight:700}
.rv-btn,.speed-btn{padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--accent-line);background:var(--surface-soft);color:var(--text-main);cursor:pointer;font-size:12px;font-weight:600}
.rv-btn:hover,.speed-btn:hover,.speed-btn.is-active,.rv-btn.is-active{background:var(--accent-soft);border-color:var(--accent);color:var(--primary)}
.replay-timeline{position:relative;height:12px;border-radius:var(--radius-xl);background:rgba(255,255,255,0.08);cursor:pointer;overflow:visible;margin-bottom:24px}
.replay-timeline-fill{position:absolute;inset:0 auto 0 0;width:0;background:var(--primary);border-radius:var(--radius-xl)}
.replay-timeline-handle{position:absolute;top:50%;left:0;width:14px;height:14px;margin-left:-7px;transform:translateY(-50%);border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,0.18)}
.replay-timeline-markers{position:absolute;left:0;right:0;top:calc(100% + 14px);height:12px;pointer-events:none}
.replay-jump-bar{position:absolute;left:0;right:0;top:calc(100% + 2px);height:4px;border-radius:var(--radius-xl);background:rgba(255,100,100,0.45);overflow:hidden;pointer-events:none;opacity:0;transition:opacity .3s}
.replay-jump-bar.is-visible{opacity:1}
.replay-jump-bar-fill{position:absolute;top:0;left:0;height:100%;background:#ff6464;border-radius:var(--radius-xl)}
@keyframes jumpBarFlash {
  0%,100%{opacity:.6}
  50%{opacity:1}
}
.replay-jump-bar.is-active .replay-jump-bar-fill{animation:jumpBarFlash .4s ease-in-out infinite}
.tl-marker{position:absolute;top:50%;width:6px;height:6px;transform:translate(-50%,-50%);border:0;border-radius:50%;cursor:pointer;background:#ffd166;pointer-events:auto}
.tl-marker-kill{background:#ff6b6b}.tl-marker-groggy{background:#ffd166}.tl-marker-phase{background:#74b9ff}
.tl-marker-focus-kill{background:#ff4757;width:10px;height:10px;z-index:10}
.tl-marker-focus-death{background:#ffffff;width:10px;height:10px;z-index:10}
.tl-marker-focus-groggy{background:#ffa502;width:8px;height:8px;z-index:9}
.tl-marker-focus-knocked{background:#dfe4ea;width:8px;height:8px;z-index:9}
.tl-marker-focus{border:1px solid rgba(0,0,0,0.5)}
.replay-loading-mask{position:absolute;inset:0;z-index:60;background:rgba(0,0,0,0.72);display:none;align-items:center;justify-content:center;padding:20px;border-radius:var(--radius-lg)}
.replay-loading-mask.is-visible{display:flex}
.replay-loading-card{position:relative;min-width:min(86vw,340px);padding:18px 20px;border-radius:var(--radius-lg);background:rgba(255,255,255,.04);border:1px solid var(--accent-line);text-align:center;overflow:hidden}
.replay-loading-card::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,0.08),transparent);animation:loadingSweep 1.6s linear infinite;pointer-events:none}
.replay-loading-badge{display:inline-flex;align-items:center;gap:6px;min-height:24px;padding:4px 10px;margin-bottom:12px;border-radius:var(--radius-xl);border:1px solid var(--accent-line);background:var(--accent-soft);color:var(--primary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.replay-loading-card .spinner{display:block;margin:0 auto 12px}
.loading-title{position:relative;z-index:1;font-size:16px;font-weight:800;color:var(--text-main)}
.loading-text{position:relative;z-index:1;margin-top:6px;font-size:12px;color:var(--text-sub);line-height:1.6}
.replay-loading-note{position:relative;z-index:1;margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.06);font-size:11px;color:var(--text-hint)}
.replay-inline-loading{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:10px;min-height:72px;padding:18px 12px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:rgba(255,255,255,.03);color:var(--text-sub);font-size:13px}
.replay-inline-loading i{color:var(--primary)}
.replay-sidebar{display:flex;flex-direction:column;min-height:0;overflow-y:auto;padding-top:2px}
.replay-panel{padding:0 0 14px;border-bottom:0}
.replay-panel:last-child{padding-bottom:0;flex:1 1 auto;overflow:auto}
.replay-panel-title{font-size:11px;color:var(--primary);margin-bottom:8px;text-transform:uppercase;letter-spacing:0.08em;font-weight:700}
.replay-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
.replay-info-item{padding:8px;border-radius:var(--radius-md);background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.05)}
.replay-info-item span{display:block;color:var(--text-sub);font-size:11px;margin-bottom:2px}
.replay-focus-card{padding:10px;border-radius:var(--radius-lg);background:var(--accent-soft);border:1px solid var(--accent-line)}
.replay-focus-name{font-size:15px;font-weight:700;margin-bottom:4px}
.replay-focus-meta{color:var(--text-sub);font-size:12px}
.replay-team-list{display:flex;flex-direction:column;gap:8px}
.rv-team{border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-md);background:rgba(255,255,255,0.03);overflow:hidden;margin-bottom:6px}
.rv-team.is-focus-team{border-color:var(--accent-line)}
.rv-team-head{display:flex;align-items:center;gap:6px;padding:6px 8px;background:rgba(255,255,255,0.04);cursor:pointer}
.rv-team-id{min-width:28px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.4)}
.rv-team-rank{font-size:11px;color:var(--text-sub);min-width:24px}
.rv-team-stats{margin-left:auto;font-size:11px;color:var(--text-sub)}
.rv-team{--rv-team-cols:14px minmax(0,1fr) 28px 28px 28px 36px}
.rv-team-head-cols{display:grid;grid-template-columns:var(--rv-team-cols);gap:2px;padding:2px 8px;font-size:10px;color:var(--text-hint);border-bottom:1px solid rgba(255,255,255,0.04)}
.rv-team-body{display:flex;flex-direction:column}
.rv-prow{display:grid;grid-template-columns:var(--rv-team-cols);gap:2px;padding:4px 8px;align-items:center;cursor:pointer;font-size:11px;color:var(--text-main);border-top:1px solid rgba(255,255,255,0.03)}
.rv-prow:hover{background:rgba(255,255,255,0.06)}
.rv-prow.is-focus{background:var(--accent-soft)}
.rv-team-head-cols span:nth-child(n+3){display:flex;align-items:center;justify-content:center;text-align:center}
.rv-pstatus{width:14px;height:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rv-pname{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;line-height:1.3}
.rv-pname.is-dead{color:#d96f6f;text-decoration:line-through}
.rv-pstat{display:flex;align-items:center;justify-content:center;text-align:center;color:#8899aa;font-size:10px}
@media(max-width:900px){
  .replay-shell{display:flex!important;flex-direction:column;flex:1;min-height:0;height:auto;padding:8px;overflow:visible}
  .replay-main{flex:0 0 auto;min-height:0}
  .replay-stage{min-height:180px;height:40vh;flex:none;overflow:visible}
  .replay-canvas-stage{touch-action:none;overflow:hidden}
  .replay-feed{position:absolute;top:10px;left:10px;z-index:50;width:auto;max-width:none}
  #kill-feed-list-container{max-height:none;overflow:visible}
  .kill-feed-list{max-height:none}
  .kill-feed-list .kill-feed{font-size:10px;height:18px;padding:0 4px;margin-bottom:2px;white-space:nowrap;width:auto;max-width:none}
  .attacker .nickname,.victim .nickname{max-width:none;font-size:10px;white-space:nowrap}
  .attacker .team-id,.victim .team-id{width:18px;height:14px;font-size:9px}
  .feed-info .weapon-silhouette{height:14px}
  .feed-info .head-shot-icon{height:12px}
  .victim .distance{font-size:9px}
  .replay-controls{padding:8px 10px 10px}
  .replay-actions,.replay-speeds{gap:6px}
  .replay-speeds{flex-direction:column;align-items:stretch}
  .replay-speed-range{width:100%}
  .replay-sidebar{flex:0 0 auto;min-height:auto;max-height:none;overflow:visible;padding-top:6px}
  .replay-sidebar .replay-panel:first-child{display:none}
  .replay-sidebar .replay-panel{display:block;overflow:visible;margin-bottom:10px;padding:0 0 10px;border-bottom:1px solid rgba(255,255,255,0.06)}
  .replay-sidebar .replay-panel:last-child{margin-bottom:0;border-bottom:0;padding-bottom:0}
  .replay-panel-title{font-size:12px;margin-bottom:6px}
  .rv-team{margin-bottom:6px}
  .rv-team-head{padding:6px 8px}
  .rv-prow{padding:5px 8px;font-size:11px}
  .match-detail-team-player{grid-template-columns:minmax(0,1fr) repeat(5,minmax(46px,auto));gap:6px;padding:8px 10px}
  .replay-tournament-card,.replay-esports-match-card,.replay-import-summary{align-items:flex-start}
}
.rv-setting-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.rv-setting-row:last-child{border-bottom:none}
.rv-setting-row>span{display:flex;align-items:center;gap:6px;color:#c8d0dc;font-size:13px}
.rv-setting-tip{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(255,255,255,0.08);color:#6b7a8d;font-size:10px;cursor:help;font-style:normal}
.rv-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.rv-switch input{opacity:0;width:0;height:0}
.rv-slider{position:absolute;cursor:pointer;inset:0;background:#3a3f4b;border-radius:20px;transition:.2s}
.rv-slider:before{content:'';position:absolute;height:16px;width:16px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:.2s}
.rv-switch input:checked+.rv-slider{background:var(--primary)}
.rv-switch input:checked+.rv-slider:before{transform:translateX(16px)}
.rv-keybind-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;color:#8899aa;font-size:12px}
.rv-key{background:rgba(255,255,255,0.06);padding:2px 8px;border-radius:4px;font-size:11px;color:#a0aec0}
.rv-faq-item{padding:6px 0;color:#7a8899;font-size:12px;line-height:1.5;border-bottom:1px solid rgba(255,255,255,0.03)}
.replay-tabs{margin-bottom:18px}
.replay-category-panel.hidden{display:none}
.replay-tournament-toolbar{display:grid;gap:12px}
.replay-tournament-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.replay-filter-group{display:grid;gap:6px;min-width:0}
.replay-filter-group label{font-size:12px;color:var(--text-sub);line-height:1}
.replay-filter-group select,.replay-filter-group input{height:40px;min-width:150px;padding:0 12px;border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--surface-soft);color:var(--text-main);outline:none}
.replay-filter-group select option{background:#1a1f2e;color:var(--text-main)}
.replay-filter-group select:focus,.replay-filter-group input:focus{border-color:var(--accent);outline:1px solid var(--accent-soft)}
.replay-filter-range{min-width:280px}
.replay-range-inputs{display:flex;align-items:center;gap:8px}
.replay-range-inputs input{min-width:0;flex:1 1 0}
.replay-range-sep{color:var(--text-hint);font-size:14px}
.replay-filter-search{flex:1 1 220px}
.replay-import-summary{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.replay-import-main{display:grid;gap:6px}
.replay-import-name{font-size:15px;font-weight:700;color:var(--text-main)}
.replay-import-meta{display:flex;gap:8px;flex-wrap:wrap;color:var(--text-sub);font-size:12px}
.replay-import-meta span{padding:4px 8px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03)}
.replay-import-actions{display:flex;gap:8px;flex-wrap:wrap}
.replay-tournament-grid{display:grid;gap:12px}
.replay-tournament-card,.replay-esports-match-card{position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;overflow:hidden;padding:16px 18px;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.replay-tournament-card.is-active{border-color:var(--accent);outline:1px solid var(--accent-soft)}
.replay-tournament-card-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(12,12,12,.88),rgba(12,12,12,.65) 55%,rgba(12,12,12,.86));pointer-events:none;border-radius:var(--radius-lg)}
.replay-tournament-card-main,.replay-esports-match-main,.replay-tournament-card-actions,.replay-esports-match-actions{position:relative;z-index:1}
.replay-tournament-card-main,.replay-esports-match-main{display:grid;gap:6px;min-width:0}
.replay-tournament-kicker,.replay-esports-match-kicker{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--primary);text-transform:uppercase;letter-spacing:.06em}
.replay-tournament-id,.replay-esports-match-id{font-size:18px;font-weight:700;color:var(--text-main);word-break:break-all}
.replay-tournament-full-id,.replay-esports-match-sub{font-size:12px;color:var(--text-sub);word-break:break-all}
.replay-tournament-meta,.replay-esports-match-meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--text-sub);font-size:12px}
.replay-tournament-meta span,.replay-esports-match-meta span{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.22)}
.replay-tournament-card-actions,.replay-esports-match-actions{display:flex;gap:8px;flex-wrap:wrap}
.replay-tournament-prefix-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:var(--radius-xl);border:1px solid var(--accent-line);background:var(--accent-soft);color:var(--primary);font-size:10px;font-weight:700;letter-spacing:.04em}
.replay-tournament-prefix-badge.is-warning{border-color:rgba(255,140,92,.35);background:rgba(255,140,92,.14);color:#ffb18a}
.replay-match-list-head{display:grid;gap:4px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06)}
.replay-tournament-match-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:14px}
.replay-tournament-match-total{margin-left:auto;align-self:center;font-size:12px;color:var(--text-sub)}
.replay-esports-match-card{align-items:stretch;gap:16px;background:rgba(255,255,255,.04)}
.replay-esports-match-card.has-cover::before{content:'';position:absolute;inset:0;background-image:var(--match-cover);background-size:contain;background-position:left center;background-repeat:no-repeat;opacity:.16;pointer-events:none;border-radius:var(--radius-lg)}
.replay-esports-match-card .replay-tournament-card-overlay{background:linear-gradient(90deg,rgba(18,18,18,.72),rgba(18,18,18,.9) 34%,rgba(18,18,18,.96) 100%)}
.replay-esports-match-cover{position:relative;z-index:1;flex:0 0 140px;width:140px;display:flex;align-items:center}
.replay-esports-match-cover-img{width:140px;height:78px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.12);background-color:rgba(255,255,255,.03);background-size:cover;background-position:center center;background-repeat:no-repeat}
.replay-esports-match-main{flex:1 1 320px}
.replay-esports-match-actions{align-items:center;justify-content:flex-end}

@media (max-width: 768px){
  .table-wrap.responsive-cards{overflow:visible}
  .table-wrap.responsive-cards table{display:none}
  .table-wrap.responsive-cards .mobile-data-list{display:flex;flex-direction:column}
  .mobile-data-main{padding:12px}
  .mobile-data-primary{min-width:96px}
  .mobile-row-extra{padding:0 12px 12px 58px}
  .replay-tournament-controls,.replay-tournament-match-toolbar{align-items:stretch}
  .replay-filter-group,.replay-filter-search,.replay-filter-range{width:100%;min-width:0}
  .replay-range-inputs{width:100%}
  .replay-tournament-card,.replay-esports-match-card{padding:14px}
  .replay-esports-match-cover{flex-basis:100%;width:100%}
  .replay-esports-match-cover-img{width:100%;height:120px}
  .replay-tournament-card-actions,.replay-esports-match-actions{width:100%}
  .replay-tournament-card-actions .btn,.replay-esports-match-actions .btn{flex:1 1 calc(50% - 4px);justify-content:center}
  .replay-tournament-match-total{margin-left:0}
}

.match-detail-modal{position:relative;max-width:980px;overflow:hidden}
.match-detail-hero{position:relative;margin:-24px -24px 20px;padding:22px 24px 20px;min-height:196px;display:flex;flex-direction:column;justify-content:space-between;background-color:rgba(24,24,24,.82);background-size:cover;background-position:left center;background-repeat:no-repeat;border-bottom:1px solid var(--card-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.match-detail-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,12,12,.18) 0%,rgba(16,16,16,.52) 42%,rgba(18,18,18,.9) 100%);pointer-events:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.match-detail-hero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:42%;background:linear-gradient(180deg,var(--accent-soft),rgba(18,18,18,.94));pointer-events:none}
.match-detail-hero>*{position:relative;z-index:1}
.match-detail-hero-top{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding-right:72px}
.match-detail-hero-title{display:flex;flex-direction:column;gap:6px}
.match-detail-hero-title h3{font-size:22px;line-height:1.2;color:var(--text-main)}
.match-detail-hero-sub{display:flex;gap:8px;flex-wrap:wrap;color:var(--text-sub);font-size:12px}
.match-detail-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-xl);border:1px solid var(--accent-line);background:var(--accent-soft);color:var(--primary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.match-detail-open-replay{flex-shrink:0;margin-right:0;justify-content:center;align-self:flex-start;min-width:160px}
.match-detail-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:18px}
.match-detail-summary .item{padding:12px 10px;text-align:center;border-radius:var(--radius-md);border:1px solid var(--card-border);background:rgba(255,255,255,.03)}
.match-detail-summary .item .lab{display:block;font-size:11px;color:var(--text-hint);margin-bottom:4px}
.match-detail-summary .item .val{display:block;font-size:14px;font-weight:700;color:var(--text-main)}
.match-detail-summary .item .val.is-rank{color:var(--primary)}
.match-detail-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}
.match-detail-stat{padding:10px;text-align:center;border-radius:var(--radius-md);border:1px solid var(--card-border);background:rgba(255,255,255,.02)}
.match-detail-stat .val{display:block;font-size:16px;font-weight:700;color:var(--primary)}
.match-detail-stat .lab{display:block;margin-top:4px;font-size:11px;color:var(--text-hint)}
.match-detail-team-highlight{padding:14px 16px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--accent-soft)}
.match-detail-team-highlight-meta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px;color:var(--text-sub);font-size:13px}
.match-detail-team-highlight-meta strong{color:var(--primary)}
.match-detail-team-list{display:grid;gap:12px}
.match-detail-team-card{border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);overflow:hidden}
.match-detail-team-card.is-my-team{border-color:var(--accent);border-left:2px solid var(--primary)}
.match-detail-team-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:rgba(255,255,255,.04)}
.match-detail-team-head-main{display:flex;align-items:center;gap:10px;min-width:0}
.match-detail-team-id{display:inline-flex;align-items:center;justify-content:center;min-width:48px;height:24px;padding:0 10px;border-radius:var(--radius-sm);background:var(--surface-strong);color:#fff;font-size:11px;font-weight:700}
.match-detail-team-name{font-size:14px;font-weight:700;color:var(--text-main)}
.match-detail-team-rank{font-size:12px;color:var(--text-sub)}
.match-detail-team-head-stats{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;color:var(--text-sub);font-size:12px}
.match-detail-team-head-stats strong{color:var(--primary)}
.match-detail-team-players{display:flex;flex-direction:column}
.match-detail-team-player{display:grid;grid-template-columns:minmax(0,1.8fr) repeat(5,minmax(52px,auto));gap:8px;align-items:center;padding:9px 12px;border-top:1px solid rgba(255,255,255,.05)}
.match-detail-team-player:first-child{border-top:0}
.match-detail-team-player.is-me{background:var(--accent-soft)}
.match-detail-team-player-name{min-width:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.match-detail-team-player-name strong{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.match-detail-team-player-stat{text-align:center;font-size:12px;color:var(--text-sub)}
.match-detail-team-player-stat strong{display:block;font-size:13px;color:var(--text-main)}

.match-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;border:1px solid rgba(80,80,80,.42);margin-bottom:10px;color:#fff;background-color:rgba(40,40,40,.7);background-size:contain;background-position:left center;background-repeat:no-repeat;min-height:64px;}
.match-card::before{content:'';position:absolute;inset:0;background:rgba(24,24,24,.78);z-index:1;border-radius:var(--radius-lg);}
.match-card>*{position:relative;z-index:2;}
.match-card:hover{border-color:var(--accent);}
.match-card.win::before{background:rgba(60,45,20,.62);}
.match-card.win{border-color:rgba(74,144,226,.42);}
.match-card-body{display:flex;align-items:center;padding:10px 14px;gap:14px;}
.match-rank{display:flex;flex-direction:column;align-items:flex-start;width:82px;min-width:82px;flex-shrink:0;margin-right:2px;padding-right:14px;border-right:1px solid rgba(60,60,60,.36);gap:4px;}
.rank-number-wrap{display:flex;align-items:baseline;gap:4px;width:100%;}
.rank-number{font-size:20px;font-weight:700;line-height:1;color:#d6d6d6;}
.rank-number.win{font-size:22px;color:var(--primary);}
.rank-number.top10{color:#f5c515;}
.rank-total{font-size:13px;line-height:1;color:#a4a4a4;}
.match-time-small{font-size:12px;color:#8c8c8c;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
.match-basic-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;}
.match-map-title{font-size:16px;font-weight:600;color:#e8e8e8;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.match-type-line{font-size:13px;color:#aaaaaa;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.match-stats{display:flex;gap:10px;flex-shrink:0;}
.match-stat{min-width:56px;text-align:center;}
.match-stat-value{font-size:18px;font-weight:700;line-height:1;color:#f2f4f8;}
.match-stat-label{margin-top:4px;font-size:11px;line-height:1;color:#8e97a8;text-transform:uppercase;letter-spacing:.04em;}
.replay-related-match-card{cursor:pointer;}
.replay-related-match-card.no-cover{background-image:none!important;}
.replay-related-match-card .match-rank{width:88px;min-width:88px;}
.replay-related-match-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.replay-related-match-meta span{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.22);font-size:12px;color:#b9c3d2;}
.replay-related-match-side{display:flex;align-items:center;gap:14px;flex-shrink:0;margin-left:auto;}
.replay-related-match-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}

.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10050;background:var(--modal-bg);display:flex;align-items:flex-start;justify-content:center;padding:12px;animation:fadeIn .2s ease;overflow-y:auto;overflow-x:hidden;}
#modalContainer{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10050;pointer-events:none;overflow:visible;}
#modalContainer>.modal-overlay{pointer-events:auto;}
.modal-content{background:var(--surface);border:1px solid var(--accent-line);border-radius:var(--radius-xl);max-width:800px;width:100%;max-height:none;overflow:visible;padding:28px;position:relative;margin:auto;}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--surface-soft);color:var(--text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;z-index:5;}
.modal-close:hover{color:var(--danger);border-color:var(--danger);}
.modal-title{font-size:18px;font-weight:800;margin-bottom:20px;padding-right:40px;}
.tournament-related-modal{max-width:1100px;}
.tournament-related-modal-subtitle{margin:-10px 0 18px;color:var(--text-sub);font-size:12px;word-break:break-all}
.detail-section{margin-bottom:20px;}
.detail-section h4{font-size:14px;font-weight:700;color:var(--text-sub);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.detail-section h4 i{color:var(--primary);}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 24px;}
.detail-grid .dg-item{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--card-border);font-size:13px;}
.detail-grid .dg-item .dg-label{color:var(--text-sub);}
.detail-grid .dg-item .dg-val{font-weight:600;}

.crate-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;align-items:start;}
.crate-sidebar,.crate-area{min-width:0;}
.crate-list{display:flex;flex-direction:column;gap:6px;max-height:600px;overflow-y:auto;}
.crate-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-lg);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-sub);border:1px solid var(--card-border);background:rgba(255,255,255,.02)}
.crate-item:hover{background:var(--accent-soft);color:var(--primary);border-color:var(--accent);}
.crate-item.active{background:var(--accent-soft);color:var(--primary);border-color:var(--accent);}
.crate-thumb{width:52px;height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:rgba(255,255,255,.03);border:1px solid var(--card-border);overflow:hidden;}
.crate-thumb img{width:100%;height:100%;object-fit:cover;}
.crate-thumb i{font-size:18px;color:var(--primary);}
.crate-item-text{min-width:0;display:flex;flex-direction:column;gap:4px;}
.crate-item-name{font-size:13px;font-weight:700;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.crate-item-meta{font-size:11px;color:var(--text-hint);}
.crate-area .crate-actions{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;}
.crate-stats{display:flex;gap:16px;margin-bottom:16px;font-size:13px;color:var(--text-sub);}
.crate-stats strong{color:var(--primary);}
.crate-hero{position:relative;min-height:180px;margin-bottom:18px;padding:22px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--accent-soft);overflow:hidden;}
.crate-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,255,255,.12),transparent 42%);pointer-events:none;}
.crate-hero-media{position:absolute;top:0;right:0;bottom:0;width:min(44%,280px);opacity:.9;display:flex;align-items:center;justify-content:center;padding:12px;}
.crate-hero-media img{max-width:100%;max-height:100%;object-fit:contain;filter:drop-shadow(0 10px 28px rgba(0,0,0,.32));}
.crate-hero-body{position:relative;z-index:1;max-width:min(56%,520px);}
.crate-hero-title{font-size:22px;font-weight:800;color:var(--text-main);margin-bottom:8px;}
.crate-hero-sub{font-size:13px;line-height:1.7;color:var(--text-sub);}
.item-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;}
.item-cell{position:relative;padding:10px;border-radius:var(--radius-lg);text-align:left;font-size:11px;border:1px solid var(--card-border);background:rgba(255,255,255,.03);overflow:hidden;}
.item-visual{position:relative;height:124px;margin-bottom:10px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.08);background:rgba(8,10,16,.82);overflow:hidden;}
.item-rarity-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.9;border-radius:var(--radius-md);}
.item-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 32%,rgba(0,0,0,.18));border-radius:var(--radius-md);}
.item-icon{position:relative;z-index:1;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px;}
.item-icon img{max-width:100%;max-height:100%;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(0,0,0,.35));}
.item-icon i{font-size:30px;color:#fff;}
.item-rarity{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;margin-bottom:8px;border-radius:var(--radius-xl);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid currentColor;background:rgba(255,255,255,.04);}
.item-name{font-weight:700;font-size:12px;color:var(--text-main);line-height:1.45;min-height:34px;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;}
.item-prob{margin-top:6px;color:var(--text-hint);font-size:11px;}
.item-cell.rarity-common{border-color:rgba(156,163,175,.45);}
.item-cell.rarity-common .item-rarity{color:#c6cbd4;}
.item-cell.rarity-common .item-visual{background:linear-gradient(180deg,rgba(156,163,175,.16),rgba(15,17,24,.86));}
.item-cell.rarity-uncommon{border-color:rgba(34,197,94,.45);}
.item-cell.rarity-uncommon .item-rarity{color:#6ee7b7;}
.item-cell.rarity-uncommon .item-visual{background:linear-gradient(180deg,rgba(34,197,94,.18),rgba(10,18,14,.86));}
.item-cell.rarity-rare{border-color:rgba(74,144,226,.45);}
.item-cell.rarity-rare .item-rarity{color:#93c5fd;}
.item-cell.rarity-rare .item-visual{background:linear-gradient(180deg,rgba(74,144,226,.18),rgba(10,14,22,.86));}
.item-cell.rarity-epic{border-color:rgba(168,85,247,.5);}
.item-cell.rarity-epic .item-rarity{color:#d8b4fe;}
.item-cell.rarity-epic .item-visual{background:linear-gradient(180deg,rgba(168,85,247,.2),rgba(17,10,24,.88));}
.item-cell.rarity-legendary{border-color:rgba(245,158,11,.5);}
.item-cell.rarity-legendary .item-rarity{color:#fcd34d;}
.item-cell.rarity-legendary .item-visual{background:linear-gradient(180deg,rgba(245,158,11,.22),rgba(24,15,8,.9));}
.item-cell.rarity-ultimate{border-color:rgba(244,63,94,.56);}
.item-cell.rarity-ultimate .item-rarity{color:#fda4af;}
.item-cell.rarity-ultimate .item-visual{background:linear-gradient(180deg,rgba(244,63,94,.24),rgba(25,10,14,.9));}
.crate-overview-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:18px;}
.crate-overview-stat{padding:12px 10px;border-radius:var(--radius-lg);border:1px solid var(--card-border);text-align:center;background:rgba(255,255,255,.03);}
.crate-overview-stat .val{display:block;font-size:18px;font-weight:800;color:var(--primary);}
.crate-overview-stat .lab{display:block;margin-top:4px;font-size:11px;color:var(--text-hint);}
.crate-overview-qualities{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.crate-overview-qualities .q-item{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--radius-md);border:1px solid currentColor;background:rgba(255,255,255,.03);font-size:12px;font-weight:600;}
.crate-overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;}
.crate-overview-grid .item-cell{margin:0;}

.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;}
.status-dot.online{background:var(--success);}
.status-dot.offline{background:var(--danger);}
.status-dot.maintenance{background:var(--warning);}
.announcement{padding:12px;border-radius:var(--radius-lg);background:var(--surface);margin-bottom:8px;font-size:13px;border:1px solid var(--card-border);}
.announcement:last-child{margin-bottom:0;border-bottom:none;}
.announcement-group{margin-bottom:16px;}
.announcement-group:last-child{margin-bottom:0;}
.announcement-group-title{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-main);margin-bottom:8px;text-align:center;}
.announcement-group-title i{color:var(--primary);}
.announcement strong{display:block;text-align:center;}
.announcement p{margin:8px 0 0;color:var(--text-sub);line-height:1.6;text-align:center;}

.lb-controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.lb-controls select{padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);font-size:13px;outline:none}
.lb-controls select option{background:#1a1f2e;color:var(--text-main)}
.lb-compare-link{font-size:11px;color:var(--primary);line-height:1.2}
.lb-compare-link:hover{color:#fff}
.lb-controls select option:disabled{color:var(--text-hint);text-decoration:line-through;background:var(--surface-strong);font-style:italic;}
.rank-1{color:#fbbf24;font-weight:800;}
.rank-2{color:#94a3b8;font-weight:700;}
.rank-3{color:#d97706;font-weight:700;}
.lb-featured-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.lb-featured-card{position:relative;padding:18px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--accent-soft);cursor:pointer;}
.lb-featured-card:hover{border-color:var(--accent);}
.lb-featured-card.is-empty{cursor:default;opacity:.72;}
.lb-featured-badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:4px 10px;border-radius:var(--radius-xl);border:1px solid var(--accent-line);background:var(--accent-soft);color:var(--primary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.lb-featured-badge.is-rank{color:#fbbf24;border-color:rgba(251,191,36,.35);background:rgba(251,191,36,.12);}
.lb-featured-badge.is-kda{color:#7dd3fc;border-color:rgba(125,211,252,.3);background:rgba(125,211,252,.1);}
.lb-featured-badge.is-winrate{color:#86efac;border-color:rgba(134,239,172,.28);background:rgba(134,239,172,.1);}
.lb-featured-main{display:flex;align-items:center;gap:14px;margin-top:14px;min-width:0;}
.lb-featured-rank{width:72px;height:72px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:rgba(255,255,255,.03);border:1px solid var(--card-border);}
.lb-featured-rank img{max-width:100%;max-height:100%;object-fit:contain;}
.lb-featured-meta{min-width:0;display:flex;flex-direction:column;gap:4px;}
.lb-featured-name{font-size:18px;font-weight:800;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lb-featured-tier{font-size:12px;color:var(--text-sub);}
.lb-featured-points{font-size:13px;color:var(--text-sub);}
.lb-featured-points strong{font-size:22px;line-height:1;color:var(--primary);}
.lb-featured-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px;}
.lb-featured-stat{padding-top:10px;border-top:1px solid var(--card-border);display:flex;flex-direction:column;gap:4px;}
.lb-featured-stat-value{font-size:16px;font-weight:800;color:var(--text-main);}
.lb-featured-stat-label{font-size:11px;color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em;}
.lb-player-cell{display:flex;align-items:center;gap:10px;min-width:0;}
.lb-player-tier-icon{width:28px;height:28px;flex-shrink:0;object-fit:contain;}
.lb-player-meta{min-width:0;display:flex;flex-direction:column;gap:2px;}
.lb-player-name{display:block;font-weight:700;color:var(--text-main);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lb-player-tier{font-size:12px;color:var(--text-hint);}
.lb-tier-guide-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;}
.lb-tier-guide-card{padding:16px 12px;text-align:center;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--surface);}
.lb-tier-guide-card img{width:58px;height:58px;object-fit:contain;margin-bottom:10px;}
.lb-tier-guide-name{font-size:14px;font-weight:700;color:var(--text-main);}
.lb-tier-guide-range{margin-top:4px;font-size:12px;color:var(--text-sub);}
.lb-guide-notes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px;}
.lb-guide-note{padding:16px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:rgba(255,255,255,.02);}
.lb-guide-note h4{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text-main);}
.lb-guide-note p{font-size:13px;line-height:1.65;color:var(--text-sub);}

.platform-select{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;}
.platform-btn{padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:700;cursor:pointer;border:1px solid var(--card-border);background:transparent;color:var(--text-sub);text-transform:uppercase;}
.platform-btn:hover{border-color:var(--accent);color:var(--primary);}
.platform-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.about-grid{align-items:stretch;}
.about-card{padding:22px;}
.about-text{line-height:1.8;font-size:14px;}
.about-feedback-link{display:inline-flex;align-items:center;gap:8px;}
.compare-controls{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.compare-field{display:grid;gap:6px;min-width:0}
.compare-field label{font-size:12px;color:var(--text-sub);line-height:1}
.compare-field select{height:40px;padding:0 12px;border-radius:var(--radius-md);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);font-size:13px;outline:none}
.compare-field select option{background:#1a1f2e;color:var(--text-main)}
.compare-input-grid{align-items:stretch}
.compare-player-form{display:flex;flex-direction:column;gap:10px;padding:16px;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface)}
.compare-player-badge{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;padding:4px 10px;border-radius:999px;background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.24);color:var(--success);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.compare-player-badge.alt{background:rgba(74,144,226,.14);border-color:rgba(74,144,226,.24);color:var(--info)}
.compare-input-tip{font-size:12px;line-height:1.6;margin:0}
.compare-hero-grid{align-items:stretch}
.compare-hero-card{display:flex;flex-direction:column;gap:16px}
.compare-hero-top{display:flex;align-items:center;gap:16px}
.compare-hero-rank{width:72px;height:72px;border-radius:18px;background:var(--surface);border:1px solid var(--card-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.compare-hero-rank img{width:100%;height:100%;object-fit:contain}
.compare-hero-rank i{font-size:26px;color:var(--text-sub)}
.compare-hero-meta{min-width:0;display:flex;flex-direction:column;gap:8px}
.compare-hero-meta h3{margin:0;font-size:22px;color:var(--text-main);word-break:break-word}
.compare-hero-role{font-size:12px;font-weight:700;color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em}
.compare-hero-tags{display:flex;flex-wrap:wrap;gap:8px}
.compare-hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.compare-hero-stats span{padding:10px 12px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--card-border);font-size:12px;color:var(--text-sub);line-height:1.5}
.compare-hero-stats strong{color:var(--text-main);font-weight:700}
.compare-hero-weapon{margin-top:4px;padding:10px 12px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--card-border)}
.compare-hero-weapon-label{display:block;font-size:11px;font-weight:700;color:var(--text-hint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.compare-hero-weapon-info{display:flex;align-items:center;gap:10px}
.compare-hero-weapon-icon{width:36px;height:36px;object-fit:contain;flex-shrink:0}
.compare-hero-weapon-name{font-size:14px;font-weight:700;color:var(--text-main)}
.compare-hero-weapon-kills{font-size:12px;color:var(--text-sub);margin-left:auto}
.compare-hero-items{margin-top:4px;display:grid;gap:4px}
.compare-item-section{padding:8px 12px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--card-border)}
.compare-item-section-label{display:block;font-size:11px;font-weight:700;color:var(--text-hint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.compare-item-list{display:flex;flex-wrap:wrap;gap:8px}
.compare-item-entry{display:flex;align-items:center;gap:6px;padding:3px 8px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.04)}
.compare-item-icon{width:24px;height:24px;object-fit:contain;flex-shrink:0}
.compare-item-name{font-size:12px;color:var(--text-main);white-space:nowrap}
.compare-item-count{font-size:11px;color:var(--text-sub);font-weight:700;margin-left:auto}
.compare-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.compare-summary-section{padding:16px;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface)}
.compare-summary-heading{font-size:13px;font-weight:800;margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em}
.compare-summary-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:10px}
.compare-summary-list li{display:flex;justify-content:space-between;gap:12px;line-height:1.6;color:var(--text-sub)}
.compare-summary-list strong{color:var(--text-main);font-weight:700}
.compare-note{margin:0 0 12px;line-height:1.7}
.compare-recent-focus{margin-top:16px;padding:16px;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface)}
.compare-sample-block{margin-bottom:18px}
.compare-sample-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.compare-sample-column{padding:16px;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface)}
.compare-sample-heading{font-size:13px;font-weight:800;margin-bottom:12px;color:var(--text-main);text-transform:uppercase;letter-spacing:.04em}
.compare-sample-item{padding:12px;border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--surface-soft)}
.compare-sample-item+.compare-sample-item{margin-top:10px}
.compare-sample-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.compare-sample-top strong{color:var(--text-main);font-size:14px}
.compare-sample-sub{font-size:12px;color:var(--text-sub);line-height:1.6}
.compare-sample-stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.compare-sample-stats span{padding:4px 8px;border-radius:999px;background:var(--surface);border:1px solid var(--card-border);font-size:11px;color:var(--text-sub)}
.hitzone-body-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}
.hitzone-body-model{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface)}
.hitzone-body-name{font-size:13px;font-weight:700;color:var(--text-main);text-align:center}
.hitzone-body-content{display:flex;align-items:flex-start;gap:10px}
.hitzone-body-labels{display:flex;flex-direction:column;gap:6px;min-width:68px}
.hz-label-row{display:flex;justify-content:space-between;gap:6px;font-size:11px;line-height:1.5}
.hz-label-row span:last-child{font-weight:700}
.hitzone-body-svg{width:56px;height:auto;flex-shrink:0}
.hitzone-body-svg path{stroke:rgba(255,255,255,0.15);stroke-width:0.5}
.ability-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:12px}
.ability-score-card{padding:16px;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--surface)}
.ability-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ability-player-name{font-size:14px;font-weight:700;color:var(--text-main)}
.ability-overall-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1.5px solid;font-size:13px;font-weight:800}
.ability-grade{font-size:16px}
.ability-overall-num{font-size:12px;opacity:.85}
.ability-rows{display:flex;flex-direction:column;gap:4px}
.ability-row{display:flex;align-items:center;gap:8px}
.ability-label{font-size:11px;color:var(--text-sub);min-width:64px;white-space:nowrap}
.ability-bar-wrap{flex:1;height:6px;border-radius:999px;background:rgba(255,255,255,0.06);overflow:hidden}
.ability-bar{height:100%;border-radius:inherit;transition:width .4s ease}
.ability-value{font-size:12px;font-weight:700;min-width:28px;text-align:right}
.ability-desc{font-size:10px;color:var(--text-hint);margin-left:72px;margin-bottom:4px;line-height:1.3}
.policy-hero{padding-top:14px;}
.policy-back{margin-bottom:16px;}
.policy-subtitle{line-height:1.75;}
.policy-section{padding:22px 0;border-bottom:1px solid var(--card-border);}
.policy-section:first-child{padding-top:0;}
.policy-section:last-child{padding-bottom:0;border-bottom:0;}
.policy-section-title{font-size:18px;font-weight:800;color:var(--text-main);margin-bottom:14px;}
.policy-section-body{display:flex;flex-direction:column;gap:12px;}
.policy-paragraph{font-size:14px;line-height:1.9;color:var(--text-sub);}
.policy-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:10px;color:var(--text-sub);}
.policy-list li{line-height:1.85;}
.policy-list strong{color:var(--text-main);}
.policy-contact{padding:16px 18px;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:rgba(255,255,255,.02);font-size:14px;color:var(--text-sub);}
.policy-contact strong{color:var(--text-main);margin-right:6px;}
.policy-contact-note{margin-top:8px;color:var(--text-hint);font-size:12px;}

.season-selector{display:grid;grid-template-columns:minmax(180px,220px) minmax(0,1fr) auto;gap:12px;align-items:center;margin-bottom:16px;}
.season-selector select{width:100%;padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);font-size:13px;outline:none}
.season-selector select option{background:#1a1f2e;color:var(--text-main)}
.season-selector .filter-btns{margin-bottom:0;}
.season-selector .btn{height:36px;justify-content:center;}
.season-update-time{font-size:13px;color:var(--text-hint);margin-bottom:12px;}

.filter-btns{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap;}
.filter-btn{padding:6px 14px;border-radius:var(--radius-md);font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--card-border);background:transparent;color:var(--text-sub);text-transform:uppercase;}
.filter-btn:hover{border-color:var(--accent);color:var(--primary);}
.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}

.mode-tabs{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap;}
.mode-tab{padding:5px 12px;border-radius:var(--radius-md);font-size:12px;font-weight:700;cursor:pointer;border:1px solid transparent;background:transparent;color:var(--text-hint);text-transform:uppercase;}
.mode-tab:hover{color:var(--primary);}
.mode-tab.active{background:var(--accent-soft);color:var(--primary);border-color:var(--accent);}

.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--surface);}
.stats-grid .sg-item{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--card-border);font-size:13px;}
.stats-grid .sg-item:nth-child(odd){border-right:1px solid var(--card-border);}
.stats-grid .sg-item .sg-label{color:var(--text-sub);}
.stats-grid .sg-item .sg-val{font-weight:700;color:var(--text-main);}

.search-box{margin-bottom:16px;}
.search-box input{width:100%;padding:10px 16px 10px 38px;border-radius:var(--radius-md);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);font-size:13px;outline:none;}
.search-box input:focus{border-color:var(--accent);background:var(--accent-soft);}
.search-box{position:relative;}
.search-box i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-hint);font-size:13px;}

.empty-state{text-align:center;padding:40px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--card-border);}
.empty-state i{font-size:40px;margin-bottom:12px;display:block;color:var(--primary);}
.empty-state p{color:var(--text-hint);}

.mb-8{margin-bottom:8px;}
.mb-12{margin-bottom:12px;}
.mb-16{margin-bottom:16px;}
.mb-24{margin-bottom:24px;}
.mt-8{margin-top:8px;}
.mt-12{margin-top:12px;}
.mt-16{margin-top:16px;}
.mt-24{margin-top:24px;}
.text-center{text-align:center;}
.text-primary{color:var(--primary);}
.text-sub{color:var(--text-sub);}
.text-hint{color:var(--text-hint);}
.text-success{color:var(--success);}
.text-danger{color:var(--danger);}
.flex-center{display:flex;align-items:center;justify-content:center;}
.gap-8{gap:8px;}
.gap-12{gap:12px;}
.gap-16{gap:16px;}
.flex{display:flex;}
.flex-wrap{flex-wrap:wrap;}
.items-center{align-items:center;}
.justify-between{justify-content:space-between;}
.w-full{width:100%;}
.hidden{display:none!important;}

@media(max-width:900px){
  .grid-4,.grid-5,.grid-6{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .crate-layout{grid-template-columns:minmax(150px,180px) minmax(0,1fr);gap:14px;}
  .crate-list{flex-direction:column;flex-wrap:nowrap;max-height:calc(100vh - 220px);padding-right:4px;}
  .crate-item{padding:10px 12px;gap:10px;}
  .crate-thumb{width:46px;height:46px;}
  .crate-item-name{font-size:12px;}
  .crate-item-meta{font-size:10px;}
  .crate-area .crate-actions{gap:8px;}
  .crate-area .crate-actions .btn{flex:1 1 calc(50% - 4px);justify-content:center;min-width:0;padding-left:12px;padding-right:12px;}
  .crate-stats{flex-wrap:wrap;gap:8px 12px;}
  .crate-hero-body{max-width:58%;}
  .detail-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr;}
  .stats-grid .sg-item:nth-child(odd){border-right:none;}
  .lb-featured-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
  .lb-tier-guide-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .lb-guide-notes{grid-template-columns:1fr;}
  .compare-controls{grid-template-columns:repeat(2,minmax(0,1fr));}
  .compare-summary-grid{grid-template-columns:1fr;}
  .compare-sample-grid{grid-template-columns:1fr;}
  .season-selector{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .nav{padding:0 16px;}
  .nav-logo{margin-right:12px;}
  .nav-logo-image{height:28px;max-width:42vw;}
  .nav-links{position:fixed;top:60px;right:0;width:280px;max-width:90vw;height:auto;max-height:calc(100vh - 70px);background:var(--nav-bg);display:none;flex-direction:column;flex:none;align-items:stretch;justify-content:flex-start;padding:16px;gap:4px;z-index:9999;border-top:1px solid var(--nav-border);transform:translateX(100%);transition:transform .3s ease;overflow:visible;min-width:0;flex-wrap:nowrap;}
  .nav-links.open{display:flex;transform:translateX(0);}
  .nav-links a{width:100%;display:block;padding:12px 14px;font-size:14px;border-radius:var(--radius-md);white-space:nowrap;border:1px solid transparent;background:transparent;text-align:left;margin:0;flex:none;}
  .nav-overlay{position:fixed;top:60px;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:9998;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;pointer-events:none;}
  .nav-overlay.open{opacity:1;visibility:visible;pointer-events:auto;}
  .hamburger{display:flex;}
  .lang-btn{min-width:34px;padding:0 8px;}
  .grid-2,.grid-3,.grid-4,.grid-5,.grid-6{grid-template-columns:1fr;}
  .main{padding:16px;}
  .compare-controls{grid-template-columns:1fr;}
  .compare-hero-top{align-items:flex-start;}
  .compare-hero-stats{grid-template-columns:1fr;}
  .compare-summary-list li{flex-direction:column;gap:4px;}
  .compare-sample-top{align-items:flex-start;flex-direction:column;}
  .hitzone-body-grid{grid-template-columns:1fr}
  .hitzone-body-svg{width:48px}
  .ability-grid{grid-template-columns:1fr}
  .site-footer{padding:12px 16px 16px;}
  .site-footer-inner{flex-direction:column;gap:6px;text-align:center;}
  .site-footer-links{justify-content:center;}
  .site-footer-link-btn{width:auto;}
  .site-footer-meta{justify-content:center;flex-wrap:wrap;flex:0 1 auto;gap:4px;}
  .site-footer-sep{display:none;}
  .site-footer-copy,.site-footer-note{white-space:normal;}
  .player-header{flex-direction:column;text-align:center;}
  .hero-search h2{font-size:22px;}
  .home-platform-tabs{gap:4px;}
  .home-platform-tabs .platform-btn{flex:1 1 calc(50% - 4px);justify-content:center;padding:8px 12px;}
  .home-history-trigger{width:50px;min-width:50px;}
  .home-history-trigger i{font-size:13px;}
  .home-history-trigger span{font-size:8px;}
  .home-search-submit{min-width:80px;padding:0 14px;}
  .home-history-item{padding:14px;}
  .home-history-item-head{margin-bottom:10px;}
  .home-history-meta{grid-template-columns:1fr;}
  .home-history-platform{font-size:11px;padding:3px 7px;}
  .crate-layout{grid-template-columns:108px minmax(0,1fr);gap:10px;}
  .crate-list{max-height:calc(100vh - 190px);gap:5px;padding-right:2px;}
  .crate-item{padding:8px 8px 8px 9px;gap:8px;align-items:flex-start;}
  .crate-thumb{width:38px;height:38px;}
  .crate-item-text{gap:2px;}
  .crate-item-name{font-size:11px;white-space:normal;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;}
  .crate-item-meta{display:none;}
  .crate-area .crate-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:14px;}
  .crate-area .crate-actions .btn{width:100%;padding:9px 8px;font-size:12px;}
  .crate-stats{margin-bottom:12px;font-size:12px;}
  .crate-area .item-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;}
  .crate-area .item-cell{padding:6px;font-size:10px;}
  .crate-area .item-visual{height:82px;margin-bottom:6px;}
  .crate-area .item-icon{padding:8px;}
  .crate-area .item-rarity{padding:2px 5px;margin-bottom:6px;font-size:9px;}
  .crate-area .item-name{font-size:10px;line-height:1.35;min-height:28px;}
  .crate-area .item-prob{margin-top:4px;font-size:10px;}
  .crate-hero{min-height:0;padding:14px;}
  .crate-hero-media{position:relative;width:100%;max-width:none;height:88px;padding:0;margin-top:8px;justify-content:flex-start;}
  .crate-hero-body{max-width:none;}
  .crate-hero-title{font-size:18px;}
  .crate-hero-sub{font-size:12px;line-height:1.55;}
  .item-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));}
  .crate-overview-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));}
  .match-card-body{padding:8px 10px;gap:10px;}
  .match-rank{width:70px;min-width:70px;padding-right:10px;margin-right:0;border-right:none;}
  .match-stat{min-width:48px;}
  .match-stat.survive-stat,.match-stat.damage-stat{display:none;}
  .replay-related-match-card .match-rank{width:72px;min-width:72px;}
  .replay-related-match-side{width:100%;margin-left:0;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap;}
  .replay-related-match-actions{width:100%;justify-content:flex-start;}
  .replay-related-match-actions .btn{flex:1 1 calc(50% - 4px);justify-content:center;}
  .match-detail-hero{margin:-20px -20px 16px;padding:18px 18px 16px;min-height:174px;border-radius:var(--radius-xl) var(--radius-xl) 0 0}
  .match-detail-hero-top{flex-direction:column;align-items:flex-start;gap:14px;padding-top:34px;padding-right:0}
  .match-detail-hero-title h3{font-size:18px}
  .match-detail-open-replay{width:100%;margin-right:0;justify-content:center}
  .match-detail-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .match-detail-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .match-detail-team-head{flex-direction:column;align-items:flex-start}
  .match-detail-team-head-stats{justify-content:flex-start}
  .match-detail-team-player{grid-template-columns:minmax(0,1fr) repeat(3,minmax(42px,auto));}
  .match-detail-team-player .hide-mobile{display:none}
  .lb-controls{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;}
  .lb-controls select{min-width:160px;}
  .lb-featured-grid{display:flex;flex-direction:column;gap:12px;}
  .lb-featured-card{padding:14px 12px;min-width:0;}
  .lb-featured-badge{min-height:22px;padding:3px 8px;font-size:10px;letter-spacing:.02em;}
  .lb-featured-main{flex-direction:row;align-items:center;gap:12px;margin-top:12px;text-align:left;}
  .lb-featured-rank{width:56px;height:56px;}
  .lb-featured-meta{align-items:flex-start;gap:4px;flex:1;min-width:0;}
  .lb-featured-name{font-size:14px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .lb-featured-tier{font-size:11px;line-height:1.3;}
  .lb-featured-points{font-size:12px;}
  .lb-featured-points strong{font-size:18px;}
  .lb-featured-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px;}
  .lb-featured-stat{padding-top:8px;gap:3px;text-align:center;}
  .lb-featured-stat-value{font-size:13px;}
  .lb-featured-stat-label{font-size:9px;letter-spacing:.02em;}
  .lb-tier-guide-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .lb-tier-guide-card{padding:12px 8px;}
  .lb-tier-guide-card img{width:44px;height:44px;margin-bottom:8px;}
  .lb-tier-guide-name{font-size:12px;}
  .lb-tier-guide-range{font-size:11px;}
  .lb-player-cell{min-width:180px;}
  .modal-content{padding:20px;max-height:90vh;}
}
.ai-report-panel{padding:20px;background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--card-border);}
.ai-report-header{margin-bottom:20px;}
.ai-report-header h3{font-size:18px;color:var(--text-main);margin:0 0 8px;display:flex;align-items:center;gap:10px;}
.ai-report-header h3 i{color:var(--accent-green);}
.ai-report-input{padding:16px;background:var(--surface);border-radius:var(--radius-md);}
.ai-report-status{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface-soft);border-radius:var(--radius-md);margin-top:16px;}
.ai-report-status .spinner{width:20px;height:20px;}
.ai-report-output{margin-top:16px;}
.ai-report-actions{display:flex;gap:10px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--card-border);}
.ai-report-markdown{padding:20px;background:var(--surface);border-radius:var(--radius-md);line-height:1.8;color:var(--text-main);}
.ai-section-title{font-size:16px;color:var(--accent);margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--accent-line);display:flex;align-items:center;gap:8px;}
.ai-section-title i{font-size:12px;}
.ai-report-markdown ul{margin:8px 0;padding-left:20px;}
.ai-report-markdown li{margin:6px 0;color:var(--text-sub);}
.ai-report-markdown strong{color:var(--text-main);}
.ai-num{color:var(--accent);font-weight:700;}
.ai-cursor{color:var(--accent);font-weight:bold;animation:blink 0.8s infinite;margin-left:2px;}
@keyframes blink{0%,50%{opacity:1;}51%,100%{opacity:0;}}
.ai-typing{min-height:200px;}
.ai-stream-cursor{color:var(--accent);font-weight:bold;animation:blink 0.7s infinite;margin-left:2px;display:inline;}
.ai-streaming{min-height:200px;}
.ai-section-heading{font-size:15px;color:var(--accent-green);margin:16px 0 10px;display:flex;align-items:center;gap:8px;}
.ai-section-heading i{font-size:10px;color:var(--accent);}
.ai-main-title{font-size:18px;color:var(--text-main);margin:20px 0 12px;font-weight:700;}
.ai-list{list-style:none;padding-left:0;margin:10px 0;}
.ai-list li{position:relative;padding-left:20px;margin:8px 0;}
.ai-list li::before{content:'•';position:absolute;left:0;color:var(--accent);}
.ai-ordered-list{list-style:none;padding-left:0;margin:10px 0;}
.ai-ordered-list li{position:relative;padding-left:30px;margin:8px 0;}
.ai-code{background:var(--surface-soft);padding:2px 6px;border-radius:4px;font-size:13px;color:var(--accent);}
.ai-report-status-info{padding:12px 16px;background:var(--surface-soft);border-radius:var(--radius-md);color:var(--text-sub);font-size:13px;display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.ai-report-status-info i{color:var(--accent);}
.ai-match-list{padding:16px;background:var(--surface);border-radius:var(--radius-md);}
.ai-match-list-title{font-size:16px;color:var(--text-main);margin:0 0 16px;display:flex;align-items:center;gap:10px;}
.ai-match-list-title i{color:var(--accent);}
.ai-match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;}
