﻿/* Theme variables: official blue/gold palette, spacing shell and shadows */
:root {
  --ink: #172033;
  --text: #4d5b6b;
  --muted: #718096;
  --blue: #123f8c;
  --blue-dark: #082b62;
  --teal: #08766b;
  --gold: #d39b21;
  --red: #b42318;
  --green: #16724e;
  --sky: #eaf5ff;
  --paper: #ffffff;
  --soft: #f5f8fb;
  --line: #d7e2ee;
  --shadow: 0 18px 45px rgba(16, 32, 51, 0.11);
  --shadow-soft: 0 8px 24px rgba(16, 32, 51, 0.08);
  --shell: 1440px;
}

/* Base reset: common browser cleanup */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Inter", "Noto Sans Devanagari", Arial, sans-serif;
  background:
    linear-gradient(180deg, #f8fbff 0%, #eef5ff 44%, #ffffff 100%);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  width: 100%;
  max-width: 100%;
}

button,
input,
select,
textarea {
  font: inherit;
}

/* Layout wrapper: keeps all sections aligned and full-width responsive */
.site-shell {
  width: min(var(--shell), calc(100% - 40px));
  margin: 0 auto;
}

/* Accessibility helper: appears only when focused */
.skip-link {
  position: fixed;
  left: 16px;
  top: -60px;
  z-index: 9999;
  background: var(--blue-dark);
  color: #fff;
  padding: 10px 14px;
  border-radius: 8px;
  transition: top 0.2s ease;
}

.skip-link:focus {
  top: 14px;
}

/* Topbar: affiliation, AISHE code and contact links */
.topbar {
  background: #052150;
  color: rgba(255, 255, 255, 0.86);
  font-size: 13px;
}

.topbar-inner,
.topbar-left,
.topbar-right,
.masthead-inner,
.identity-strip,
.nav-inner,
.alert-inner,
.hero-actions,
.hero-metrics,
.chip-list,
.footer-bottom {
  display: flex;
  align-items: center;
}

.topbar-inner {
  min-height: 38px;
  justify-content: space-between;
  gap: 16px;
}

.topbar-left,
.topbar-right {
  gap: 18px;
  flex-wrap: wrap;
}

.topbar a,
.topbar span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

/* Masthead: logo, college name, PPU logo and accreditation pills */
.masthead {
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}

.masthead-inner {
  min-height: 92px;
  justify-content: space-between;
  gap: 22px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 280px;
}

.brand img {
  width: 66px;
  height: 66px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: #fff;
  object-fit: contain;
  padding: 4px;
}

.brand strong {
  display: block;
  color: var(--blue-dark);
  font-size: clamp(22px, 2.6vw, 34px);
  line-height: 1.05;
  letter-spacing: 0;
}

.brand small {
  display: block;
  color: var(--ink);
  font-family: "Noto Sans Devanagari", sans-serif;
  font-size: 16px;
  font-weight: 800;
  margin-top: 4px;
}

.identity-strip {
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.identity-strip img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--line);
  padding: 4px;
}

.identity-strip span {
  background: #fff8e8;
  border: 1px solid #ead8ad;
  color: #7c5514;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 800;
}

.menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--blue);
  font-size: 22px;
}

/* Main navigation: sticky menu with desktop dropdowns */
.main-nav {
  position: sticky;
  top: 0;
  z-index: 900;
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(12px);
  box-shadow: 0 8px 18px rgba(16, 32, 51, 0.05);
}

.nav-inner {
  justify-content: center;
  gap: 2px;
  flex-wrap: wrap;
}

.nav-item {
  position: relative;
}

.nav-link,
.nav-inner a {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  padding: 0 11px;
  color: var(--ink);
  font-size: 13.5px;
  font-weight: 800;
  border-bottom: 3px solid transparent;
  position: relative;
  transition: color 0.22s ease, border-color 0.22s ease, background 0.22s ease, transform 0.22s ease;
}

.nav-drop {
  border-left: 0;
  border-right: 0;
  border-top: 0;
  background: transparent;
  cursor: pointer;
}

.nav-drop i {
  font-size: 12px;
  margin-left: 5px;
  transition: transform 0.18s ease;
}

/* Dropdown menu: matches current website's grouped menu behavior */
.dropdown-menu {
  position: absolute;
  left: 0;
  top: 100%;
  min-width: 250px;
  z-index: 30;
  display: none;
  padding: 8px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 3px solid var(--gold);
  border-radius: 0 0 8px 8px;
  box-shadow: var(--shadow);
}

.dropdown-menu a {
  min-height: 0;
  display: flex;
  padding: 10px 11px;
  border: 0;
  border-radius: 6px;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}

.dropdown-menu a:hover {
  background: var(--sky);
  color: var(--blue);
}

.has-dropdown:hover .dropdown-menu,
.has-dropdown.open .dropdown-menu {
  display: grid;
}

.has-dropdown:hover .nav-drop i,
.has-dropdown.open .nav-drop i {
  transform: rotate(180deg);
}

.nav-link:hover,
.nav-inner a:hover,
.nav-inner a.active {
  color: var(--blue);
  border-bottom-color: var(--blue);
  background: var(--sky);
  transform: translateY(-1px);
}

.search-trigger {
  width: 40px;
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--blue);
  display: grid;
  place-items: center;
  cursor: pointer;
}

/* Notice ticker: latest updates strip below menu */
.alert-strip {
  background: linear-gradient(90deg, #ffffff, #eef6ff);
  border-bottom: 1px solid var(--line);
}

.alert-inner {
  min-height: 50px;
  gap: 16px;
}

.alert-inner strong {
  background: var(--red);
  color: #fff;
  border-radius: 8px;
  padding: 8px 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  flex: 0 0 auto;
}

.ticker {
  overflow: hidden;
  white-space: nowrap;
  flex: 1;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
}

.ticker span {
  display: inline-block;
  padding-left: 100%;
  animation: ticker 30s linear infinite;
}

.alert-inner a {
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
}

/* Hero section: large campus banner, intro actions and student counters */
.hero {
  position: relative;
  isolation: isolate;
  min-height: 720px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.95), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.58)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  filter: saturate(1.08);
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(3, 18, 44, 0.18), rgba(3, 18, 44, 0.74)),
    radial-gradient(circle at 18% 24%, rgba(211, 155, 33, 0.28), transparent 30%);
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
  gap: 44px;
  align-items: center;
  padding: 78px 0 104px;
}

.eyebrow,
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 12px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.hero-copy {
  color: #fff;
  position: relative;
  z-index: 2;
  max-width: 780px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.hero-copy .eyebrow {
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: #fff;
  backdrop-filter: blur(10px);
}

.hero h1 {
  color: #fff;
  font-size: clamp(38px, 6vw, 74px);
  line-height: 1.02;
  letter-spacing: 0;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.hero-lead {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.94);
  font-size: clamp(16px, 1.65vw, 19px);
  font-weight: 600;
}

.hero-actions {
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 30px;
}

.btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 11px 17px;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.btn:hover {
  transform: translateY(-3px);
}

.btn.primary {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  box-shadow: 0 10px 24px rgba(10, 76, 135, 0.24);
}

.btn.primary:hover {
  background: #0b58ad;
  box-shadow: 0 14px 34px rgba(10, 76, 135, 0.34);
}

.btn.light {
  background: #fff;
  color: var(--blue);
  border-color: #fff;
}

.btn.light:hover {
  background: #fff8e8;
  color: #7c5514;
}

.btn.ghost {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.38);
  backdrop-filter: blur(8px);
}

.hero-metrics {
  margin-top: 34px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  background: transparent;
  border: 0;
  width: min(780px, 100%);
  backdrop-filter: none;
}

.hero-metrics div {
  min-width: 120px;
  padding: 15px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(10px);
  transition: transform 0.22s ease, background 0.22s ease;
}

.hero-metrics div:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.2);
}

.hero-metrics strong,
.hero-metrics span {
  display: block;
}

.hero-metrics strong {
  color: #fff;
  font-size: clamp(21px, 2.4vw, 28px);
  line-height: 1.1;
}

.hero-metrics span {
  color: rgba(255, 255, 255, 0.76);
  font-size: 12px;
  font-weight: 800;
}

.hero-media {
  position: relative;
  min-height: 500px;
  animation: heroMediaFloat 7s ease-in-out infinite;
}

.hero-media img {
  height: 500px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  box-shadow: var(--shadow);
  outline: 10px solid rgba(255, 255, 255, 0.08);
}

.media-card {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 260px;
  border-radius: 8px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--ink);
  box-shadow: var(--shadow);
  font-weight: 900;
  animation: floatCard 5s ease-in-out infinite;
}

.media-card i {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
}

.media-card.one {
  left: -26px;
  bottom: 58px;
}

.media-card.two {
  right: -18px;
  top: 48px;
  animation-delay: 1.2s;
}

/* Quick services: high-priority student links under hero */
.quick-services {
  margin-top: -54px;
  position: relative;
  z-index: 5;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--shadow);
  background: var(--line);
  gap: 1px;
}

.service-card {
  min-height: 150px;
  padding: 20px 14px;
  display: grid;
  place-items: center;
  text-align: center;
  gap: 8px;
  background: #fff;
  color: var(--ink);
  position: relative;
  overflow: hidden;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease, box-shadow 0.24s ease;
}

.service-card::before,
.programme-card::before,
.support-card::before,
.exam-card::before,
.download-card::before,
.disclosure-card::before,
.dept-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(135deg, rgba(18, 63, 140, 0.12), rgba(211, 155, 33, 0.16));
  transition: opacity 0.24s ease;
}

.service-card:hover {
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
  transform: translateY(-7px);
  box-shadow: var(--shadow);
}

.service-card:hover::before,
.programme-card:hover::before,
.support-card:hover::before,
.exam-card:hover::before,
.download-card:hover::before,
.disclosure-card:hover::before,
.dept-card:hover::before {
  opacity: 1;
}

.service-card i {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 24px;
}

.service-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.service-card strong {
  font-size: 15px;
}

.service-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.service-card:hover span {
  color: rgba(255, 255, 255, 0.76);
}

/* Shared section spacing and headings */
.section {
  padding: 86px 0;
  position: relative;
}

.section-title {
  max-width: 820px;
  margin: 0 auto 34px;
  text-align: center;
}

.section-title::after {
  content: "";
  display: block;
  width: 78px;
  height: 4px;
  margin: 18px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue), var(--gold));
}

/* Reusable section slider: used by Administration, Academics, Departments, Students, Facilities, Gallery, Events and Media */
.slider-shell {
  position: relative;
}

.slider-controls {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin: -8px 0 14px;
}

.slider-btn {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--blue);
  box-shadow: var(--shadow-soft);
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.slider-btn:hover {
  transform: translateY(-2px);
  background: var(--blue);
  color: #fff;
}

.slider-btn.is-disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none;
}

.slider-track {
  display: flex;
  gap: 18px;
  overflow: hidden;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  padding: 4px 4px 18px;
  scrollbar-width: none;
}

.slider-track.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;
  scroll-behavior: auto;
}

.slider-track::-webkit-scrollbar {
  display: none;
}

.slider-dots {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin-top: 6px;
}

.slider-dot {
  width: 9px;
  height: 9px;
  border: 0;
  border-radius: 999px;
  background: #b9cbe0;
  cursor: pointer;
  transition: width 0.2s ease, background 0.2s ease;
}

.slider-dot.active {
  width: 28px;
  background: var(--blue);
}

.slider-track > * {
  flex: 0 0 42%;
  scroll-snap-align: start;
}

.programme-grid.slider-track > *,
.dept-grid.slider-track > *,
.support-grid.slider-track > * {
  flex-basis: 31%;
}

.gallery-grid.slider-track > *,
.facility-track.slider-track > *,
.event-grid.slider-track > *,
.media-grid.slider-track > * {
  flex-basis: 42%;
}

.gallery-grid.slider-track .gallery-item.big {
  flex-basis: 42%;
  grid-row: auto;
}

.section-title.left {
  text-align: left;
  margin-left: 0;
  margin-right: 0;
}

h2 {
  color: var(--ink);
  font-size: clamp(27px, 3vw, 42px);
  line-height: 1.15;
  letter-spacing: 0;
}

h3 {
  color: var(--ink);
}

.section-title h2,
.content-block h2,
.contact-info h2,
.admin-scope h2,
.alumni-card h2 {
  margin: 12px 0 10px;
}

/* Shared two-column layouts used across content sections */
.two-col,
.split-section,
.notice-layout,
.naac-grid,
.downloads-layout,
.contact-grid,
.exam-grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 34px;
  align-items: center;
}

.reverse {
  grid-template-columns: 1.05fr 0.95fr;
}
/* Founder / Principal portrait image */
.image-panel {
  width: 100%;
  max-width: 360px;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #f6f8fb;
  box-shadow: var(--shadow-sm);
}

.image-panel img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

/* Agar same height chahiye */
.portrait-panel {
  aspect-ratio: 360 / 460;
  display: flex;
  align-items: center;
  justify-content: center;
}

.portrait-panel img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.content-block p {
  font-size: 16px;
}

/* About checklist: small feature/value highlights */
.check-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 22px;
}

.check-grid span,
.programme-card,
.official-card,
.support-card,
.exam-card,
.download-card,
.disclosure-card {
  position: relative;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-soft);
}

.check-grid span {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 800;
}

.check-grid i {
  color: var(--green);
}

/* White band sections: administration, student support and downloads */
.official-section,
.students-section,
.downloads-section {
  background: #fff;
}

.official-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.official-card {
  overflow: hidden;
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.official-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow);
}

.official-card img {
  height: 235px;
  object-fit: contain;
  background: #f8fbff;
  transition: transform 0.4s ease, filter 0.4s ease;
}

.official-card:hover img {
  transform: scale(1.03);
  filter: saturate(1.08);
}

.official-card h3,
.official-card p {
  padding-left: 20px;
  padding-right: 20px;
}

.official-card h3 {
  padding-top: 18px;
  font-size: 20px;
}

