/* Font Families */
body {
   font-family: 'Montserrat', sans-serif !important;
   letter-spacing: 0.5px;
}

h1, h2, h3, h4, h5, h6 {
   font-family: 'Newsreader', serif;
   letter-spacing: 0.5px;
}

p {
   font-family: 'Montserrat', sans-serif;
   letter-spacing: 0.5px;
}

.main-landing-page {
   background-image: none !important;
}

.padbottom-20 {
   padding-bottom: 20px;
}

.slideHero.slideLanding-3 .swiper-slide {
   min-height: calc(85vh - 20px) !important;
}

@media (max-width: 575.98px) {
   .slideHero.slideLanding-3 .swiper-slide {
      min-height: calc(30vh - 42px) !important;
   }
}

@media (max-width: 991.98px) {
   .slideHero.slideLanding-3 .swiper-slide {
      min-height: calc(40vh - 42px) !important;
   }
}

.buttonfs23 {
   background-color: #ed591b;
   border: none;
   color: white;
   padding: 6px 22px;
   text-align: center;
   text-decoration: none;
   display: inline-block;
   margin: 4px 2px;
   transition-duration: 0.4s;
   cursor: pointer;
}

.buttonfs23:hover {
   background-color: #f44336;
   color: white;
}

.footer-share {
   z-index: 10000;
   pointer-events: auto;
}


.countdown-timer .countdown-segment {
   min-width: 80px;
}

.countdown-timer .countdown-value {
   font-family: 'Newsreader', serif;
   font-size: 2.5rem;
   color: #fff;
   display: block;
}

.countdown-timer .countdown-label {
   font-size: 0.85rem;
   letter-spacing: 2px;
   text-transform: uppercase;
   color: #ed591b;
}

.countdown-expired {
   color: #ed591b;
   font-weight: 600;
}

.row-festive {
   display: flex;
   justify-content: space-between;
   align-items: center;
   margin-bottom: 20px;
}

.image-container {
   width: 60%;
}

.image-container img {
   width: 100%;
   height: auto;
}

.text-container {
   width: 40%;
   padding-left: 80px;
}

.reverse {
   flex-direction: row-reverse;
}

@media (max-width: 1200px) {
   .row-festive {
      flex-direction: column;
   }

   .image-container {
      width: 100%;
   }

   .image-container img {
      width: 100%;
      height: auto;
   }

   .text-container {
      width: 100%;
      padding: 30px;
   }
}

@media (max-width: 768px) {
   .text-container {
      padding: 20px 16px;
   }

   .text-container h1,
   .text-container h2 {
      font-size: 24px !important;
   }

   .text-container h3 {
      font-size: 20px !important;
   }

   .text-container p,
   .text-container li {
      font-size: 15px !important;
   }
}

.banner-container {
   width: 100%;
   max-width: 1024px;
   height: 100%;
   position: relative;
}

.banner {
   display: flex;
   width: 100%;
   height: 100%;
   background: #fff;
   overflow: hidden;
}

.banner-image {
   flex: 1;
   max-width: 50%;
}

.banner-image img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   transition: opacity 0.5s ease;
}

.banner-content {
   flex: 1;
   max-width: 50%;
   display: flex;
   flex-direction: column;
   justify-content: center;
   padding: 20px;
   box-sizing: border-box;
}

.banner h1 {
   font-size: 1.65em;
   font-weight: bold;
   margin: 0 0 15px;
   transition: opacity 0.5s ease;
}

.banner p {
   font-size: 1.1em;
   margin: 15px 0;
   transition: opacity 0.5s ease;
}

.banner ul {
   list-style-type: disc;
   padding: 1.5rem;
}

.banner ul li {
   margin: 10px 0;
   font-size: 1.1em;
   color: #333;
   transition: opacity 0.5s ease;
}

.banner .button {
   display: inline-block;
   margin-top: 15px;
   padding: 10px 20px;
   background-color: #F37021;
   color: white;
   text-decoration: none;
   font-weight: bold;
   transition: background-color 0.3s ease, opacity 0.5s ease;
}

.banner .button:hover,
.banner .button:focus {
   background-color: #a06b62;
}

@media (max-width: 768px) {
   .banner {
      flex-direction: column;
   }

   .banner-image,
   .banner-content {
      max-width: 100%;
   }

   .banner-content {
      padding: 16px;
   }

   .banner h1 {
      font-size: 1.35em;
   }

   .banner p {
      font-size: 0.95em;
   }

   .banner ul {
      padding: 1rem;
   }

   .banner ul li {
      font-size: 0.95em;
   }
}

