*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{

    --background:#0f1115;
    --card:#181b22;
    --border:#2b313d;

    --text:#f5f5f5;
    --secondary:#a8adb8;

    --green:#39d353;
    --green-hover:#2fb54a;

}

body{

    background:var(--background);

    color:var(--text);

    font-family:Inter,system-ui,sans-serif;

    line-height:1.7;

    max-width:1400px;

    margin:auto;

    padding:45px 25px;

}

/* ========================= */
/* HEADER */
/* ========================= */

.header{

    text-align:center;

    margin-bottom:60px;

}

.logo{

    display:block;

    width:380px;

    max-width:90%;

    margin:0 auto 18px;

    user-select:none;

}

.subtitle{

    color:var(--secondary);

    font-size:1.05rem;

    margin-bottom:10px;

}

.date{

    color:#6f7683;

    font-size:.9rem;

}

.header::after{

    content:"";

    display:block;

    width:220px;

    height:1px;

    background:var(--border);

    margin:28px auto 0;

}

/* ========================= */
/* HERO */
/* ========================= */

.hero{

    display:grid;

    grid-template-columns:420px 1fr;

    gap:35px;

    background:var(--card);

    border:1px solid var(--border);

    border-radius:22px;

    overflow:hidden;

    margin-bottom:35px;

}

.hero-image{

    width:100%;

    height:100%;

    min-height:420px;

    object-fit:cover;

}

.hero-content{

    padding:35px;

}

.badge{

    display:inline-block;

    background:var(--green);

    color:#000;

    padding:8px 16px;

    border-radius:999px;

    font-weight:bold;

    margin-bottom:15px;

}

.category{

    float:right;

    color:var(--green);

    text-transform:uppercase;

    font-weight:bold;

    letter-spacing:1px;

}

.hero h2{

    clear:both;

    margin-top:20px;

    font-size:2.2rem;

    line-height:1.25;

    margin-bottom:20px;

}

.article{

    color:#d8d8d8;

    text-align:justify;

    margin-bottom:30px;

}

.meta{

    display:flex;

    justify-content:space-between;

    align-items:center;

    gap:20px;

    border-top:1px solid var(--border);

    padding-top:20px;

    flex-wrap:wrap;

    color:var(--secondary);

}

.meta a{

    background:var(--green);

    color:#000;

    text-decoration:none;

    padding:12px 20px;

    border-radius:12px;

    font-weight:bold;

    transition:.2s;

}

.meta a:hover{

    background:var(--green-hover);

}

/* ========================= */
/* GRID */
/* ========================= */

.news-grid{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:25px;

}

.card{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:20px;

    overflow:hidden;

    display:flex;

    flex-direction:column;

    transition:.2s;

}

.card:hover{

    transform:translateY(-4px);

}

.card-image{

    width:100%;

    height:220px;

    object-fit:cover;

}

.card .category{

    float:none;

    display:block;

    padding:20px 25px 0;

}

.card h3{

    padding:12px 25px;

    font-size:1.35rem;

    line-height:1.35;

}

.card .article{

    padding:0 25px;

    flex:1;

}

.card-footer{

    border-top:1px solid var(--border);

    margin-top:10px;

    padding:20px 25px;

    display:flex;

    justify-content:space-between;

    align-items:center;

    gap:15px;

    flex-wrap:wrap;

    color:var(--secondary);

}

.card-footer a{

    color:var(--green);

    text-decoration:none;

    font-weight:bold;

}

.card-footer a:hover{

    text-decoration:underline;

}

/* ========================= */
/* FOOTER */
/* ========================= */

footer{

    margin-top:70px;

    padding-top:30px;

    border-top:1px solid var(--border);

    text-align:center;

    color:#8a909c;

    font-size:.95rem;

}

footer p{

    margin-bottom:8px;

}

.footer-date{

    color:#666;

    font-size:.85rem;

}

/* ========================= */
/* RESPONSIVE */
/* ========================= */

@media(max-width:1000px){

    .hero{

        grid-template-columns:1fr;

    }

    .hero-image{

        min-height:280px;

    }

}

@media(max-width:750px){

    .news-grid{

        grid-template-columns:1fr;

    }

}

@media(max-width:600px){

    body{

        padding:20px 15px;

    }

    .logo{

        width:250px;

    }

    .hero-content{

        padding:25px;

    }

    .hero h2{

        font-size:1.7rem;

    }

    .meta{

        flex-direction:column;

        align-items:flex-start;

    }

    .card-footer{

        flex-direction:column;

        align-items:flex-start;

    }

}