@media (max-width: 1280px) {
    :root {
        --shell: 1080px;
    }

    .site-nav {
        gap: 26px;
        font-size: 14px;
    }

    .hero-shell {
        grid-template-columns: minmax(0, 1fr) 470px;
        gap: 38px;
    }

    .hero-copy h1 {
        font-size: 48px;
    }

    .hero-model {
        right: -100px;
        width: 650px;
    }

    .metric-section,
    .feature-section,
    .proof-section {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1040px) {
    .site-shell,
    .landing-shell,
    .footer-shell {
        width: min(100% - 36px, var(--shell));
    }

    .site-nav {
        display: none;
    }

    .hero-shell {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .hero-copy h1 {
        font-size: 42px;
    }

    .hero-visual {
        min-height: 360px;
    }

    .hero-visual-card {
        height: 360px;
    }

    .hero-model {
        right: -30px;
        width: 640px;
    }

    .today-pick-board__content {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .worldcup-promo {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .today-pick-board__side {
        justify-content: stretch;
    }

    .today-pick-board__pick {
        width: 100%;
        min-height: 112px;
        flex-direction: row;
        justify-content: space-between;
        padding: 0 24px;
    }

    .today-pick-board__pick strong {
        font-size: 46px;
    }
}

@media (max-width: 760px) {
    .landing-below-pick {
        position: relative;
        margin-top: 18px;
        padding: 16px 0 28px;
        background:
                linear-gradient(180deg, rgba(232, 242, 255, 0.78) 0%, rgba(247, 251, 255, 0.96) 42%, rgba(255, 255, 255, 0) 100%);
        border-top: 1px solid rgba(198, 217, 242, 0.7);
    }

    .site-header {
        height: 64px;
    }

    .logo-image {
        width: 146px;
    }

    .logo-text {
        font-size: 22px;
    }

    .header-download {
        display: inline-flex;
        min-width: 42px;
        width: 42px;
        height: 42px;
        padding: 0;
    }

    .header-download span {
        display: none;
    }

    .landing-hero {
        padding: 34px 0 30px;
    }

    .eyebrow {
        font-size: 15px;
    }

    .eyebrow span {
        width: 100%;
        width: fit-content;
    }

    .hero-copy h1 {
        font-size: 34px;
        line-height: 1.22;
        letter-spacing: -1.6px;
    }

    .summary {
        font-size: 15px;
        line-height: 1.68;
    }

    .download-actions {
        flex-wrap: wrap;
        gap: 10px;
    }

    .download-button {
        flex: 1 1 150px;
        padding: 0 16px;
    }

    .mobile-only-download {
        display: inline-flex;
    }

    .download-button.primary {
        flex-basis: 100%;
    }

    .hero-visual {
        min-height: 310px;
    }

    .hero-visual-card {
        height: 310px;
        border-radius: 26px;
    }

    .hero-model {
        right: -90px;
        width: 560px;
    }

    .worldcup-promo-section {
        padding: 2px 0 24px;
    }

    .worldcup-promo {
        gap: 22px;
        min-height: 0;
        padding: 26px 22px 22px;
        border-radius: 24px;
    }

    .worldcup-promo__copy h2 {
        font-size: 28px;
    }

    .worldcup-promo__squad {
        display: flex;
        overflow-x: auto;
        gap: 10px;
        padding: 10px 0 4px;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }

    .worldcup-promo__squad::-webkit-scrollbar {
        display: none;
    }

    .worldcup-promo-player {
        min-width: 156px;
        min-height: 202px;
        scroll-snap-align: start;
    }

    .worldcup-promo-player--featured {
        transform: translateY(-8px);
    }

    .hero-floating--rate {
        left: 12px;
        bottom: 34px;
    }

    .hero-floating--odds {
        right: 12px;
        bottom: 22px;
    }

    .today-pick-board {
        border-radius: 24px;
    }

    .today-pick-board::before {
        border-radius: 23px;
    }

    .today-pick-board__content {
        padding: 26px 22px;
    }

    .today-pick-board__match {
        font-size: 25px;
    }

    .today-pick-board__action a {
        width: 100%;
    }

    .metric-section,
    .proof-section {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .metric-section {
        margin-top: 14px;
    }

    .today-game-section {
        padding-top: 4px;
    }

    .today-game-section__head {
        padding: 12px 2px;
    }

    .today-game-section__head h2 {
        font-size: 23px;
    }

    .today-game-section__head span {
        font-size: 12px;
    }

    .today-game-section__head time {
        font-size: 11px;
    }

    .today-game-list {
        display: flex;
        overflow-x: auto;
        gap: 10px;
        padding-bottom: 6px;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }

    .today-game-list::-webkit-scrollbar {
        display: none;
    }

    .today-game-card {
        min-width: min(78vw, 268px);
        scroll-snap-align: start;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .today-game-empty {
        border-radius: 16px;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .team-rank-section {
        padding-top: 12px;
    }

    .team-rank-section__head {
        padding: 12px 2px;
    }

    .team-rank-section__head h2 {
        font-size: 23px;
    }

    .team-rank-section__head span {
        font-size: 12px;
    }

    .team-rank-section__head time {
        font-size: 11px;
    }

    .team-rank-board {
        border-radius: 16px;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .team-rank-table {
        table-layout: auto;
    }

    .team-rank-table th,
    .team-rank-table td {
        padding: 10px 6px;
        font-size: 12px;
    }

    .team-rank-table th {
        font-size: 11px;
    }

    .team-rank-col--games,
    .team-rank-col--draws,
    .team-rank-col--gap {
        display: none;
    }

    .team-rank-table th:nth-child(2),
    .team-rank-table td:nth-child(2) {
        width: 28%;
    }

    .team-rank-badge {
        width: 25px;
        height: 25px;
        border-radius: 9px;
    }

    .team-rank-team {
        gap: 5px;
    }

    .team-rank-team span {
        font-size: 13px;
    }

    .team-rank-team small {
        font-size: 10px;
    }

    .team-rank-streak {
        min-width: 36px;
        padding: 4px 5px;
        font-size: 10px;
    }

    .metric-card {
        min-height: 150px;
        flex-direction: column;
        align-items: flex-start;
        justify-content: space-between;
        gap: 10px;
        padding: 16px;
        border-radius: 18px;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .metric-icon {
        width: 42px;
        height: 42px;
        border-radius: 14px;
        font-size: 20px;
    }

    .metric-card strong {
        margin-top: 3px;
        font-size: 23px;
    }

    .metric-card span {
        margin-top: 4px;
        font-size: 11px;
        line-height: 1.45;
    }

    .feature-section {
        grid-template-columns: 1fr;
        gap: 11px;
        margin-top: 24px;
    }

    .feature-section__head {
        margin-bottom: 4px;
        padding: 16px 2px 10px;
        text-align: left;
    }

    .feature-section__head p {
        margin-bottom: 6px;
        font-size: 11px;
    }

    .feature-section__head h2 {
        max-width: 420px;
        font-size: 24px;
        line-height: 1.32;
        letter-spacing: 0;
    }

    .feature-section__head span {
        max-width: 480px;
        margin-top: 8px;
        font-size: 14px;
        line-height: 1.65;
    }

    .feature-card {
        min-height: 156px;
        grid-template-columns: 116px minmax(0, 1fr);
        grid-template-rows: 1fr;
        border-radius: 18px;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .feature-card:hover {
        transform: none;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .feature-image {
        min-height: 156px;
    }

    .feature-image::before {
        left: 12px;
        right: 12px;
        height: 108px;
        border-radius: 18px 18px 0 0;
    }

    .feature-image img {
        width: 92px;
        margin-top: 12px;
    }

    .feature-copy {
        justify-content: center;
        padding: 18px 16px;
    }

    .feature-copy h2 {
        gap: 8px;
        font-size: 16px;
    }

    .feature-copy p {
        margin-top: 9px;
        font-size: 13px;
        line-height: 1.58;
    }

    .feature-icon {
        width: 26px;
        height: 26px;
        border-radius: 9px;
    }

    .proof-section {
        gap: 10px;
        margin-top: 22px;
        margin-bottom: 20px;
    }

    .proof-card {
        min-height: 148px;
        flex-direction: column;
        align-items: flex-start;
        justify-content: space-between;
        gap: 10px;
        padding: 16px;
        border-radius: 18px;
        box-shadow: 0 10px 24px rgba(20, 55, 110, 0.07);
    }

    .proof-card img,
    .live-icon {
        width: 44px;
        height: 44px;
        border-radius: 14px;
    }

    .proof-icon {
        padding: 10px;
    }

    .live-icon {
        font-size: 11px;
    }

    .proof-card strong {
        margin-top: 3px;
        font-size: 21px;
    }

    .proof-card span {
        margin-top: 4px;
        font-size: 11px;
        line-height: 1.45;
    }

    .footer-shell {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 480px) {
    .site-shell,
    .landing-shell,
    .footer-shell {
        width: min(100% - 24px, var(--shell));
    }

    .landing-hero {
        padding-top: 28px;
    }

    .hero-copy h1 {
        font-size: 30px;
    }

    .hero-trust span {
        width: 100%;
        justify-content: center;
    }

    .download-button {
        font-size: 14px;
    }

    .hero-visual {
        min-height: 270px;
    }

    .hero-visual-card {
        height: 270px;
    }

    .hero-model {
        right: -112px;
        width: 510px;
    }

    .worldcup-promo {
        padding: 24px 18px 18px;
    }

    .worldcup-promo__copy h2 {
        font-size: 25px;
    }

    .worldcup-promo__copy p:not(.worldcup-promo__eyebrow) {
        font-size: 14px;
    }

    .worldcup-promo__button {
        flex: 1 1 auto;
        padding: 0 14px;
        font-size: 13px;
    }

    .hero-floating {
        padding: 12px 13px;
        border-radius: 17px;
    }

    .hero-floating strong {
        font-size: 24px;
    }

    .today-pick-board__content {
        padding: 24px 18px;
    }

    .today-pick-board__top,
    .today-pick-board__info,
    .today-pick-board__meta {
        flex-wrap: wrap;
    }

    .today-pick-board__round {
        width: 100%;
    }

    .today-pick-board__match {
        display: grid;
        gap: 8px;
        font-size: 23px;
    }

    .today-pick-board__match b {
        width: fit-content;
    }

    .today-pick-board__game-time,
    .today-pick-board__countdown {
        width: 100%;
        justify-content: center;
    }

    .today-pick-board__meta span {
        flex: 1 1 auto;
        justify-content: center;
    }

    .today-pick-board__pick {
        min-height: 98px;
        padding: 0 16px;
    }

    .today-pick-board__pick strong {
        font-size: 38px;
    }

    .landing-below-pick {
        margin-top: 14px;
        padding-top: 12px;
    }

    .team-rank-section__head {
        align-items: flex-start;
        flex-direction: column;
        gap: 6px;
    }

    .today-game-section__head {
        align-items: flex-start;
        flex-direction: column;
        gap: 6px;
    }

    .today-game-section__head time {
        padding-bottom: 0;
    }

    .team-rank-section__head time {
        padding-bottom: 0;
    }

    .metric-section,
    .proof-section {
        gap: 8px;
    }

    .metric-card {
        min-height: 142px;
        padding: 14px;
    }

    .metric-card p,
    .proof-card p {
        font-size: 12px;
    }

    .metric-card strong {
        font-size: 21px;
    }

    .feature-section {
        gap: 9px;
    }

    .feature-section__head h2 {
        font-size: 22px;
    }

    .feature-card {
        min-height: 148px;
        grid-template-columns: 102px minmax(0, 1fr);
    }

    .feature-image {
        min-height: 148px;
    }

    .feature-image img {
        width: 82px;
    }

    .feature-copy {
        padding: 15px 13px;
    }

    .feature-copy p {
        font-size: 12px;
        line-height: 1.55;
    }

    .proof-card {
        min-height: 140px;
        padding: 14px;
    }
}
