﻿/* =========================
   NEWS LIST PAGE
========================= */

.news-list-page {
    background: radial-gradient(circle at top left, rgba(242, 201, 76, .22), transparent 34rem), linear-gradient(180deg, #fff 0%, var(--color-bg) 100%);
    min-height: 100vh;
}

/* HERO */
.news-hero {
    position: relative;
    padding: clamp(4.5rem, 3rem + 4vw, 7rem) 0 clamp(2rem, 1.3rem + 2vw, 3rem);
    overflow: hidden;
}

    .news-hero::before {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(135deg, rgba(0,59,142,.96), rgba(0,27,66,.92)), url("/Content/img/home/hero-rd.jpg");
        background-size: cover;
        background-position: center;
        z-index: 0;
    }

    .news-hero::after {
        content: "";
        position: absolute;
        width: 32rem;
        height: 32rem;
        right: -10rem;
        top: -12rem;
        border-radius: 50%;
        background: rgba(242, 201, 76, .22);
        filter: blur(4px);
        z-index: 1;
    }

    .news-hero .container {
        position: relative;
        z-index: 2;
    }

.news-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: clamp(1.5rem, 1rem + 2vw, 3rem);
    align-items: end;
}

.news-hero__copy {
    color: #fff;
    max-width: 820px;
}

.news-hero__kicker,
.news-section-kicker {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.news-hero__kicker {
    color: var(--color-accent);
    margin-bottom: .85rem;
}

    .news-hero__kicker::before,
    .news-section-kicker::before {
        content: "";
        display: inline-block;
        width: 28px;
        height: 2px;
        border-radius: 999px;
        background: currentColor;
    }

.news-hero h1 {
    margin: 0;
    max-width: 12ch;
    font-size: clamp(2.4rem, 4.5vw, 5rem);
    line-height: .98;
    font-weight: 900;
    letter-spacing: -.045em;
    text-wrap: balance;
}

.news-hero p {
    margin: 1.1rem 0 0;
    max-width: 58ch;
    color: rgba(255,255,255,.88);
    font-size: clamp(1rem, .96rem + .3vw, 1.2rem);
}

.news-hero__panel {
    display: grid;
    gap: .8rem;
    padding: 1rem;
    border-radius: 24px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(14px);
    box-shadow: 0 24px 60px rgba(0,0,0,.18);
}

.news-hero__stat {
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255,255,255,.94);
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
}

    .news-hero__stat strong {
        display: block;
        color: var(--color-primary-700);
        font-size: 1.15rem;
        font-weight: 900;
    }

    .news-hero__stat span {
        display: block;
        margin-top: .15rem;
        color: var(--color-text-soft);
        font-size: .9rem;
        font-weight: 700;
    }

/* BODY */
.news-list-section {
    padding: clamp(2rem, 1.5rem + 3vw, 4.5rem) 0 clamp(4rem, 3rem + 3vw, 6rem);
}

.news-filter-card {
    position: relative;
    margin-top: -4rem;
    margin-bottom: clamp(1.5rem, 1rem + 2vw, 2.6rem);
    padding: clamp(1.1rem, .9rem + 1vw, 1.6rem);
    border-radius: 28px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(226,232,240,.94);
    box-shadow: 0 24px 65px rgba(15,23,42,.14);
    z-index: 3;
}

.news-filter-card__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    margin-bottom: 1.15rem;
}

.news-filter-card h2,
.news-results-head h2 {
    margin: .25rem 0 0;
    color: var(--color-primary-700);
    font-size: clamp(1.35rem, 1.1rem + 1vw, 2rem);
    line-height: 1.08;
    font-weight: 900;
    letter-spacing: -.025em;
}

.news-section-kicker {
    color: var(--color-danger);
}

.news-filter-card__badge {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    min-height: 42px;
    padding: .55rem .85rem;
    border-radius: var(--radius-pill);
    background: rgba(0,59,142,.07);
    color: var(--color-primary-700);
    font-size: .84rem;
    font-weight: 800;
    white-space: nowrap;
}

.news-filter-form {
    display: grid;
    grid-template-columns: minmax(220px, 1.3fr) minmax(160px, .7fr) minmax(160px, .7fr) auto;
    gap: .9rem;
    align-items: end;
}

.news-field {
    display: grid;
    gap: .4rem;
}

    .news-field label {
        color: var(--color-text-soft);
        font-size: .86rem;
        font-weight: 800;
    }

