/* SakuraWash Theme */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0f0a14;
  --card:#1a1428;
  --card-hover:#231e3a;
  --border:#2c2448;
  --accent:#ec4899;
  --accent2:#f472b6;
  --accent-glow:rgba(236,72,153,.12);
  --text:#e2e8f0;
  --dim:#8b95a8;
  --radius:16px;
  --shadow:0 4px 22px rgba(0,0,0,.36);
}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;min-height:100vh}
a{color:var(--accent);text-decoration:none;transition:all .2s}
a:hover{color:var(--accent2)}

.site-header{background:var(--bg);border-bottom:1px solid var(--border);padding:14px 0;position:sticky;top:0;z-index:100;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto;padding:0 20px}
.site-header .logo{font-size:1.3rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.site-header nav{display:flex;gap:4px;flex-wrap:wrap}
.site-header nav a{font-weight:600;color:var(--dim);padding:6px 14px;border-radius:8px;font-size:.85rem;transition:all .2s}
.site-header nav a:hover{color:var(--accent);background:var(--accent-glow)}

header:not(.site-header){background:var(--bg);border-bottom:1px solid var(--border);padding:16px 24px;position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
header:not(.site-header) h1{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline}
header:not(.site-header) p{display:none}
nav:not(.site-header nav){background:var(--card);border-bottom:1px solid var(--border);padding:10px 24px;text-align:center}
nav:not(.site-header nav) a{font-weight:600;color:var(--dim);padding:6px 16px;border-radius:8px;font-size:.9rem;transition:all .2s}
nav:not(.site-header nav) a:hover{color:var(--accent);background:var(--accent-glow)}

.container{max-width:1000px;margin:0 auto;padding:24px 16px}
main.container{padding-top:32px}

.hero,.hero-box{position:relative;border-radius:var(--radius);padding:18px 28px;margin-bottom:24px;overflow:hidden;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 15%,var(--card)),color-mix(in srgb,var(--accent2) 8%,var(--card)));border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:20px}
.hero::before,.hero-box::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent);opacity:.7}
.hero::after,.hero-box::after{content:"";position:absolute;top:-50%;right:-10%;width:350px;height:350px;background:var(--accent-glow);border-radius:50%;filter:blur(80px);opacity:.6}
.hero h1,.hero-box h2{font-size:1.2rem;font-weight:800;color:#fff;margin-bottom:4px;position:relative;z-index:1;line-height:1.3}
.hero p,.hero-box p{color:var(--dim);margin-bottom:0;position:relative;z-index:1;font-size:.85rem;max-width:500px}

.btn,.btn-cta,.btn-white{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:12px;font-weight:700;font-size:1rem;transition:all .3s;cursor:pointer;border:none;text-decoration:none;position:relative;z-index:1}
.btn-cta,.btn-accent,.btn-white{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 16px var(--accent-glow)}
.btn-cta:hover,.btn-accent:hover,.btn-white:hover{filter:brightness(1.15);transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow);color:#fff}
.hero .btn-cta{flex-shrink:0;white-space:nowrap;font-size:1.05rem;padding:16px 36px;min-width:200px;text-align:center}
.btn-outline{border:1px solid var(--border);color:var(--dim);background:transparent}
.btn-outline:hover{border-color:var(--accent);color:#fff}

.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:28px 0}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center;transition:all .3s}
.stat-card:hover{border-color:var(--accent);background:var(--card-hover);transform:translateY(-3px);box-shadow:var(--shadow)}
.stat-card .number{font-size:1.9rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}
.stat-card .label{font-size:.8rem;color:var(--dim);margin-top:6px}

.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0;padding:24px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius)}
.stats-bar .stat{text-align:center}
.stats-bar .stat strong{font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}
.stats-bar .stat span{font-size:.8rem;color:var(--dim);margin-top:4px;display:block}

.section-title,section h2{font-size:1.15rem;font-weight:700;color:#fff;margin:36px 0 18px;display:flex;align-items:center;gap:10px}
.section-title::after,section h2::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}

.post-list{list-style:none;display:grid;gap:12px}
.post-list li{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;transition:all .3s}
.post-list li:hover{border-color:var(--accent);background:var(--card-hover);transform:translateX(4px);box-shadow:var(--shadow)}
.post-list li a{font-size:.95rem;font-weight:600;color:var(--text);line-height:1.4}
.post-list li a:hover{color:var(--accent)}
.post-list li .meta{font-size:.78rem;color:var(--dim);margin-top:6px}
.post-list li p{font-size:.85rem;color:var(--dim);margin-top:4px}

