
/* ── Organising Committee Section ── */
.oc-section {
  background: #fff;
  padding: 80px 20px;
  position: relative;
  overflow: hidden;
}
.oc-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 10% 80%, rgba(196,155,65,0.06) 0%, transparent 55%),
    radial-gradient(ellipse at 90% 10%, rgba(196,155,65,0.04) 0%, transparent 50%);
  pointer-events: none;
}
.oc-inner {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* Page heading */
.oc-eyebrow {
  text-align: center;
  font-size: 11px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: #c49b41;
  font-weight: 700;
  margin-bottom: 8px;
}
.oc-title {
  text-align: center;
  font-size: 34px;
  font-weight: 700;
  color: #002b4a;
  margin: 0 0 14px;
  line-height: 1.2;
}
.oc-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 56px;
}
.oc-div-line {
  width: 70px;
  height: 1px;
  background: linear-gradient(to right, transparent, #ffb30b);
}
.oc-div-line.r {
  background: linear-gradient(to left, transparent, #ffb30b);
}
.oc-div-dia {
  width: 8px;
  height: 8px;
  background: #ffb30b;
  transform: rotate(45deg);
  flex-shrink: 0;
}

/* Sub-section block */
.oc-block {
  margin-bottom: 52px;
}
.oc-block-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 22px;
}
.oc-block-icon {
  width: 46px;
  height: 46px;
  flex-shrink: 0;
  background: rgba(196, 155, 65, 0.12);
  border: 1px solid rgba(196, 155, 65, 0.3);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.oc-block-icon svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: #c49b41;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.oc-block-label {
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(196, 155, 65, 0.7);
  font-weight: 700;
  margin-bottom: 2px;
}
.oc-block-title {
  font-family: 'Cinzel', serif;
  font-size: 18px;
  font-weight: 600;
  color: #ffffff;
  margin: 0;
}
.oc-block-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, rgba(196, 155, 65, 0.4), transparent);
}
.oc-count {
  display: inline-block;
  background: rgba(196, 155, 65, 0.15);
  border: 1px solid rgba(196, 155, 65, 0.35);
  color: #c49b41;
  font-size: 10px;
  letter-spacing: 1px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  margin-left: 10px;
  vertical-align: middle;
  font-family: 'Lato', sans-serif;
}

/* Name grids */
.oc-grid {
  display: grid;
  gap: 10px;
}
.oc-grid-5 { grid-template-columns: repeat(5, 1fr); }
.oc-grid-4 { grid-template-columns: repeat(4, 1fr); }

/* Name cards */
.oc-name {
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 7px;
  padding: 12px 15px;
  font-size: 16px;
  color:  #1e1e1e !important;
  font-weight: 500;
  line-height: 1.35;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.oc-name::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: #1e1e1e !important;
  opacity: 0.5;
}
.oc-name:hover {
  border-color: rgba(196, 155, 65, 0.35);
  background: rgba(196, 155, 65, 0.07);
}
.oc-name .dr {
  color: #1e1e1e !important;
  font-weight: 500;
  font-size: 16px;
  margin-right: 1px;
}

