/* =============================================
   MTPC2026 - Custom Theme Overrides
   Replaces apita.css for the MTPC2026 rebrand
   ============================================= */

/* ===== Header Overrides ===== */
.header-logo {
  max-width: 140px;
}

/* Header: transparent initially, glassmorphic on scroll */
.exvent-header-2 {
  transition: background-color 0.4s ease, backdrop-filter 0.4s ease;
}

.exvent-header-2 .header-wrap {
  background: none;
  padding: 10px 0;
  transition: padding 0.3s ease;
}

/* Sticky header: deep purple with blur */
.exvent-header-2.sticky,
.exvent-header-2.sticky .header-wrap {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.2);
}

.exvent-header-2.sticky .header-wrap {
  padding: 5px 0;
}

/* Nav links: white with smooth hover to accent pink */
.exvent-header-2 .header-menu .main-menu li a {
  color: #ffffff;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0.3px;
  transition: color 0.3s ease;
}

.exvent-header-2 .header-menu .main-menu li:hover > a,
.exvent-header-2 .header-menu .main-menu li.active-menu > a {
  color: #fc097c;
}

.exvent-header-2 .header-menu .main-menu li .menu-icon::after {
  color: #ffffff;
  transition: color 0.3s ease;
}

.exvent-header-2 .header-menu .main-menu li:hover > .menu-icon::after,
.exvent-header-2 .header-menu .main-menu li.active-menu > .menu-icon::after {
  color: #fc097c;
}

/* Sticky nav links */
.exvent-header-2.sticky .header-menu .main-menu li a {
  color: rgba(255, 255, 255, 0.9);
}

.exvent-header-2.sticky .header-menu .main-menu li:hover > a,
.exvent-header-2.sticky .header-menu .main-menu li.active-menu > a {
  color: #fc097c;
}

.exvent-header-2.sticky .header-menu .main-menu li .menu-icon::after {
  color: rgba(255, 255, 255, 0.9);
}

.exvent-header-2.sticky .header-menu .main-menu li:hover > .menu-icon::after,
.exvent-header-2.sticky .header-menu .main-menu li.active-menu > .menu-icon::after {
  color: #fc097c;
}

/* Sub-menu: refined with pink accent border */
.exvent-header-2 .header-menu .main-menu li .sub-menu {
  border-top: 3px solid #fc097c;
  border-radius: 0 0 8px 8px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
}

.exvent-header-2 .header-menu .main-menu li .sub-menu li a {
  color: #333;
  transition: color 0.3s ease, padding-left 0.3s ease;
}

.exvent-header-2 .header-menu .main-menu li .sub-menu li a::before {
  background: #fc097c;
}

.exvent-header-2 .header-menu .main-menu li .sub-menu li:hover > a,
.exvent-header-2 .header-menu .main-menu li .sub-menu li.active > a {
  color: #fc097c;
}

.exvent-header-2.sticky .header-menu .main-menu li .sub-menu {
  border-top: 3px solid #fc097c;
}

.exvent-header-2.sticky .header-menu .main-menu li .sub-menu li a {
  color: #333;
}

.exvent-header-2.sticky .header-menu .main-menu li .sub-menu li a::before {
  background: #fc097c;
}

.exvent-header-2.sticky .header-menu .main-menu li .sub-menu li:hover > a,
.exvent-header-2.sticky .header-menu .main-menu li .sub-menu li.active > a {
  color: #fc097c;
}