.predictions-grid,.today-predictions .predictions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin:16px 0}
.prediction-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .3s;overflow:hidden;position:relative}
.prediction-card:hover{border-color:var(--accent);background:var(--card-hover);transform:translateY(-3px);box-shadow:var(--shadow)}
.prediction-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));opacity:0;transition:opacity .3s}
.prediction-card:hover::before{opacity:1}
.prediction-card a{color:inherit;text-decoration:none}
.prediction-card .match-info{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.prediction-card .match-info .date{font-size:.75rem;color:var(--dim);background:var(--card-hover);padding:3px 8px;border-radius:6px}
.prediction-card .match-info .league{font-size:.72rem;font-weight:600;color:var(--accent);background:var(--accent-glow);padding:3px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px}
.prediction-card h3{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.4;margin-bottom:10px}
.prediction-card .prediction-preview{margin-top:8px}
.prediction-card .win-rate{font-size:.82rem;font-weight:600;color:var(--accent)}

.number-preview{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.number-preview .ball{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--accent-glow)}
.game-keno .ball{background:linear-gradient(135deg,#f97316,#fb923c)}
.game-power .ball{background:linear-gradient(135deg,#7c3aed,#a78bfa)}
.game-mega .ball{background:linear-gradient(135deg,#eab308,#facc15)}

.games-grid,.games-section .games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;margin:16px 0}
.game-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .3s}
.game-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.game-card h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:8px}
.game-card p{font-size:.85rem;color:var(--dim);margin-bottom:12px;line-height:1.6}
.game-card a{font-weight:600;font-size:.85rem}

.how-it-works{margin:40px 0;padding:32px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius)}
.how-it-works h2{margin-top:0}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:20px}
.step{padding:20px;background:var(--card-hover);border:1px solid var(--border);border-radius:12px;transition:all .3s}
.step:hover{border-color:var(--accent);transform:translateY(-2px)}
.step h3{font-size:.9rem;font-weight:700;color:var(--accent);margin-bottom:8px}
.step p{font-size:.83rem;color:var(--dim);line-height:1.6}

.picks-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 26px;margin:24px 0}
.picks-card h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:16px}
table{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden}
thead th{background:color-mix(in srgb,var(--accent) 20%,var(--card));color:var(--accent);padding:12px 14px;font-size:.8rem;font-weight:600;text-align:left;text-transform:uppercase;letter-spacing:.5px}
tbody td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:.85rem;color:var(--text)}
tbody tr:hover{background:var(--card-hover)}
.badge-ai{display:inline-flex;align-items:center;gap:3px;background:rgba(34,197,94,.12);color:#22c55e;padding:4px 12px;border-radius:8px;font-size:.75rem;font-weight:600}

.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin:16px 0}
.cat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 18px;text-align:center;font-weight:600;font-size:.88rem;color:var(--dim);transition:all .3s}
.cat-card:hover{border-color:var(--accent);background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}

.cta-section{text-align:center;margin:44px 0;padding:44px 32px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 12%,var(--card)),color-mix(in srgb,var(--accent2) 8%,var(--card)));border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden}
.cta-section::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent);opacity:.5}
.cta-section h2,.cta-section h3{font-size:1.25rem;font-weight:800;color:#fff;margin-bottom:10px}
.cta-section p{color:var(--dim);margin-bottom:22px;font-size:.9rem}

.site-footer,.partners{border-top:1px solid var(--border)}
.partners{text-align:center;padding:14px 0;font-size:.78rem;color:var(--dim)}
.partners a{color:var(--dim);margin:0 8px}
.partners a:hover{color:var(--accent)}
.site-footer{padding:40px 20px;text-align:center}
.site-footer .container{max-width:800px;margin:0 auto}
.footer-cta{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 10%,var(--card)),var(--card));border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:24px}
.footer-cta h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:8px}
.footer-cta p{color:var(--dim);font-size:.85rem;margin-bottom:16px}
.footer-info{font-size:.8rem;color:var(--dim)}
.footer-info p{margin-bottom:8px}
.footer-info a{color:var(--dim)}
.footer-info a:hover{color:var(--accent)}
.footer-links a{margin:0 6px}
footer:not(.site-footer){margin-top:48px;padding:24px 20px;text-align:center;font-size:.8rem;color:var(--dim);border-top:1px solid var(--border)}
footer:not(.site-footer) a{color:var(--dim);margin:0 8px}
footer:not(.site-footer) a:hover{color:var(--accent)}

