html,
body{
    min-height:100%;
}

body.news-page{
    min-height:100vh;
    background-color:#07131f;
    background-image:
        radial-gradient(circle at top, rgba(33,69,112,.22), transparent 26%),
        radial-gradient(circle at 85% 16%, rgba(255,193,7,.11), transparent 22%),
        linear-gradient(180deg,#06121f 0%,#081b2c 38%,#07131f 100%);
    background-repeat:no-repeat;
    background-size:100% 100%;
}

body.news-page .site-wrapper{
    min-height:100vh;
    background:transparent !important;
}

body.news-page .app-header,
body.news-page .news-hero-wrap,
body.news-page .news-article-hero-wrap,
body.news-page .news-page-body,
body.news-page .news-post-layout,
body.news-page .news-article-layout,
body.news-page .news-related-section,
body.news-page .site-footer{
    background:transparent !important;
}

.news-page .site-footer{
    margin-top:42px;
}

.news-hero-wrap,
.news-article-hero-wrap{
    padding:18px 0 10px;
}

.news-hero-box,
.news-article-hero-box{
    display:grid;
    grid-template-columns:minmax(0,1fr) 390px;
    gap:22px;
    align-items:stretch;
    padding:24px;
    border-radius:26px;
    background:
        radial-gradient(circle at top left, rgba(255,193,7,.08), transparent 35%),
        radial-gradient(circle at bottom right, rgba(80,140,255,.10), transparent 40%),
        linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.025));
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 18px 40px rgba(0,0,0,.22);
}

.news-hero-content,
.news-article-main,
.news-article-search{
    min-width:0;
}

.news-hero-badge,
.news-chip{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:7px 12px;
    border-radius:999px;
    background:rgba(255,193,7,.12);
    border:1px solid rgba(255,193,7,.22);
    color:#ffd76a;
    font-size:12px;
    font-weight:800;
}

.news-hero-title,
.news-article-title{
    margin:14px 0 10px;
    font-size:42px;
    line-height:1.08;
    font-weight:900;
    color:#fff;
    letter-spacing:-.03em;
}

.news-hero-title-highlight{
    color:#ffd76a;
}

.news-hero-subtitle,
.news-article-lead{
    margin:0;
    font-size:15px;
    line-height:1.78;
    color:#b8c7d9;
    max-width:760px;
}

.news-hero-inline-link{
    margin-top:18px;
}

.news-hero-link{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#ffd54a;
    font-weight:700;
    text-decoration:none;
}

.news-hero-link:hover{
    color:#fff;
    text-decoration:none;
}

.news-hero-search,
.news-article-search{
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:20px;
    border-radius:22px;
    background:rgba(8,18,30,.72);
    border:1px solid rgba(255,255,255,.08);
    min-width:0;
}

.news-hero-search-top{
    margin-bottom:12px;
}

.news-hero-search-label{
    font-size:13px;
    font-weight:800;
    color:#dbe6f5;
    margin-bottom:4px;
}

.news-hero-search-help{
    font-size:13px;
    color:#9fb3c8;
}

.news-hero-search .hero-search-row,
.news-article-search .hero-search-row{
    display:block;
}

.news-hero-search .hero-search-input-wrap,
.news-article-search .hero-search-input-wrap{
    width:100%;
}

.news-hero-search .hero-search-input,
.news-article-search .hero-search-input{
    width:100%;
    min-width:0;
    background:rgba(255,255,255,.05);
}

.news-hero-search .hero-nearby-btn,
.news-article-search .hero-nearby-btn{
    margin-top:10px;
    width:100%;
}

.news-hero-quick-links{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:14px;
}

.news-hero-quick-links a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:38px;
    padding:0 14px;
    border-radius:12px;
    text-decoration:none;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    color:#dbe6f5;
    font-size:13px;
    font-weight:700;
    transition:.18s ease;
}

.news-hero-quick-links a:hover{
    border-color:rgba(255,193,7,.22);
    color:#fff;
    background:rgba(255,255,255,.06);
}

.news-page-body,
.news-article-layout,
.news-related-section,
.news-post-layout{
    padding-top:22px;
    padding-bottom:36px;
}