.fancybox__content>.carousel__button.is-close {
   top: 20px;
   left: 1280px;
   color: black;
}

@media (max-width: 768px) {
   .fancybox__content>.carousel__button.is-close {
      top: 20px;
      left: 336px;
      color: white;
   }
}

/* Calendar Slider Container */
.calendar-slider-container {
   max-width: 1200px;
   margin: 0 auto;
   padding: 40px 20px;
}

.calendar-grid {
   display: grid;
   grid-template-columns: 1fr 1fr;
   align-items: stretch;
   border-bottom: solid #F37021 12px;
}

.event-display,
.festive-calendar-wrapper {
   height: 100%;
   display: flex;
   flex-direction: column;
}

/* Event Display */
.event-display {
   background: white;
   position: relative;
}

.event-nav-buttons {
   margin-top: 20px;
   display: flex;
   justify-content: center;
   gap: 15px;
   position: static;
   transform: none;
   width: auto;
   padding: 0;
}

.event-nav-btn {
   width: 40px;
   height: 40px;
   background: rgba(243, 112, 33, 0.9);
   border: none;
   color: white;
   font-size: 20px;
   cursor: pointer;
   transition: all 0.3s ease;
   display: flex;
   align-items: center;
   justify-content: center;
}

.event-nav-btn:hover {
   background: rgba(243, 112, 33, 1);
   transform: scale(1.1);
}

.event-nav-btn:disabled {
   opacity: 0.3;
   cursor: not-allowed;
}

.event-nav-btn:disabled:hover {
   transform: none;
}

.event-indicators {
   position: absolute;
   bottom: -40px;
   left: 50%;
   transform: translateX(-50%);
   display: flex;
   gap: 10px;
   z-index: 3;
}

.event-indicator {
   width: 12px;
   height: 12px;
   background: #ccc;
   cursor: pointer;
   transition: all 0.3s ease;
}

.event-indicator.active {
   background: #F37021;
   width: 30px;
}

.event-image-slideshow {
   position: relative;
   width: 100%;
   height: 500px;
   overflow: hidden;
}

.event-image {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 500px;
   object-fit: cover;
   opacity: 0;
   transition: opacity 0.8s ease-in-out;
   z-index: 1;
}

.event-image.active {
   opacity: 1;
   z-index: 2;
}

.event-info-card {
   background: white;
   padding: 30px;
   margin-top: auto;
   position: relative;
   z-index: 2;
   box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
   height: 460px;
   overflow: hidden;
}

.event-date-badge {
   display: inline-block;
   background: #F37021;
   color: white;
   padding: 8px 20px;
   font-size: 14px;
   font-weight: bold;
   margin-bottom: 15px;
}

.event-title {
   font-size: 28px;
   font-weight: bold;
   color: #000;
   margin-bottom: 20px;
   text-transform: uppercase;
}

.event-description {
   font-size: 15px;
   line-height: 1.6;
   color: #333;
   margin-bottom: 25px;
}

.event-details {
   display: grid;
   gap: 12px;
   padding-top: 20px;
   border-top: 1px solid #e0e0e0;
}

.event-detail-row {
   display: flex;
   align-items: flex-start;
   gap: 10px;
   font-size: 14px;
}

.event-detail-label {
   font-weight: bold;
   color: #000;
   min-width: 80px;
}

.event-detail-value {
   color: #333;
}

/* Festive Calendar */
.festive-calendar-wrapper {
   background: #EEEEEE;
   padding: 30px;
}

.festive-calendar-header {
   text-align: center;
   margin-bottom: 30px;
}

.festive-calendar-title {
   font-size: 24px;
   font-weight: bold;
   color: #333;
   margin-bottom: 10px;
}

.festive-calendar-month {
   font-size: 28px;
   font-weight: bold;
   color: #000;
   margin: 0;
}

.festive-calendar-weekdays {
   display: grid;
   grid-template-columns: repeat(7, 1fr);
   gap: 8px;
   margin-bottom: 15px;
}

.festive-calendar-weekday {
   text-align: center;
   font-weight: bold;
   font-size: 14px;
   color: #666;
   padding: 10px 0;
}

.festive-calendar-days {
   display: grid;
   grid-template-columns: repeat(7, 1fr);
   gap: 8px;
}