/* Registration button: gradient pink pill */
.btn-2 {
  background: linear-gradient(135deg, #fc097c, #e0076b);
  color: #ffffff;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 600;
  height: auto;
  line-height: 1;
  padding: 12px 28px;
  border: none;
  box-shadow: 0 4px 15px rgba(252, 9, 124, 0.3);
  transition: all 0.4s ease;
  text-transform: capitalize;
}

.btn-2:hover {
  background: #ffffff;
  color: #fc097c;
  box-shadow: 0 6px 20px rgba(252, 9, 124, 0.25);
  transform: translateY(-2px);
}

.btn-2:focus,
.btn-2:focus:active {
  box-shadow: 0 4px 15px rgba(252, 9, 124, 0.3);
}

.btn-2.btn-sm {
  line-height: 1;
  height: auto;
  padding: 8px 20px;
}

.btn-2.btn-blue {
  background: linear-gradient(135deg, #00acee, #0095d0);
  box-shadow: 0 4px 15px rgba(0, 172, 238, 0.3);
}

.btn-2.btn-blue:hover {
  box-shadow: none;
  background: #ffffff;
  color: #00acee;
}

/* Mobile hamburger toggle: pink bars */
.exvent-header-2 .header-toggle button span {
  background: #fc097c;
}

/* ===== Offcanvas (Mobile Nav) ===== */
.offcanvas-header {
  background: linear-gradient(135deg, #150328, #250449);
}

.offcanvas .offcanvas-logo a img {
  width: 100px;
}

.offcanvas-header .close-btn {
  color: #fc097c;
}

.offcanvas-header .close-btn:hover {
  color: #ffae4a;
}

.offcanvas-menu .main-menu li a {
  color: #150328;
}

.offcanvas-menu .main-menu li:hover > a {
  color: #fc097c;
}

.offcanvas-menu .main-menu li .menu-expand::before,
.offcanvas-menu .main-menu li .menu-expand::after {
  background-color: #fc097c;
}

/* ===== Footer Overrides ===== */
.footer-widget .logo-wrap img {
  max-width: 180px;
}

/* ===== Form & Misc ===== */
.form-label {
  font-weight: 900;
}

.contact-form-section .map-section .map iframe {
  filter: initial;
}

/* ===== Faculty Accordion ===== */
.faculty-area {
  position: relative;
}

.faculty-area .accordion .accordion-item {
  border: none;
  background: transparent;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button {
  border-bottom: 1px solid #ddd;
  font-size: 20px;
  font-weight: 600;
  color: #1a0a1e;
  padding-bottom: 25px;
  background: transparent;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button::after {
  content: "\f106";
  font-family: "Font Awesome 5 Free";
  background-image: none;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button:not(.collapsed) {
  border-bottom: 1px solid #ddd;
  font-size: 20px;
  font-weight: 600;
  color: #fc097c;
  background: none;
  box-shadow: none;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button:not(.collapsed)::after {
  content: "\f107";
  font-family: "Font Awesome 5 Free";
  background-image: none;
  transform: none;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button:focus {
  color: #fc097c;
  outline: none;
  box-shadow: none;
  background: none;
}

.faculty-area .accordion .accordion-item .accordion-collapse .accordion-body p {
  font-size: 16px;
  line-height: 36px;
}

/* ===== Page Title ===== */
@media only screen and (max-width: 767px) {
  .page-title .section-title {
    font-size: 36px;
  }
}


/* ===== Inner Page Hero Banner ===== */
/* Override the old blue-purple gradient to match MTPC2026 theme */
.inner-page-hero {
  height: auto;
  min-height: 320px;
  background-image: url(/assets/images/apita/taiwan-bg.jpg) !important;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}

.inner-page-hero::after {
  background: linear-gradient(135deg, rgba(3, 1, 39, 0.9) 0%, rgba(21, 3, 40, 0.85) 0%, rgba(76, 13, 110, 0.78) 100%) !important;
  opacity: 1 !important;
}

/* Accent stripe at the bottom */
.inner-page-hero::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #fc097c, #ffae4a, #00acee);
  z-index: 3;
}

/* Page title styling */
.inner-page-hero .page-title .section-title {
  font-family: "Ubuntu", sans-serif;
  font-weight: 700;
  letter-spacing: -0.5px;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}

.inner-page-hero .page-title h4 {
  font-family: "Ubuntu", sans-serif;
  font-weight: 300;
  font-size: 18px;
  color: rgba(255, 255, 255, 0.75);
  letter-spacing: 1px;
}

/* Breadcrumb styling */
.inner-page-hero .page-navigation {
  margin-bottom: 60px;
}

.inner-page-hero .page-navigation ol.breadcrumb {
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 50px;
  padding: 10px 24px;
  display: inline-flex;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.inner-page-hero .page-navigation ol.breadcrumb .breadcrumb-item a {
  color: rgba(255, 255, 255, 0.7);
  font-weight: 500;
  font-size: 14px;
  transition: color 0.3s ease;
}

.inner-page-hero .page-navigation ol.breadcrumb .breadcrumb-item a:hover {
  color: #fc097c;
}

.inner-page-hero .page-navigation ol.breadcrumb .breadcrumb-item.active {
  color: #ffae4a;
  font-weight: 600;
  font-size: 14px;
}

.inner-page-hero .page-navigation ol.breadcrumb .breadcrumb-item::before {
  color: rgba(255, 255, 255, 0.4);
}

@media only screen and (max-width: 991px) {
  .inner-page-hero {
    min-height: 260px;
  }
}

@media only screen and (max-width: 575px) {
  .inner-page-hero {
    min-height: 220px;
  }

  .inner-page-hero .page-title .section-title {
    font-size: 28px;
  }

  .inner-page-hero .page-title h4 {
    font-size: 14px;
  }

  .inner-page-hero .page-navigation ol.breadcrumb {
    padding: 8px 16px;
  }
}


/* ===========================================================
   Homepage Specific Styles
   =========================================================== */

/* ===== Hero Section ===== */
.mtpc-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-image: url(/assets/images/apita/taiwan-bg.jpg);
  background-size: cover;
  background-position: center;
  z-index: 1;
}

.mtpc-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(3, 1, 39, 0.88) 0%, rgba(21, 3, 40, 0.82) 0%, rgba(76, 13, 110, 0.75) 100%);
  z-index: -1;
}

.mtpc-hero::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 120px;
  background: #fff;
  clip-path: ellipse(55% 100% at 50% 100%);
  z-index: 2;
}

/* Floating particles */
.hero-particles {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.hero-particles .particle {
  position: absolute;
  border-radius: 50%;
  opacity: 0.15;
  animation: floatParticle linear infinite;
}

.hero-particles .particle:nth-child(1) {
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, #fc097c, transparent 70%);
  top: 10%;
  left: -5%;
  animation-duration: 18s;
}

.hero-particles .particle:nth-child(2) {
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, #00acee, transparent 70%);
  top: 60%;
  right: -3%;
  animation-duration: 22s;
  animation-delay: -5s;
}

.hero-particles .particle:nth-child(3) {
  width: 150px;
  height: 150px;
  background: radial-gradient(circle, #ffae4a, transparent 70%);
  bottom: 20%;
  left: 30%;
  animation-duration: 15s;
  animation-delay: -8s;
}

.hero-particles .particle:nth-child(4) {
  width: 250px;
  height: 250px;
  background: radial-gradient(circle, #a221b9, transparent 70%);
  top: 5%;
  right: 20%;
  animation-duration: 20s;
  animation-delay: -3s;
}

@keyframes floatParticle {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25% { transform: translate(30px, -40px) scale(1.1); }
  50% { transform: translate(-20px, 20px) scale(0.95); }
  75% { transform: translate(15px, 35px) scale(1.05); }
}

/* Hero Content */
.hero-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 160px 20px 120px;
}

.hero-badge {
  display: inline-block;
  background: rgba(255, 174, 74, 0.15);
  border: 1px solid rgba(255, 174, 74, 0.4);
  color: #ffae4a;
  padding: 8px 28px;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 30px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.hero-title {
  font-family: "Ubuntu", sans-serif;
  font-size: 90px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  margin-bottom: 30px;
  letter-spacing: -2px;
  text-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
}

.hero-title span {
  background: linear-gradient(135deg, #fc097c, #ffae4a);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-subtitle {
  font-family: "Ubuntu", sans-serif;
  font-size: 28px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.9);
  max-width: 800px;
  margin: 0 auto 20px;
  line-height: 1.5;
}

.hero-date-line {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 50px;
  flex-wrap: wrap;
}

.hero-date-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255, 255, 255, 0.85);
  font-size: 20px;
  font-weight: 500;
}

.hero-date-item i {
  color: #ffae4a;
  font-size: 22px;
}

.hero-date-divider {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
}

.hero-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}

.btn-hero-primary {
  display: inline-block;
  background: linear-gradient(135deg, #fc097c, #e0076b);
  color: #fff;
  font-family: "Ubuntu", sans-serif;
  font-size: 16px;
  font-weight: 600;
  padding: 16px 42px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.4s ease;
  box-shadow: 0 8px 30px rgba(252, 9, 124, 0.35);
}

.btn-hero-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(252, 9, 124, 0.5);
  color: #fff;
}

.btn-hero-outline {
  display: inline-block;
  border: 2px solid rgba(255, 255, 255, 0.3);
  color: #fff;
  font-family: "Ubuntu", sans-serif;
  font-size: 16px;
  font-weight: 600;
  padding: 14px 42px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.4s ease;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.btn-hero-outline:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.5);
  transform: translateY(-3px);
  color: #fff;
}

/* ===== Countdown Cards ===== */
.countdown-strip {
  position: relative;
  z-index: 3;
  margin-top: -80px;
  margin-bottom: 60px;
}

.countdown-card {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 20px;
  padding: 40px 20px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.8);
}

.countdown-grid {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.cd-item {
  text-align: center;
  min-width: 100px;
  padding: 10px 20px;
}

.cd-item .cd-num {
  font-family: "Ubuntu", sans-serif;
  font-size: 52px;
  font-weight: 700;
  line-height: 1;
  background: linear-gradient(135deg, #150328, #fc097c);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cd-item .cd-label {
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #666;
  margin-top: 8px;
}

.cd-separator {
  font-size: 36px;
  font-weight: 300;
  color: #ddd;
  padding: 0 5px;
  line-height: 1;
  align-self: flex-start;
  margin-top: 8px;
}

/* ===== Event Highlights ===== */
.highlights-section {
  padding: 40px 0 80px;
  background: #fff;
}

.highlight-box {
  text-align: center;
  padding: 40px 25px;
  border-radius: 16px;
  transition: all 0.4s ease;
  border: 1px solid transparent;
}

.highlight-box:hover {
  background: rgba(21, 3, 40, 0.03);
  border-color: rgba(252, 9, 124, 0.1);
  transform: translateY(-5px);
}

.highlight-icon {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 28px;
}

.highlight-icon.icon-date {
  background: rgba(252, 9, 124, 0.1);
  color: #fc097c;
}

.highlight-icon.icon-venue {
  background: rgba(0, 172, 238, 0.1);
  color: #00acee;
}

.highlight-icon.icon-topic {
  background: rgba(255, 174, 74, 0.1);
  color: #ffae4a;
}

.highlight-box h5 {
  font-family: "Ubuntu", sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #1a0a1e;
  margin-bottom: 8px;
}

.highlight-box p {
  font-size: 15px;
  color: #666;
  line-height: 1.6;
  margin: 0;
}

/* ===== About Section ===== */
.about-refresh {
  padding: 80px 0 100px;
  background: linear-gradient(180deg, #f8f6fb 0%, #fff 100%);
}

.about-refresh .section-label {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #fc097c;
  margin-bottom: 15px;
}

.about-refresh .about-heading {
  font-family: "Ubuntu", sans-serif;
  font-size: 38px;
  font-weight: 700;
  color: #1a0a1e;
  line-height: 1.3;
  margin-bottom: 25px;
}

.about-refresh .about-text {
  font-size: 16px;
  color: #555;
  line-height: 1.8;
  margin-bottom: 30px;
}

.about-info-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.about-info-list li {
  display: flex;
  align-items: flex-start;
  gap: 15px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.about-info-list li:last-child {
  border-bottom: none;
}

.about-info-list li .info-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  background: rgba(252, 9, 124, 0.08);
  color: #fc097c;
}

.about-info-list li .info-content h6 {
  font-family: "Ubuntu", sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: #1a0a1e;
  margin-bottom: 2px;
}

.about-info-list li .info-content p {
  font-size: 14px;
  color: #666;
  margin: 0;
}

.about-image-wrap {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 25px 60px rgba(21, 3, 40, 0.15);
}

.about-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-image-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(252, 9, 124, 0.15), rgba(0, 172, 238, 0.1));
  pointer-events: none;
}

.about-image-accent {
  position: absolute;
  bottom: -15px;
  right: -15px;
  width: 120px;
  height: 120px;
  border-radius: 20px;
  background: linear-gradient(135deg, #fc097c, #ffae4a);
  z-index: -1;
}

/* ===== Speaker Section ===== */
.speaker-refresh {
  padding: 100px 0;
  background: #fff;
}

.section-header {
  text-align: center;
  margin-bottom: 60px;
}

.section-header .section-label {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #fc097c;
  margin-bottom: 12px;
}

.section-header .section-heading {
  font-family: "Ubuntu", sans-serif;
  font-size: 42px;
  font-weight: 700;
  color: #1a0a1e;
}

/* ===== MTPC Speaker Cards ===== */
.mtpc-speaker-card {
  display: block;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(0, 0, 0, 0.03);
  height: 100%;
}

.mtpc-speaker-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 16px 40px rgba(21, 3, 40, 0.12);
  border-color: rgba(252, 9, 124, 0.15);
}

.mtpc-speaker-geom-wrap {
  position: relative;
  padding: 24px 24px 10px 24px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mtpc-speaker-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 12px;
  z-index: 2;
  position: relative;
  transition: transform 0.4s ease;
  display: block;
}

/* 前景幾何框 A - 粉紅漸層實線 */
.mtpc-speaker-geom-wrap::before {
  content: '';
  position: absolute;
  inset: 18px;
  border: 2px solid transparent;
  background: linear-gradient(135deg, #fc097c, transparent) border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  border-radius: 16px;
  transform: rotate(-3deg);
  transition: transform 0.4s ease, opacity 0.4s ease;
  z-index: 3;
  opacity: 0.6;
  pointer-events: none;
}

/* 前景幾何框 B - 橘色漸層虛線 */
.mtpc-speaker-geom-wrap::after {
  content: '';
  position: absolute;
  inset: 14px;
  border: 2px dashed transparent;
  background: linear-gradient(135deg, transparent, #ffae4a) border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  border-radius: 16px;
  transform: rotate(3deg);
  transition: transform 0.4s ease, opacity 0.4s ease;
  z-index: 3;
  opacity: 0.6;
  pointer-events: none;
}

/* Hover 時的幾何框交錯旋轉 */
.mtpc-speaker-card:hover .mtpc-speaker-geom-wrap::before {
  transform: rotate(4deg) scale(1.02);
  opacity: 1;
}

.mtpc-speaker-card:hover .mtpc-speaker-geom-wrap::after {
  transform: rotate(-4deg) scale(1.02);
  opacity: 1;
}

.mtpc-speaker-card:hover .mtpc-speaker-img {
  transform: scale(1.02);
}

.mtpc-speaker-info {
  padding: 16px 24px 24px 24px;
  position: relative;
}

/* 幾何線條裝飾背景 */
.mtpc-speaker-info::before {
  content: '';
  position: absolute;
  top: 0;
  left: 24px;
  right: 24px;
  height: 2px;
  background: linear-gradient(90deg, #fc097c, transparent);
  transition: all 0.4s ease;
}

.mtpc-speaker-card:hover .mtpc-speaker-info::before {
  background: linear-gradient(90deg, #fc097c, #ffae4a);
}

.mtpc-speaker-name {
  font-family: "Ubuntu", sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #1a0a1e;
  margin-bottom: 8px;
  line-height: 1.3;
  transition: color 0.3s ease;
}

.mtpc-speaker-card:hover .mtpc-speaker-name {
  color: #fc097c;
}

.mtpc-speaker-org {
  font-size: 13px;
  color: #777;
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color 0.3s ease;
}

.mtpc-speaker-card:hover .mtpc-speaker-org {
  color: #555;
}

/* ===== CTA Section ===== */
.cta-refresh {
  position: relative;
  padding: 120px 0;
  background-image: url(/assets/images/apita/index_footer.jpg);
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  z-index: 1;
}

.cta-refresh::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(3, 1, 39, 0.92) 0%, rgba(76, 13, 110, 0.85) 100%);
  z-index: -1;
}

.cta-refresh .cta-content {
  text-align: center;
  position: relative;
  z-index: 1;
}

.cta-refresh .cta-title {
  font-family: "Ubuntu", sans-serif;
  font-size: 44px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 20px;
  line-height: 1.3;
}

.cta-refresh .cta-desc {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 40px;
  max-width: 550px;
  margin-left: auto;
  margin-right: auto;
}

/* ===== Fancybox ===== */
.fancybox__backdrop {
  background: rgba(1, 1, 1, .5);
}

/* ===== Responsive ===== */
@media only screen and (max-width: 991px) {
  .hero-title { font-size: 64px; }
  .hero-subtitle { font-size: 22px; }
  .hero-date-item { font-size: 18px; }
  .hero-date-item i { font-size: 20px; }
  .cd-item .cd-num { font-size: 40px; }
  .cd-item { min-width: 80px; padding: 8px 12px; }
  .about-refresh .about-heading { font-size: 30px; }
  .cta-refresh .cta-title { font-size: 34px; }
  .about-image-accent { display: none; }
}

@media only screen and (max-width: 575px) {
  .hero-title { font-size: 42px; letter-spacing: -1px; }
  .hero-subtitle { font-size: 18px; }
  .hero-date-item { font-size: 16px; }
  .hero-date-item i { font-size: 18px; }
  .hero-inner { padding: 140px 15px 100px; }
  .hero-badge { font-size: 11px; padding: 6px 18px; letter-spacing: 2px; }
  .cd-item .cd-num { font-size: 32px; }
  .cd-item { min-width: 65px; padding: 5px 8px; }
  .cd-separator { font-size: 24px; }
  .countdown-card { padding: 25px 15px; border-radius: 14px; }
  .section-header .section-heading { font-size: 30px; }
  .cta-refresh .cta-title { font-size: 26px; }
  .cta-refresh { padding: 80px 0; }
}

/* ===== Large Screen Scaling (27"+ monitors) ===== */
@media only screen and (min-width: 1600px) {
  /* Header */
  .header-logo { max-width: 160px; }
  .exvent-header-2 .header-menu .main-menu li a { font-size: 18px; }
  .exvent-header-2 .header-menu .main-menu li { padding: 30px 20px; }

  /* Hero */
  .hero-title { font-size: 110px; }
  .hero-subtitle { font-size: 32px; max-width: 900px; }
  .hero-badge { font-size: 16px; padding: 10px 32px; }
  .hero-date-item { font-size: 22px; }
  .hero-date-item i { font-size: 24px; }

  /* Countdown */
  .cd-item .cd-num { font-size: 60px; }
  .cd-item .cd-label { font-size: 15px; }

  /* Highlights */
  .highlight-box h5 { font-size: 20px; }
  .highlight-box p { font-size: 17px; }

  /* Sections */
  .section-header .section-heading { font-size: 48px; }
  .section-header .section-label { font-size: 15px; }
  .cta-refresh .cta-title { font-size: 50px; }
  .cta-refresh .cta-desc { font-size: 20px; }

  /* General body text */
  body { font-size: 17px; }
}

@media only screen and (min-width: 1920px) {
  /* Header */
  .header-logo { max-width: 180px; }
  .exvent-header-2 .header-menu .main-menu li a { font-size: 19px; }

  /* Hero */
  .hero-title { font-size: 130px; }
  .hero-subtitle { font-size: 36px; max-width: 1000px; }
  .hero-badge { font-size: 17px; padding: 12px 36px; }
  .hero-date-item { font-size: 24px; }
  .hero-date-item i { font-size: 26px; }
  .hero-inner { padding: 180px 20px 140px; }

  /* Countdown */
  .cd-item .cd-num { font-size: 68px; }

  /* Sections */
  .section-header .section-heading { font-size: 52px; }
  .cta-refresh .cta-title { font-size: 56px; }

  /* General body text */
  body { font-size: 18px; }
}

/* ===== Submit Buttons Styling ===== */
.submit_btn {
  background: linear-gradient(135deg, #fc097c, #e0076b) !important;
  border-radius: 50px !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 15px rgba(252, 9, 124, 0.3) !important;
  transition: all 0.3s ease-in-out !important;
}

.submit_btn:hover {
  box-shadow: 0 6px 20px rgba(252, 9, 124, 0.4) !important;
  transform: translateY(-2px);
}

.submit_btn.btn-blue {
  background: linear-gradient(135deg, #00acee, #0095d0) !important;
  box-shadow: 0 4px 15px rgba(0, 172, 238, 0.3) !important;
}

.submit_btn.btn-blue:hover {
  box-shadow: 0 6px 20px rgba(0, 172, 238, 0.4) !important;
}

/* ===== Sponsor Logo Normalization ===== */
.brand-area .brand-item {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 140px;
  padding: 20px 15px;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  transition: all 0.3s ease;
}

.brand-area .brand-item:hover {
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
  transform: translateY(-3px);
  border-color: rgba(252, 9, 124, 0.15);
}

.brand-area .brand-item a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.brand-area .brand-item img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

/* ===== Sponsor Page Background ===== */
.brand-area {
  background: linear-gradient(180deg, #f8f6fb 0%, #fff 100%) !important;
}

/* ===== Sponsor Tier System ===== */
.sponsor-tier {
  margin-bottom: 30px;
  height: calc(100% - 30px);
  display: flex;
  flex-direction: column;
}

.sponsor-tier-organizer {
  background: #fff;
  border-radius: 20px;
  padding: 45px 35px;
  box-shadow: 0 10px 40px rgba(21, 3, 40, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.04);
}

.sponsor-tier .row {
  flex-grow: 1;
  align-items: center;
}

.sponsor-tier-header {
  text-align: center;
  margin-bottom: 30px;
}

.sponsor-tier-header .sub-title {
  color: #fc097c !important;
  font-family: "Ubuntu", sans-serif;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* Diamond Sponsor */
.sponsor-tier-diamond {
  position: relative;
  justify-content: center;
}

.sponsor-tier-diamond .row {
  flex-grow: 0;
}


.sponsor-tier-diamond .sponsor-tier-header {
  margin-bottom: 30px;
}

.sponsor-tier-diamond .sponsor-tier-header i {
  font-size: 32px;
  background: linear-gradient(135deg, #b8d4e3, #7ec8e3, #a8e6cf);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
  margin-bottom: 10px;
}

.sponsor-tier-diamond .sponsor-tier-header h4 {
  font-family: "Ubuntu", sans-serif;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  background: linear-gradient(135deg, #6cb4d9, #4a9cc7, #7ec8e3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.brand-item-diamond {
  height: 200px !important;
  padding: 30px 40px !important;
  border: 3px solid transparent !important;
  border-radius: 16px !important;
  background-image: linear-gradient(#fff, #fff), linear-gradient(135deg, #7ec8e3 0%, #ffffff 25%, #fc097c 50%, #ffffff 75%, #7ec8e3 100%) !important;
  background-origin: border-box !important;
  background-clip: padding-box, border-box !important;
  box-shadow:
    0 15px 45px rgba(21, 3, 40, 0.06),
    0 0 25px rgba(126, 200, 227, 0.15),
    inset 0 0 15px rgba(126, 200, 227, 0.05) !important;
  position: relative;
}

.brand-item-diamond::after {
  content: '';
  position: absolute;
  top: 4px;
  left: 4px;
  right: 4px;
  bottom: 4px;
  border: 1px solid rgba(126, 200, 227, 0.25);
  border-radius: 10px;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(126, 200, 227, 0.02) 0%, rgba(252, 9, 124, 0.02) 100%);
}

.brand-item-diamond:hover {
  box-shadow:
    0 20px 50px rgba(21, 3, 40, 0.1),
    0 0 35px rgba(126, 200, 227, 0.35),
    inset 0 0 20px rgba(126, 200, 227, 0.1) !important;
  transform: translateY(-5px);
}

.brand-item-diamond img {
  max-height: 100%;
  max-width: 100%;
  position: relative;
  z-index: 1;
}


.sponsor-tier-general {
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  padding-top: 40px;
  margin-top: 20px;
}

.sponsor-tier-general .sponsor-tier-header {
  margin-bottom: 35px;
}

/* ===== Welcome Message Page ===== */
.welcome-section {
  background: linear-gradient(180deg, #f8f6fb 0%, #fff 100%);
}

/* President Info Card */
.welcome-president-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(21, 3, 40, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.04);
  margin-bottom: 50px;
}

.welcome-president-photo {
  position: relative;
  padding: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.welcome-president-photo img {
  width: 100%;
  max-width: 220px;
  border-radius: 16px;
  display: block;
  box-shadow: 0 8px 25px rgba(21, 3, 40, 0.12);
}

.welcome-president-photo::after {
  display: none;
}

.welcome-president-info {
  padding: 40px 45px;
}

.welcome-president-label {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #fc097c;
  margin-bottom: 12px;
  padding: 6px 16px;
  background: rgba(252, 9, 124, 0.08);
  border-radius: 50px;
}

.welcome-president-name {
  font-family: "Ubuntu", sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #1a0a1e;
  margin-bottom: 24px;
  line-height: 1.2;
}

.welcome-president-titles {
  list-style: none;
  padding: 0;
  margin: 0;
}

.welcome-president-titles li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  font-size: 15px;
  color: #444;
  line-height: 1.5;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.welcome-president-titles li:last-child {
  border-bottom: none;
}

.welcome-president-titles li i {
  color: #fc097c;
  font-size: 16px;
  margin-top: 3px;
  min-width: 20px;
  text-align: center;
}

/* Letter Content */
.welcome-letter {
  background: #fff;
  border-radius: 20px;
  padding: 50px 60px;
  box-shadow: 0 10px 40px rgba(21, 3, 40, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.04);
  position: relative;
}

.welcome-letter::before {
  content: '\201C';
  position: absolute;
  top: 25px;
  left: 35px;
  font-size: 80px;
  font-family: Georgia, serif;
  color: rgba(252, 9, 124, 0.1);
  line-height: 1;
  pointer-events: none;
}

.welcome-letter-body p {
  font-size: 16px;
  line-height: 1.9;
  color: #333;
  margin-bottom: 16px;
}

@media (min-width: 992px) {
  .welcome-letter-body p {
    text-align: justify;
  }
}

.welcome-letter-body p:first-child {
  font-size: 18px;
  font-weight: 600;
  color: #1a0a1e;
}

.welcome-letter-body p strong {
  color: #150328;
}

.welcome-letter-signature {
  margin-top: 30px;
  padding-top: 25px;
  border-top: 2px solid transparent;
  border-image: linear-gradient(90deg, #fc097c, #ffae4a, transparent) 1;
  text-align: right;
}

.welcome-letter-signature p {
  font-size: 16px;
  color: #666;
  margin-bottom: 8px;
  font-style: italic;
}

.welcome-letter-signature strong {
  font-family: "Ubuntu", sans-serif;
  font-size: 20px;
  color: #1a0a1e;
}

.welcome-letter-signature span {
  font-size: 14px;
  color: #fc097c;
  font-weight: 600;
  letter-spacing: 1px;
}

/* Responsive */
@media only screen and (max-width: 991px) {
  .welcome-president-info {
    padding: 30px 25px;
  }

  .welcome-president-name {
    font-size: 26px;
  }

  .welcome-letter {
    padding: 30px 25px;
  }

  .welcome-letter::before {
    font-size: 50px;
    top: 15px;
    left: 15px;
  }
}

/* ===== Faculty Page ===== */
.faculty-area {
  background: linear-gradient(180deg, #f8f6fb 0%, #fff 100%) !important;
}

.faculty-accordion .accordion-item {
  background: #fff;
  border-radius: 12px !important;
  border: 1px solid rgba(21, 3, 40, 0.08) !important;
  box-shadow: 0 4px 20px rgba(21, 3, 40, 0.03);
  margin-bottom: 15px;
  overflow: hidden;
}

/* Collapsed State */
.faculty-area .accordion .accordion-item .accordion-header .accordion-button {
  font-family: "Ubuntu", sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: #1a0a1e !important;
  padding: 20px 25px;
  background-color: #ffffff !important;
  border-left: 4px solid transparent;
  transition: all 0.3s ease;
}

/* Expanded State */
.faculty-area .accordion .accordion-item .accordion-header .accordion-button:not(.collapsed) {
  color: #ffffff !important;
  background: linear-gradient(135deg, #fc097c 0%, #4C0D6E 100%) !important;
  border-left: 4px solid #fc097c;
  box-shadow: 0 8px 20px rgba(252, 9, 124, 0.15) !important;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button::after {
  filter: grayscale(1) opacity(0.6);
  transition: transform 0.3s ease, filter 0.3s ease;
}

.faculty-area .accordion .accordion-item .accordion-header .accordion-button:not(.collapsed)::after {
  filter: brightness(0) invert(1) !important;
}

.faculty-accordion .accordion-body {
  padding: 25px 30px;
  background-color: #fff;
  border-top: 1px solid rgba(0, 0, 0, 0.04);
}


.faculty-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.faculty-list li {
  font-size: 16px;
  line-height: 1.8;
  color: #444;
  margin-bottom: 10px;
}

.faculty-list li:last-child {
  margin-bottom: 0;
}

.faculty-list li strong {
  color: #1a0a1e;
  display: inline-block;
  min-width: 130px;
}

.faculty-names {
  font-size: 16px;
  line-height: 1.8;
  color: #444;
  margin: 0;
}