.official-card p {
  padding-bottom: 22px;
  margin-top: 6px;
}

/* Notices module: tabbed notice board and priority links */
.notice-section {
  background: linear-gradient(180deg, #f5f8fb, #eef5fb);
}

.notice-layout {
  grid-template-columns: 1.38fr 0.62fr;
  align-items: stretch;
}

.notice-board,
.priority-panel,
.admission-card,
.naac-highlight,
.admin-scope,
.contact-info,
.enquiry-form,
.alumni-card {
  border-radius: 8px;
  box-shadow: var(--shadow-soft);
}

.notice-board {
  background: #fff;
  border: 1px solid var(--line);
  overflow: hidden;
}

.board-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: end;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.tab {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.tab:hover {
  transform: translateY(-2px);
  background: var(--sky);
  color: var(--blue);
}

.tab.active {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  box-shadow: 0 8px 20px rgba(18, 63, 140, 0.2);
}

.tab-panel {
  display: none;
  padding: 0 24px;
}

.tab-panel.active {
  display: block;
}

.notice-item {
  display: grid;
  grid-template-columns: 86px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  transition: background 0.2s ease, transform 0.2s ease;
}

.notice-item:hover {
  background: #f8fbff;
  transform: translateX(4px);
}

.notice-item:last-child {
  border-bottom: none;
}

.notice-item time {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  text-align: center;
  background: #fff;
}

.notice-item time strong {
  display: block;
  background: var(--blue);
  color: #fff;
  font-size: 23px;
  line-height: 1;
  padding: 9px 0 6px;
}

.notice-item time span {
  display: block;
  color: var(--blue-dark);
  font-size: 11px;
  font-weight: 900;
  padding: 6px 4px;
}

.notice-item b {
  display: block;
  color: var(--ink);
  line-height: 1.35;
}

.notice-item p {
  font-size: 13.5px;
  margin-top: 4px;
}

.notice-item a {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
}

.priority-panel,
.admission-card,
.contact-info,
.admin-scope,
.naac-highlight {
  background: var(--blue-dark);
  color: #fff;
  padding: 28px;
}

.priority-panel h3,
.admission-card h3,
.contact-info h2,
.admin-scope h2,
.naac-highlight strong {
  color: #fff;
}

.priority-panel a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
  padding: 13px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
  font-weight: 800;
  transition: background 0.2s ease, transform 0.2s ease;
}

.priority-panel a:hover {
  background: rgba(255, 255, 255, 0.16);
  transform: translateX(5px);
}

.priority-panel span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Academics cards: courses, calendar, syllabus and timetable */
.programme-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}

.programme-card {
  position: relative;
  padding: 20px;
  min-height: 210px;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.programme-card:hover,
.support-card:hover,
.exam-card:hover,
.download-card:hover,
.disclosure-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.programme-card i,
.support-card i,
.exam-card i,
.download-card i,
.disclosure-card i {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 23px;
  margin-bottom: 16px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.programme-card:hover i,
.support-card:hover i,
.exam-card:hover i,
.download-card:hover i,
.disclosure-card:hover i {
  transform: rotate(-5deg) scale(1.08);
  background: var(--blue);
  color: #fff;
}

.programme-card h3,
.support-card h3,
.exam-card h3 {
  font-size: 18px;
  margin-bottom: 8px;
}

/* Light blue band sections: departments, facilities and admin/alumni */
.departments-section,
.facilities-section,
.alumni-admin-section {
  background: linear-gradient(180deg, #eef5fb, #f8fbff);
}

/* Department grid: subject/category cards */
.dept-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.dept-card {
  position: relative;
  overflow: hidden;
  min-height: 170px;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-soft);
  display: grid;
  align-content: space-between;
  transition: transform 0.24s ease, background 0.24s ease, box-shadow 0.24s ease;
}

.dept-card:hover {
  transform: translateY(-8px);
  background: linear-gradient(135deg, var(--blue), var(--blue-dark));
  box-shadow: var(--shadow);
}

.dept-card span {
  width: fit-content;
  background: var(--sky);
  color: var(--blue);
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 900;
}

.dept-card strong {
  color: var(--ink);
  font-size: 22px;
  line-height: 1.2;
}

.dept-card small {
  color: var(--muted);
  font-weight: 700;
}

.dept-card:hover strong,
.dept-card:hover small {
  color: #fff;
}

/* Admissions section: application flow and helpdesk card */
.admissions-section {
  background: #fff;
}

.timeline {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.timeline div {
  display: grid;
  grid-template-columns: 50px 1fr;
  column-gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.timeline div:hover {
  transform: translateX(5px);
  border-color: #aac7e6;
}

.timeline span {
  grid-row: span 2;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--blue);
  color: #fff;
  font-weight: 900;
}

.timeline b {
  color: var(--ink);
}

.timeline small {
  color: var(--muted);
  font-weight: 700;
}

.admission-card {
  min-height: 390px;
  display: grid;
  align-content: center;
  gap: 14px;
  background:
    linear-gradient(rgba(8, 43, 98, 0.9), rgba(8, 43, 98, 0.9)),
    url("../img/bdcpat_202605201518.jpg") center/cover;
}

.admission-card p,
.priority-panel p,
.contact-info p,
.admin-scope p,
.naac-highlight p {
  color: rgba(255, 255, 255, 0.78);
}

/* Examination section: form, schedule, admit card and result cards */
.exam-grid {
  grid-template-columns: 0.75fr 1.25fr;
}

.exam-cards,
.support-grid,
.download-grid,
.disclosure-grid {
  display: grid;
  gap: 16px;
}

.exam-cards {
  grid-template-columns: repeat(4, 1fr);
}

.exam-card,
.support-card {
  padding: 20px;
  min-height: 180px;
}

.support-grid {
  grid-template-columns: repeat(4, 1fr);
}

/* Committees/cells section: statutory groups and activity image */
.committees-section {
  background: #fff;
}

.chip-list {
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 22px;
}

.chip-list span {
  border-radius: 999px;
  padding: 7px 11px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12.5px;
  font-weight: 900;
}

.chip-list.inverse span {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.16);
}

/* NAAC/IQAC section: dark quality-assurance document area */
.naac-section {
  background: #06233e;
}

.naac-grid {
  grid-template-columns: 0.85fr 1.15fr;
}

.light-kicker {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.naac-highlight strong {
  display: block;
  font-size: clamp(34px, 5vw, 70px);
  line-height: 1;
  margin: 20px 0 14px;
}

.document-list {
  display: grid;
  gap: 12px;
}

.document-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 16px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(255, 255, 255, 0.18);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.document-list a:hover {
  transform: translateX(6px);
  box-shadow: var(--shadow-soft);
}

.document-list i {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff1f1;
  color: var(--red);
  font-size: 23px;
}

.document-list b,
.document-list small {
  display: block;
}

.document-list b {
  color: var(--ink);
}

.document-list em {
  color: var(--blue);
  font-style: normal;
  font-weight: 900;
}

/* RTI/statutory disclosure cards */
.disclosure-section {
  background: #fff;
}

.disclosure-grid {
  grid-template-columns: repeat(8, 1fr);
}

.disclosure-card {
  min-height: 135px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 16px;
  color: var(--ink);
  font-weight: 900;
}

/* Facilities cards: image-based campus facility tiles */
.facility-track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.facility-card {
  position: relative;
  overflow: hidden;
  min-height: 320px;
  border-radius: 8px;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.facility-card:hover {
  transform: translateY(-7px);
  box-shadow: var(--shadow);
}

.facility-card img {
  height: 320px;
  object-fit: contain;
  background: #061e35;
  transition: transform 0.4s ease;
}

.facility-card::after,
.gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent, rgba(6, 30, 53, 0.84));
}

.facility-card h3,
.gallery-item span {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  color: #fff;
  z-index: 1;
}

.facility-card:hover img,
.gallery-item:hover img {
  transform: scale(1.06);
}

/* Gallery section: campus, NSS/NCC, seminars and media images */
.gallery-section {
  background: #fff;
}

.gallery-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr;
  grid-auto-rows: 230px;
  gap: 14px;
}

.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: #061e35;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.gallery-item:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow);
}

.gallery-item.big {
  grid-row: span 2;
}

.gallery-item img {
  height: 100%;
  object-fit: contain;
  background: #061e35;
  transition: transform 0.4s ease;
}

.gallery-item span {
  font-size: 18px;
  font-weight: 900;
}

.media-highlights {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.media-news {
  display: grid;
  grid-template-columns: 128px 1fr;
  gap: 14px;
  align-items: center;
  min-height: 138px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.media-news:hover {
  transform: translateY(-5px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.media-news img {
  width: 128px;
  height: 112px;
  object-fit: contain;
  border-radius: 8px;
  background: #061e35;
}

.media-news strong,
.media-news span {
  display: block;
}

.media-news strong {
  color: var(--ink);
  font-size: 15px;
  line-height: 1.25;
}

.media-news span {
  color: var(--text);
  font-size: 13px;
  margin-top: 4px;
}

/* Events section: dedicated cards for college activities */
.events-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.event-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.event-card,
.press-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.event-card:hover,
.press-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow);
}

.event-card img {
  height: 230px;
  object-fit: contain;
  background: #061e35;
}

.event-card div,
.press-card div {
  padding: 18px;
}

.event-card span,
.press-card span {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 9px;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.event-card h3,
.press-card h3 {
  font-size: 19px;
  line-height: 1.25;
  margin-bottom: 7px;
}

/* Media section: separate press/news coverage layout */
.media-section {
  background: #fff;
}

.media-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.press-card img {
  height: 260px;
  object-fit: contain;
  background: #061e35;
}

/* Slider overrides: keep old grid classes usable as horizontal tracks */
.official-grid.slider-track,
.programme-grid.slider-track,
.dept-grid.slider-track,
.support-grid.slider-track,
.facility-track.slider-track,
.gallery-grid.slider-track,
.event-grid.slider-track,
.media-grid.slider-track {
  display: flex;
  grid-template-columns: none;
  grid-auto-rows: auto;
}

.official-grid.slider-track > * {
  flex: 0 0 calc((100% - 54px) / 4);
}

.programme-grid.slider-track > *,
.dept-grid.slider-track > *,
.support-grid.slider-track > *,
.facility-track.slider-track > *,
.gallery-grid.slider-track > *,
.event-grid.slider-track > *,
.media-grid.slider-track > * {
  flex: 0 0 calc((100% - 72px) / 5);
}

.gallery-grid.slider-track > * {
  height: 280px;
}

/* Downloads section: document category cards */
.downloads-layout {
  grid-template-columns: 0.95fr 1.05fr;
}

.download-grid {
  grid-template-columns: repeat(4, 1fr);
}

.download-card {
  min-height: 170px;
  padding: 18px;
  display: grid;
  align-content: center;
  gap: 6px;
}

.download-card i {
  color: var(--red);
  background: #fff1f1;
}

.download-card b {
  color: var(--ink);
}

.download-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

/* Admin scope and alumni cards */
.admin-scope {
  min-height: 430px;
  display: grid;
  align-content: center;
  background: var(--blue-dark);
}

.alumni-card {
  background: #fff;
  border: 1px solid var(--line);
  overflow: hidden;
}

.alumni-card img {
  height: 250px;
  object-fit: cover;
}

.alumni-card div {
  padding: 24px;
}

/* Contact section: address block and enquiry form */
.contact-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.contact-grid {
  grid-template-columns: 0.85fr 1.15fr;
}

.contact-info {
  min-height: 430px;
  display: grid;
  align-content: center;
  gap: 12px;
}

.contact-info a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #fff;
  font-weight: 800;
  transition: transform 0.2s ease, color 0.2s ease;
}

.contact-info a:hover {
  transform: translateX(5px);
  color: #ffe49d;
}

.enquiry-form {
  background: #fff;
  border: 1px solid var(--line);
  padding: 26px;
}

.enquiry-form h3 {
  font-size: 24px;
  margin-bottom: 18px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 16px;
}

.form-grid label {
  display: grid;
  gap: 7px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}

.form-grid .wide {
  grid-column: 1 / -1;
}

.form-grid input,
.form-grid select,
.form-grid textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
  color: var(--ink);
  outline: none;
}

.form-grid textarea {
  min-height: 120px;
  resize: vertical;
}

.form-grid input:focus,
.form-grid select:focus,
.form-grid textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(10, 76, 135, 0.1);
}


/* Footer: repeated important links and copyright */
.footer {
  background: #061e35;
  color: rgba(255, 255, 255, 0.72);
  padding-top: 50px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr 0.8fr;
  gap: 30px;
  padding-bottom: 34px;
}

.footer h3,
.footer h4 {
  color: #fff;
  margin-bottom: 12px;
}

.footer a {
  display: block;
  margin-top: 8px;
  font-size: 14px;
  transition: color 0.2s ease, transform 0.2s ease;
}

.footer a:hover {
  color: #fff;
  transform: translateX(4px);
}

.footer-bottom {
  justify-content: space-between;
  gap: 14px;
  padding: 16px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 13px;
}

/* Search modal: frontend-only search interface */
.search-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 2000;
  padding: 90px 18px;
  background: rgba(6, 30, 53, 0.72);
  backdrop-filter: blur(8px);
}

.search-modal.show {
  display: flex;
}

.search-box {
  width: min(760px, 100%);
  position: relative;
  background: #fff;
  border-radius: 8px;
  padding: 26px;
  box-shadow: var(--shadow);
}

.close-search {
  position: absolute;
  right: 16px;
  top: 16px;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
}

.search-box h3 {
  font-size: 26px;
  margin-bottom: 18px;
}

.search-row {
  display: flex;
  gap: 10px;
}

.search-row input {
  flex: 1;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  outline: none;
}

/* Scroll reveal animation classes controlled by main.js */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.reveal.in-view {
  opacity: 1;
  transform: translateY(0);
}

.delay-1 { transition-delay: 0.08s; }
.delay-2 { transition-delay: 0.16s; }
.delay-3 { transition-delay: 0.24s; }
.delay-4 { transition-delay: 0.32s; }
.delay-5 { transition-delay: 0.4s; }

