/* ==============================================================================
 ROOT & RESET 
 ================================================================================ */
:root{
  --accent: #004d40;
  --accent-2: #26b832;
  --primary:#fc8f00;
  --primary-shade: rgba(252, 143, 0, 0.5);
  --primary-2:#ffc013;
  /* --accent: #ff7d13;
  --accent-2:#93c5ff; */
  --accent-light:#e8f5e9;
  --muted-white: rgba(255,255,255,0.92);
  --glass: rgba(255,255,255,0.06);
  --glass-2: rgba(255,255,255,0.12);
  /* --bg-img: url('https://images.unsplash.com/photo-1508609349937-5ec4ae374ebf?auto=format&fit=crop&w=1800&q=80'); */
  --bg-img: url('/asset/banner/banner.jpeg');
  --max-width: 75vw;
  --radius: 12px;
  --shadow: 0 10px 30px rgba(4,6,15,0.6);
  /* --background-shade-light:rgba(76,175,80,0.2); */
  --background-shade-light:rgba(255, 123, 0, 0.2);
  /* font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial; */
  font-family: "Lora", serif;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color: #fff;
  /* background: linear-gradient(180deg, var(--accent-2), var(--accent-light)); */
  /* background: var(--accent-light); */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
[data-src] {opacity: 0;transition: opacity 0.6s ease;}
img:not([data-src]) {opacity: 1;}
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 20px}
.underline{position: relative;width:max-content;}
.underline::before{
  content: '';
  background:linear-gradient(90deg, var(--primary), var(--accent-2));
  left: 0;
  bottom: 0;
  height: 0.5rem;
  width: 35%;
  position: absolute;
}
/* ==============================================================================
 NAVBAR 
 ================================================================================ */
header.top-header{
  position:relative;
}
header.site-header{
  position:relative;
  inset:0 0 auto 0;
  z-index:80;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px 0;
  backdrop-filter: blur(6px);
  background: linear-gradient(180deg, rgba(6,10,25,0.28), rgba(6,10,25,0.12));
  border-bottom: 1px solid rgba(255,255,255,0.03);
}
.site-header.color-change {
    background-color: rgba(0, 0, 0, 0.8);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
  }
header.site-header.sticky {
    z-index: 9999;
    position: fixed;
    top: 0;
    background: rgba(10, 15, 30, 0.85);
    box-shadow: 0 6px 20px rgba(0,0,0,0.15);
    backdrop-filter: blur(10px);
    animation: slideDown 0.7s ease forwards;
  }
  
  @keyframes slideDown {
    from { transform: translateY(-100%); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
  }
.nav-inner{width:100%;max-width:var(--max-width);display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{
    display:none;
}
.site-title{font-weight:700;font-size:1rem;line-height:1}
.site-title img{
    position: relative;
    height: 5rem;
    border-radius: 0.5rem;
}
nav.main-nav{display:flex;gap:14px;align-items:center}
nav.main-nav a{padding:8px 12px;border-radius:10px;color:rgba(255,255,255,0.9);font-weight:600}
nav.main-nav a:hover{background:rgba(255,255,255,0.04)}
.cta-register{background:linear-gradient(90deg,var(--accent),var(--accent-2));padding:9px 14px;border-radius:12px;color:white;font-weight:700;box-shadow:0 8px 24px rgba(64,80,201,0.18)}

/* mobile nav */
.hamburger{display:none;background:transparent;border:0;color:inherit;padding:8px;border-radius:8px}
@media (max-width:920px){
  nav.main-nav{display:none}
  .hamburger{display:inline-flex}
}
/* ==============================================================================
 FIRST-MODAL-POPUP
 ================================================================================ */
/* Overlay */
/* Overlay */
#onload-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease;
  z-index: 1000;
}

/* Close button */
#onload-modal .close-btn {
  position: absolute;
  top: 8px;
  right: 10px;

  background: transparent;
  border: none;
  font-size: 24px;
  font-weight: bold;
  cursor: pointer;
  color: #333;

  line-height: 1;
}