.festive-calendar-day {
   aspect-ratio: 1;
   display: flex;
   align-items: center;
   justify-content: center;
   font-size: 16px;
   color: #333;
   cursor: pointer;
   transition: all 0.3s ease;
   position: relative;
}

.festive-calendar-day:hover {
   background: #f5f5f5;
}

.festive-calendar-day.has-event {
   background: #F37021;
   color: white;
   font-weight: bold;
}

.festive-calendar-day.has-event:hover {
   background: #d85e18;
}

.festive-calendar-day.active {
   background: #000;
   color: white;
   font-weight: bold;
}

.festive-calendar-day.empty {
   cursor: default;
}

.event-list {
   margin-top: 30px;
   padding-top: 30px;
   border-top: 2px solid #e0e0e0;
}

.event-list-title {
   font-size: 18px;
   font-weight: bold;
   color: #000;
   margin-bottom: 20px;
}

.event-list-item {
   padding: 15px;
   margin-bottom: 10px;
   cursor: pointer;
}

.event-list-item:hover {
   color: #F37021;
}

.event-list-item.active {
   color: #F37021;
}

.event-list-date {
   font-weight: bold;
   color: #F37021;
   font-size: 13px;
   margin-bottom: 5px;
}

.event-list-name {
   color: #333;
   font-size: 15px;
}

.event-list-item.active .event-list-name {
   color: #F37021;
   font-weight: bold;
}

.event-status {
   display: inline-block;
   padding: 4px 10px;
   font-size: 12px;
   margin-top: 8px;
   font-weight: bold;
}

.event-status.ongoing {
   background: #4CAF50;
   color: white;
}

.event-status.ending {
   background: #FF9800;
   color: white;
}

@media (max-width: 1024px) and (min-width: 769px) {
   .calendar-grid {
      grid-template-columns: 1fr 1fr;
   }

   .event-image-slideshow {
      height: 350px;
   }

   .event-image {
      height: 350px;
   }

   .event-image-wrapper {
      height: 350px;
   }

   .event-image-wrapper img {
      object-fit: cover;
   }

   .event-info-card {
      height: 380px;
      padding: 24px;
   }

   .event-title {
      font-size: 22px;
   }

   .festive-calendar-wrapper {
      padding: 24px;
   }
}

@media (max-width: 768px) {
   .calendar-slider-container {
      padding: 20px 10px;
   }

   .event-info-card {
      padding: 20px 16px;
      margin-left: 0;
      margin-right: 0;
      height: auto;
      min-height: 420px;
   }

   .event-title {
      font-size: 20px;
   }

   .event-description {
      font-size: 14px;
   }

   .event-image {
      height: 300px;
   }

   .event-image-wrapper {
      height: 300px;
   }

   .event-image-wrapper img {
      object-fit: cover;
   }

   .festive-calendar-wrapper {
      padding: 20px 16px;
   }

   .festive-calendar-day {
      font-size: 13px;
   }

   .festive-calendar-month {
      font-size: 24px;
   }

   .festive-calendar-title {
      font-size: 20px;
   }
}

.event-image-wrapper {
   position: relative;
   width: 100%;
   height: 500px;
}

.event-image-wrapper img {
   width: 100%;
   height: 100%;
   object-fit: cover;
}

@media (max-width: 1024px) {
   .event-image-slideshow {
      height: 300px;
   }

   .event-image {
      height: 300px;
   }

   .event-image-wrapper {
      height: 300px;
   }
}

.event-progress {
   position: absolute;
   bottom: 0;
   left: 0;
   width: 100%;
   height: 5px;
   background: rgba(0, 0, 0, 0.2);
   overflow: hidden;
}

.event-progress-bar {
   width: 0%;
   height: 100%;
   background: #F37021;
   transition: width 5s linear;
}

/* Activity Grid */
.activity-grid {
   display: block;
   padding: 20px 48px 28px;
}

@media (min-width: 1200px) {
   .activity-grid {
      display: grid;
      grid-template-columns: 520px 1fr;
      gap: 48px;
   }

   .activity-grid-left {
      display: flex !important;
   }

   .activity-grid-right {
      display: block !important;
   }

   .activity-card-mobile {
      display: none !important;
   }

   .activity-thumb,
   .activity-meta {
      display: block !important;
   }
}