/* Keyframe animations: ticker, hero image zoom and floating cards */
@keyframes ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-100%); }
}

@keyframes heroZoom {
  from { transform: scale(1); }
  to { transform: scale(1.07); }
}

@keyframes floatCard {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

@keyframes heroMediaFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* Tablet/laptop responsiveness */
@media (max-width: 1280px) {
  .programme-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .disclosure-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .service-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .download-grid,
  .exam-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile navigation drawer and tablet layout */
@media (max-width: 1024px) {
  .menu-toggle {
    display: grid;
    place-items: center;
  }

  .masthead-inner {
    min-height: 82px;
  }

  .identity-strip {
    display: none;
  }

  .main-nav {
    position: fixed;
    inset: 0 0 0 auto;
    width: min(380px, 88vw);
    transform: translateX(105%);
    transition: transform 0.25s ease;
    overflow-y: auto;
    padding-top: 88px;
    box-shadow: var(--shadow);
  }

  .main-nav.open {
    transform: translateX(0);
  }

  .nav-inner {
    width: 100%;
    display: grid;
    justify-content: stretch;
    padding: 0 18px 24px;
  }

  .nav-item {
    width: 100%;
  }

  .nav-link,
  .nav-inner a {
    min-height: 48px;
    border-bottom: 1px solid var(--line);
    width: 100%;
    justify-content: space-between;
  }

  .dropdown-menu {
    position: static;
    display: none;
    min-width: 0;
    border: 0;
    border-left: 3px solid var(--gold);
    box-shadow: none;
    border-radius: 0;
    padding: 5px 0 8px 12px;
    background: #f8fbff;
  }

  .has-dropdown:hover .dropdown-menu {
    display: none;
  }

  .has-dropdown.open .dropdown-menu {
    display: grid;
  }

  .has-dropdown:hover .nav-drop i {
    transform: none;
  }

  .has-dropdown.open .nav-drop i {
    transform: rotate(180deg);
  }

  .search-trigger {
    width: 100%;
  }

  .hero-grid,
  .two-col,
  .reverse,
  .split-section,
  .notice-layout,
  .naac-grid,
  .downloads-layout,
  .contact-grid,
  .exam-grid {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
  }

  .hero-grid {
    padding: 56px 0 78px;
  }

  .hero-media {
    min-height: auto;
    max-width: 760px;
    width: 100%;
  }

  .hero-copy {
    max-width: 100%;
  }

  .official-grid,
  .dept-grid,
  .support-grid,
  .facility-track,
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .media-highlights {
    grid-template-columns: 1fr;
  }

  .event-grid,
  .media-grid {
    grid-template-columns: 1fr;
  }

  .gallery-item.big {
    grid-column: span 2;
    grid-row: span 1;
  }

  .official-grid.slider-track > * {
    flex-basis: calc((100% - 18px) / 2);
  }

  .programme-grid.slider-track > *,
  .dept-grid.slider-track > *,
  .support-grid.slider-track > *,
  .facility-track.slider-track > *,
  .gallery-grid.slider-track > *,
  .event-grid.slider-track > *,
  .media-grid.slider-track > * {
    flex-basis: calc((100% - 36px) / 3);
  }
}

/* Phone layout: single-column grids and compact media */
@media (max-width: 700px) {
  .site-shell {
    width: min(100% - 24px, var(--shell));
  }

  .topbar-inner,
  .topbar-left,
  .topbar-right,
  .alert-inner,
  .hero-actions,
  .board-head,
  .search-row,
  .footer-bottom {
    align-items: stretch;
    flex-direction: column;
  }

  .topbar-inner {
    padding: 9px 0;
  }

  .brand {
    min-width: 0;
  }

  .brand img {
    width: 54px;
    height: 54px;
  }

  .brand small {
    font-size: 13px;
  }

  .hero h1 {
    font-size: clamp(36px, 14vw, 56px);
  }

  .hero-copy {
    padding: 18px;
  }

  .hero-lead {
    font-size: 15.5px;
  }

  .hero-actions .btn {
    width: 100%;
  }

  .hero-metrics div {
    padding: 13px;
  }

  .hero-metrics span {
    font-size: 11.5px;
  }

  .hero-media img {
    height: 260px;
    outline-width: 6px;
  }

  .media-card {
    position: static;
    margin-top: 10px;
    max-width: none;
    animation: none;
  }

  .quick-services {
    margin-top: 0;
  }

  .service-grid,
  .programme-grid,
  .official-grid,
  .dept-grid,
  .support-grid,
  .facility-track,
  .footer-grid,
  .disclosure-grid,
  .download-grid,
  .exam-cards,
  .check-grid,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .hero-metrics {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-top: 20px;
  }

  .hero-metrics div {
    min-width: 0;
    padding: 10px 8px;
  }

  .hero-metrics strong {
    font-size: 18px;
  }

  .hero-metrics span {
    font-size: 10.5px;
    line-height: 1.25;
  }

  .section {
    padding: 62px 0;
  }

  .notice-item {
    grid-template-columns: 70px 1fr;
  }

  .notice-item a {
    grid-column: 2;
  }

  .gallery-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 230px;
  }

  .gallery-item.big {
    grid-column: span 1;
  }

  .media-news {
    grid-template-columns: 96px 1fr;
  }

  .media-news img {
    width: 96px;
    height: 88px;
  }

  .event-card img,
  .press-card img {
    height: 220px;
  }

  .form-grid .wide {
    grid-column: auto;
  }

  .slider-controls {
    justify-content: center;
    margin-top: 0;
  }

  .official-grid.slider-track > *,
  .programme-grid.slider-track > *,
  .dept-grid.slider-track > *,
  .support-grid.slider-track > *,
  .facility-track.slider-track > *,
  .gallery-grid.slider-track > *,
  .event-grid.slider-track > *,
  .media-grid.slider-track > * {
    flex-basis: 88%;
  }

  .gallery-grid.slider-track > * {
    height: 240px;
  }
}

/* Very small phones: keep hero statistic cards compact and readable */
@media (max-width: 380px) {
  .hero-metrics {
    gap: 6px;
  }

  .hero-metrics div {
    padding: 9px 6px;
  }

  .hero-metrics strong {
    font-size: 16px;
  }

  .hero-metrics span {
    font-size: 10px;
  }
}

/* Accessibility: disable motion for users who request reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }
}



/* ================= ABOUT PAGE START ================= */

.about-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.about-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.about-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.about-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.about-hero-content {
  max-width: 840px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.about-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.about-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.2vw, 68px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.about-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.about-hero-card {
  padding: 28px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.4);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.about-hero-card img {
  width: 112px;
  height: 112px;
  object-fit: contain;
  margin: 0 auto 18px;
  padding: 8px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: #fff;
}

.about-hero-card h3 {
  color: var(--blue-dark);
  font-size: 24px;
  margin-bottom: 6px;
}

.about-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.about-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.about-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.about-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.breadcrumb-inner {
  min-height: 54px;
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.breadcrumb-inner a {
  color: var(--blue);
}

.breadcrumb-inner strong {
  color: var(--ink);
}

.founder-legacy-section,
.college-glance-section,
.journey-section,
.principal-preview-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.about-intro-section,
.vision-mission-section,
.academic-env-section,
.about-links-section {
  background: #fff;
}

.about-quote-box {
  margin-top: 22px;
  padding: 20px;
  border-left: 4px solid var(--gold);
  border-radius: 8px;
  background: #fff8e8;
  color: var(--ink);
  box-shadow: var(--shadow-soft);
}

.about-quote-box i {
  color: var(--gold);
  font-size: 28px;
}

.about-quote-box p {
  margin-top: 6px;
  font-weight: 800;
}

.legacy-card {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  display: grid;
  align-content: center;
  padding: 32px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.legacy-icon {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffe49d;
  font-size: 28px;
  margin-bottom: 18px;
}

.legacy-card h3 {
  color: #fff;
  font-size: 28px;
  margin-bottom: 10px;
}

.legacy-card p {
  color: rgba(255, 255, 255, 0.78);
}

.legacy-card ul {
  list-style: none;
  display: grid;
  gap: 10px;
  margin-top: 22px;
}

.legacy-card li {
  display: flex;
  align-items: center;
  gap: 9px;
  font-weight: 800;
}

.legacy-card li i {
  color: #ffe49d;
}

.glance-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.glance-card,
.vm-card,
.value-mini-card,
.about-link-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.glance-card {
  min-height: 190px;
  padding: 24px;
}

.glance-card:hover,
.vm-card:hover,
.value-mini-card:hover,
.about-link-card:hover {
  transform: translateY(-7px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.glance-card i,
.vm-icon,
.value-mini-card i,
.about-link-card > i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 24px;
  margin-bottom: 16px;
}

.glance-card h3,
.vm-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.glance-card p {
  color: var(--text);
  font-weight: 700;
}

.vm-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.vm-card {
  min-height: 290px;
  padding: 26px;
}

.vm-card:hover .vm-icon {
  background: var(--blue);
  color: #fff;
  transform: rotate(-5deg) scale(1.06);
}

.vm-icon {
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.values-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.value-mini-card {
  min-height: 170px;
  padding: 22px;
  display: grid;
  align-content: center;
}

.value-mini-card strong,
.value-mini-card span {
  display: block;
}

.value-mini-card strong {
  color: var(--ink);
  font-size: 19px;
  margin-bottom: 4px;
}

.value-mini-card span {
  color: var(--muted);
  font-weight: 700;
}

.journey-timeline {
  display: grid;
  gap: 16px;
  max-width: 980px;
  margin: 0 auto;
  position: relative;
}

.journey-item {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 18px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.journey-item:hover {
  transform: translateX(6px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.journey-item > span {
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--blue);
  color: #fff;
  font-size: 22px;
  font-weight: 900;
}

.journey-item h3 {
  font-size: 21px;
  margin-bottom: 5px;
}

.about-link-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.about-link-card {
  min-height: 150px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 18px;
}

.about-link-card > i {
  margin-bottom: 0;
}

.about-link-card strong,
.about-link-card small {
  display: block;
}

.about-link-card strong {
  color: var(--ink);
  font-size: 17px;
}

.about-link-card small {
  color: var(--muted);
  font-weight: 700;
  margin-top: 3px;
}

.about-link-card em {
  color: var(--blue);
  font-style: normal;
  font-size: 18px;
}

/* About page responsive */
@media (max-width: 1024px) {
  .about-hero-inner {
    grid-template-columns: 1fr;
  }

  .about-hero-card {
    max-width: 520px;
  }

  .glance-grid,
  .vm-grid,
  .about-link-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 700px) {
  .about-page-hero {
    min-height: auto;
  }

  .about-hero-inner {
    padding: 52px 0;
  }

  .about-hero-content {
    padding: 18px;
  }

  .about-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .about-hero-content .btn {
    width: 100%;
  }

  .glance-grid,
  .vm-grid,
  .values-grid,
  .about-link-grid {
    grid-template-columns: 1fr;
  }

  .journey-item {
    grid-template-columns: 1fr;
  }

  .journey-item > span {
    width: fit-content;
    padding: 10px 16px;
  }

  .about-link-card {
    grid-template-columns: auto 1fr;
  }

  .about-link-card em {
    grid-column: 2;
  }
}

/* ================= ABOUT PAGE END ================= */


/* ================= ACADEMIC PAGE START ================= */

.academic-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.academic-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.academic-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.academic-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.academic-hero-content {
  max-width: 840px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.academic-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.academic-hero-content h1 {
  color: #fff;
  font-size: clamp(42px, 6vw, 76px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.academic-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.academic-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.academic-card-icon {
  width: 86px;
  height: 86px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.academic-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.academic-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.academic-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.academic-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.academic-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.breadcrumb-inner {
  min-height: 54px;
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.breadcrumb-inner a {
  color: var(--blue);
}

.breadcrumb-inner strong {
  color: var(--ink);
}

.academic-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.academic-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.academic-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.academic-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.academic-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.academic-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.academic-quick-card strong {
  font-size: 16px;
}

.academic-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.academic-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.academic-overview-section,
.courses-section,
.syllabus-section,
.digital-section {
  background: #fff;
}

.holiday-section,
.timetable-section,
.academic-calendar-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.course-category-grid,
.syllabus-grid,
.digital-grid {
  display: grid;
  gap: 18px;
}

.course-category-grid {
  grid-template-columns: repeat(4, 1fr);
}

.course-category-card,
.syllabus-card,
.digital-card,
.timetable-card,
.calendar-panel,
.holiday-main,
.holiday-side {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.course-category-card {
  min-height: 340px;
  padding: 24px;
}

.course-category-card:hover,
.syllabus-card:hover,
.digital-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.course-icon,
.syllabus-card i,
.digital-card i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.course-category-card:hover .course-icon,
.syllabus-card:hover > i,
.digital-card:hover > i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.course-category-card h3,
.syllabus-card h3 {
  font-size: 21px;
  margin-bottom: 9px;
}

.course-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 18px;
}

.course-tags span {
  padding: 6px 9px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.holiday-layout {
  display: grid;
  grid-template-columns: 1.35fr 0.65fr;
  gap: 24px;
  align-items: start;
}

.holiday-main {
  padding: 0;
}

.holiday-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.holiday-head h3,
.holiday-side h3 {
  font-size: 24px;
  margin-bottom: 4px;
}

.holiday-list {
  display: grid;
}

.holiday-item {
  display: grid;
  grid-template-columns: 82px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 18px 24px;
  border-bottom: 1px solid var(--line);
  transition: background 0.2s ease, transform 0.2s ease;
}

.holiday-item:hover {
  background: #f8fbff;
  transform: translateX(4px);
}

.holiday-item:last-child {
  border-bottom: none;
}

.holiday-year {
  min-height: 56px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--blue);
  color: #fff;
  font-size: 18px;
  font-weight: 900;
}

.holiday-item h4 {
  color: var(--ink);
  font-size: 17px;
  line-height: 1.35;
}

.holiday-item p {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  margin-top: 3px;
}

.holiday-item > a {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
}

.holiday-side {
  padding: 24px;
  background: var(--blue-dark);
  color: #fff;
}

.holiday-side h3 {
  color: #fff;
}

.holiday-side > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 10px;
  padding: 13px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
  font-weight: 800;
  transition: background 0.2s ease, transform 0.2s ease;
}

.holiday-side > a:hover {
  background: rgba(255, 255, 255, 0.16);
  transform: translateX(5px);
}

.holiday-side > a span {
  display: flex;
  align-items: center;
  gap: 9px;
}

.holiday-note {
  margin-top: 20px;
  padding: 16px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
}

.holiday-note i {
  color: #ffe49d;
  font-size: 24px;
}

.holiday-note p {
  color: rgba(255, 255, 255, 0.78);
  margin-top: 8px;
}

.timetable-card {
  padding: 28px;
  background: var(--blue-dark);
  color: #fff;
}

.timetable-card h3 {
  color: #fff;
  font-size: 28px;
}

.timetable-card p {
  color: rgba(255, 255, 255, 0.78);
  margin-top: 6px;
}

.timetable-list {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.timetable-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 13px;
  align-items: center;
  padding: 15px;
  border-radius: 8px;
  background: #fff;
}

.timetable-list i {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff1f1;
  color: var(--red);
  font-size: 23px;
}

.timetable-list b,
.timetable-list small {
  display: block;
}

.timetable-list b {
  color: var(--ink);
}

.timetable-list small {
  color: var(--muted);
  font-weight: 700;
}

.timetable-list em {
  color: var(--blue);
  font-style: normal;
  font-weight: 900;
}

.syllabus-grid {
  grid-template-columns: repeat(4, 1fr);
}

.syllabus-card {
  min-height: 270px;
  padding: 24px;
}

.syllabus-card a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 18px;
  color: var(--blue);
  font-weight: 900;
}

.calendar-panel {
  padding: 28px;
}

.calendar-panel-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 22px;
}

.calendar-panel-head i {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 30px;
}

.calendar-panel-head h3 {
  font-size: 25px;
}

.calendar-month-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 22px;
}

.calendar-month-grid span {
  min-height: 54px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  font-weight: 900;
  box-shadow: var(--shadow-soft);
}

.digital-grid {
  grid-template-columns: repeat(6, 1fr);
}

.digital-card {
  min-height: 190px;
  padding: 20px;
  display: grid;
  align-content: center;
}

.digital-card strong,
.digital-card span {
  display: block;
}

.digital-card strong {
  color: var(--ink);
  font-size: 17px;
  line-height: 1.25;
}

.digital-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  margin-top: 5px;
}

.academic-help-section {
  background: #fff;
}

.academic-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.academic-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.academic-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.academic-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Academic responsive */
@media (max-width: 1280px) {
  .course-category-grid,
  .syllabus-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .digital-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 1024px) {
  .academic-hero-inner,
  .holiday-layout,
  .academic-help-box {
    grid-template-columns: 1fr;
  }

  .academic-hero-card {
    max-width: 520px;
  }

  .academic-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .academic-help-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .academic-page-hero {
    min-height: auto;
  }

  .academic-hero-inner {
    padding: 52px 0;
  }

  .academic-hero-content {
    padding: 18px;
  }

  .academic-hero-content h1 {
    font-size: clamp(38px, 14vw, 58px);
  }

  .academic-hero-content .btn,
  .academic-help-actions .btn {
    width: 100%;
  }

  .academic-quick-section {
    margin-top: 0;
  }

  .academic-quick-grid,
  .course-category-grid,
  .syllabus-grid,
  .digital-grid {
    grid-template-columns: 1fr;
  }

  .holiday-head {
    align-items: stretch;
    flex-direction: column;
  }

  .holiday-head .btn {
    width: 100%;
  }

  .holiday-item {
    grid-template-columns: 1fr;
  }

  .holiday-year {
    width: fit-content;
    min-height: 0;
    padding: 9px 14px;
  }

  .holiday-item > a {
    width: 100%;
  }

  .timetable-list a {
    grid-template-columns: auto 1fr;
  }

  .timetable-list em {
    grid-column: 2;
  }

  .calendar-month-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .academic-help-box {
    padding: 24px;
  }
}

/* ================= ACADEMIC PAGE END ================= */



/* ================= ADMINISTRATION PAGE START ================= */

.admin-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.admin-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.admin-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.admin-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.admin-hero-content {
  max-width: 840px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.admin-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.admin-hero-content h1 {
  color: #fff;
  font-size: clamp(42px, 6vw, 76px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.admin-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.admin-hero-card {
  padding: 28px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.admin-hero-card img {
  width: 132px;
  height: 150px;
  object-fit: contain;
  object-position: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: #f8fbff;
  padding: 4px;
}

.admin-hero-card h3 {
  color: var(--blue-dark);
  font-size: 24px;
  line-height: 1.2;
  margin-bottom: 8px;
}

.admin-hero-card p {
  color: var(--text);
  font-weight: 800;
}

.admin-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.admin-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.admin-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.breadcrumb-inner {
  min-height: 54px;
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.breadcrumb-inner a {
  color: var(--blue);
}

.breadcrumb-inner strong {
  color: var(--ink);
}

.admin-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.admin-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.admin-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.admin-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.admin-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.admin-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.admin-quick-card strong {
  font-size: 16px;
}

.admin-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.principal-desk-section,
.admin-staff-section,
.admin-gallery-section {
  background: #fff;
}

.admin-overview-section,
.former-principal-section,
.staff-list-section,
.admin-committee-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.admin-overview-grid,
.staff-section-grid,
.committee-grid {
  display: grid;
  gap: 18px;
}

.admin-overview-grid {
  grid-template-columns: repeat(4, 1fr);
}

.staff-section-grid,
.committee-grid {
  grid-template-columns: repeat(3, 1fr);
}

.admin-overview-card,
.staff-section-card,
.committee-card {
  position: relative;
  overflow: hidden;
  min-height: 230px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.admin-overview-card:hover,
.staff-section-card:hover,
.committee-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.admin-overview-card i,
.staff-section-card i,
.committee-card i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.admin-overview-card:hover i,
.staff-section-card:hover i,
.committee-card:hover i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.admin-overview-card h3,
.staff-section-card h3,
.committee-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.principal-table-wrap {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.principal-table-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.principal-table-head h3 {
  font-size: 25px;
  margin-bottom: 4px;
}

.principal-table-scroll {
  width: 100%;
  overflow-x: auto;
}

.principal-table {
  width: 100%;
  min-width: 880px;
  border-collapse: collapse;
}

.principal-table th,
.principal-table td {
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

.principal-table th {
  background: var(--blue-dark);
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.principal-table td {
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.principal-table td:nth-child(1) {
  color: var(--blue);
  font-weight: 900;
}

.principal-table td:nth-child(2) {
  color: var(--ink);
  font-weight: 900;
}

.principal-table tbody tr {
  transition: background 0.2s ease;
}

.principal-table tbody tr:hover {
  background: #f8fbff;
}

.current-principal-row {
  background: #fff8e8;
}

.status {
  display: inline-flex;
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.status.principal {
  background: var(--sky);
  color: var(--blue);
}

.status.incharge {
  background: #fff4df;
  color: #9a620c;
}

.status.current {
  background: #e9f8f0;
  color: var(--green);
}

.staff-download-card {
  padding: 28px;
  border-radius: 8px;
  background: var(--blue-dark);
  color: #fff;
  box-shadow: var(--shadow);
}

.staff-download-card h3 {
  color: #fff;
  font-size: 28px;
}

.staff-download-card p {
  color: rgba(255, 255, 255, 0.78);
  margin-top: 6px;
}

.staff-download-list {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.staff-download-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 13px;
  align-items: center;
  padding: 15px;
  border-radius: 8px;
  background: #fff;
}

.staff-download-list i {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff1f1;
  color: var(--red);
  font-size: 23px;
}

.staff-download-list b,
.staff-download-list small {
  display: block;
}

.staff-download-list b {
  color: var(--ink);
}

.staff-download-list small {
  color: var(--muted);
  font-weight: 700;
}

.staff-download-list em {
  color: var(--blue);
  font-style: normal;
  font-weight: 900;
}

.admin-gallery-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr;
  grid-auto-rows: 230px;
  gap: 14px;
}

.admin-gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: #061e35;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.admin-gallery-item:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow);
}

.admin-gallery-item.big {
  grid-row: span 2;
}

.admin-gallery-item img {
  height: 100%;
  object-fit: contain;
  background: #061e35;
  transition: transform 0.4s ease;
}

.admin-gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent, rgba(6, 30, 53, 0.84));
}

.admin-gallery-item span {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  color: #fff;
  z-index: 1;
  font-size: 18px;
  font-weight: 900;
}

.admin-gallery-item:hover img {
  transform: scale(1.06);
}

.admin-contact-section {
  background: #fff;
}

.admin-contact-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.admin-contact-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.admin-contact-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.admin-contact-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Administration responsive */
@media (max-width: 1280px) {
  .admin-overview-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .staff-section-grid,
  .committee-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .admin-hero-inner,
  .admin-contact-box {
    grid-template-columns: 1fr;
  }

  .admin-hero-card {
    max-width: 520px;
  }

  .admin-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .admin-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .admin-gallery-item.big {
    grid-column: span 2;
    grid-row: span 1;
  }

  .admin-contact-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .admin-page-hero {
    min-height: auto;
  }

  .admin-hero-inner {
    padding: 52px 0;
  }

  .admin-hero-content {
    padding: 18px;
  }

  .admin-hero-content h1 {
    font-size: clamp(36px, 13vw, 56px);
  }

  .admin-hero-content .btn,
  .admin-contact-actions .btn {
    width: 100%;
  }

  .admin-quick-section {
    margin-top: 0;
  }

  .admin-quick-grid,
  .admin-overview-grid,
  .staff-section-grid,
  .committee-grid,
  .admin-gallery-grid {
    grid-template-columns: 1fr;
  }

  .admin-gallery-item.big {
    grid-column: span 1;
  }

  .principal-table-head {
    align-items: stretch;
    flex-direction: column;
  }

  .principal-table-head .btn {
    width: 100%;
  }

  .staff-download-list a {
    grid-template-columns: auto 1fr;
  }

  .staff-download-list em {
    grid-column: 2;
  }

  .admin-contact-box {
    padding: 24px;
  }
}

/* ================= ADMINISTRATION PAGE END ================= */



/* ================= DEPARTMENT PAGES START ================= */

.department-page-hero,
.department-detail-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.department-hero-bg,
.department-detail-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.department-page-hero::after,
.department-detail-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.department-hero-inner,
.department-detail-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.department-hero-content,
.department-detail-content {
  max-width: 840px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.department-hero-content .eyebrow,
.department-detail-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.department-hero-content h1,
.department-detail-content h1 {
  color: #fff;
  font-size: clamp(40px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.department-hero-content p,
.department-detail-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.department-hero-card,
.department-detail-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.department-card-icon,
.department-detail-card > i {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.department-hero-card h3,
.department-detail-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.department-hero-card p,
.department-detail-card p {
  color: var(--text);
  font-weight: 700;
}

.department-detail-card span {
  display: inline-flex;
  margin-top: 10px;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.department-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.department-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.department-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.department-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.department-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.department-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.department-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.department-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.department-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.department-quick-card strong {
  font-size: 16px;
}

.department-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.department-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.department-overview-section,
.department-list-section,
.department-profile-section,
.department-faculty-section,
.department-resource-section,
.department-help-section {
  background: #fff;
}

.soft-bg,
.department-notice-section,
.common-course-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.department-table-wrap {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.department-table-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.department-table-head h3 {
  font-size: 25px;
  margin-bottom: 4px;
}

.department-table-scroll {
  width: 100%;
  overflow-x: auto;
}

.department-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.department-table th,
.department-table td {
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
  text-align: left;
}

.department-table th {
  background: var(--blue-dark);
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
}

.department-table td {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}

.department-table td:nth-child(1) {
  color: var(--blue);
  font-weight: 900;
}

.department-table td:nth-child(2) {
  color: var(--ink);
  font-weight: 900;
}

.department-table td a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 13px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
}

.department-table tbody tr:hover {
  background: #f8fbff;
}

.dept-badge {
  display: inline-flex;
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  background: #fff4df;
  color: #9a620c;
  font-size: 11px;
  font-weight: 900;
}

.dept-badge.pg {
  background: #e9f8f0;
  color: var(--green);
}

.department-card-grid,
.professional-grid,
.common-course-grid,
.faculty-grid,
.resource-grid {
  display: grid;
  gap: 18px;
}

.department-card-grid {
  grid-template-columns: repeat(4, 1fr);
}

.department-subject-card,
.professional-card,
.common-course-card,
.faculty-card,
.resource-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.department-subject-card {
  min-height: 180px;
  padding: 22px;
  display: grid;
  align-content: space-between;
}

.department-subject-card:hover,
.professional-card:hover,
.common-course-card:hover,
.faculty-card:hover,
.resource-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.department-subject-card span {
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.department-subject-card strong {
  color: var(--ink);
  font-size: 20px;
  line-height: 1.2;
}

.department-subject-card small {
  color: var(--muted);
  font-weight: 700;
}

.department-feature-card {
  display: grid;
  grid-template-columns: 1fr 190px;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.department-feature-card h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.department-feature-card p {
  color: rgba(255, 255, 255, 0.78);
}

.department-feature-icon {
  width: 170px;
  height: 170px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.13);
  color: #ffe49d;
  font-size: 74px;
}

.professional-grid {
  grid-template-columns: repeat(4, 1fr);
}

.professional-card {
  min-height: 190px;
  padding: 22px;
  display: grid;
  align-content: center;
}

.professional-card i,
.common-course-card i,
.resource-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 24px;
  margin-bottom: 16px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.professional-card:hover i,
.common-course-card:hover i,
.resource-card:hover i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.professional-card strong,
.common-course-card strong,
.resource-card strong {
  color: var(--ink);
  font-size: 17px;
  line-height: 1.25;
}

.professional-card span,
.resource-card span {
  display: inline-flex;
  width: fit-content;
  margin-top: 10px;
  padding: 6px 9px;
  border-radius: 999px;
  background: #fff4df;
  color: #9a620c;
  font-size: 12px;
  font-weight: 900;
}

.common-course-grid {
  grid-template-columns: repeat(4, 1fr);
}

.common-course-card {
  min-height: 155px;
  padding: 20px;
  display: grid;
  align-content: center;
}

.department-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.department-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.department-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.department-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.faculty-grid {
  grid-template-columns: repeat(3, 1fr);
}

.faculty-card {
  min-height: 250px;
  padding: 24px;
  text-align: center;
}

.faculty-photo {
  width: 96px;
  height: 96px;
  display: grid;
  place-items: center;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: var(--sky);
  color: var(--blue);
  font-size: 46px;
}

.faculty-card h3 {
  font-size: 20px;
  margin-bottom: 4px;
}

.faculty-card p {
  color: var(--blue);
  font-weight: 900;
}

.faculty-card span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  margin-top: 5px;
}

.resource-grid {
  grid-template-columns: repeat(4, 1fr);
}

.resource-card {
  min-height: 180px;
  padding: 22px;
  display: grid;
  align-content: center;
}

/* Department responsive */
@media (max-width: 1280px) {
  .department-card-grid,
  .professional-grid,
  .common-course-grid,
  .resource-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 1024px) {
  .department-hero-inner,
  .department-detail-inner,
  .department-help-box,
  .department-feature-card {
    grid-template-columns: 1fr;
  }

  .department-hero-card,
  .department-detail-card {
    max-width: 520px;
  }

  .department-quick-grid,
  .department-card-grid,
  .professional-grid,
  .common-course-grid,
  .faculty-grid,
  .resource-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .department-feature-icon {
    width: 120px;
    height: 120px;
    font-size: 54px;
  }
}

@media (max-width: 700px) {
  .department-page-hero,
  .department-detail-hero {
    min-height: auto;
  }

  .department-hero-inner,
  .department-detail-inner {
    padding: 52px 0;
  }

  .department-hero-content,
  .department-detail-content {
    padding: 18px;
  }

  .department-hero-content h1,
  .department-detail-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .department-hero-content .btn,
  .department-detail-content .btn,
  .department-help-actions .btn {
    width: 100%;
  }

  .department-quick-section {
    margin-top: 0;
  }

  .department-quick-grid,
  .department-card-grid,
  .professional-grid,
  .common-course-grid,
  .faculty-grid,
  .resource-grid {
    grid-template-columns: 1fr;
  }

  .department-table-head {
    align-items: stretch;
    flex-direction: column;
  }

  .department-feature-card,
  .department-help-box {
    padding: 24px;
  }
}

/* ================= DEPARTMENT PAGES END ================= */


/* ================= STUDENT ZONE PAGES START ================= */

.student-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.student-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.student-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.student-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.student-hero-content {
  max-width: 840px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.student-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.student-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.student-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.student-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.student-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.student-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.student-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.student-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.student-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.student-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.student-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.student-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.student-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.student-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.student-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.student-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.student-quick-card strong {
  font-size: 16px;
}

.student-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.student-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.student-overview-section,
.student-services-section,
.forms-certificates-section,
.student-support-section,
.policy-document-section {
  background: #fff;
}

.student-admission-section,
.reservation-preview-section,
.policy-note-section,
.reservation-detail-section,
.certificate-guideline-section,
.obc-policy-section,
.ews-policy-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.student-service-grid,
.reservation-grid,
.student-form-grid,
.student-support-grid,
.certificate-grid {
  display: grid;
  gap: 18px;
}

.student-service-grid {
  grid-template-columns: repeat(3, 1fr);
}

.student-service-card,
.reservation-card,
.student-form-card,
.student-support-card,
.certificate-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.student-service-card {
  min-height: 260px;
  padding: 24px;
}

.student-service-card:hover,
.reservation-card:hover,
.student-form-card:hover,
.student-support-card:hover,
.certificate-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.student-service-card > i,
.reservation-card > i,
.student-form-card > i,
.student-support-card > i,
.certificate-card > i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.student-service-card:hover > i,
.reservation-card:hover > i,
.student-form-card:hover > i,
.student-support-card:hover > i,
.certificate-card:hover > i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.student-service-card h3,
.reservation-card h3,
.student-support-card h3,
.certificate-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.student-service-card span,
.reservation-card a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 18px;
  color: var(--blue);
  font-weight: 900;
}

.student-admission-card,
.online-service-panel {
  min-height: 360px;
  display: grid;
  align-content: center;
  gap: 14px;
  padding: 30px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.student-admission-card h3,
.online-service-panel h3 {
  color: #fff;
  font-size: 28px;
}

.student-admission-card p,
.online-service-panel p {
  color: rgba(255, 255, 255, 0.78);
}

.reservation-grid {
  grid-template-columns: repeat(3, 1fr);
}

.student-note-box,
.policy-alert {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: start;
  padding: 22px;
  border-radius: 8px;
  border: 1px solid #ead8ad;
  background: #fff8e8;
  color: var(--ink);
  box-shadow: var(--shadow-soft);
  margin-top: 20px;
}

.student-note-box i,
.policy-alert i {
  color: var(--gold);
  font-size: 30px;
}

.policy-alert {
  margin-top: 0;
}

.policy-alert h3 {
  font-size: 23px;
  margin-bottom: 6px;
}

.student-form-grid {
  grid-template-columns: repeat(3, 1fr);
}

.student-form-card {
  min-height: 170px;
  padding: 22px;
  display: grid;
  align-content: center;
}

.student-form-card strong,
.student-form-card span {
  display: block;
}

.student-form-card strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.student-form-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  margin-top: 5px;
}

.student-support-grid {
  grid-template-columns: repeat(4, 1fr);
}

.student-support-card {
  min-height: 230px;
  padding: 24px;
}

.student-help-section {
  background: #fff;
}

.student-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.student-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.student-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.student-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.reservation-percent-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 24px;
}

.reservation-percent-grid.single {
  grid-template-columns: 1fr;
  max-width: 260px;
}

.reservation-percent-grid div {
  padding: 18px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  text-align: center;
}

.reservation-percent-grid strong {
  display: block;
  color: var(--blue);
  font-size: 34px;
  line-height: 1;
}

.reservation-percent-grid span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  margin-top: 8px;
}

.policy-card {
  padding: 28px;
  border-radius: 8px;
  background: var(--blue-dark);
  color: #fff;
  box-shadow: var(--shadow);
}

.policy-card h3 {
  color: #fff;
  font-size: 26px;
  margin-bottom: 16px;
}

.policy-card ul {
  list-style: none;
  display: grid;
  gap: 12px;
}

.policy-card li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: rgba(255, 255, 255, 0.86);
  font-weight: 800;
}

.policy-card li i {
  color: #ffe49d;
}

.certificate-grid {
  grid-template-columns: repeat(4, 1fr);
}

.certificate-card {
  min-height: 220px;
  padding: 24px;
}

.policy-info-box {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px;
  align-items: center;
  padding: 30px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.policy-info-icon {
  width: 76px;
  height: 76px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff8e8;
  color: var(--gold);
  font-size: 38px;
}

.student-doc-list {
  display: grid;
  gap: 10px;
}

.student-doc-list span {
  display: flex;
  align-items: center;
  gap: 9px;
  color: rgba(255, 255, 255, 0.86);
  font-weight: 800;
}

.student-doc-list i {
  color: #ffe49d;
}

/* Student Zone responsive */
@media (max-width: 1280px) {
  .student-service-grid,
  .student-form-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .student-support-grid,
  .certificate-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .student-hero-inner,
  .student-help-box,
  .policy-info-box {
    grid-template-columns: 1fr;
  }

  .student-hero-card {
    max-width: 520px;
  }

  .student-quick-grid,
  .reservation-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .student-help-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .student-page-hero {
    min-height: auto;
  }

  .student-hero-inner {
    padding: 52px 0;
  }

  .student-hero-content {
    padding: 18px;
  }

  .student-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .student-hero-content .btn,
  .student-help-actions .btn {
    width: 100%;
  }

  .student-quick-section {
    margin-top: 0;
  }

  .student-quick-grid,
  .student-service-grid,
  .reservation-grid,
  .student-form-grid,
  .student-support-grid,
  .certificate-grid,
  .reservation-percent-grid {
    grid-template-columns: 1fr;
  }

  .student-note-box,
  .policy-alert {
    grid-template-columns: 1fr;
  }

  .student-admission-card,
  .online-service-panel,
  .student-help-box,
  .policy-info-box,
  .policy-card {
    padding: 24px;
  }
}

/* ================= STUDENT ZONE PAGES END ================= */

/* ================= RESERVATION POLICY SECTION FIX START ================= */

.reservation-preview-section {
  position: relative;
  overflow: hidden;
  padding: 90px 0;
  background:
    radial-gradient(circle at 10% 10%, rgba(18, 63, 140, 0.08), transparent 28%),
    radial-gradient(circle at 90% 80%, rgba(211, 155, 33, 0.12), transparent 30%),
    linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
}

.reservation-preview-section .section-title {
  max-width: 820px;
  margin: 0 auto 42px;
  text-align: center;
}

.reservation-preview-section .section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(18, 63, 140, 0.08);
  color: var(--blue, #123f8c);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.02em;
}

.reservation-preview-section .section-kicker i {
  font-size: 16px;
}

.reservation-preview-section .section-title h2 {
  color: var(--ink, #172033);
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.15;
  margin-bottom: 14px;
}

.reservation-preview-section .section-title p {
  max-width: 720px;
  margin: 0 auto;
  color: var(--text, #4d5b6b);
  font-size: 15px;
  line-height: 1.8;
  font-weight: 600;
}

.reservation-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.reservation-card {
  position: relative;
  overflow: hidden;
  min-height: 310px;
  padding: 30px 26px;
  border: 1px solid rgba(18, 63, 140, 0.12);
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 14px 35px rgba(23, 32, 51, 0.08);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.reservation-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, var(--blue, #123f8c), var(--gold, #d39b21));
}

.reservation-card::after {
  content: "";
  position: absolute;
  right: -45px;
  bottom: -45px;
  width: 130px;
  height: 130px;
  border-radius: 50%;
  background: rgba(18, 63, 140, 0.06);
  transition: transform 0.28s ease;
}

.reservation-card:hover {
  transform: translateY(-8px);
  border-color: rgba(18, 63, 140, 0.28);
  box-shadow: 0 22px 55px rgba(23, 32, 51, 0.14);
}

.reservation-card:hover::after {
  transform: scale(1.18);
}

.reservation-card > i {
  width: 62px;
  height: 62px;
  display: grid;
  place-items: center;
  margin-bottom: 22px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(18, 63, 140, 0.12), rgba(211, 155, 33, 0.12));
  color: var(--blue, #123f8c);
  font-size: 30px;
  transition: transform 0.28s ease, background 0.28s ease, color 0.28s ease;
}

.reservation-card:hover > i {
  transform: rotate(-6deg) scale(1.08);
  background: linear-gradient(135deg, var(--blue, #123f8c), #0b58ad);
  color: #ffffff;
}

.reservation-card h3 {
  position: relative;
  z-index: 1;
  color: var(--ink, #172033);
  font-size: 22px;
  line-height: 1.25;
  margin-bottom: 12px;
}

.reservation-card p {
  position: relative;
  z-index: 1;
  color: var(--text, #4d5b6b);
  font-size: 14.5px;
  line-height: 1.75;
  font-weight: 600;
  margin-bottom: 20px;
}

.reservation-card a {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin-top: auto;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(18, 63, 140, 0.08);
  color: var(--blue, #123f8c);
  font-size: 13px;
  font-weight: 900;
  transition: background 0.25s ease, color 0.25s ease, gap 0.25s ease;
}

.reservation-card a:hover {
  gap: 12px;
  background: var(--blue, #123f8c);
  color: #ffffff;
}

.student-note-box {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: flex-start;
  margin-top: 26px;
  padding: 22px 24px;
  border-radius: 14px;
  border: 1px solid rgba(211, 155, 33, 0.35);
  background: linear-gradient(135deg, #fff9ec, #ffffff);
  box-shadow: 0 14px 35px rgba(23, 32, 51, 0.07);
}

.student-note-box i {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: rgba(211, 155, 33, 0.14);
  color: var(--gold, #d39b21);
  font-size: 24px;
}

.student-note-box p {
  color: var(--ink, #172033);
  font-size: 14.5px;
  line-height: 1.8;
  font-weight: 700;
  margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
  .reservation-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .reservation-card {
    min-height: 280px;
  }
}

@media (max-width: 700px) {
  .reservation-preview-section {
    padding: 60px 0;
  }

  .reservation-grid {
    grid-template-columns: 1fr;
  }

  .reservation-card {
    min-height: auto;
    padding: 24px 20px;
  }

  .student-note-box {
    grid-template-columns: 1fr;
    padding: 20px;
  }

  .student-note-box i {
    width: 44px;
    height: 44px;
    font-size: 22px;
  }
}

/* ================= RESERVATION POLICY SECTION FIX END ================= */


/* ================= EXTENSION ACTIVITY PAGES START ================= */

.extension-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.extension-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.extension-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.extension-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.extension-hero-content {
  max-width: 840px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.extension-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.extension-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.extension-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.extension-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.extension-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.extension-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.extension-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.extension-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.extension-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.extension-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.extension-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.extension-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.extension-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.extension-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.extension-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.extension-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.extension-quick-card strong {
  font-size: 16px;
}

.extension-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.extension-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.extension-overview-section,
.extension-units-section,
.nss-benefits-section,
.nss-activities-section,
.program-officers-section {
  background: #fff;
}

.nss-preview-section,
.activity-events-section,
.nss-mission-section,
.nss-objectives-section,
.nss-join-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.extension-unit-grid,
.activity-event-grid,
.objective-grid,
.benefit-grid,
.officer-grid {
  display: grid;
  gap: 18px;
}

.extension-unit-grid {
  grid-template-columns: repeat(4, 1fr);
}

.extension-unit-card,
.activity-event-card,
.objective-card,
.benefit-card,
.officer-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.extension-unit-card {
  min-height: 270px;
  padding: 24px;
}

.extension-unit-card:hover,
.activity-event-card:hover,
.objective-card:hover,
.benefit-card:hover,
.officer-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.extension-unit-card > i,
.activity-event-card > i,
.objective-card > i,
.benefit-card > i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.extension-unit-card:hover > i,
.activity-event-card:hover > i,
.objective-card:hover > i,
.benefit-card:hover > i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.extension-unit-card h3,
.activity-event-card h3,
.objective-card h3,
.benefit-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.extension-unit-card span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 18px;
  color: var(--blue);
  font-weight: 900;
}

.extension-feature-card {
  padding: 28px;
  border-radius: 8px;
  background: var(--blue-dark);
  color: #fff;
  box-shadow: var(--shadow);
}

.extension-feature-card h3 {
  color: #fff;
  font-size: 28px;
  margin-bottom: 18px;
}

.officer-list {
  display: grid;
  gap: 12px;
  margin-bottom: 20px;
}

.officer-list div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
}

.officer-list i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.15);
  color: #ffe49d;
  font-size: 22px;
}

.officer-list b,
.officer-list small {
  display: block;
}

.officer-list b {
  color: #fff;
}

.officer-list small {
  color: rgba(255, 255, 255, 0.75);
}

.activity-event-grid,
.objective-grid {
  grid-template-columns: repeat(4, 1fr);
}

.activity-event-card,
.objective-card,
.benefit-card {
  min-height: 220px;
  padding: 24px;
}

.benefit-grid {
  grid-template-columns: repeat(4, 1fr);
}

.mission-points {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 22px;
}

.mission-points div {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  color: var(--ink);
  font-weight: 900;
}

.mission-points i {
  color: var(--blue);
  font-size: 22px;
}

.motto-box {
  padding: 22px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
}

.motto-box strong {
  display: block;
  color: #ffe49d;
  font-size: 28px;
  line-height: 1.2;
  margin-bottom: 10px;
}

.motto-box p {
  color: rgba(255, 255, 255, 0.78);
}

.officer-grid {
  grid-template-columns: repeat(2, 1fr);
  max-width: 820px;
  margin: 0 auto;
}

.officer-card {
  padding: 28px;
  text-align: center;
}

.officer-avatar {
  width: 96px;
  height: 96px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: var(--sky);
  color: var(--blue);
  font-size: 48px;
}

.officer-card h3 {
  font-size: 22px;
  margin-bottom: 5px;
}

.officer-card p {
  color: var(--blue);
  font-weight: 900;
}

.officer-card a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding: 10px 13px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
}

.extension-help-section {
  background: #fff;
}

.extension-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.extension-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.extension-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.extension-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 1280px) {
  .extension-unit-grid,
  .activity-event-grid,
  .objective-grid,
  .benefit-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .extension-hero-inner,
  .extension-help-box {
    grid-template-columns: 1fr;
  }

  .extension-hero-card {
    max-width: 520px;
  }

  .extension-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .extension-help-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .extension-page-hero {
    min-height: auto;
  }

  .extension-hero-inner {
    padding: 52px 0;
  }

  .extension-hero-content {
    padding: 18px;
  }

  .extension-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .extension-hero-content .btn,
  .extension-help-actions .btn {
    width: 100%;
  }

  .extension-quick-section {
    margin-top: 0;
  }

  .extension-quick-grid,
  .extension-unit-grid,
  .activity-event-grid,
  .objective-grid,
  .benefit-grid,
  .officer-grid,
  .mission-points {
    grid-template-columns: 1fr;
  }

  .extension-help-box,
  .extension-feature-card {
    padding: 24px;
  }
}

/* ================= EXTENSION ACTIVITY PAGES END ================= */


/* ================= IQAC PAGES START ================= */

.iqac-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.iqac-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.iqac-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.iqac-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.iqac-hero-content {
  max-width: 850px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.iqac-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.iqac-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.iqac-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.iqac-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.iqac-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.iqac-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.iqac-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.iqac-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.iqac-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.iqac-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.iqac-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.iqac-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.iqac-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.iqac-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.iqac-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.iqac-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.iqac-quick-card strong {
  font-size: 16px;
}

.iqac-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.iqac-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.iqac-intro-section,
.iqac-members-preview-section,
.iqac-policy-preview-section,
.iqac-members-section,
.iqac-feedback-section,
.iqac-document-list-section {
  background: #fff;
}

.iqac-purpose-section,
.iqac-reports-preview-section,
.iqac-stakeholder-section,
.iqac-objectives-section,
.iqac-mechanism-section,
.iqac-survey-process-section,
.soft-bg {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.iqac-purpose-grid,
.iqac-policy-grid,
.iqac-document-grid,
.iqac-objective-grid,
.iqac-doc-grid {
  display: grid;
  gap: 18px;
}

.iqac-purpose-grid,
.iqac-document-grid {
  grid-template-columns: repeat(4, 1fr);
}

.iqac-policy-grid {
  grid-template-columns: repeat(3, 1fr);
}

.iqac-objective-grid {
  grid-template-columns: repeat(3, 1fr);
}

.iqac-purpose-card,
.iqac-policy-card,
.iqac-document-card,
.iqac-objective-card,
.iqac-report-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.iqac-purpose-card,
.iqac-policy-card,
.iqac-document-card,
.iqac-objective-card,
.iqac-report-card {
  min-height: 230px;
  padding: 24px;
}

.iqac-purpose-card:hover,
.iqac-policy-card:hover,
.iqac-document-card:hover,
.iqac-objective-card:hover,
.iqac-report-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.iqac-purpose-card > i,
.iqac-policy-card > i,
.iqac-document-card > i,
.iqac-objective-card > i,
.iqac-report-card > i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.iqac-purpose-card:hover > i,
.iqac-policy-card:hover > i,
.iqac-document-card:hover > i,
.iqac-objective-card:hover > i,
.iqac-report-card:hover > i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.iqac-purpose-card h3,
.iqac-policy-card h3,
.iqac-objective-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.iqac-document-card strong,
.iqac-document-card span,
.iqac-report-card strong,
.iqac-report-card span {
  display: block;
}

.iqac-document-card strong,
.iqac-report-card strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.iqac-document-card span,
.iqac-report-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  margin-top: 6px;
}

.iqac-feature-card {
  padding: 28px;
  border-radius: 8px;
  background: var(--blue-dark);
  color: #fff;
  box-shadow: var(--shadow);
}

.iqac-feature-card h3 {
  color: #fff;
  font-size: 28px;
  margin-bottom: 18px;
}

.iqac-person-list {
  display: grid;
  gap: 12px;
  margin-bottom: 20px;
}

.iqac-person-list div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
}

.iqac-person-list i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.15);
  color: #ffe49d;
  font-size: 22px;
}

.iqac-person-list b,
.iqac-person-list small {
  display: block;
}

.iqac-person-list b {
  color: #fff;
}

.iqac-person-list small {
  color: rgba(255, 255, 255, 0.75);
}

.iqac-table-wrap {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.iqac-table-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.iqac-table-head h3 {
  font-size: 25px;
  margin-bottom: 4px;
}

.iqac-table-scroll {
  width: 100%;
  overflow-x: auto;
}

.iqac-table {
  width: 100%;
  min-width: 880px;
  border-collapse: collapse;
}

.iqac-table th,
.iqac-table td {
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

.iqac-table th {
  background: var(--blue-dark);
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
}

.iqac-table td {
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.iqac-table td:nth-child(1) {
  color: var(--blue);
  font-weight: 900;
}

.iqac-table td:nth-child(2) {
  color: var(--ink);
  font-weight: 900;
}

.iqac-table tbody tr:hover {
  background: #f8fbff;
}

.iqac-table td a {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.iqac-role {
  display: inline-flex;
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
  background: var(--sky);
  color: var(--blue);
}

.iqac-role.chairman {
  background: #fff4df;
  color: #9a620c;
}

.iqac-role.coordinator {
  background: #e9f8f0;
  color: var(--green);
}

.iqac-role.advisor {
  background: #f1ecff;
  color: #6b3fc8;
}

.iqac-role.teacher {
  background: var(--sky);
  color: var(--blue);
}

.iqac-role.admin {
  background: #fff1f1;
  color: var(--red);
}

.iqac-role.university,
.iqac-role.society,
.iqac-role.alumni,
.iqac-role.student {
  background: #f4f6fb;
  color: var(--ink);
}

.iqac-doc-list {
  display: grid;
}

.iqac-doc-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 18px 24px;
  border-bottom: 1px solid var(--line);
  transition: background 0.2s ease;
}

.iqac-doc-list a:hover {
  background: #f8fbff;
}

.iqac-doc-list a:last-child {
  border-bottom: none;
}

.iqac-doc-list i {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff1f1;
  color: var(--red);
  font-size: 24px;
}

.iqac-doc-list b,
.iqac-doc-list small {
  display: block;
}

.iqac-doc-list b {
  color: var(--ink);
}

.iqac-doc-list small {
  color: var(--muted);
  font-weight: 700;
}

.iqac-doc-list em {
  color: var(--blue);
  font-style: normal;
  font-weight: 900;
}

.iqac-doc-grid {
  grid-template-columns: repeat(3, 1fr);
}

.iqac-help-section {
  background: #fff;
}

.iqac-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.iqac-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.iqac-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.iqac-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 1280px) {
  .iqac-purpose-grid,
  .iqac-document-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .iqac-policy-grid,
  .iqac-objective-grid,
  .iqac-doc-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .iqac-hero-inner,
  .iqac-help-box {
    grid-template-columns: 1fr;
  }

  .iqac-hero-card {
    max-width: 520px;
  }

  .iqac-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .iqac-help-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .iqac-page-hero {
    min-height: auto;
  }

  .iqac-hero-inner {
    padding: 52px 0;
  }

  .iqac-hero-content {
    padding: 18px;
  }

  .iqac-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .iqac-hero-content .btn,
  .iqac-help-actions .btn {
    width: 100%;
  }

  .iqac-quick-section {
    margin-top: 0;
  }

  .iqac-quick-grid,
  .iqac-purpose-grid,
  .iqac-policy-grid,
  .iqac-document-grid,
  .iqac-objective-grid,
  .iqac-doc-grid {
    grid-template-columns: 1fr;
  }

  .iqac-table-head {
    align-items: stretch;
    flex-direction: column;
  }

  .iqac-table-head .btn {
    width: 100%;
  }

  .iqac-doc-list a {
    grid-template-columns: auto 1fr;
  }

  .iqac-doc-list em {
    grid-column: 2;
  }

  .iqac-help-box,
  .iqac-feature-card {
    padding: 24px;
  }
}

/* ================= IQAC PAGES END ================= */


/* ================= NIRF PAGES START ================= */

.nirf-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.nirf-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.nirf-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.nirf-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.nirf-hero-content {
  max-width: 850px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.nirf-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.nirf-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.nirf-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.nirf-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.nirf-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.nirf-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.nirf-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.nirf-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.nirf-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.nirf-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.nirf-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.nirf-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.nirf-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.nirf-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.nirf-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.nirf-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.nirf-quick-card strong {
  font-size: 16px;
}

.nirf-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.nirf-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.nirf-overview-section,
.nirf-reports-section,
.nirf-links-section,
.nirf-data-section {
  background: #fff;
}

.nirf-parameters-section,
.nirf-outcome-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.nirf-table-wrap {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.nirf-table-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.nirf-table-head h3 {
  font-size: 25px;
  margin-bottom: 4px;
}

.nirf-table-scroll {
  width: 100%;
  overflow-x: auto;
}

.nirf-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}

.nirf-table th,
.nirf-table td {
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

.nirf-table th {
  background: var(--blue-dark);
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
}

.nirf-table td {
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.nirf-table td:nth-child(1) {
  color: var(--blue);
  font-weight: 900;
}

.nirf-table td:nth-child(2) {
  color: var(--ink);
  font-weight: 900;
}

.nirf-table tbody tr:hover {
  background: #f8fbff;
}

.nirf-badge {
  display: inline-flex;
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  background: #e9f8f0;
  color: var(--green);
  font-size: 11px;
  font-weight: 900;
}

.nirf-badge.muted {
  background: #f4f6fb;
  color: var(--ink);
}

.nirf-action {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.nirf-action.download {
  background: #fff4df;
  color: #9a620c;
}

.nirf-action.view {
  background: var(--sky);
  color: var(--blue);
}

.nirf-empty-note {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  padding: 18px 24px;
  background: #fff8e8;
  border-top: 1px solid #ead8ad;
}

.nirf-empty-note i {
  color: var(--gold);
  font-size: 26px;
}

.nirf-empty-note p {
  margin: 0;
  color: var(--ink);
  font-weight: 700;
  line-height: 1.7;
}

.nirf-parameter-grid,
.nirf-related-grid,
.nirf-profile-grid {
  display: grid;
  gap: 18px;
}

.nirf-parameter-grid {
  grid-template-columns: repeat(3, 1fr);
}

.nirf-related-grid,
.nirf-profile-grid {
  grid-template-columns: repeat(3, 1fr);
}

.nirf-parameter-card,
.nirf-related-card,
.nirf-profile-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.nirf-parameter-card,
.nirf-related-card {
  min-height: 230px;
  padding: 24px;
}

.nirf-parameter-card:hover,
.nirf-related-card:hover,
.nirf-profile-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.nirf-parameter-card > i,
.nirf-related-card > i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.nirf-parameter-card:hover > i,
.nirf-related-card:hover > i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.nirf-parameter-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.nirf-related-card strong,
.nirf-related-card span {
  display: block;
}

.nirf-related-card strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.nirf-related-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  margin-top: 6px;
}

.nirf-feature-card {
  padding: 28px;
  border-radius: 8px;
  background: var(--blue-dark);
  color: #fff;
  box-shadow: var(--shadow);
}

.nirf-feature-card h3 {
  color: #fff;
  font-size: 28px;
  margin-bottom: 18px;
}

.nirf-list-box {
  display: grid;
  gap: 12px;
  margin-bottom: 20px;
}

.nirf-list-box div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
}

.nirf-list-box i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.15);
  color: #ffe49d;
  font-size: 22px;
}

.nirf-list-box b,
.nirf-list-box small {
  display: block;
}

.nirf-list-box b {
  color: #fff;
}

.nirf-list-box small {
  color: rgba(255, 255, 255, 0.75);
}

.nirf-profile-card {
  min-height: 150px;
  padding: 24px;
  display: grid;
  align-content: center;
  gap: 8px;
}

.nirf-profile-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.nirf-profile-card strong {
  color: var(--ink);
  font-size: 19px;
  line-height: 1.35;
}

.nirf-help-section {
  background: #fff;
}

.nirf-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.nirf-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.nirf-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.nirf-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 1280px) {
  .nirf-parameter-grid,
  .nirf-related-grid,
  .nirf-profile-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .nirf-hero-inner,
  .nirf-help-box {
    grid-template-columns: 1fr;
  }

  .nirf-hero-card {
    max-width: 520px;
  }

  .nirf-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .nirf-help-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .nirf-page-hero {
    min-height: auto;
  }

  .nirf-hero-inner {
    padding: 52px 0;
  }

  .nirf-hero-content {
    padding: 18px;
  }

  .nirf-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .nirf-hero-content .btn,
  .nirf-help-actions .btn {
    width: 100%;
  }

  .nirf-quick-section {
    margin-top: 0;
  }

  .nirf-quick-grid,
  .nirf-parameter-grid,
  .nirf-related-grid,
  .nirf-profile-grid {
    grid-template-columns: 1fr;
  }

  .nirf-table-head {
    align-items: stretch;
    flex-direction: column;
  }

  .nirf-table-head .btn {
    width: 100%;
  }

  .nirf-empty-note {
    grid-template-columns: 1fr;
  }

  .nirf-help-box,
  .nirf-feature-card {
    padding: 24px;
  }
}

/* ================= NIRF PAGES END ================= */

/* ================= NOTICE PAGES START ================= */

.notice-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.notice-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.notice-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.notice-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.notice-hero-content {
  max-width: 850px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.notice-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.notice-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.notice-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.notice-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.notice-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.notice-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.notice-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.notice-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.notice-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.notice-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.notice-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.notice-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.notice-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.notice-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.notice-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.notice-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.notice-quick-card strong {
  font-size: 16px;
}

.notice-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.notice-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.notice-overview-section,
.notice-list-section,
.notice-help-section,
.notice-detail-section {
  background: #fff;
}

.notice-filter-section,
.notice-category-section,
.event-list-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.notice-filter-box {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 24px;
  align-items: end;
  padding: 28px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.notice-filter-form {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.8fr auto;
  gap: 14px;
  align-items: end;
}

.notice-filter-form label {
  display: grid;
  gap: 7px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}

.notice-filter-form input,
.notice-filter-form select {
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  outline: none;
  color: var(--ink);
  background: #fff;
}

.notice-filter-form input:focus,
.notice-filter-form select:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(18, 63, 140, 0.08);
}

.notice-table-wrap {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.notice-table-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.notice-table-head h3 {
  font-size: 25px;
  margin-bottom: 4px;
}

.notice-table-scroll {
  width: 100%;
  overflow-x: auto;
}

.notice-table {
  width: 100%;
  min-width: 1100px;
  border-collapse: collapse;
}

.notice-table th,
.notice-table td {
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

.notice-table th {
  background: var(--blue-dark);
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
  white-space: nowrap;
}

.notice-table td {
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.notice-table td:nth-child(1) {
  color: var(--blue);
  font-weight: 900;
}

.notice-table td:nth-child(2) {
  min-width: 260px;
  color: var(--ink);
  font-weight: 900;
}

.notice-table td:nth-child(3) {
  min-width: 360px;
  line-height: 1.65;
}

.notice-table tbody tr:hover {
  background: #f8fbff;
}

.notice-date,
.notice-expire {
  display: inline-flex;
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  background: #e9f8f0;
  color: var(--green);
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.notice-expire {
  background: #fff4df;
  color: #9a620c;
}

.notice-expire.danger {
  background: #fff1f1;
  color: var(--red);
}

.notice-action {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.notice-action.download {
  background: #fff4df;
  color: #9a620c;
}

.notice-action.view {
  background: var(--sky);
  color: var(--blue);
}

.notice-category-grid,
.event-grid {
  display: grid;
  gap: 18px;
}

.notice-category-grid {
  grid-template-columns: repeat(3, 1fr);
}

.notice-category-card {
  min-height: 220px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.notice-category-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.notice-category-card i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  margin-bottom: 18px;
}

.notice-category-card strong,
.notice-category-card span {
  display: block;
}

.notice-category-card strong {
  color: var(--ink);
  font-size: 19px;
  line-height: 1.25;
}

.notice-category-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  margin-top: 7px;
}

.event-grid {
  grid-template-columns: repeat(2, 1fr);
}

.event-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  min-height: 180px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.event-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow);
}

.event-date {
  width: 86px;
  height: 86px;
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 8px;
  background: var(--blue);
  color: #fff;
  text-align: center;
}

.event-date strong {
  font-size: 30px;
  line-height: 1;
}

.event-date span {
  font-size: 11px;
  font-weight: 900;
}

.event-card h3 {
  font-size: 21px;
  margin-bottom: 8px;
}

.event-card p {
  color: var(--text);
  line-height: 1.7;
}

.event-card a {
  display: inline-flex;
  gap: 7px;
  align-items: center;
  margin-top: 12px;
  color: var(--blue);
  font-weight: 900;
}

.notice-empty-note {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  padding: 18px 24px;
  background: #fff8e8;
  border-top: 1px solid #ead8ad;
}

.notice-empty-note i {
  color: var(--gold);
  font-size: 26px;
}

.notice-empty-note p {
  margin: 0;
  color: var(--ink);
  font-weight: 700;
  line-height: 1.7;
}

.notice-detail-layout {
  display: grid;
  grid-template-columns: 1fr 330px;
  gap: 24px;
  align-items: start;
}

.notice-detail-card,
.notice-side-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.notice-detail-head {
  padding: 28px;
  border-bottom: 1px solid var(--line);
}

.notice-type {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 12px;
  padding: 7px 11px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.notice-detail-head h2 {
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.15;
  margin-bottom: 14px;
}

.notice-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.notice-meta span {
  display: inline-flex;
  gap: 7px;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: #f4f6fb;
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
}

.notice-detail-body {
  padding: 28px;
}

.notice-detail-body p,
.notice-detail-body li {
  color: var(--text);
  line-height: 1.8;
  font-weight: 600;
}

.notice-detail-body h3 {
  margin: 22px 0 12px;
  font-size: 24px;
}

.notice-detail-body ul {
  padding-left: 20px;
}

.notice-document-box {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  margin-top: 24px;
  padding: 18px;
  border-radius: 8px;
  background: #f8fbff;
  border: 1px solid var(--line);
}

.notice-document-box > i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff1f1;
  color: var(--red);
  font-size: 26px;
}

.notice-document-box strong,
.notice-document-box span {
  display: block;
}

.notice-document-box strong {
  color: var(--ink);
}

.notice-document-box span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.notice-side-panel {
  padding: 22px;
  position: sticky;
  top: 110px;
}

.notice-side-panel h3 {
  font-size: 22px;
  margin-bottom: 16px;
}

.notice-side-panel a {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font-weight: 900;
}

.notice-side-panel a:last-child {
  border-bottom: none;
}

.notice-side-panel span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.notice-side-panel i {
  color: var(--blue);
}

.notice-help-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.notice-help-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.notice-help-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.notice-help-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 1280px) {
  .notice-category-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .notice-filter-box {
    grid-template-columns: 1fr;
  }

  .notice-filter-form {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .notice-hero-inner,
  .notice-help-box,
  .notice-detail-layout {
    grid-template-columns: 1fr;
  }

  .notice-hero-card {
    max-width: 520px;
  }

  .notice-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .notice-side-panel {
    position: static;
  }

  .event-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .notice-page-hero {
    min-height: auto;
  }

  .notice-hero-inner {
    padding: 52px 0;
  }

  .notice-hero-content {
    padding: 18px;
  }

  .notice-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .notice-hero-content .btn,
  .notice-help-actions .btn,
  .notice-document-box .btn {
    width: 100%;
  }

  .notice-quick-section {
    margin-top: 0;
  }

  .notice-quick-grid,
  .notice-category-grid,
  .notice-filter-form {
    grid-template-columns: 1fr;
  }

  .notice-table-head {
    align-items: stretch;
    flex-direction: column;
  }

  .notice-table-head .btn {
    width: 100%;
  }

  .event-card,
  .notice-document-box,
  .notice-empty-note {
    grid-template-columns: 1fr;
  }

  .notice-detail-head,
  .notice-detail-body,
  .notice-help-box {
    padding: 24px;
  }
}

/* ================= NOTICE PAGES END ================= */

/* ================= FEEDBACK PAGES START ================= */

.feedback-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.feedback-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.feedback-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.feedback-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.feedback-hero-content {
  max-width: 850px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.feedback-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.feedback-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.feedback-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.feedback-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.feedback-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.feedback-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.feedback-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.feedback-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.feedback-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.feedback-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.feedback-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.feedback-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.feedback-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.feedback-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.feedback-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.feedback-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.feedback-quick-card strong {
  font-size: 16px;
}

.feedback-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.feedback-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.feedback-overview-section,
.student-feedback-form-section {
  background: #fff;
}

.feedback-section-overview {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.feedback-area-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.feedback-area-card {
  min-height: 230px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.feedback-area-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.feedback-area-card i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.feedback-area-card:hover i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.feedback-area-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}

.student-feedback-form {
  display: grid;
  gap: 24px;
}

.feedback-form-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.feedback-form-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  padding: 22px 24px;
  background: linear-gradient(135deg, var(--blue-dark), var(--blue));
  color: #fff;
}

.feedback-form-head i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffe49d;
  font-size: 26px;
}

.feedback-form-head h3 {
  color: #fff;
  font-size: 24px;
  margin-bottom: 3px;
}

.feedback-form-head p {
  color: rgba(255, 255, 255, 0.78);
  margin: 0;
}

.feedback-form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  padding: 24px;
}

.feedback-form-grid label,
.feedback-question label {
  display: grid;
  gap: 8px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 900;
}

.feedback-form-grid label.wide {
  grid-column: 1 / -1;
}

.feedback-form-grid input,
.feedback-form-grid select,
.feedback-question select {
  width: 100%;
  min-height: 48px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  outline: none;
  background: #fff;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.feedback-form-grid input:focus,
.feedback-form-grid select:focus,
.feedback-question select:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(18, 63, 140, 0.08);
}

.feedback-question-list {
  display: grid;
  gap: 1px;
  padding: 0;
  background: var(--line);
}

.feedback-question {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 18px;
  align-items: center;
  padding: 20px 24px;
  background: #fff;
}

.feedback-question label {
  line-height: 1.6;
}

.feedback-submit-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 26px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.feedback-submit-box h3 {
  color: #fff;
  font-size: 26px;
  margin-bottom: 4px;
}

.feedback-submit-box p {
  color: rgba(255, 255, 255, 0.78);
  margin: 0;
}

/* Responsive */
@media (max-width: 1280px) {
  .feedback-area-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .feedback-question {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1024px) {
  .feedback-hero-inner {
    grid-template-columns: 1fr;
  }

  .feedback-hero-card {
    max-width: 520px;
  }

  .feedback-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .feedback-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .feedback-page-hero {
    min-height: auto;
  }

  .feedback-hero-inner {
    padding: 52px 0;
  }

  .feedback-hero-content {
    padding: 18px;
  }

  .feedback-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .feedback-hero-content .btn,
  .feedback-submit-box .btn {
    width: 100%;
  }

  .feedback-quick-section {
    margin-top: 0;
  }

  .feedback-quick-grid,
  .feedback-area-grid {
    grid-template-columns: 1fr;
  }

  .feedback-form-head {
    grid-template-columns: 1fr;
  }

  .feedback-submit-box {
    flex-direction: column;
    align-items: stretch;
    padding: 24px;
  }
}


/* ================= FEEDBACK EXTRA PAGES START ================= */

.feedback-textarea {
  width: 100%;
  min-height: 120px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  outline: none;
  resize: vertical;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
}

.feedback-textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(18, 63, 140, 0.08);
}

.feedback-stat-section,
.feedback-report-section {
  background: #fff;
}

.feedback-action-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.feedback-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.feedback-stat-card {
  min-height: 220px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.feedback-stat-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.feedback-stat-card i {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 28px;
}

.feedback-stat-card strong {
  display: block;
  color: var(--ink);
  font-size: 15px;
  margin-bottom: 12px;
}

.feedback-stat-card h3 {
  color: var(--blue);
  font-size: 42px;
  line-height: 1;
  margin-bottom: 10px;
}

.feedback-stat-card p {
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}

.feedback-report-table-wrap {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.feedback-report-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border-bottom: 1px solid var(--line);
}

.feedback-report-head h3 {
  font-size: 25px;
  margin-bottom: 4px;
}

.feedback-table-scroll {
  width: 100%;
  overflow-x: auto;
}

.feedback-report-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}

.feedback-report-table th,
.feedback-report-table td {
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

.feedback-report-table th {
  background: var(--blue-dark);
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
}

.feedback-report-table td {
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.feedback-report-table td:nth-child(1) {
  color: var(--blue);
  font-weight: 900;
}

.feedback-report-table td:nth-child(2) {
  color: var(--ink);
  font-weight: 900;
}

.feedback-report-table tbody tr:hover {
  background: #f8fbff;
}

.feedback-action {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.feedback-action.download {
  background: #fff4df;
  color: #9a620c;
}

.feedback-action.view {
  background: var(--sky);
  color: var(--blue);
}

.feedback-action-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.94), rgba(18, 63, 140, 0.86)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.feedback-action-box h2 {
  color: #fff;
  margin: 12px 0 8px;
}

.feedback-action-box p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.78);
}

.feedback-action-links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 1280px) {
  .feedback-stat-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .feedback-action-box {
    grid-template-columns: 1fr;
  }

  .feedback-action-links {
    justify-content: flex-start;
  }
}

@media (max-width: 700px) {
  .feedback-stat-grid {
    grid-template-columns: 1fr;
  }

  .feedback-report-head {
    flex-direction: column;
    align-items: stretch;
  }

  .feedback-report-head .btn,
  .feedback-action-links .btn {
    width: 100%;
  }

  .feedback-action-box {
    padding: 24px;
  }
}

/* ================= FEEDBACK EXTRA PAGES END ================= */
/* ================= FEEDBACK PAGES END ================= */


/* ================= CONTACT PAGE START ================= */

.contact-page-hero {
  position: relative;
  isolation: isolate;
  min-height: 520px;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #061f48;
}

.contact-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(3, 18, 44, 0.94), rgba(8, 43, 98, 0.86), rgba(18, 63, 140, 0.52)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  animation: heroZoom 20s ease-in-out infinite alternate;
}

.contact-page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 25%, rgba(211, 155, 33, 0.28), transparent 30%),
    linear-gradient(180deg, rgba(3, 18, 44, 0.08), rgba(3, 18, 44, 0.72));
}

.contact-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 34px;
  align-items: center;
  padding: 70px 0;
}

.contact-hero-content {
  max-width: 850px;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(5, 33, 80, 0.76), rgba(5, 33, 80, 0.46));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(12px);
}

.contact-hero-content .eyebrow {
  color: #fff;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.contact-hero-content h1 {
  color: #fff;
  font-size: clamp(38px, 5.8vw, 74px);
  line-height: 1.02;
  margin: 18px 0;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.38);
}

.contact-hero-content p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 600;
}

.contact-hero-card {
  padding: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(12px);
}

.contact-card-icon {
  width: 88px;
  height: 88px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 42px;
}

.contact-hero-card h3 {
  color: var(--blue-dark);
  font-size: 25px;
  margin-bottom: 8px;
}

.contact-hero-card p {
  color: var(--text);
  font-weight: 700;
}

.contact-hero-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.contact-hero-pills span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--sky);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.contact-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.contact-quick-section {
  margin-top: -46px;
  position: relative;
  z-index: 6;
}

.contact-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--line);
  box-shadow: var(--shadow);
}

.contact-quick-card {
  min-height: 160px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  padding: 22px 16px;
  text-align: center;
  background: #fff;
  color: var(--ink);
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.contact-quick-card:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, var(--blue), #0b58ad);
  color: #fff;
}

.contact-quick-card i {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 25px;
}

.contact-quick-card:hover i {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.contact-quick-card strong {
  font-size: 16px;
}

.contact-quick-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  word-break: break-word;
}

.contact-quick-card:hover span {
  color: rgba(255, 255, 255, 0.78);
}

.contact-info-section,
.contact-map-section {
  background: #fff;
}

.contact-form-section,
.contact-related-section {
  background: linear-gradient(180deg, #f8fbff, #eef5fb);
}

.contact-info-layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 34px;
  align-items: start;
}

.contact-info-left h2 {
  font-size: clamp(30px, 3vw, 48px);
  margin: 14px 0;
}

.contact-info-left > p {
  max-width: 780px;
  color: var(--text);
  font-weight: 600;
  line-height: 1.8;
}

.contact-detail-list {
  display: grid;
  gap: 14px;
  margin-top: 24px;
}

.contact-detail-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.contact-detail-item > i {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 24px;
}

.contact-detail-item strong,
.contact-detail-item span {
  display: block;
}

.contact-detail-item strong {
  color: var(--ink);
  font-size: 16px;
  margin-bottom: 5px;
}

.contact-detail-item span,
.contact-detail-item a {
  color: var(--text);
  font-weight: 700;
  line-height: 1.6;
}

.contact-detail-item a:hover {
  color: var(--blue);
}

.contact-info-card {
  position: sticky;
  top: 110px;
}

.contact-office-card {
  padding: 28px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(8, 43, 98, 0.96), rgba(18, 63, 140, 0.88)),
    url("../img/bdcpat_img_001.jpg") center/cover;
  color: #fff;
  box-shadow: var(--shadow);
}

.contact-office-card > i {
  width: 68px;
  height: 68px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffe49d;
  font-size: 34px;
}

.contact-office-card h3 {
  color: #fff;
  font-size: 28px;
  margin-bottom: 10px;
}

.contact-office-card p {
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.75;
}

.office-timing-box {
  margin: 20px 0;
  padding: 16px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.12);
}

.office-timing-box span,
.office-timing-box strong {
  display: block;
}

.office-timing-box span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.office-timing-box strong {
  color: #fff;
  font-size: 22px;
  margin-top: 5px;
}

.contact-form-layout {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 34px;
  align-items: start;
}

.contact-form-content h2 {
  font-size: clamp(30px, 3vw, 48px);
  margin: 14px 0;
}

.contact-form-content p {
  color: var(--text);
  font-weight: 600;
  line-height: 1.8;
}

.contact-form-points {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.contact-form-points span {
  display: flex;
  align-items: center;
  gap: 9px;
  color: var(--ink);
  font-weight: 900;
}

.contact-form-points i {
  color: var(--green);
}

.contact-enquiry-form {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.contact-form-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  padding: 22px 24px;
  background: linear-gradient(135deg, var(--blue-dark), var(--blue));
  color: #fff;
}

.contact-form-head i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffe49d;
  font-size: 26px;
}

.contact-form-head h3 {
  color: #fff;
  font-size: 24px;
  margin-bottom: 3px;
}

.contact-form-head p {
  color: rgba(255, 255, 255, 0.78);
  margin: 0;
}

.contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  padding: 24px;
}

.contact-form-grid label {
  display: grid;
  gap: 8px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 900;
}

.contact-form-grid label.wide {
  grid-column: 1 / -1;
}

.contact-form-grid input,
.contact-form-grid select,
.contact-form-grid textarea {
  width: 100%;
  min-height: 48px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  outline: none;
  background: #fff;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.contact-form-grid textarea {
  min-height: 130px;
  padding: 14px;
  resize: vertical;
}

.contact-form-grid input:focus,
.contact-form-grid select:focus,
.contact-form-grid textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(18, 63, 140, 0.08);
}

.contact-enquiry-form > .btn {
  margin: 0 24px 24px;
}

.contact-map-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 24px;
  align-items: stretch;
}

.map-box {
  min-height: 460px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.map-box iframe {
  width: 100%;
  height: 100%;
  min-height: 460px;
  border: 0;
  display: block;
}

.map-side-card {
  padding: 28px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.map-side-card > i {
  width: 62px;
  height: 62px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 32px;
}

.map-side-card h3 {
  font-size: 27px;
  margin-bottom: 10px;
}

.map-side-card p {
  color: var(--text);
  line-height: 1.8;
  font-weight: 700;
  margin-bottom: 20px;
}

.contact-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.contact-related-card {
  min-height: 220px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.contact-related-card:hover {
  transform: translateY(-8px);
  border-color: #aac7e6;
  box-shadow: var(--shadow);
}

.contact-related-card > i {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 8px;
  background: var(--sky);
  color: var(--blue);
  font-size: 26px;
  transition: transform 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.contact-related-card:hover > i {
  transform: rotate(-5deg) scale(1.06);
  background: var(--blue);
  color: #fff;
}

.contact-related-card strong,
.contact-related-card span {
  display: block;
}

.contact-related-card strong {
  color: var(--ink);
  font-size: 19px;
  line-height: 1.25;
}

.contact-related-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  margin-top: 7px;
}

/* Responsive */
@media (max-width: 1280px) {
  .contact-related-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .contact-info-layout,
  .contact-form-layout,
  .contact-map-layout {
    grid-template-columns: 1fr;
  }

  .contact-info-card {
    position: static;
  }
}

@media (max-width: 1024px) {
  .contact-hero-inner {
    grid-template-columns: 1fr;
  }

  .contact-hero-card {
    max-width: 520px;
  }

  .contact-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 700px) {
  .contact-page-hero {
    min-height: auto;
  }

  .contact-hero-inner {
    padding: 52px 0;
  }

  .contact-hero-content {
    padding: 18px;
  }

  .contact-hero-content h1 {
    font-size: clamp(34px, 13vw, 54px);
  }

  .contact-hero-content .btn,
  .contact-enquiry-form > .btn,
  .map-side-card .btn {
    width: 100%;
  }

  .contact-quick-section {
    margin-top: 0;
  }

  .contact-quick-grid,
  .contact-form-grid,
  .contact-related-grid {
    grid-template-columns: 1fr;
  }

  .contact-form-head,
  .contact-detail-item {
    grid-template-columns: 1fr;
  }

  .map-box,
  .map-box iframe {
    min-height: 360px;
  }

  .contact-office-card,
  .map-side-card {
    padding: 24px;
  }
}

/* ================= CONTACT PAGE END ================= */


.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr repeat(4, 1fr);
  gap: 34px 24px;
}

.footer-brand {
  max-width: 390px;
}

.footer-logo {
  display: grid;
  grid-template-columns: 68px 1fr;
  gap: 14px;
  align-items: center;
  color: #fff;
  margin-bottom: 16px;
}

.footer-logo img {
  width: 68px;
  height: 68px;
  object-fit: contain;
  border-radius: 50%;
  background: #fff;
  padding: 7px;
}

.footer-logo h3 {
  color: #fff;
  font-size: 24px;
  margin: 0 0 4px;
}

.footer-logo span {
  display: block;
  color: #ffe49d;
  font-size: 12px;
  font-weight: 800;
}

.footer-col a i {
  margin-right: 7px;
  color: #ffe49d;
}

.footer-bottom-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
}

@media (max-width: 1280px) {
  .footer-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .footer-brand {
    grid-column: 1 / -1;
    max-width: none;
  }
}

@media (max-width: 900px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
}

@media (max-width: 575px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .footer-logo {
    grid-template-columns: 58px 1fr;
  }

  .footer-logo img {
    width: 58px;
    height: 58px;
  }
}


/* ================= FOOTER MAP CONTACT START ================= */

.footer-map-contact {
  grid-column: 1 / -1;
  margin-top: 12px;
}

.footer-map-wrap {
  display: grid;
  grid-template-columns: 8fr 4fr;
  gap: 22px;
  align-items: stretch;
  padding: 18px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.footer-map-col {
  min-height: 280px;
  overflow: hidden;
  border-radius: 10px;
  background: #fff;
}

.footer-map-col iframe {
  width: 100%;
  height: 100%;
  min-height: 280px;
  border: 0;
  display: block;
}

.footer-contact-col {
  padding: 22px;
  border-radius: 10px;
  background: rgba(3, 18, 44, 0.36);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-contact-col h4 {
  position: relative;
  color: #fff;
  font-size: 20px;
  margin-bottom: 18px;
  padding-bottom: 12px;
}

.footer-contact-col h4::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 44px;
  height: 3px;
  border-radius: 999px;
  background: var(--gold);
}

.footer-contact-col a {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 11px;
  align-items: center;
  margin-bottom: 12px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.55;
}

.footer-contact-col a:last-child {
  margin-bottom: 0;
}

.footer-contact-col a i {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.11);
  color: #ffe49d;
  font-size: 18px;
}

.footer-contact-col a span {
  word-break: break-word;
}

.footer-contact-col a:hover {
  color: #ffe49d;
}

@media (max-width: 991px) {
  .footer-map-wrap {
    grid-template-columns: 1fr;
  }

  .footer-map-col,
  .footer-map-col iframe {
    min-height: 300px;
  }
}

@media (max-width: 575px) {
  .footer-map-wrap {
    padding: 12px;
  }

  .footer-contact-col {
    padding: 18px;
  }

  .footer-map-col,
  .footer-map-col iframe {
    min-height: 260px;
  }
}

/* ================= FOOTER MAP CONTACT END ================= */

/* Home events image slider: overrides later notice-page event-card rules */
.events-section .slider-shell {
  position: relative;
  margin-top: 28px;
}

.events-section .slider-controls {
  align-items: center;
  justify-content: flex-end;
  margin: 0 0 16px;
}

.events-section .slider-btn {
  box-shadow: 0 10px 24px rgba(12, 44, 74, 0.12);
}

.events-section .event-grid.slider-track {
  display: flex;
  gap: 22px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 4px 2px 18px;
  scroll-padding: 2px;
}

.events-section .event-grid.slider-track > .event-card {
  flex: 0 0 calc((100% - 44px) / 3);
  min-width: 0;
  scroll-snap-align: start;
}

.events-section .event-card {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-height: 100%;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(20, 68, 105, 0.12);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 38px rgba(10, 45, 78, 0.08);
}

.events-section .event-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 50px rgba(10, 45, 78, 0.14);
}

.events-section .event-card img {
  display: block;
  width: 100%;
  height: 220px;
  object-fit: cover;
  background: #eef5fb;
}

.events-section .event-card > div {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 20px;
}

.events-section .event-card span {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #eef6ff;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.events-section .event-card h3 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 20px;
  line-height: 1.28;
}

.events-section .event-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.7;
}

@media (max-width: 1100px) {
  .events-section .event-grid.slider-track > .event-card {
    flex-basis: calc((100% - 22px) / 2);
  }
}

@media (max-width: 700px) {
  .events-section .slider-controls {
    justify-content: center;
  }

  .events-section .event-grid.slider-track > .event-card {
    flex-basis: 88%;
  }

  .events-section .event-card img {
    height: 210px;
  }
}