.news-control {
    width: 100%;
    min-height: 52px;
    padding: .78rem .95rem;
    border-radius: 16px;
    border: 1px solid var(--color-border);
    background: #fff;
    color: var(--color-text);
    font-weight: 650;
    box-shadow: 0 8px 20px rgba(15,23,42,.04);
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

    .news-control:focus {
        outline: none;
        border-color: rgba(0,59,142,.38);
        box-shadow: 0 0 0 .22rem rgba(0,59,142,.09);
    }

.news-filter-form__actions {
    display: flex;
    gap: .65rem;
    align-items: end;
}

.news-filter-button {
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding-inline: 1.05rem;
    font-weight: 800;
    white-space: nowrap;
}

.news-results-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 1.2rem;
    margin-bottom: 1.25rem;
}

.news-results-count {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: .55rem .9rem;
    border-radius: var(--radius-pill);
    background: #fff;
    border: 1px solid var(--color-border);
    color: var(--color-text-soft);
    font-size: .9rem;
    font-weight: 800;
    box-shadow: var(--shadow-sm);
    white-space: nowrap;
}

.news-alert {
    margin-bottom: 1rem;
    padding: .85rem 1rem;
    border-radius: 18px;
    background: rgba(198,40,57,.08);
    border: 1px solid rgba(198,40,57,.18);
    color: var(--color-danger-700);
    font-weight: 750;
}

/* GRID / CARDS */
.news-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.15rem;
}

.news-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    overflow: hidden;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(226,232,240,.92);
    box-shadow: var(--shadow-sm);
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

    .news-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--shadow-md);
        border-color: rgba(0,59,142,.16);
    }

.news-card__media {
    position: relative;
    display: block;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(0,59,142,.95), rgba(0,27,66,.92));
    aspect-ratio: 16 / 10;
}

    .news-card__media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform .42s ease;
    }

.news-card:hover .news-card__media img {
    transform: scale(1.045);
}

.news-card__placeholder {
    width: 100%;
    height: 100%;
    min-height: 190px;
    display: grid;
    place-items: center;
    color: rgba(255,255,255,.82);
    font-size: 2rem;
}

.news-card__play {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    transform: translate(-50%, -50%);
    border-radius: 999px;
    background: rgba(255,255,255,.94);
    color: var(--color-primary);
    box-shadow: 0 16px 34px rgba(0,0,0,.2);
}

.news-card__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 1.05rem;
}

.news-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    align-items: center;
    margin-bottom: .75rem;
}

.news-card__category {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: .35rem .7rem;
    border-radius: var(--radius-pill);
    background: rgba(198,40,57,.08);
    color: var(--color-danger);
    font-size: .76rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .03em;
}

.news-card time {
    color: var(--color-text-soft);
    font-size: .86rem;
    font-weight: 750;
}

.news-card h3 {
    margin: 0;
    color: var(--color-primary-700);
    font-size: clamp(1.05rem, 1rem + .25vw, 1.24rem);
    line-height: 1.22;
    font-weight: 900;
    letter-spacing: -.02em;
}

    .news-card h3 a {
        color: inherit;
    }

        .news-card h3 a:hover {
            color: var(--color-primary);
        }

.news-card p {
    margin: .75rem 0 1rem;
    color: var(--color-text-soft);
    font-size: .95rem;
    line-height: 1.55;
}

.news-card__footer {
    margin-top: auto;
    padding-top: .85rem;
    border-top: 1px solid rgba(226,232,240,.82);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .85rem;
}

.news-card__source {
    min-width: 0;
    color: var(--color-text-soft);
    font-size: .85rem;
    font-weight: 750;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

a.news-card__source:hover {
    color: var(--color-primary);
}

.news-card__read {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--color-primary);
    font-size: .88rem;
    font-weight: 900;
    white-space: nowrap;
}

    .news-card__read i {
        transition: transform .2s ease;
    }

    .news-card__read:hover i {
        transform: translateX(3px);
    }

/* EMPTY */
.news-empty {
    margin-top: 1.25rem;
    padding: clamp(1.5rem, 1rem + 2vw, 2.6rem);
    border-radius: 28px;
    background: #fff;
    border: 1px dashed rgba(148,163,184,.8);
    text-align: center;
    box-shadow: var(--shadow-sm);
}

.news-empty__icon {
    width: 72px;
    height: 72px;
    display: grid;
    place-items: center;
    margin: 0 auto 1rem;
    border-radius: 24px;
    background: rgba(0,59,142,.07);
    color: var(--color-primary);
    font-size: 1.8rem;
}

