/* Homepage-specific styles */

/* ── Hero Carousel ── */
.hero-carousel {
    min-height: clamp(200px, 28vw, 360px);
}
.hero-carousel .carousel-inner,
.hero-carousel .carousel-item {
    height: 100%;
}
.hero-carousel .carousel-item img {
    height: 100%;
    min-height: clamp(200px, 28vw, 360px);
    object-fit: cover;
    width: 100%;
    display: block;
}
.hero-carousel .carousel-item a { display: block; height: 100%; }
.hero-carousel .carousel-caption {
    background: linear-gradient(transparent, rgba(0,0,0,0.65));
    bottom: 0; left: 0; right: 0;
    padding: 28px 20px 16px;
    text-align: left;
    border-radius: 0 0 0.5rem 0.5rem;
}
.hero-carousel .carousel-control-prev,
.hero-carousel .carousel-control-next {
    width: 40px;
    height: 40px;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0,91,153,0.82);
    border-radius: 50%;
    opacity: 1;
}
.hero-carousel .carousel-control-prev { left: 12px; }
.hero-carousel .carousel-control-next { right: 12px; }

/* ── What's New ── */
.whats-new-list {
    max-height: 320px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--nsic-blue-light) #f0f0f0;
}
.whats-new-list::-webkit-scrollbar { width: 4px; }
.whats-new-list::-webkit-scrollbar-thumb { background: var(--nsic-blue-light); border-radius: 4px; }
.whats-new-list .list-group-item { font-size: 0.875rem; }
.whats-new-list .list-group-item:hover { background: #f8fafc; }

/* ── Minister Cards ── */
.minister-card {
    border: 1px solid #e9ecef;
    border-radius: 10px;
    transition: transform 0.2s, box-shadow 0.2s;
}
.minister-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0,119,190,0.15) !important;
}
.minister-card img {
    width: 88px;
    height: 88px;
    object-fit: cover;
    border: 3px solid #0077BE;
}

/* ── Scheme Cards ── */
.scheme-card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.07);
    transition: transform 0.25s, box-shadow 0.25s;
    height: 100%;
}
.scheme-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 10px 28px rgba(0,119,190,0.18);
}
.scheme-card .scheme-thumb {
    height: 160px;
    object-fit: cover;
    border-radius: 12px 12px 0 0;
    width: 100%;
}
.scheme-card .scheme-video {
    height: 160px;
    border-radius: 12px 12px 0 0;
    overflow: hidden;
    background: #000;
    position: relative;
}
.scheme-card .scheme-video iframe {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    border: none;
}
.scheme-badge {
    font-size: 0.68rem;
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

/* ── Media Grid Card ── */
.media-grid-card {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.2s;
    background: #fff;
}
.media-grid-card:hover {
    box-shadow: 0 4px 14px rgba(220,53,69,0.12);
    transform: translateY(-2px);
}
.media-grid-card img {
    width: 100%;
    height: 140px;
    object-fit: cover;
    display: block;
}

/* ── Info Cards (Skill Dev / Testing) ── */
.info-card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.07);
    transition: transform 0.2s, box-shadow 0.2s;
}
.info-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 22px rgba(220,53,69,0.12);
}

/* ── Partner Logo Strip ── */
.partner-strip {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 18px 16px;
}
.partner-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 14px;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.08);
    transition: box-shadow 0.2s, transform 0.2s;
    text-decoration: none;
}
.partner-logo:hover {
    box-shadow: 0 4px 14px rgba(0,119,190,0.2);
    transform: translateY(-2px);
}
.partner-logo img {
    max-height: 54px;
    width: auto;
    object-fit: contain;
}

/* ── Section header accent ── */
.section-accent {
    border-left: 4px solid #0077BE;
    padding-left: 10px;
}