@media (max-width: 1400px) and (min-width: 1200px) {
   .activity-grid {
      grid-template-columns: 420px 1fr;
      gap: 32px;
      padding: 20px 24px 28px;
   }
}

.activity-grid-left {
   display: flex;
   flex-direction: column;
   gap: 16px;
   padding-right: 4px;
   scroll-behavior: smooth;
}

.activity-grid-right {
   overflow: visible;
}

.activity-card {
   display: grid;
   grid-template-columns: 160px 1fr;
   gap: 16px;
   align-items: center;
   background: transparent;
   border: none;
   border-bottom: 1px solid rgba(0, 0, 0, 0.08);
   padding: 16px 8px;
   cursor: pointer;
   transition: background .2s ease, border-color .2s ease;
}

.activity-card:hover {
   background: rgba(0, 0, 0, 0.02);
}

.activity-card.active {
   border-left: 3px solid #F37021;
   background: rgba(243, 112, 33, 0.03);
}

.activity-thumb {
   width: 160px;
   height: 120px;
   overflow: hidden;
   flex-shrink: 0;
}

.activity-thumb img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   display: block;
}

.activity-meta h4 {
   font-size: 18px;
   font-weight: 700;
   color: #000;
   margin: 0 0 6px;
   text-transform: uppercase;
   line-height: 1.25;
}

.activity-meta .sub {
   font-size: 13px;
   color: #666;
   margin-bottom: 6px;
}

.activity-meta .chips {
   display: flex;
   flex-wrap: wrap;
   gap: 6px;
}

.chip {
   font-size: 12px;
   font-weight: 700;
   padding: 4px 8px;
   border-radius: 999px;
   background: #f5f5f5;
   color: #333;
}

.chip.orange {
   background: #F37021;
   color: #fff;
}

.chip.blue {
   background: #000;
   color: #fff;
}

.chip.ghost {
   background: #eee;
   color: #555;
}

/* Activity Detail */
.activity-detail-container {
   position: sticky;
   top: 111px;
}

.activity-item-detail {
   display: grid;
   grid-template-columns: 1fr 450px;
   gap: 20px;
}

.activity-detail-cover {
   width: 100%;
   margin: 0;
   overflow: hidden;
   background: #fafafa;
}

.activity-detail-cover img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   display: block;
}

.activity-detail-side {
   display: flex;
   flex-direction: column;
   gap: 14px;
}

.activity-tags {
   list-style: none;
   padding: 0;
   margin: 0;
   display: flex;
   flex-wrap: wrap;
   gap: 8px;
}

.activity-tags li {
   font-size: 12px;
   background: #eef4fa;
   color: #000;
   padding: 6px 10px;
   font-weight: 700;
}

.activity-mini-gallery {
   display: grid;
   grid-template-columns: repeat(2, 1fr);
   gap: 8px;
}

.activity-mini-gallery img {
   width: 100%;
   height: 86px;
   object-fit: cover;
}