.news-empty h3 {
    margin: 0 0 .45rem;
    color: var(--color-primary-700);
    font-weight: 900;
}

.news-empty p {
    margin: 0;
    color: var(--color-text-soft);
}

/* PAGINATION */
.news-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .85rem;
    margin-top: clamp(1.5rem, 1rem + 2vw, 2.5rem);
}

.news-pagination__button,
.news-pagination__go {
    font-weight: 800;
    transition: transform .2s ease, opacity .2s ease, background-color .2s ease;
}

.news-pagination__button {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    padding: 0;
    border: 1px solid rgba(226,232,240,.95);
    border-radius: 50%;
    background: #fff;
    color: var(--color-primary);
    box-shadow: var(--shadow-sm);
}

    .news-pagination__button:hover:not(:disabled),
    .news-pagination__go:hover:not(:disabled) {
        transform: translateY(-1px);
    }

    .news-pagination__button:disabled,
    .news-pagination__go:disabled {
        opacity: .48;
        cursor: not-allowed;
    }

.news-pagination__info {
    min-width: 140px;
    text-align: center;
    color: var(--color-primary-700);
    font-weight: 800;
}

.news-pagination__jump {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .38rem;
    border: 1px solid rgba(226,232,240,.95);
    border-radius: var(--radius-pill);
    background: rgba(255,255,255,.92);
    box-shadow: var(--shadow-sm);
}

.news-pagination__jump label {
    padding-left: .75rem;
    color: var(--color-text-soft);
    font-size: .92rem;
    font-weight: 800;
    white-space: nowrap;
}

.news-pagination__input {
    width: 82px;
    min-height: 42px;
    text-align: center;
    border-radius: 999px;
    border: 1px solid rgba(226,232,240,.95);
    color: var(--color-primary-700);
    font-weight: 800;
    background: #fff;
}

    .news-pagination__input:focus {
        outline: none;
        border-color: rgba(0,59,142,.38);
        box-shadow: 0 0 0 .2rem rgba(0,59,142,.09);
    }

.news-pagination__go {
    min-height: 42px;
    padding-inline: .95rem;
}

/* LOADING */
.news-grid.is-loading {
    position: relative;
    min-height: 320px;
    opacity: .72;
}

.news-skeleton {
    min-height: 360px;
    border-radius: 24px;
    background: linear-gradient(90deg, rgba(226,232,240,.52), rgba(248,250,252,.96), rgba(226,232,240,.52));
    background-size: 200% 100%;
    animation: newsSkeleton 1.15s ease-in-out infinite;
}

@keyframes newsSkeleton {
    from {
        background-position: 200% 0;
    }

    to {
        background-position: -200% 0;
    }
}

/* RESPONSIVE */
@media (max-width: 1199.98px) {
    .news-hero__grid {
        grid-template-columns: 1fr;
    }

    .news-hero__panel {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        max-width: 760px;
    }

    .news-filter-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .news-filter-form__actions {
        grid-column: 1 / -1;
    }

    .news-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .news-hero {
        padding-top: 4.25rem;
    }

        .news-hero h1 {
            max-width: none;
        }

    .news-hero__panel {
        grid-template-columns: 1fr;
    }

    .news-filter-card {
        margin-top: -2.2rem;
        border-radius: 22px;
    }

    .news-filter-card__header,
    .news-results-head {
        flex-direction: column;
        align-items: stretch;
    }

    .news-filter-card__badge,
    .news-results-count {
        justify-content: center;
        width: 100%;
    }

    .news-filter-form {
        grid-template-columns: 1fr;
    }

    .news-filter-form__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .news-filter-button {
        width: 100%;
    }

    .news-grid {
        grid-template-columns: 1fr;
    }

    .news-pagination {
        flex-wrap: wrap;
        gap: .65rem;
    }

    .news-pagination__info {
        order: -1;
        width: 100%;
        min-width: 0;
    }

    .news-pagination__jump {
        width: 100%;
        justify-content: space-between;
        border-radius: 22px;
        padding: .55rem;
    }

        .news-pagination__input {
            flex: 1 1 auto;
            width: 100%;
            max-width: 120px;
        }

        .news-pagination__go {
            white-space: nowrap;
        }
}

@media (prefers-reduced-motion: reduce) {
    .news-card,
    .news-card__media img,
    .news-card__read i,
    .news-pagination__button,
    .news-pagination__go {
        transition: none !important;
    }

    .news-skeleton {
        animation: none !important;
    }
}