.post-content{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:36px;margin:16px 0}
.post-content h1,.post-content h2,.post-content h3{color:#fff;margin:24px 0 12px}
.post-content h1{font-size:1.5rem;line-height:1.3}
.post-content h2{font-size:1.2rem;border-bottom:1px solid var(--border);padding-bottom:8px}
.post-content h3{font-size:1.05rem}
.post-content p{color:var(--dim);margin-bottom:14px;line-height:1.85;font-size:.92rem}
.post-content table{margin:16px 0}
.post-content blockquote{border-left:3px solid var(--accent);padding:14px 18px;background:var(--accent-glow);border-radius:0 10px 10px 0;margin:18px 0;font-size:.9rem}
.post-content ul,.post-content ol{color:var(--dim);padding-left:22px;margin:10px 0}
.post-content li{margin-bottom:6px;line-height:1.7}
.post-content strong{color:var(--text)}
.post-content a{color:var(--accent);border-bottom:1px solid var(--accent-glow)}
.post-content a:hover{color:var(--accent2);border-bottom-color:var(--accent2)}

@media(max-width:768px){
  .stats-grid,.stats-bar{grid-template-columns:1fr}
  .predictions-grid{grid-template-columns:1fr}
  .games-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .categories-grid{grid-template-columns:1fr 1fr}
  .hero,.hero-box{padding:14px 16px;flex-direction:column;text-align:center}
  .hero h1,.hero-box h2{font-size:1.1rem}
  .container,main.container{padding:16px 12px}
  table{display:block;overflow-x:auto}
  .picks-card{padding:16px}
  .site-header .container{flex-direction:column;gap:10px}
  .site-header nav{justify-content:center}
  .number-preview .ball{width:28px;height:28px;font-size:.7rem}
}
@media(min-width:769px) and (max-width:1024px){
  .predictions-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid,.stats-bar{grid-template-columns:repeat(3,1fr)}
}
/* World Cup 2026 Countdown Banner */
.wc-banner{position:relative;overflow:hidden;border-radius:var(--radius);margin-bottom:20px}
.wc-banner .wc-banner-img{width:100%;display:block;max-height:280px;object-fit:cover;object-position:center top}
.wc-banner::before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 40%,rgba(0,0,0,.1) 70%,rgba(0,0,0,.5) 100%);z-index:1}
.wc-banner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;z-index:2}
.wc-bar-title{font-size:1rem;font-weight:800;letter-spacing:2px;background:linear-gradient(135deg,#facc15,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}
.wc-bar-flags{font-size:1.1rem;margin:6px 0}
.wc-cd{display:flex;gap:10px;align-items:center;margin-top:4px}
.wc-cd-unit{text-align:center}
.wc-cd-num{font-size:1.5rem;font-weight:800;color:#fff;background:rgba(250,204,21,.15);padding:4px 10px;border-radius:8px;min-width:42px;display:inline-block;font-variant-numeric:tabular-nums;backdrop-filter:blur(4px)}
.wc-cd-lbl{font-size:.6rem;color:rgba(255,255,255,.7);text-transform:uppercase;margin-top:3px;display:block;letter-spacing:.5px}
@media(max-width:480px){.wc-banner .wc-banner-img{min-height:120px}.wc-bar-title{font-size:.85rem}.wc-cd-num{font-size:1.2rem;padding:3px 7px;min-width:34px}.wc-cd{gap:6px}}


/* === Redesign v2: Match Cards === */

/* Featured matches */
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin:16px 0}
.featured-match{display:block;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:all .3s;text-decoration:none;color:inherit;position:relative;overflow:hidden}
.featured-match::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.featured-match:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.fm-league{font-size:.72rem;font-weight:600;color:var(--accent);background:var(--accent-glow);padding:3px 10px;border-radius:6px;display:inline-block;margin-bottom:14px;text-transform:uppercase;letter-spacing:.3px}
.fm-teams{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:12px}
.fm-team{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px}
.fm-team img{width:48px;height:48px;object-fit:contain;border-radius:8px}
.fm-team span{font-size:.85rem;font-weight:600;color:var(--text);text-align:center}
.fm-vs{font-size:1.3rem;font-weight:800;color:var(--dim)}
.fm-meta{text-align:center;font-size:.78rem;color:var(--dim);margin-bottom:10px}
.fm-prediction{margin-bottom:8px}
.fm-pick{font-size:.82rem;font-weight:600;color:var(--accent);display:block;margin-bottom:6px;text-align:center}
.fm-odds{display:flex;justify-content:center;gap:8px;margin-top:8px}

/* Probability bar */
.prob-bar{height:6px;border-radius:3px;background:var(--border);overflow:hidden;flex:1}
.prob-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .5s}
.prob-fill.draw{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.prob-fill.away{background:linear-gradient(90deg,#ef4444,#f87171)}

/* Odds tags */
.odds-tag{background:var(--accent-glow);color:var(--accent);padding:3px 10px;border-radius:6px;font-size:.75rem;font-weight:600}

/* Prediction card teams */
.pc-teams{display:flex;align-items:center;gap:8px;margin:8px 0}
.pc-team{display:flex;align-items:center;gap:6px;flex:1;min-width:0}
.pc-team img{width:24px;height:24px;object-fit:contain;border-radius:4px;flex-shrink:0}
.pc-team span{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pc-vs{font-size:.75rem;color:var(--dim);font-weight:700;flex-shrink:0}
.pc-prediction{margin-top:6px}
.pc-odds{display:flex;gap:6px;margin-top:8px}

/* Breadcrumb */
.breadcrumb{font-size:.8rem;color:var(--dim);margin-bottom:16px;padding:0}
.breadcrumb a{color:var(--dim)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:var(--text)}

/* Match header (article page) */
.match-header{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:16px;text-align:center;position:relative;overflow:hidden}
.match-header::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent)}
.mh-league{font-size:.8rem;font-weight:600;color:var(--accent);margin-bottom:16px}
.mh-teams{display:flex;align-items:center;justify-content:center;gap:32px;margin-bottom:14px}
.mh-team{display:flex;flex-direction:column;align-items:center;gap:8px}
.mh-team img{width:64px;height:64px;object-fit:contain}
.mh-team span{font-size:1rem;font-weight:700;color:var(--text)}
.mh-vs{font-size:1.6rem;font-weight:800;color:var(--dim)}
.mh-meta{font-size:.85rem;color:var(--dim)}

/* AI Summary card */
.ai-summary{background:var(--card);border:1px solid var(--accent);border-radius:var(--radius);padding:24px;margin-bottom:16px}
.ai-title{font-size:.95rem;font-weight:700;color:var(--accent);margin-bottom:16px}
.ai-probs{display:flex;flex-direction:column;gap:10px}
.prob-row{display:flex;align-items:center;gap:12px}
.prob-label{font-size:.82rem;color:var(--text);width:120px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prob-pct{font-size:.82rem;font-weight:700;color:var(--accent);width:40px;text-align:right;flex-shrink:0}
.ai-odds{display:flex;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}

/* Mobile */
@media(max-width:640px){
  .featured-grid{grid-template-columns:1fr}
  .fm-team img{width:36px;height:36px}
  .fm-team span{font-size:.78rem}
  .mh-teams{gap:16px}
  .mh-team img{width:48px;height:48px}
  .mh-team span{font-size:.88rem}
  .prob-label{width:80px;font-size:.75rem}
  .ai-odds{flex-wrap:wrap}
}

/* tool-pages */
.tool-page { max-width:800px; margin:0 auto; }
.tool-desc { color:#aaa; font-size:15px; margin-bottom:20px; }
.filter-btn { padding:8px 16px; border-radius:20px; border:1px solid #333; background:transparent; color:#ccc; cursor:pointer; font-size:13px; }
.filter-btn.active { background:var(--accent,#00d4ff); color:#fff; border-color:var(--accent,#00d4ff); }
.odds-card { background:var(--bg2,#1a1a2e); border-radius:10px; padding:16px; margin-bottom:12px; border:1px solid #222; }
.odds-card.odds-hot { border-color:var(--accent,#00d4ff); }
.odds-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; font-size:12px; color:#888; }
.odds-badge { background:#ff5722; color:#fff; padding:2px 8px; border-radius:4px; font-size:11px; font-weight:700; }
.odds-teams { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.odds-team { font-weight:700; font-size:15px; }
.odds-vs { color:#666; font-size:12px; }
.odds-row { display:flex; gap:8px; }
.odds-cell { flex:1; text-align:center; background:rgba(255,255,255,0.05); padding:8px; border-radius:6px; }
.odds-label { font-size:11px; color:#888; margin-bottom:4px; }
.odds-value { font-weight:700; font-size:16px; color:var(--accent,#00d4ff); }
.odds-ai { margin-top:8px; font-size:12px; color:#4CAF50; text-align:center; }
.calc-input-group { margin-bottom:12px; }
.calc-input-group label { display:block; font-size:13px; color:#aaa; margin-bottom:6px; }
.calc-result-card { background:var(--bg2,#1a1a2e); border-radius:12px; padding:20px; border:1px solid var(--accent,#00d4ff); }
.calc-prob-row { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.calc-prob-label { width:80px; font-size:13px; text-align:right; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.calc-prob-bar-bg { flex:1; height:24px; background:rgba(255,255,255,0.1); border-radius:4px; overflow:hidden; }
.calc-prob-bar { height:100%; border-radius:4px; transition:width 0.6s ease; }
.calc-prob-pct { width:40px; font-weight:700; font-size:14px; }
@media(max-width:600px) {
  .odds-team { font-size:13px; }
  .calc-prob-label { width:60px; font-size:11px; }
}
