.city-page{color:var(--text)}.city-page .schools-scroller,.city-page .matches-scroller{-ms-overflow-style:none;scrollbar-width:none}.city-page .schools-scroller::-webkit-scrollbar{height:0;display:none}.city-page .matches-scroller::-webkit-scrollbar{height:0;display:none}.city-page .banner{background-image:url(../media/milano.f695d298.png);background-position:50%;background-repeat:no-repeat;background-size:cover;width:100%;height:220px}.city-page .banner .banner-content{background-color:rgba(0,0,0,.7);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.city-page .banner .banner-content h1{color:var(--text);margin-top:110px;font-size:max(2rem,min(5vw,5rem));font-weight:500}.city-info{padding:0 10vw}.city-page .titleScrollers{color:var(--text);margin:1rem 1rem .25rem;font-size:max(1.1rem,min(2.4vw,1.6rem));font-weight:600}.city-page .schools-scroller{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;justify-content:flex-start;gap:1rem;padding:3rem 1rem 1rem;scroll-padding-left:1rem;display:flex;overflow-x:auto;overflow-y:hidden}.city-page .schools-scroller::-webkit-scrollbar{height:8px}.city-page .schools-scroller::-webkit-scrollbar-track{background:0 0}.city-page .schools-scroller::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.city-page .school-card{scroll-snap-align:start;background:#111;border:1px solid #222;border-radius:10px;flex-direction:column;flex:0 0 160px;align-items:center;gap:.5rem;padding:.75rem .75rem 1rem;transition:transform .25s,box-shadow .25s;display:flex}.city-page .school-card:first-child{margin-left:0}.city-page .school-card:hover{transform:translateY(-4px);box-shadow:0 6px 14px -6px rgba(0,0,0,.6)}.city-page .logo-wrap{aspect-ratio:1;background:#1c1c1c;border-radius:8px;place-items:center;width:100%;display:grid;position:relative;overflow:hidden}.city-page .school-name{text-align:center;font-size:.85rem;font-weight:500;line-height:1.1}.city-page .matches-section{margin-top:1rem;position:relative}.city-page .matches-scroller{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;justify-content:flex-start;gap:1rem;padding:.5rem 1rem 1rem;scroll-padding-left:1rem;display:flex;overflow-x:auto;overflow-y:hidden}.city-page .matches-scroller::-webkit-scrollbar{height:8px}.city-page .matches-scroller::-webkit-scrollbar-track{background:0 0}.city-page .matches-scroller::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.city-page .match-card{scroll-snap-align:start;background:#111;border:1px solid #222;border-radius:14px;flex-direction:column;flex:0 0 max(280px,min(42vw,420px));gap:.75rem;padding:.85rem 1rem;transition:transform .25s,box-shadow .25s;display:flex}.city-page .match-card:hover{transform:translateY(-4px);box-shadow:0 6px 14px -6px rgba(0,0,0,.6)}.city-page .match-header{color:var(--text);justify-content:space-between;align-items:center;gap:.5rem;display:flex}.city-page .match-date{opacity:.9;font-size:.85rem}.city-page .match-stage{opacity:.75;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:999px;padding:2px 8px;font-size:.75rem}.city-page .match-body{grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem;display:grid}.city-page .team{flex-direction:column;align-items:center;gap:.4rem;min-width:0;display:flex}.city-page .team-logo{aspect-ratio:1;background:#1c1c1c;border-radius:10px;place-items:center;width:66px;display:grid;position:relative;overflow:hidden}.city-page .team-name{text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.8rem;line-height:1.15;overflow:hidden}.city-page .score-wrap{flex-direction:column;justify-content:center;align-items:center;min-width:72px;padding:0 .5rem;display:flex}.city-page .score{letter-spacing:.5px;font-size:max(1.4rem,min(3.6vw,2rem));font-weight:700}.city-page .status{opacity:.7;margin-top:2px;font-size:.7rem}.city-page .matches-controls{pointer-events:none;position:absolute;top:0;bottom:0;left:0;right:0}.city-page .nav-btn{pointer-events:auto;color:#fff;cursor:pointer;background:rgba(20,20,20,.8);border:1px solid #333;border-radius:50%;place-items:center;width:36px;height:36px;font-size:20px;line-height:1;display:grid;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 10px rgba(0,0,0,.25)}.city-page .nav-btn:hover{background:rgba(35,35,35,.9)}.city-page .nav-btn.prev{z-index:1;left:8px}.city-page .nav-btn.next{z-index:1;right:8px}@media (max-width:640px){.city-page .banner{height:130px}.city-page .nav-btn{display:none}.city-page .school-card{flex:0 0 120px}}.city-page .standings-section{margin:1rem 0 1.25rem}.city-page .standings-header-wrap{justify-content:space-between;align-items:center;margin:0 1rem .5rem;display:flex}.city-page .group-tabs{flex-wrap:wrap;gap:.5rem;display:flex}.city-page .group-tab{color:var(--text);cursor:pointer;background:#121212;border:1px solid #2a2a2a;border-radius:999px;padding:6px 12px;font-size:.85rem;transition:background .2s,border-color .2s,color .2s}.city-page .group-tab:hover{background:#171717;border-color:#3a3a3a}.city-page .group-tab.active{background:#1f1f1f;border-color:#4a4a4a}.city-page .standings-card{background:#0e0e0e;border:1px solid #222;border-radius:14px;margin:0 1rem;padding:.5rem}.city-page .standings-row{color:var(--text);grid-template-columns:36px 1fr repeat(8,minmax(28px,44px));align-items:center;gap:.5rem;padding:.5rem;display:grid}.city-page .standings-row.head{opacity:.85;border-bottom:1px solid #222;padding-bottom:.6rem;font-size:.75rem}.city-page .standings-row.body{font-size:.9rem}.city-page .standings-row.body+.standings-row.body{border-top:1px dashed #1f1f1f}.city-page .standings-row.top{background:linear-gradient(rgba(255,215,0,.06),rgba(255,215,0,0))}.city-page .standings-row .col.team{min-width:0}.city-page .standings-row .team-info{align-items:center;gap:.6rem;min-width:0;display:flex}.city-page .standings-row .team-info .logo{background:#1c1c1c;border:1px solid #262626;border-radius:8px;place-items:center;width:32px;height:32px;display:grid;overflow:hidden}.city-page .standings-row .team-info .logo img{object-fit:contain;filter:drop-shadow(0 1px 1px rgba(0,0,0,.4));width:70%;height:70%}.city-page .standings-row .team-info .logo .placeholder{background:#2a2a2a;border-radius:6px;width:60%;height:60%}.city-page .standings-row .team-info .name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.city-page .standings-row .col.pos{justify-content:center;display:flex}.city-page .standings-row .badge{background:#1a1a1a;border:1px solid #333;border-radius:50%;place-items:center;width:26px;height:26px;font-size:.8rem;font-weight:700;display:grid}.city-page .standings-row .badge.gold{color:gold;background:linear-gradient(#3a3000,#241e00);border-color:#6c5b00}.city-page .standings-row .badge.silver{color:#d8d8d8;background:linear-gradient(#2d2d2d,#1d1d1d);border-color:#5a5a5a}.city-page .standings-row .col{text-align:center}.city-page .standings-row .col.team{text-align:left}@media (max-width:840px){.city-page .standings-row{grid-template-columns:30px 1fr repeat(8,36px)}}@media (max-width:600px){.city-page .standings-row{grid-template-columns:28px 1fr repeat(4,36px)}.city-page .standings-row .col.p,.city-page .standings-row .col.w,.city-page .standings-row .col.d,.city-page .standings-row .col.l{display:none}}.city-page .news-intro{color:var(--text);opacity:.9;margin:0 .5rem .5rem 1rem;font-size:.95rem}.city-page .news-section{margin:.25rem 0 1.5rem}.city-page .news-grid{grid-template-columns:repeat(12,1fr);gap:1rem;margin:0 1rem;display:grid}.city-page .news-card{color:var(--text);background:#111;border:1px solid #222;border-radius:14px;grid-column:span 6;padding:1rem 1rem 1.1rem;transition:transform .25s,box-shadow .25s,border-color .2s,background .2s}.CityTitleInfo{text-align:left;border-top:1px solid #222;padding:3rem 0 1rem}.city-page .news-card:hover{background:#121212;border-color:#2b2b2b;transform:translateY(-3px);box-shadow:0 10px 18px -10px rgba(0,0,0,.55)}.city-page .news-header{flex-direction:column;gap:.25rem;display:flex}.city-page .news-meta{opacity:.75;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:999px;align-self:flex-start;padding:2px 8px;font-size:.78rem}.city-page .news-title{margin:.1rem 0 .25rem;font-size:max(1rem,min(2.2vw,1.15rem));font-weight:600;line-height:1.2}.city-page .news-excerpt{opacity:.92;font-size:.95rem;line-height:1.35}@media (max-width:920px){.city-page .news-card{grid-column:span 6}}@media (max-width:640px){.city-page .news-grid{grid-template-columns:repeat(6,1fr)}.city-page .news-card{grid-column:span 6}.city-page .news-intro{margin:0 1rem .5rem}.city-info{padding:0 2vw}}@media (max-width:420px){.city-page .news-excerpt{font-size:.9rem}}
