/* ===================================
   NEWS & GALLERY MOBILE OVERRIDES (< 480px)
   =================================== */

.news {
    margin-top: 0 !important;
    padding: 40px 20px !important;
    gap: 30px !important;
    flex-direction: column !important;
}

.newstop {
    width: 100% !important;
    text-align: center !important;
}

.newstop h1 {
    font-size: 32px !important;
    font-family: var(--font-head) !important;
    font-weight: 700 !important;
    text-align: center !important;
    border-left: none !important;
    padding-left: 0 !important;
    width: 100% !important;
    margin-bottom: 20px !important;
}

/* Wrapper: Stack Columns */
.news-wrapper {
    flex-direction: column !important;
    gap: 30px !important;
    width: 100% !important;
    margin: 0 !important;
}

/* Featured Card */
.news-featured {
    width: 100% !important;
    min-height: auto !important;
    flex: none !important;
}

.feat-card {
    height: auto !important;
    min-height: auto !important;
    width: 100% !important;
    padding: 25px 20px !important;
    flex-direction: column !important;
    align-items: flex-start !important;
}

.feat-badge {
    margin-bottom: 15px !important;
}

.feat-card h1 {
    font-size: 22px !important;
    margin-bottom: 15px !important;
    line-height: 1.2 !important;
}

.feat-card p {
    font-size: 14px !important;
    margin-bottom: 20px !important;
}

.feat-footer {
    flex-direction: column !important;
    /* Stack footer items */
    align-items: flex-start !important;
    gap: 15px !important;
    width: 100% !important;
}

.read-more {
    width: 100% !important;
    justify-content: center !important;
}

/* News List */
.news-list-container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 20px !important;
    flex: none !important;
}

.news-item {
    flex-direction: column !important;
    align-items: flex-start !important;
    padding: 15px !important;
}

.news-date {
    flex-direction: row !important;
    width: auto !important;
    height: auto !important;
    padding: 8px 12px !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
}

.news-date .month {
    margin-top: 0 !important;
}

.news-details h4 {
    font-size: 16px !important;
}

/* Gallery - Stack Grid */
.gallery {
    padding: 40px 20px !important;
    width: 100% !important;
    margin: 0 !important;
}

.gallerytext h1 {
    font-size: 32px !important;
    font-family: var(--font-head) !important;
    margin-bottom: 20px !important;
}

.gallerypics {
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
}

.gallpictop,
.gallpicbot {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    gap: 15px !important;
}

.gallpictop div,
.gallpicbot div {
    width: 100% !important;
    height: 200px !important;
    margin: 0 !important;
    border-radius: 16px !important;
}

.gallpictop img,
.gallpicbot img {
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}