/* Tablet - แสดงแบบ accordion 2 columns */
@media (max-width: 1199px) and (min-width: 769px) {
   .activity-grid {
      grid-template-columns: 1fr;
      gap: 0;
      padding: 20px 24px;
   }

   .activity-grid-left {
      max-height: unset;
      overflow: visible;
      display: grid !important;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
      padding-right: 0;
   }

   .activity-grid-right {
      display: none !important;
   }

   .activity-thumb,
   .activity-meta {
      display: none !important;
   }

   .activity-card-mobile {
      display: flex !important;
   }

   .activity-card {
      display: block !important;
      grid-template-columns: unset !important;
      border: none !important;
      border-bottom: 1px solid #e5e5e5 !important;
      border-radius: 0 !important;
      overflow: visible;
      margin-bottom: 0;
      cursor: default;
      box-shadow: none !important;
      transform: none !important;
      padding: 0;
      background: transparent;
   }

   .activity-card:hover {
      box-shadow: none !important;
      transform: none !important;
      background: #fafafa;
   }

   .activity-card-mobile {
      display: flex;
      flex-direction: column;
      background: transparent;
   }

   .mobile-card-header {
      cursor: pointer;
      transition: background 0.2s ease;
   }

   .activity-card-image-wrapper {
      width: 100%;
      height: 240px;
      overflow: hidden;
      position: relative;
   }

   .activity-card-image-wrapper img {
      width: 100%;
      height: 100%;
      object-fit: cover;
   }

   .mobile-card-header-content {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 20px 8px;
   }

   .activity-card-title {
      font-size: 16px;
      font-weight: 600;
      color: #333;
      margin: 0;
      text-transform: none;
      letter-spacing: 0;
      flex: 1;
      line-height: 1.4;
   }

   .mobile-card-toggle {
      font-size: 16px;
      color: #999;
      margin-left: 16px;
      transition: transform 0.2s ease, color 0.2s ease;
      flex-shrink: 0;
   }

   .activity-card.active .mobile-card-toggle {
      color: #333;
   }

   .activity-card.active .mobile-card-toggle {
      transform: rotate(180deg);
      display: inline-block;
   }

   .mobile-card-collapse {
      max-height: 0;
      overflow: hidden;
      padding: 0 8px;
      transition: max-height 0.3s ease, padding 0.3s ease;
   }

   .activity-card.active .mobile-card-collapse {
      max-height: 1200px;
      padding: 0 8px 20px 8px;
   }

   .activity-card-description {
      font-size: 14px;
      line-height: 1.6;
      color: #666;
      margin: 0 0 16px 0;
   }

   .activity-card-meta {
      display: flex;
      flex-direction: column;
      gap: 8px;
   }

   .meta-row {
      display: flex;
      align-items: baseline;
      gap: 8px;
      font-size: 13px;
   }

   .meta-label {
      font-weight: bold;
      color: #000;
      min-width: 55px;
      font-size: 13px;
   }

   .meta-value {
      color: #333;
      flex: 1;
      font-size: 13px;
   }

   .chip {
      font-size: 11px;
      padding: 3px 8px;
   }
}

/* Mobile Events Section */
.mobile-events-section {
   padding: 40px 16px;
   background: #fff;
}

.mobile-events-title {
   font-size: 24px;
   font-weight: bold;
   color: #000;
   text-align: center;
   margin-bottom: 24px;
   text-transform: uppercase;
}

.event-pills-container {
   overflow-x: auto;
   -webkit-overflow-scrolling: touch;
   margin-bottom: 24px;
   scrollbar-width: none;
}

.event-pills-container::-webkit-scrollbar {
   display: none;
}

.event-pills {
   display: flex;
   gap: 8px;
   padding: 4px 0;
   min-width: min-content;
}

.event-pill {
   flex-shrink: 0;
   padding: 10px 20px;
   background: #f5f5f5;
   border: 2px solid #e0e0e0;
   border-radius: 24px;
   font-size: 14px;
   font-weight: 600;
   color: #666;
   cursor: pointer;
   white-space: nowrap;
   transition: all 300ms ease-in-out;
}

.event-pill.active {
   background: #F37021;
   border-color: #F37021;
   color: #fff;
}

.event-pill:hover {
   border-color: #F37021;
}

.mobile-event-cards {
   display: flex;
   flex-direction: column;
   gap: 24px;
}

.mobile-event-card {
   display: none;
   flex-direction: column;
   background: #fff;
   border: 1px solid #e0e0e0;
   overflow: hidden;
}

.mobile-event-card.active {
   display: flex;
}

.mobile-event-card-image {
   width: 100%;
   height: 220px;
   object-fit: cover;
}

.mobile-event-card-body {
   padding: 20px;
}

.mobile-event-card-date {
   display: inline-block;
   background: #F37021;
   color: #fff;
   padding: 6px 16px;
   font-size: 13px;
   font-weight: bold;
   margin-bottom: 12px;
}

.mobile-event-card-title {
   font-size: 22px;
   font-weight: bold;
   color: #000;
   margin: 0 0 12px 0;
   text-transform: uppercase;
}

.mobile-event-card-description {
   font-size: 15px;
   line-height: 1.6;
   color: #333;
   margin: 0 0 16px 0;
}

.mobile-event-card-details {
   display: flex;
   flex-direction: column;
   gap: 8px;
   padding-top: 16px;
   border-top: 1px solid #e0e0e0;
}

.mobile-event-card-detail {
   display: flex;
   gap: 8px;
   font-size: 14px;
}

.mobile-event-card-detail-label {
   font-weight: bold;
   color: #000;
   min-width: 60px;
}

.mobile-event-card-detail-value {
   color: #333;
   flex: 1;
}

.mobile-event-progress {
   display: none;
   width: calc(100% - 40px);
   margin: 8px 20px 16px 20px;
   height: 3px;
   background: #eee;
   overflow: hidden;
}