/* Responsive */
@media (max-width: 900px) {
  .oc-grid-5 { grid-template-columns: repeat(3, 1fr); }
  .oc-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .oc-block-line { display: none; }
  .oc-title { font-size: 26px; }
}
@media (max-width: 560px) {
  .oc-grid-5,
  .oc-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 380px) {
  .oc-grid-5,
  .oc-grid-4 { grid-template-columns: 1fr; }
}
/* ── HERO ── */
.pw-hero {
 background: linear-gradient(135deg, #060f1c 0%, #0b1a35 55%, #0f2347 100%);
 padding: 64px 24px 56px;
 text-align: center;
 position: relative;
 overflow: hidden;
 border-bottom: 1px solid rgba(196, 155, 65, 0.2);
}
.pw-hero::before {
 content: "";
 position: absolute;
 inset: 0;
 background: radial-gradient(
  ellipse at 50% 0%,
  rgba(196, 155, 65, 0.1) 0%,
  transparent 65%
 );
 pointer-events: none;
}
.pw-hero-tag {
 display: inline-block;
 border: 1px solid rgba(196, 155, 65, 0.5);
 background: rgba(196, 155, 65, 0.1);
 color: #c49b41;
 font-size: 10px;
 letter-spacing: 4px;
 text-transform: uppercase;
 font-weight: 700;
 padding: 6px 18px;
 border-radius: 2px;
 margin-bottom: 22px;
}
.pw-hero h1 {

 font-size: 38px;
 font-weight: 700;
 line-height: 1.15;
 color: #fff;
 margin-bottom: 6px;
}
.pw-hero h1 em {
 color: #c49b41;
 font-style: normal;
}
.pw-hero-sub {
 font-size: 16px;
 color: rgba(255, 255, 255, 0.55);
 font-weight: 300;
 letter-spacing: 1px;
 margin-bottom: 30px;
}
.pw-hero-meta {
 display: inline-flex;
 align-items: center;
 gap: 30px;
 background: rgba(255, 255, 255, 0.04);
 border: 1px solid rgba(255, 255, 255, 0.1);
 border-radius: 8px;
 padding: 14px 28px;
}
.pw-hero-meta-item {
 text-align: center;
}
.pw-hero-meta-val {

 font-size: 18px;
 font-weight: 700;
 color: #c49b41;
 display: block;
}
.pw-hero-meta-lbl {
 font-size: 10px;
 letter-spacing: 2px;
 text-transform: uppercase;
 color: rgba(255, 255, 255, 0.45);
 margin-top: 2px;
 display: block;
}
.pw-hero-meta-sep {
 width: 1px;
 height: 38px;
 background: rgba(255, 255, 255, 0.12);
}

/* ── GALLERY ── */
.pw-gallery {
 padding: 52px 24px 44px;
 max-width: 1100px;
 margin: 0 auto;
}
.pw-gallery-label {
 font-size: 10px;
 letter-spacing: 4px;
 text-transform: uppercase;
 color: #c49b41;
 font-weight: 700;
 margin-bottom: 18px;
 display: flex;
 align-items: center;
 gap: 12px;
}
.pw-gallery-label::after {
 content: "";
 flex: 1;
 height: 1px;
 background: linear-gradient(to right, rgba(196, 155, 65, 0.4), transparent);
}

.pg-grid {
 display: grid;
 gap: 8px;
}
.pg-row {
 display: grid;
 gap: 8px;
}
.pg-row-1 {
 grid-template-columns: 2fr 1.4fr 2fr;
}
.pg-row-2 {
 grid-template-columns: 1.3fr 1.6fr 1.3fr;
 margin-top: 0;
}
.pg-row-3 {
 grid-template-columns: 1fr 1fr 1fr 1fr;
}

.pg-photo {
 border-radius: 6px;
 overflow: hidden;
 background: linear-gradient(135deg, #0d1f3c, #15305a);
 border: 1px solid rgba(196, 155, 65, 0.15);
 display: flex;
 align-items: center;
 justify-content: center;
 flex-direction: column;
 gap: 6px;
 min-height: 130px;
 position: relative;
}
.pg-photo.tall {
 min-height: 170px;
}
.pg-photo.short {
 min-height: 105px;
}
.pg-photo img {
 width: 100%;
 height: 100%;
 object-fit: cover;
 display: block;
 position: absolute;
 inset: 0;
}
.pg-photo-placeholder {
 width: 28px;
 height: 28px;
 opacity: 0.25;
 border: 2px solid #c49b41;
 border-radius: 4px;
 display: flex;
 align-items: center;
 justify-content: center;
 font-size: 14px;
 color: #c49b41;
}
.pg-photo-lbl {
 font-size: 10px;
 color: rgba(196, 155, 65, 0.4);
 letter-spacing: 1px;
 text-transform: uppercase;
}

/* ── ABOUT SECTION ── */
.pw-about {
 max-width: 1100px;
 margin: 0 auto;
 padding: 0 24px 56px;
 display: grid;
 grid-template-columns: 1fr 340px;
 gap: 48px;
 align-items: start;
}
.pw-about-text p {
 font-size: 14.5px;
 color: #18347a;
 line-height: 1.85;
 font-weight: 300;
 margin-bottom: 20px;
}
.pw-about-text p strong {
 color: #0f2343;
 font-weight: 700;
}
.pw-about-text p:first-child::first-letter {
 font-size: 42px;
 font-weight: 700;
 color: #c49b41;
 float: left;
 line-height: 0.85;
 margin: 6px 10px 0 0;
}

/* ── SIDEBAR CARD ── */
.pw-sidebar {
}
.pw-sidebar-card {
 background: rgba(196, 155, 65, 0.07);
 border: 1px solid rgba(196, 155, 65, 0.3);
 border-radius: 10px;
 padding: 24px 22px;
 margin-bottom: 16px;
}
.pw-sidebar-card-title {
 font-size: 13px;
 font-weight: 600;
 color: #c49b41;
 margin-bottom: 16px;
 letter-spacing: 0.5px;
 padding-bottom: 10px;
 border-bottom: 1px solid rgba(196, 155, 65, 0.2);
}
.pw-who-item {
 display: flex;
 align-items: center;
 gap: 10px;
 padding: 8px 0;
 border-bottom: 1px solid rgba(255, 255, 255, 0.06);
 font-size: 13px;
     color: rgb(18 41 78);
}
.pw-who-item:last-child {
 border-bottom: none;
}
.pw-who-dot {
 width: 6px;
 height: 6px;
 border-radius: 50%;
 background: #c49b41;
 flex-shrink: 0;
}
.pw-reg-btn {
 display: block;
 text-align: center;
 background: #c49b41;
 color: #0a1628;
 font-weight: 700;
 font-size: 13px;
 letter-spacing: 1px;
 text-transform: uppercase;
 text-decoration: none;
 padding: 14px 20px;
 border-radius: 7px;
 transition: background 0.2s;
}

/* ── CURRICULUM ── */
.pw-curriculum {
 background: linear-gradient(180deg, #0b1a35 0%, #07111f 100%);
 padding: 52px 24px 64px;
 border-top: 1px solid rgba(196, 155, 65, 0.15);
}
.pw-curr-inner {
 max-width: 1100px;
 margin: 0 auto;
}
.pw-section-label {
 text-align: center;
 font-size: 10px;
 letter-spacing: 4px;
 text-transform: uppercase;
 color: #c49b41;
 font-weight: 700;
 margin-bottom: 8px;
}
.pw-section-title {
 text-align: center;
 font-size: 26px;
 font-weight: 700;
 color: #fff;
 margin-bottom: 10px;
}
.pw-section-div {
 display: flex;
 align-items: center;
 justify-content: center;
 gap: 12px;
 margin-bottom: 40px;
}
.pw-div-line {
 width: 50px;
 height: 1px;
 background: linear-gradient(to right, transparent, #c49b41);
}
.pw-div-line.r {
 background: linear-gradient(to left, transparent, #c49b41);
}
.pw-div-dia {
 width: 6px;
 height: 6px;
 background: #c49b41;
 transform: rotate(45deg);
}

.pw-modules {
 display: grid;
 grid-template-columns: repeat(5, 1fr);
 gap: 14px;
}
.pw-module {
 background: rgba(255, 255, 255, 0.03);
 border: 1px solid rgba(255, 255, 255, 0.08);
 border-radius: 9px;
 padding: 22px 16px;
 text-align: center;
 position: relative;
 overflow: hidden;
}
.pw-module::after {
 content: "";
 position: absolute;
 bottom: 0;
 left: 0;
 right: 0;
 height: 2px;
 background: linear-gradient(to right, transparent, #c49b41, transparent);
}
.pw-module-num {

 font-size: 28px;
 font-weight: 700;
 color: rgb(255 255 255 / 24%);
 line-height: 1;
 margin-bottom: 12px;
}
.pw-module-icon {
 width: 38px;
 height: 38px;
 background: rgba(196, 155, 65, 0.12);
 border-radius: 8px;
 display: flex;
 align-items: center;
 justify-content: center;
 margin: 0 auto 12px;
}
.pw-module-icon svg {
 width: 18px;
 height: 18px;
 fill: none;
 stroke: #c49b41;
 stroke-width: 1.8;
 stroke-linecap: round;
 stroke-linejoin: round;
}
.pw-module-title {
 font-size: 12.5px;
 font-weight: 700;
 color: #fff;
 line-height: 1.4;
 margin-bottom: 8px;
}
.pw-module-desc {
 font-size: 11.5px;
 color: rgba(255, 255, 255, 0.5);
 line-height: 1.6;
 font-weight: 300;
}
.heading-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 2rem;
    border-radius: var(--border-radius-lg);
    text-align: center;
  }
  .nvc-eyebrow {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #C9A84C;
    margin-bottom: 0.75rem;
  }
  .nvc-title {
    font-size: 2.4rem;
    font-weight: 700;
    color: #1a2744;
    margin: 0 0 1.1rem;
    line-height: 1.15;
  }
  .nvc-divider {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .nvc-line {
    width: 48px;
    height: 1.5px;
    background: #C9A84C;
    border-radius: 2px;
  }
  .nvc-diamond {
    width: 8px;
    height: 8px;
    background: #C9A84C;
    transform: rotate(45deg);
    border-radius: 1px;
  }