.news-post-grid{
    display:grid;
    grid-template-columns:minmax(0,1fr) 340px;
    gap:22px;
    align-items:start;
}

.news-post-main,
.news-post-sidebar{
    min-width:0;
}

.news-post-sidebar{
    position:sticky;
    top:92px;
}

.news-featured-card{
    display:grid;
    grid-template-columns:1fr;
    gap:20px;
    margin-bottom:26px;
}

.news-featured-main,
.news-card,
.news-empty-state,
.news-article-card,
.news-side-box,
.news-seo-box{
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
    border:1px solid rgba(255,255,255,.08);
    border-radius:24px;
    box-shadow:0 22px 54px rgba(0,0,0,.22);
}

.news-featured-main{
    padding:28px;
}

.news-featured-meta-row,
.news-card-top,
.news-article-meta-wrap{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
}

.news-featured-date,
.news-card-date,
.news-article-meta,
.news-breadcrumbs{
    color:rgba(255,255,255,.62);
    font-size:14px;
    line-height:1.5;
}

.news-featured-main h2{
    margin:16px 0 0;
    color:#fff;
    font-size:clamp(34px, 4vw, 50px);
    font-weight:900;
    line-height:1.06;
    max-width:860px;
}

.news-featured-main p,
.news-card p,
.prose-news p,
.news-empty-state p{
    margin:16px 0 0;
    color:rgba(255,255,255,.84);
    line-height:1.75;
    font-size:16px;
}

.news-featured-main p{
    max-width:760px;
}

.news-featured-actions,
.news-article-actions{
    margin-top:24px;
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}

.news-featured-actions.center{
    justify-content:center;
}

.news-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:50px;
    padding:0 22px;
    border-radius:999px;
    text-decoration:none;
    font-weight:900;
    transition:.18s ease;
}

.news-btn-primary{
    background:linear-gradient(135deg,#ffc107,#ffb400);
    color:#111827;
    box-shadow:0 14px 32px rgba(255,193,7,.18);
}

.news-btn-primary:hover{
    transform:translateY(-1px);
    color:#111827;
}

.news-btn-secondary{
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.12);
    color:#fff;
}

.news-btn-secondary:hover{
    background:rgba(255,255,255,.08);
    color:#fff;
}

.news-section-head{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:18px;
    margin-bottom:18px;
}

.news-section-head h2{
    margin:8px 0 0;
    color:#fff;
    font-size:34px;
    font-weight:900;
}

.news-section-link,
.news-read-more,
.news-card h3 a,
.news-breadcrumbs a{
    color:#ffd36a;
    text-decoration:none;
}

.news-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
}