.mobile-event-progress-bar {
   width: 0%;
   height: 100%;
   background: #F37021;
   transition: width 4s linear;
}

.mobile-event-card.with-progress.active .mobile-event-progress {
   display: block;
}

/* Landing Menu Hover Effects */
.landing-menu>div[class*="col-"] {
   overflow: hidden;
}

.landing-menu>div[class*="col-"]:hover .position-absolute[style*="background: url"] {
   transform: scale(1.1);
   transition: transform 0.5s ease;
}

.landing-menu>div[class*="col-"] .position-absolute[style*="background: url"] {
   transition: transform 0.5s ease;
}

.landing-menu>div[class*="col-"]:hover .position-absolute[style*="rgba(0,0,0"] {
   background: rgba(0, 0, 0, 0.2) !important;
}

.landing-menu>div[class*="col-"] .position-relative.h-100 {
   transition: transform 0.3s ease;
   letter-spacing: 0.5px;
}

.landing-menu>div[class*="col-"]:hover .position-relative.h-100 {
   transform: scale(1.05);
}

@media (max-width: 768px) {
   .landing-menu>div[class*="col-"] {
      height: 120px !important;
   }

   h2[style*="padding: 0 48px"] {
      padding: 16px !important;
      font-size: 22px !important;
   }

   #audTabs {
      padding: 0 16px 6px !important;
   }

   .activity-grid {
      grid-template-columns: 1fr;
      gap: 0;
      padding: 16px;
   }

   .activity-grid-left {
      max-height: unset;
      overflow: visible;
      display: flex !important;
      flex-direction: column;
      gap: 16px;
      padding-right: 0;
   }

   .activity-grid-right {
      display: none !important;
   }

   .activity-thumb,
   .activity-meta {
      display: none !important;
   }

   .activity-card-mobile {
      display: flex !important;
   }

   .activity-card {
      display: block !important;
      grid-template-columns: unset !important;
      border: none !important;
      border-bottom: 1px solid #e5e5e5 !important;
      border-radius: 0 !important;
      overflow: visible;
      margin-bottom: 0;
      cursor: default;
      box-shadow: none !important;
      transform: none !important;
      padding: 0;
   }

   .activity-card:hover {
      box-shadow: none !important;
      transform: none !important;
   }

   .activity-card-mobile {
      display: flex;
      flex-direction: column;
      background: transparent;
   }

   .mobile-card-header {
      cursor: pointer;
   }

   .activity-card-image-wrapper {
      width: 100%;
      height: 220px;
      overflow: hidden;
      position: relative;
   }

   .activity-card-image-wrapper img {
      width: 100%;
      height: 100%;
      object-fit: cover;
   }

   .mobile-card-header-content {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 18px 0;
   }

   .activity-card-title {
      font-size: 16px;
      font-weight: 600;
      color: #333;
      margin: 0;
      text-transform: none;
      letter-spacing: 0;
      flex: 1;
      line-height: 1.4;
   }

   .mobile-card-toggle {
      font-size: 16px;
      color: #999;
      margin-left: 16px;
      transition: transform 0.2s ease, color 0.2s ease;
      flex-shrink: 0;
   }

   .activity-card.active .mobile-card-toggle {
      transform: rotate(180deg);
      display: inline-block;
      color: #333;
   }

   .mobile-card-collapse {
      max-height: 0;
      overflow: hidden;
      padding: 0;
      transition: max-height 0.3s ease, padding 0.3s ease;
   }

   .activity-card.active .mobile-card-collapse {
      max-height: 1200px;
      padding: 0 0 18px 0;
   }

   .activity-card-description {
      font-size: 14px;
      line-height: 1.6;
      color: #666;
      margin: 0 0 16px 0;
   }

   .activity-card-meta {
      display: flex;
      flex-direction: column;
      gap: 8px;
   }

   .meta-row {
      display: flex;
      align-items: baseline;
      gap: 8px;
      font-size: 13px;
   }

   .meta-label {
      font-weight: bold;
      color: #000;
      min-width: 55px;
      font-size: 13px;
   }

   .meta-value {
      color: #333;
      flex: 1;
      font-size: 13px;
   }

   .chip {
      font-size: 11px;
      padding: 3px 8px;
   }
}

[role="tablist"] [role="tab"] {
   background: none;
   border: 0;
   padding: 0 2px;
   cursor: pointer;
   font: 600 22px/1.1 system-ui, Segoe UI, Arial;
   color: #000;
}