#onload-modal .close-btn:hover {
  color: #000;
}
/* Show modal */
#onload-modal.active {
  opacity: 1;
  visibility: visible;
}

/* Modal content box */
#onload-modal .modal-content {
  background: #fff;
  border-radius: 8px;
  padding: 20px;
  padding-top: 20px;
  position: relative;
  /* width: 90%;
  max-width: 00px; */

  height: auto;
  max-height: 70vh;          /* limit modal height */

  display: flex;
  align-items: center;
  justify-content: center;

  animation: fadeIn 0.25s ease;
  box-sizing: border-box;
}

/* Image sizing */
#onload-modal img {
  /* width: 80%; */
  height: auto;

  max-height: 70vh;         /* THIS controls vertical size */
  object-fit: contain;

  margin: 0 auto;
  padding: 0;
}

/* Fade animation */
@keyframes fadeIn {
  from { transform: scale(0.95); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

/* ==============================================================================
 HERO & INTRO
 ================================================================================ */
.hero-wrap{
  min-height:88vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:78px;padding-bottom:48px;
}
.hero-bg{
  position:absolute;inset:0;background-image:var(--bg-img);background-size:cover;background-position:center;z-index:0;
  transform:scale(1.04);filter:saturate(1.05) contrast(0.9) brightness(0.9);
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(15, 75, 18, 0.7), rgba(6,10,25,0.6));z-index:1}
.hero{
  position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1fr 400px;gap:28px;align-items:center;
}
/* .hero-left{padding:20px;} */
.hero-left{text-align: center;margin:auto}
.eyebrow{display:inline-block;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,0.04);margin-top:16px;margin-bottom:16px;font-weight:600;font-size:clamp(0.9rem,2vw,1.7rem);}
.eyebrow.bg-primary{background:var(--primary);}
.eyebrow.bg-secondary{background:var(--primary-2);}
h1.hero-title{font-size:clamp(2.2rem,5vw,4.9rem);line-height:1;margin:0 0 14px 0;}
h2.hero-title{font-size:clamp(1.8rem,5vw,3.5rem);line-height:1;margin:0 0 3rem 0;}
/* p.lead{margin:0 0 20px 0;color:rgba(255,255,255,0.92);max-width:60ch;font-size:clamp(0.9rem,2vw,1.2rem);} */
p.lead{color:rgba(255,255,255,0.92);font-size:clamp(0.9rem,2vw,1.5rem); text-align: center;}
.cta-row{display:flex;gap:12px;flex-wrap:wrap; align-items: center;justify-content: center;}
.btn{font-size:1.2rem; display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:28px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.04);color:white;font-weight:700;cursor:pointer;backdrop-filter:blur(6px);transition:all .18s ease}
.btn:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(5,6,15,0.6)}
.btn.primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));border:0}
.meta-cards{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}
.appear-left{
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.appear-right{
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.appear-left.in-view, .appear-right.in-view{
  opacity: 1;
  transform: translateX(0);
}
.card{
  background:linear-gradient(180deg,rgba(255,255,255,0.5),rgba(255,255,255,0.05));
  padding:12px 16px;border-radius:14px;border:1px solid rgba(255,255,255,0.04);min-width:120px;backdrop-filter:blur(6px)
}
.card h3{margin:0;font-size:1.1rem}
.card p{margin:6px 0 0 0;font-size:0.9rem;color:rgba(255,255,255,0.75)}

/* right column - route snapshot + countdown */
.hero-right{padding:18px;background:linear-gradient(180deg,rgba(255,255,255,0.2),rgba(255,255,255,0.02));border-radius:18px;border:0px solid rgba(255,255,255,0.04);backdrop-filter:blur(6px)}
.route-thumb{height:420px;border-radius:12px;overflow:hidden;margin-bottom:12px}
.route-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.countdown{display:flex;gap:10px;justify-content:space-between}
.countdown .unit{flex:1;background:rgba(255,255,255,0.03);padding:10px;border-radius:10px;text-align:center}
.countdown .unit .num{font-weight:800;font-size:1.5rem}
.countdown .unit .label{font-size:0.8rem;color:rgba(255,255,255,0.78)}

/* ==============================================================================
 SECTION STYLE- COMMON
 ================================================================================ */
section{padding:64px 0}
.section-title{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.section-title{
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.section-title.appear {
  opacity: 1;
  transform: translateX(0);
}
.section-title h2{margin:0;font-size:3rem;}
.section-sub{color:var(--accent);margin:0 0 24px 0;}
.light-text{color:var(--accent-light);font-size: 1.2rem;}
.dark-text{color:var(--accent);font-size: 1.2rem;}

/* ==============================================================================
 ABOUT EVENT
 ================================================================================ */
#about{
    /* background-color: var(--accent-light); */
    background-color: #fff;
}
.about-wrap{display:grid;grid-template-columns:1fr 500px;gap:28px;align-items:center;color: var(--accent);}
.feature-list{display:grid;gap:12px;color: var(--accent); }
.feature{display:flex;gap:12px;align-items:flex-start;background:var(--accent-light);padding:12px;border-radius:12px;border:1px solid rgba(232,245,233,0.03);}
.feature .icon{width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:grid;place-items:center;font-weight:800;color:var(--accent)}
.icon i {color: #fff;font-size: 32px;width: 48px; text-align: center;}
.feature-card{padding:18px;border-radius:12px;background:linear-gradient(180deg,var(--accent-light),var(--accent-light));box-shadow: 0 2px 4px 2px rgb(0 0 0 / 10%);}
.feature-thumb{height:420px;border-radius:12px;overflow:hidden;margin-bottom:12px}
.feature-thumb img{width:100%;height:100%;object-fit:fill;display:block}
/* ==============================================================================
 MAPS CARDS
 ================================================================================ */
 #maps{    background-color: var(--primary-2); }
 .map-container{    display: grid;    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); /* responsive auto-fit grid */    gap: 2rem;    justify-items: center;    align-items: stretch;    width: 100%;margin: 0 auto; }

.map-card{padding:18px;border-radius:12px;background:linear-gradient(180deg,var(--accent),var(--accent));box-shadow: 0 2px 4px 2px rgb(0 0 0 / 10%);}
.map-card {
  transform: scale(0.8);
  opacity: 0;
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.map-card.appear {
  transform: scale(1);
  opacity: 1;
}
.map-thumb{height:80%; border-radius:12px;overflow:hidden;margin-bottom:12px}
.map-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
/* ==============================================================================
 SCHEDULE GRID
 ================================================================================ */
 #schedule{background-color: var(--accent-light);color: var(--accent);}
 .schedule-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
 .sched-item{padding:12px;background:linear-gradient(135deg,var(--primary),var(--primary-2));border-radius:10px;border:1px solid rgba(255,255,255,0.03);
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.sched-item.appear{
  opacity: 1;
  transform: translateY(0);
}
 .sched-item .sched-item-heading {font-size: 2rem;}
 .sched-item .sched-item-text {font-size: 1.5rem;}
 
/* ==============================================================================
 EVENT CATERGORIES
 ================================================================================ */
#events{  background-color: var(--accent);}
/* Cards Container */
.cards-container {    display: grid;    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); /* responsive auto-fit grid */    gap: 2rem;    justify-items: center;    align-items: stretch;    width: 100%;    margin: 0 auto;}
/* Individual Event Card */
.event-card {border-radius: 20px;overflow: hidden;box-shadow: 0 2px 8px rgba(0,0,0,0.15);display: flex;flex-direction: column;transition: transform 0.3s ease, box-shadow 0.3s ease;
  transform: translateY(100px);opacity: 0;transition: transform 0.8s cubic-bezier(0.645, 0.045, 0.355, 1), opacity 0.8s;
  /* opacity: 0;transform: translateX(-100px);transition: opacity 0.6s ease-out, transform 0.6s ease-out; */
}
.event-card.is-inview{
  transform: translateY(0);
opacity: 1;
}  
/* Optional: Add a staggered effect */
.event-card:nth-child(2) {
  transition-delay: 0.1s;
}
.event-card:nth-child(3) {
  transition-delay: 0.2s;
}
.event-card:nth-child(4) {
  transition-delay: 0.3s;
}
/* .event-card.appear{opacity: 1;transform: translateX(0);} */
/* Image Section (Top Half) - Simulated Backgrounds and Text */
.card-image-section {    position: relative;    height: 200px;    overflow: hidden;    background-size: cover;    background-position: center;    position: relative;    overflow: hidden;    color: #fff;}
/* Details Section (Bottom Half) */
.card-details-section {    padding: 1.5rem;    background: rgba(255, 255, 255, 0.08);    color: #fff;    flex-grow: 1;    display: flex;    flex-direction: column;    justify-content: space-between;    border-top: 1px solid rgba(255,255,255,0.08);}
.event-title {    font-size: 1.4rem;    font-weight: 800;    margin-bottom: 0.8rem;    color: #fff;}
.detail-item {    font-size: 0.95rem;    margin-bottom: 0.4rem;    color: rgba(255,255,255,0.85);    display: flex;    align-items: center;}
.detail-item i {    color: var(--accent-2); /* Dark icon color */    margin-right: 10px;    font-size: 1.1rem;}
.price-and-cta {    display: flex;    justify-content: space-between;    align-items: center;    padding-top: 1rem;    border-top: 1px solid rgba(255,255,255,0.1);}
.price-text {    font-size: 1.6rem;    font-weight: 800;    color: #fff;}
.ticket-suffix {    font-size: 0.8rem;    color: rgba(255,255,255,0.7);    margin-left: 4px;}
.cta-button {    background-color: #ffc90a;    color: var(--accent);    padding: 10px 18px;    border-radius: 50px;    font-weight: 700;    display: inline-flex;    align-items: center;    transition: all 0.3s ease;}
.cta-button:hover {    background-color: #ffae00;    transform: translateY(-2px);}
.cta-button i {    margin-left: 8px;    font-size: 0.8rem;}
/* --- CARD 1: Aarley Marathon Specific Styling --- */
.card-image-section {    background-color: #f7d22b; /* Yellow background as a fallback/overlay color */    background-blend-mode: multiply;}
.card-image-section::before {    content: '';    position: absolute;    top: 0;    left: 0;    right: 0;    bottom: 0;    background: rgba(255, 201, 10, 0.6);     z-index: 1;}
.card-image-section > * {    position: relative;    z-index: 2;}
/* ==============================================================================
 AWARDS
 ================================================================================ */
 #awards{    background: #fff; }
 .awards-container table,th,td{    border: 2px solid var(--primary-2);    padding: 0.5rem 1rem; }
 .awards-container table{    width: 100%;    border-collapse: collapse; }
/* ==============================================================================
 ROUTE MAP
 ================================================================================ */
#route{background: linear-gradient(rgba(0, 77, 64, 0.8), rgba(0, 77, 64, 0.8)),url("/asset/images/route_bg.svg"); background-color: var(--accent-light);}
.route-card{padding:18px;border-radius:12px;background:linear-gradient(180deg,var(--primary-2),rgba(255,255,255,0.01));border:0px solid rgba(255,255,255,0.03)}
.route-map{height:280px;border-radius:10px;overflow:hidden;background:#081022;display:grid;place-items:center;color:rgba(255,255,255,0.45)}



.map-thumb {
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.map-thumb:hover {
  transform: scale(1.03);
}

/* Popup overlay */
.img-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 1rem;
  background: rgba(0,0,0,0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 9999;
}

/* Show popup */
.img-popup.active {
  visibility: visible;
  opacity: 1;
}

/* Popup box */
.popup-content {
  position: relative;
  background: #fff;
  padding: 0; /* remove padding so image fills the box edge-to-edge */
  border-radius: 10px;
  max-width: 100%;
  max-height: 100%;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  object-fit: cover;
  overflow: hidden; 
  display: flex;
  justify-content: center;
  align-items: center;
  border: 10px solid #fff;
}

.popup-content img {
  height: 100%;
  object-fit:contain;   /* fills the box completely */
  border-radius: 10px;
}


/* Close button */
.close-btn {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  font-size: 30px;
  background-color: red;
  padding-left:0.7rem;
  padding-right:0.7rem;
  border-radius: 0.4rem;
  color: var(--accent-light);
  cursor: pointer;
  font-weight: bold;
}




/* ==============================================================================
 GALLERY
 ================================================================================ */
 #gallery {    padding: 80px 0;    background: var(--background-shade-light, #f9f9f9);    text-align: center;  }
  #gallery .section-title h2 {    margin-bottom: 40px;    font-size: 2.5rem;    color: var(--accent, #333);  }
  .gallery-grid {    display: grid;    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));    gap: 24px;  }
  .gallery-card {    position: relative;    border-radius: 12px;    overflow: hidden;    background: #fff;    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);    transition: transform 0.3s ease, box-shadow 0.3s ease;  }
  .gallery-card img {    width: 100%;    height: 100%;    object-fit: cover;    display: block;  }
  .gallery-card:hover {    transform: translateY(-6px);    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);  }
  /* Overlay for hover effect */
  .overlay {    position: absolute;    inset: 0;    background: var(--primary-shade);    opacity: 0;    display: flex;    align-items: center;    justify-content: center;    transition: opacity 0.35s ease;  }
  .gallery-card:hover .overlay {    opacity: 1;  }
  /* Learn More button */
  .btn-learn {    background: var(--primary-2);    color: #fff;    border: none;    padding: 10px 22px;    font-size: 1.5rem;    font-weight: 600;    border-radius: 50px;    cursor: pointer;    transition: background 0.3s ease;}
  .btn-learn:hover {    background: var(--primary);  }
/* ==============================================================================
 SPONSERS
 ================================================================================ */
 /* #sponsors {    padding: 80px 0;    background: var(--background-shade-light, #f9f9f9);  display: flex; } */
/* .sponsors{display:flex;gap:18px;flex-wrap:wrap;align-items:center;background: var(--background-shade-light, #f9f9f9);} */
.partner-logo-slider {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  box-sizing: border-box;
  position: relative;
}
.partner-logo-slider:before {
  content: "";
  background: linear-gradient(to right, #fff 0%, rgba(255, 255, 255, 0) 100%);
  position: absolute;
  top: 0;
  left: 0;
  /* width: 120px; */
  height: 100%;
  z-index: 9;
}
.partner-logo-slider:after {
  content: "";
  background: linear-gradient(to left, #fff 0%, rgba(255, 255, 255, 0) 100%);
  position: absolute;
  top: 0;
  right: 0;
  /* width: 120px; */
  height: 100%;
  z-index: 9;
}
.partner-logo-slide {
  display: flex;
  align-items: center;
  gap: 20px;
  animation: partner-logo 30s linear infinite;
}
.partner-logo-slide:hover {
  animation-play-state: paused;
}
.partner-logo-slide img {
  height: 200px;
  border: 1px solid #b2b2b2;
  padding: 20px;
  border-radius: 10px;
}
@keyframes partner-logo {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

/* ==============================================================================
 FAQ
 ================================================================================ */
 .faq{
    max-height: 50vh;
    overflow-y: auto;
    overflow-x: hidden; 
    scrollbar-width:auto; 
    padding-right: 8px;
    scrollbar-color: var(--accent, #fc8f00) transparent;
 }
 /* Chrome, Edge, Safari */
.faq::-webkit-scrollbar {
  width: 8px;
}

.faq::-webkit-scrollbar-track {
  background: transparent; /* no old gray box */
  margin: 4px 0;            /* creates top/bottom breathing space */
}

.faq::-webkit-scrollbar-thumb {
  background-color: var(--accent, #fc8f00); /* modern accent color */
  border-radius: 8px;
  border: 2px solid transparent; /* creates slight gap look */
  background-clip: content-box;
  transition: background-color 0.3s ease;
}

.faq::-webkit-scrollbar-thumb:hover {
  background-color: var(--accent-dark, #d97700); /* subtle hover shade */
}

.faq .q{margin-top:1rem;background:linear-gradient(135deg,var(--primary),var(--primary-2));padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,0.03);cursor:pointer;}
.faq .q:hover {
    background-color: rgba(252, 143, 0, 0.05); /* light hover effect */
  }
.q-ans{margin-top: 0.5rem; display: none;}
/* ==============================================================================
 CONTACT
 ================================================================================ */
 #contact{
    background-color: var(--accent);
 }
.contact-grid{display:grid;grid-template-columns:1fr 50%;gap:20px}
.contact-form input,.contact-form textarea{width:100%;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:var(--accent);color:var(--accent-light);margin-bottom:10px;font-size: 1rem;}
.contact-form button{padding:12px 16px;border-radius:10px;border:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));color:white;font-weight:700;}

/* ==============================================================================
 TERM & CONDITION
 ================================================================================ */
.termcond-container ul li{
    font-size: 1.2rem;
    line-height: 2.5rem;
}
/* ==============================================================================
 FOOTER
 ================================================================================ */
footer{padding:28px 0;border-top:1px solid rgba(255,255,255,0.03);color:rgba(255,255,255,0.75)}
footer {background: var(--accent);color: #fafafa;padding: 21px;display: flex;flex-direction: column;justify-content: center;align-items: center;}
  footer .content {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
  }
  footer .content .logo {
    display: flex;
    justify-content: center;
    align-items: center;
    gap:3rem;
    margin-bottom: 2rem;
  }
  footer .content .logo img{
    width: 8vw;
    height: 8vw;
    border-radius: 50%;
    object-fit: cover;          /* fills the circle, crops if needed */
    object-position: center;    /* centers the image */
    display: block;
    margin: 0 auto;
    border: 3px solid var(--accent, #fc8f00);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
    background-color: #fff;
  }
  footer .content p {
    font-family: var(--font-text);
    font-size: 1.2rem;
    text-align: center;
    width: 100%;
    max-width: 60%;
  }
  footer .content .sm,
  footer .content .links {
    display: flex;
    justify-content: center;
    align-items: center;
    list-style: none;
  }
  footer .content .links {
    flex-wrap: wrap;
  }
  footer .content .sm li {
    margin: 15px;
  }
  footer .content .links li {
    margin: 0 12px;
    margin-bottom: 10px;
  }
  footer .content .links li a,
  footer .content .sm li a {
    font-family: var(--font-heading-4);
    color: #fafafa;
    transition: 0.3s ease;
  }
  footer .content .sm li a {
    font-size: 25px;
    padding: 8px;
    display: flex;
    align-items: center;
  }
  footer .content .sm li a:hover {
    background: #fafafa;
    color: #222;
    border-radius: 10px;
  }
  footer .content .links li a:hover {
    opacity: 0.5;
  }
  footer .copyright {
    font-family: var(--font-text);
    text-align: center;
    padding-top: 20px;
    margin-bottom: 160px;
    width: 100%;
    border-top: 1px solid #555;
  }

/* ==============================================================================
 MODAL - REGISTER
 ================================================================================ */
.modal-backdrop{position:fixed;inset:0;background:var(--accent);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal{width:100%;max-width:740px;background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.02));border-radius:14px;padding:20px;border:1px solid rgba(255,255,255,0.04);box-shadow:var(--shadow)}
.modal h3{margin:0 0 12px 0}
.modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.modal input,.modal select{padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:transparent;color:var(--muted-white)}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}

/* ==============================================================================
 LIGHT BOX
 ================================================================================ */
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,0.85);z-index:300}
.lightbox img{max-width:90%;max-height:85%;border-radius:8px}

/* ==============================================================================
 FLOATING BUTTONS
 ================================================================================ */
.floationg-button ul {
    z-index: 99;
    clear: both;
      position: fixed;
      display: block;
      list-style-type: none;
      right: -3.2em;
      top: 50%;
      -webkit-animation: slideright 1s forwards;
      -webkit-animation-delay: 1.5s;
      animation: slideright 1s forwards;
      animation-delay: 1.5s; 
  }
  
  @keyframes slideright {
      100% {
          right: 0;
      }
  }
  
  .floationg-button ul li {
    margin-bottom: 40px;
    margin-right: -20px;
    padding: 15px;
    transform: rotate(270deg);
    -webkit-transform: rotate(270deg);
      -moz-transform: rotate(270deg);
      -o-transform: rotate(270deg);
       background-color: var(--accent-2);
      border-top-left-radius: 10px;
      border-top-right-radius: 10px;
    
      -webkit-transition: width .5s, background-color .1s;
      transition: width .5s, background-color .1s;
  
  }
  
  
  .floationg-button ul li a {
    font-family: var(--font-text);
      font-size: 19px;
    font-weight: 800;
      text-transform: none;
      text-align: center;
    text-decoration: none;
      color: var(--accent-light);
  }
  
  .floationg-button ul li:hover {
      background-color: var(--primary-2);
    color: var(--accent-light);
  }
  .floationg-button ul li a:hover{
    color: var(--color-accent-1);
  }
  /* Scroll-to-top button */
  .scroll-top {
    position: fixed;
    display: block;
    right: 25px;
    bottom: 25px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background-color: var(--accent-2);
    color: var(--accent-light);
    border: none;
    outline: none;
    cursor: pointer;
    z-index: 10000;
    display: none;
    transition: background-color 0.3s;
  }
  .scroll-top:hover {
    background-color: var(--color-secondary);
    color: var(--color-accent-1);
  }
  .scroll-top svg {
    width: 20px;
    height: 20px;
    vertical-align: middle;
  }

/* ==============================================================================
 RESPONSIVE 
 ================================================================================ */
@media (max-width:1100px){
  .hero{grid-template-columns:1fr 360px}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .partner-logo-slide {
    gap: 20px;
  }
  .partner-logo-slide img {
    height: 120px;
  }
}
@media (max-width:920px){
  .hero{grid-template-columns:1fr;gap:18px}
  .hero-right{order:2}
  .about-wrap{grid-template-columns:1fr;gap:18px}
  .schedule-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  :root {--max-width: 90%;}
  .container{width:100%;max-width:100vw;margin:0 auto;padding:0 20px}
  .schedule-grid{grid-template-columns:1fr;}
  .map-container{display: flex; width: 100%; flex-direction: column;}
   nav.main-nav{display:none}
  .hamburger{display:inline-flex}
  .brand .site-title{display:none}
  .brand .logo {display: block;height:44px;border-radius:10px; padding:0 1rem; background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;font-weight:800;color:white;font-size:1rem;box-shadow:var(--shadow);}
  .gallery-grid {gap: 16px;}
  .gallery-grid img{height:120px}
  .hero-right{padding:12px}
  .route-thumb{height:180px}
  .meta-cards{width:100%;display: flex; flex-wrap: nowrap;}
  #openRegister2{width:100%;display: block;}
  .event-title {
    font-size: 1.2rem;
  }
  .card-details-section {
    padding: 1rem;
  }
  .cta-button {
    font-size: 0.85rem;
    padding: 8px 14px;
  }
  .cards-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 1rem; /* tighter vertical spacing between cards */
  }

  .event-card {
    max-width: 100%; /* allow full stretch */
    margin: 0; /* remove auto margins or centering */
    border-radius: 12px; /* optional - keep soft corners */
  }


  /*Footer*/
  footer {
    width: 100%;
  }
  footer .content .logo {
    gap:1rem;
    font-size: 30px;
  }
  footer .content .logo img{
    width: 15vw;
    height: 15vw;    
    border-radius: 0;
    object-fit: cover;
    object-position: center;  }
  footer .content p {
    padding: 15px;
  }
  footer .content .sm li a {
    padding: 5px;
  }
}

/* small util */
.muted{color:rgba(95, 93, 93, 0.78);font-size:0.95rem}
.center{display:grid;place-items:center}
.kbd{background:rgba(255,255,255,0.04);padding:6px 8px;border-radius:8px;font-weight:700}

/****************************************************************************************/
  