/* ── HERO SLIDER ── */
.hero-swiper { width: 100%; height: 420px; }
.hero-swiper .swiper-slide { position: relative; overflow: hidden; }
.hero-swiper img { width: 100%; height: 100%; object-fit: cover; }
.hero-caption { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 100%); padding: 32px 28px 24px; color: #fff; }
.hero-caption h2 { font-size: 22px; font-weight: 800; text-transform: uppercase; letter-spacing: .02em; margin-bottom: 8px; }
.hero-caption a { display: inline-block; border: 2px solid #fff; padding: 5px 16px; font-size: 12px; font-weight: 600; color: #fff; text-decoration: none; border-radius: 4px; transition: all .2s; }
.hero-caption a:hover { background: #fff; color: #2460B9; }

/* ── HERO TWO-COL LAYOUT ── */
.hero-layout { display: grid; grid-template-columns: 1fr 340px; gap: 20px; align-items: start; }
.hero-layout > * { min-width: 0; overflow: hidden; }
@media (max-width: 900px) { .hero-layout { grid-template-columns: 1fr; gap: 32px; } }

/* ── QUICK SERVICES (REDESIGNED: BOXED) ── */
.qs-boxed-container { 
    background: #fff; 
    border: 1px solid #e2e8f0; 
    border-radius: 12px; 
    padding: 32px 20px; 
    margin-top: 24px; 
    box-shadow: 0 4px 20px rgba(0,0,0,.04); 
}
.qs-row { 
    display: grid; 
    grid-template-columns: repeat(3, 1fr); 
    gap: 20px; 
    max-width: 1000px; 
    margin: 0 auto; 
}
@media (max-width: 640px) { .qs-row { grid-template-columns: 1fr; gap: 32px; } }
.qs-box-item { 
    display: flex; 
    flex-direction: column; 
    align-items: center; 
    text-decoration: none; 
    transition: transform .3s cubic-bezier(0.4, 0, 0.2, 1); 
    text-align: center; 
}
.qs-box-item:hover { transform: translateY(-5px); }
.qs-box-icon { 
    width: 90px; 
    height: 90px; 
    border-radius: 50%; 
    background: transparent; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    margin-bottom: 16px; 
    transition: all .3s; 
    border: none;
}
.qs-box-item:hover .qs-box-icon { 
    background: transparent; 
    box-shadow: none; 
    border: none;
    transform: scale(1.05); /* Clean zoom instead of shadow */
}
.qs-box-icon img { transition: transform .3s; }
.qs-box-item:hover .qs-box-icon img { transform: scale(1.1); }
.qs-box-label { 
    font-size: 15px; 
    font-weight: 800; 
    color: #2460B9; 
    text-transform: uppercase; 
    letter-spacing: .01em; 
}

/* ── QUICK TABS (DOP STYLE) ── */
.tab-panel { background: #fff; border-radius: 10px; border: 1px solid #e2e8f0; overflow: hidden; min-height: 380px; box-shadow: 0 4px 20px rgba(0,0,0,.04); display: flex; flex-direction: column; margin-bottom: 24px; }
.tab-panel:last-child { margin-bottom: 0; }
.tab-header { display: flex; background: #f1f5f9; padding: 6px; gap: 6px; }
.tab-header.compact-tabs { flex-wrap: wrap; }
.tab-btn { flex: 1; min-width: 80px; padding: 10px 4px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .02em; border: none; cursor: pointer; background: transparent; color: #64748b; border-radius: 6px; transition: all .25s; font-family: inherit; }
.tab-btn.active { background: #2460B9; color: #fff; box-shadow: 0 4px 10px rgba(36,96,185,.2); }
.tab-content-area { padding: 0; }
.tab-pane { display: none; }
.tab-pane.active { display: block; }
.notice-list { list-style: none; padding: 0; margin: 0; }
.notice-item { display: flex; align-items: flex-start; gap: 12px; padding: 12px 16px; border-bottom: 1px solid #f1f5f9; transition: background .15s; }
.notice-item:last-child { border: none; }
.notice-item:hover { background: #f8fafc; }
.empty-list {
    padding: 32px 16px;
    text-align: center;
    color: #94a3b8;
    font-size: 13.5px;
    font-weight: 500;
    font-style: italic;
    background: #f8fafc;
    border-radius: 8px;
    margin: 16px;
}
.notice-date { flex-shrink: 0; width: 44px; height: 44px; background: #2460B9; color: #fff; border-radius: 6px; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 16px; font-weight: 800; line-height: 1; text-align: center; }
.notice-date span { font-size: 9px; font-weight: 500; opacity: .8; text-transform: uppercase; }
.notice-body { flex: 1; min-width: 0; }
.notice-body a { display: block; font-size: 13.5px; font-weight: 600; color: #1e293b; text-decoration: none; line-height: 1.4; margin-bottom: 4px; }
.notice-body a:hover { color: #2460B9; }
.notice-body .notice-meta { font-size: 11px; color: #94a3b8; }
.view-all-row { padding: 10px 16px; border-top: 1px solid #f1f5f9; text-align: right; }
.view-all-row a { font-size: 12px; font-weight: 600; color: #2460B9; }
.view-all-row a:hover { text-decoration: underline; }

/* ── WELCOME SECTION ── */
.welcome-band { background: #fff; border-bottom: 1px solid #f0f0f0; padding: 36px 0; }
.welcome-inner { max-width: 1280px; margin: 0 auto; padding: 0 20px; display: grid; grid-template-columns: 280px 1fr; gap: 36px; align-items: center; }
@media (max-width: 768px) { .welcome-inner { grid-template-columns: 1fr; } }
.welcome-photo { border-radius: 10px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,.10); aspect-ratio: 4/3; }
.welcome-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.welcome-text h2 { font-size: 22px; font-weight: 800; color: var(--theme-color); margin-bottom: 12px; }
.welcome-text p { font-size: 14px; line-height: 1.85; color: #444; margin-bottom: 16px; }
.welcome-readmore { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 700; color: var(--theme-color); border-bottom: 2px solid var(--secondary-color); padding-bottom: 2px; transition: color 150ms; }
.welcome-readmore:hover { color: var(--secondary-color); }

/* ── MISSION BAND ── */
.mission-band { background: #2460B9; color: #fff; padding: 40px 16px; margin: 32px 0; }
.mission-inner { max-width: 1280px; margin: 0 auto; display: flex; gap: 32px; align-items: center; flex-wrap: wrap; }
.mission-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.65); margin-bottom: 6px; }
.mission-text h3 { font-size: 20px; font-weight: 800; margin-bottom: 10px; }
.mission-text p { font-size: 14px; opacity: .85; line-height: 1.7; max-width: 660px; }
.mission-cta a { display: inline-block; background: #CC1424; color: #fff; padding: 10px 24px; border-radius: 6px; font-size: 13px; font-weight: 700; text-decoration: none; transition: background .2s; flex-shrink: 0; }
.mission-cta a:hover { background: #a80f1a; }

/* ── MAIN CONTENT + SIDEBAR GRID ── */
.main-content-grid { display: grid; grid-template-columns: 1fr 300px; gap: 28px; align-items: start; }
.main-content-grid > * { min-width: 0; }
@media (max-width: 900px) { .main-content-grid { grid-template-columns: 1fr; } }

/* ── PUBLICATIONS GRID ── */
.pub-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 8px; overflow: hidden; transition: all .2s; display: flex; flex-direction: column; }
.pub-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.1); transform: translateY(-2px); }
.pub-card-body { padding: 16px; flex: 1; }
.pub-card-footer { padding: 12px 16px; border-top: 1px solid #f1f5f9; display: flex; gap: 8px; }
.pub-card h4 { font-size: 14px; font-weight: 700; color: #1e293b; margin: 8px 0 6px; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.pub-card p { font-size: 12px; color: #64748b; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* ── SOCIAL & MEDIA ── */
.social-media-band { background: var(--grey-100); padding: 36px 0; border-top: 1px solid #e8e8e8; }
.social-media-inner { max-width: 1280px; margin: 0 auto; padding: 0 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 700px) { .social-media-inner { grid-template-columns: 1fr; } }
.social-card { background: #fff; border-radius: 10px; border: 1px solid #e8e8e8; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,.05); }
.social-card-header { background: var(--theme-color); padding: 12px 18px; display: flex; align-items: center; gap: 10px; color: #fff; }
.social-card-header svg { width: 20px; height: 20px; flex-shrink: 0; }
.social-card-header h4 { font-size: 14px; font-weight: 700; }
.social-card-body { padding: 28px 20px; display: flex; flex-direction: column; align-items: center; gap: 12px; min-height: 180px; justify-content: center; text-align: center; }
.social-card-body p { font-size: 13px; color: #666; line-height: 1.65; }
.social-card-body a.social-ext-btn { display: inline-flex; align-items: center; gap: 8px; background: var(--theme-color); color: #fff; padding: 10px 22px; border-radius: 6px; font-size: 13px; font-weight: 700; text-decoration: none; transition: background 150ms; }
.social-card-body a.social-ext-btn:hover { background: var(--theme-color-400); }
.photo-grid-preview { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; padding: 12px; }
.photo-grid-preview a { aspect-ratio: 1; overflow: hidden; border-radius: 5px; background: #e8e8e8; display: block; }
.photo-grid-preview a img { width: 100%; height: 100%; object-fit: cover; transition: transform 300ms; }
.photo-grid-preview a:hover img { transform: scale(1.08); }
.photo-view-all { display: block; text-align: center; padding: 10px; font-size: 12px; font-weight: 700; color: var(--theme-color); border-top: 1px solid #f0f0f0; transition: background 150ms; }
.photo-view-all:hover { background: var(--theme-color-100); }

/* ── PARTNERS BAND ── */
.partners-band { background: #fff; border-top: 1px solid #e2e8f0; padding: 32px 16px; }
.partners-inner { max-width: 1280px; margin: 0 auto; }
.partners-label { text-align: center; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #94a3b8; margin-bottom: 24px; }
.partners-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 16px; }
@media (max-width: 768px) { .partners-grid { grid-template-columns: repeat(3,1fr); } }
.partner-item { display: flex; flex-direction: column; align-items: center; gap: 6px; text-decoration: none; color: #64748b; opacity: .55; filter: grayscale(1); transition: all .3s; }
.partner-item:hover { opacity: 1; filter: none; }
.partner-item img { height: 40px; width: auto; }
.partner-item span { font-size: 9px; font-weight: 600; text-align: center; text-transform: uppercase; }

/* ── HOME SIDEBAR OVERRIDES ── */
.profile-card { border-top-width: 4px; box-shadow: 0 2px 8px rgba(0,0,0,.06); }
.profile-avatar { width: 80px; height: 80px; }
.profile-avatar .avatar-letter { font-size: 28px; font-weight: 700; color: #94a3b8; }