[role="tablist"] [role="tab"][aria-selected="true"] {
   color: #F37021;
   text-decoration: underline;
}

.image-slider {
   position: relative;
   width: 100%;
   height: 100%;
   min-height: 600px;
   overflow: hidden;
}

.image-slider img {
   position: absolute;
   inset: 0;
   width: 100%;
   height: 100%;
   object-fit: cover;
   opacity: 0;
   transition: opacity 0.7s ease-in-out;
}

.image-slider img.active {
   opacity: 1;
}

@media (max-width: 1200px) {
   .image-slider {
      min-height: 450px;
   }
}

@media (max-width: 991px) {
   .image-slider {
      display: none !important;
   }

   .bg-org .col-lg-6:first-child {
      order: 2;
   }
}

.footer {
   z-index: 100 !important;
}

.view-bc:hover {
   text-decoration: underline !important;
}


/* Activity Mobile Swiper */
.activity-swiper-mobile {
   padding: 40px 20px;
   background: #fff;
}

.activityMobileSwiper .swiper-slide {
   background: #fff;
   border: 1px solid #e0e0e0;
   overflow: hidden;
   height: auto;
}

.activity-mobile-card-image {
   width: 100%;
   height: 250px;
   object-fit: cover;
}

.activity-mobile-card-content {
   padding: 24px;
}

.activity-mobile-card-title {
   font-size: 22px;
   font-weight: bold;
   color: #000;
   margin: 0 0 16px 0;
   text-transform: uppercase;
   font-family: 'Newsreader', serif;
}

.activity-mobile-card-description {
   font-size: 15px;
   line-height: 1.6;
   color: #666;
   margin: 0 0 20px 0;
}

.activity-mobile-card-details {
   display: flex;
   flex-direction: column;
   gap: 12px;
   padding-top: 20px;
   border-top: 1px solid #e0e0e0;
}

.activity-mobile-card-detail {
   display: flex;
   gap: 8px;
   font-size: 14px;
}

.activity-mobile-detail-label {
   font-weight: bold;
   color: #000;
   min-width: 70px;
}

.activity-mobile-detail-value {
   color: #333;
   flex: 1;
}

.activityMobileSwiper .swiper-pagination {
   position: relative;
   margin-top: 24px;
}

.activityMobileSwiper .swiper-pagination-bullet {
   width: 10px;
   height: 10px;
   background: #ccc;
   opacity: 1;
}

.activityMobileSwiper .swiper-pagination-bullet-active {
   background: #F37021;
   width: 24px;
   border-radius: 5px;
}

@media (max-width: 768px) {
   .activity-swiper-mobile {
      padding: 30px 16px;
   }

   .activity-mobile-card-image {
      height: 220px;
   }

   .activity-mobile-card-content {
      padding: 20px;
   }

   .activity-mobile-card-title {
      font-size: 20px;
   }
}

/* Hide accordion on mobile only (not tablet), show swiper */
@media (max-width: 768px) {
   .activity-grid-left {
      display: none !important;
   }

   .activity-swiper-mobile {
      display: block !important;
   }
}

/* Hide swiper on desktop and tablet */
@media (min-width: 769px) {
   .activity-swiper-mobile {
      display: none !important;
   }
}

/* Gallery List Container (Vertical Layout) */
.gallery-list-container {
   padding: 1rem 0;
}

.gallery-list-item {
   margin-bottom: 2rem;
   padding-bottom: 2rem;
   border-bottom: 1px solid #e0e0e0;
}

.gallery-list-item:last-child {
   border-bottom: none;
   margin-bottom: 0;
   padding-bottom: 0;
}

.gallery-list-item img {
   width: 100%;
   object-fit: cover;
   margin-bottom: 1rem;
}

.gallery-list-item h5 {
   font-weight: bold;
   margin-bottom: 0.5rem;
}

.gallery-list-item .collapse {
   margin-top: 1rem;
}

.gallery-list-item .btn-link:hover {
   text-decoration: none;
}

.gallery-list-item .accordion-icon {
   transition: transform 0.3s ease;
}

.gallery-list-item .btn-link[aria-expanded="true"] .accordion-icon {
   transform: rotate(45deg);
}

@media (max-width: 768px) {
   .gallery-list-item {
      margin-bottom: 1.5rem;
      padding-bottom: 1.5rem;
   }
}