.news-grid-related{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

.news-card{
    padding:20px;
    display:flex;
    flex-direction:column;
    min-height:260px;
}

.news-card h3{
    margin:14px 0 0;
    font-size:22px;
    line-height:1.24;
    font-weight:900;
}

.news-card h3 a{
    color:#fff;
}

.news-card h3 a:hover,
.news-read-more:hover,
.news-section-link:hover,
.news-breadcrumbs a:hover{
    color:#ffd36a;
}

.news-card p{
    font-size:15px;
    line-height:1.68;
    color:rgba(255,255,255,.78);
}

.news-card-footer{
    margin-top:auto;
    padding-top:18px;
}

.news-read-more{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-weight:800;
}

.news-empty-state,
.news-not-found-wrap{
    text-align:center;
}

.news-empty-state{
    padding:34px 28px;
}

.news-empty-state-single{
    margin-top:28px;
}

.news-empty-icon{
    font-size:42px;
    color:#ffd36a;
}

.news-breadcrumbs{
    margin-bottom:14px;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.news-breadcrumbs strong{
    color:#fff;
    font-weight:800;
}

.news-article-card{
    padding:30px;
}

.news-post-article-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:16px;
    padding-bottom:18px;
    margin-bottom:20px;
    border-bottom:1px solid rgba(255,255,255,.08);
}

.news-post-submeta{
    margin-top:6px;
    color:rgba(255,255,255,.62);
    font-size:14px;
    line-height:1.5;
}

.prose-news{
    color:#e7eef8;
}

.prose-news > *:first-child{
    margin-top:0;
}

.prose-news h2,
.prose-news h3,
.prose-news h4{
    color:#fff;
    font-weight:900;
    margin:28px 0 12px;
}

.prose-news ul,
.prose-news ol{
    margin:16px 0 16px 22px;
    color:#d9e5f3;
}

.prose-news li{
    margin:8px 0;
}

.prose-news a{
    color:#ffd36a;
}

.news-seo-block{
    margin-top:34px;
    margin-bottom:10px;
}

.news-seo-box{
    padding:28px;
    color:#dbe7ff;
}

.news-seo-box h2{
    font-size:28px;
    line-height:1.15;
    margin:0 0 16px;
    color:#fff;
}

.news-seo-box p{
    margin:0 0 14px;
    color:#b9c9e6;
    font-size:16px;
    line-height:1.7;
}

.news-seo-box p:last-child{
    margin-bottom:0;
}

.news-side-box{
    padding:20px;
    margin-bottom:18px;
}

.news-side-box-accent{
    background:
        linear-gradient(180deg, rgba(255,193,7,.12), rgba(255,255,255,.03)),
        linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}

.news-side-kicker{
    color:#ffd36a;
    font-size:12px;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
    margin-bottom:10px;
}

.news-side-box h3{
    margin:0;
    color:#fff;
    font-size:20px;
    font-weight:900;
    line-height:1.2;
}

.news-side-box p{
    margin:12px 0 0;
    color:rgba(255,255,255,.82);
    line-height:1.72;
    font-size:15px;
}

.news-side-links{
    display:grid;
    gap:10px;
    margin-top:18px;
}

.news-side-link{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:12px 14px;
    border-radius:16px;
    text-decoration:none;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    color:#fff;
    font-size:14px;
    font-weight:800;
    transition:.18s ease;
}

.news-side-link span{
    display:inline-flex;
    align-items:center;
    gap:10px;
}

.news-side-link:hover{
    background:rgba(255,255,255,.07);
    border-color:rgba(255,193,7,.22);
    color:#fff;
    transform:translateY(-1px);
}

.news-side-mini-list{
    display:grid;
    gap:12px;
    margin-top:18px;
}

.news-side-mini-item{
    display:block;
    text-decoration:none;
    padding:0 0 12px;
    border-bottom:1px solid rgba(255,255,255,.08);
}

.news-side-mini-item:last-child{
    padding-bottom:0;
    border-bottom:none;
}

.news-side-mini-title{
    color:#fff;
    font-size:15px;
    font-weight:800;
    line-height:1.45;
}

.news-side-mini-date{
    margin-top:5px;
    color:rgba(255,255,255,.58);
    font-size:12px;
}

@media(max-width:1100px){
    .news-post-grid{
        grid-template-columns:1fr;
    }

    .news-post-sidebar{
        position:static;
    }

    .news-hero-box,
    .news-article-hero-box{
        grid-template-columns:1fr;
    }

    .news-hero-title,
    .news-article-title{
        font-size:34px;
    }
}

@media(max-width:760px){
    .news-grid,
    .news-grid-related{
        grid-template-columns:1fr;
    }
}

@media(max-width:640px){
    .news-hero-wrap,
    .news-article-hero-wrap{
        padding-top:14px;
    }

    .news-hero-box,
    .news-article-hero-box,
    .news-featured-main,
    .news-card,
    .news-article-card,
    .news-empty-state,
    .news-side-box,
    .news-seo-box{
        border-radius:20px;
    }

    .news-hero-box,
    .news-article-hero-box{
        padding:18px;
        gap:16px;
    }

    .news-featured-main,
    .news-card,
    .news-article-card,
    .news-empty-state,
    .news-side-box,
    .news-seo-box{
        padding:20px;
    }

    .news-section-head{
        flex-direction:column;
        align-items:flex-start;
    }

    .news-section-head h2{
        font-size:28px;
    }

    .news-hero-title,
    .news-article-title{
        font-size:28px;
    }

    .news-featured-main h2{
        font-size:28px;
    }

    .news-featured-actions,
    .news-article-actions{
        flex-direction:column;
    }

    .news-btn{
        width:100%;
    }

    .news-post-article-top{
        flex-direction:column;
        align-items:flex-start;
    }
}