/* 2.  GLOBAL RESET  */
    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    html{scroll-behavior:smooth}
    body{
      font-family:'Poppins',sans-serif;
      background:var(--ivory);
      color:var(--text-primary);
      line-height:1.6;
      overflow-x:hidden;
    }
    img{max-width:100%;display:block}
    a{text-decoration:none;color:inherit}

    /* 3.  UTILITIES */
    .container{width:90%;max-width:var(--max-width);margin:0 auto;padding:0 15px}
    .section{padding:80px 0}
    .flex-center{display:flex;align-items:center;justify-content:center}
    .grid-2{--min:280px;display:grid;grid-template-columns:repeat(auto-fit,minmax(var(--min),1fr));gap:40px}

    /* 4.  TYPOGRAPHY */
    h1,h2,h3{font-family:'Dancing Script',cursive;color:var(--dusty-rose);line-height:1.2}
    h1{font-size:clamp(2.2rem,5vw,4rem)}
    h2{font-size:clamp(1.8rem,4vw,2.8rem)}
    h3{font-size:clamp(1.3rem,3vw,2rem)}
    p,li{font-size:clamp(.95rem,2vw,1.1rem);color:var(--text-secondary)}
    .btn{
      display:inline-block;padding:14px 32px;
      background:linear-gradient(135deg,var(--rose),var(--dusty-rose));
      color:#fff;border:none;border-radius:50px;font-weight:600;
      transition:.3s;cursor:pointer
    }
    .btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px var(--shadow)}

    /* 5.  HEADER  */
    header{position:fixed;top:0;left:0;width:100%;background:rgba(253,248,240,.95);backdrop-filter:blur(2px);z-index:1000}
    .nav{display:flex;align-items:center;justify-content:space-between;padding:15px var(--container-padding)}
    .logo{font-family:'Dancing Script',cursive;font-size:1.8rem;color:var(--dusty-rose)}
    .nav-links{display:flex;gap:30px;list-style:none}
    .nav-links a{color:var(--text-primary);font-weight:500;transition:.3s}
    .nav-links a:hover{color:var(--dusty-rose)}
    .hamburger{display:none;
      flex-direction:column;
      gap:4px;
      cursor:pointer}
    .hamburger span{width:25px;
      height:3px;
      background:var(--dusty-rose);
      border-radius:3px;
      transition:.3s}

    /* 6.  HERO  */
    .hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff}
    .hero img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:-1}
    .hero::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.45)}
    .hero-content{z-index:1;padding:0 20px}
    .hero-content p{margin:15px 0 30px;font-size:clamp(1rem,2.5vw,1.3rem)}

    /* 7.  ABOUT GRID  */
    .about .grid-2{--min:300px;align-items:center;gap:60px}
    .about img{border-radius:20px;box-shadow:0 10px 30px var(--shadow)}

    /* 8.  TIMELINE  */
    .timeline{position:relative;margin:60px auto;max-width:900px}
    .timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--dusty-rose);transform:translateX(-50%)}
    .timeline-item{position:relative;width:50%;padding:20px 40px;opacity:0}
    .timeline-item:nth-child(odd){left:0;text-align:right}
    .timeline-item:nth-child(even){left:50%;text-align:left}
    .timeline-dot{position:absolute;top:50%;width:14px;height:14px;background:var(--gold);border:3px solid var(--dusty-rose);border-radius:50%;transform:translateY(-50%)}
    .timeline-item:nth-child(odd) .timeline-dot{right:-8px}
    .timeline-item:nth-child(even) .timeline-dot{left:-8px}
    .timeline-content{background:#fff;padding:20px;border-radius:15px;box-shadow:0 5px 15px var(--shadow)}
    .timeline-year{font-family:'Dancing Script',cursive;font-size:1.4rem;color:var(--dusty-rose)}

    /* 9.  GALLERY  */
    .gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-top:50px}
    .gallery-item{overflow:hidden;border-radius:15px;cursor:pointer}
    .gallery-item img{transition:.4s}
    .gallery-item:hover img{transform:scale(1.08)}
    .gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:.3s}
    .gallery-item:hover .gallery-overlay{opacity:1}

    /* 10. FOOTER  */
    footer{background:var(--light-pink);text-align:center;padding:50px 0}
    .social-links{display:flex;justify-content:center;gap:20px;margin:20px 0}
    .social-links a{width:45px;height:45px;border-radius:50%;background:#fff;color:var(--dusty-rose);display:flex;align-items:center;justify-content:center;transition:.3s}
    .social-links a:hover{background:var(--dusty-rose);color:#fff;transform:translateY(-3px)}

    /* 11.  MEDIA QUERIES  */
    @media(max-width:992px){
      .timeline::before{left:30px}
      .timeline-item{width:100%;padding-left:70px;padding-right:20px;text-align:left}
      .timeline-item:nth-child(even){left:0}
      .timeline-dot{left:22px!important}
    }
    @media(max-width:768px){
      .nav-links{position:fixed;top:70px;right:-100%;flex-direction:column;background:var(--ivory);height:calc(100vh - 70px);padding:30px 0;transition:.3s}
      .nav-links.active{right:0}
      .hamburger{display:flex}
    }
    @media(max-width:480px){
      .hero-content{padding:0 10px}
      .gallery-grid{grid-template-columns:1fr}
    }


    .timeline {
  position: relative;
  margin: 60px auto;
  max-width: 900px;
  padding: 0 20px;
}

/* Timeline line */
.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--dusty-rose);
  transform: translateX(-50%);
}

/* Timeline items container */
.timeline-items {
  position: relative;
  width: 100%;
}

.timeline-item {
  position: relative;
  width: 100%;
  margin-bottom: 40px;
  opacity: 1;
}

.timeline-content {
  background: #fff;
  padding: 25px;
  border-radius: 15px;
  box-shadow: 0 5px 15px var(--shadow);
  position: relative;
}

.timeline-dot {
  position: absolute;
  top: 30px;
  width: 16px;
  height: 16px;
  background: var(--gold);
  border: 3px solid var(--dusty-rose);
  border-radius: 50%;
  z-index: 2;
}

.timeline-year {
  font-family: 'Dancing Script', cursive;
  font-size: 1.4rem;
  color: var(--dusty-rose);
  margin-bottom: 10px;
}

/* Desktop Layout (alternating sides) */
@media (min-width: 992px) {
  .timeline-item {
    width: 50%;
    padding: 0 40px;
  }
  
  .timeline-item:nth-child(odd) {
    left: 0;
    text-align: right;
    padding-right: 60px;
  }
  
  .timeline-item:nth-child(even) {
    left: 50%;
    text-align: left;
    padding-left: 60px;
  }
  
  .timeline-item:nth-child(odd) .timeline-dot {
    right: -8px;
  }
  
  .timeline-item:nth-child(even) .timeline-dot {
    left: -8px;
  }
}

/* Tablet Layout (smaller alternating) */
@media (min-width: 768px) and (max-width: 991px) {
  .timeline::before {
    left: 100px;
    transform: none;
  }
  
  .timeline-item {
    padding-left: 130px;
    text-align: left;
  }
  
  .timeline-item:nth-child(even) {
    left: 0;
  }
  
  .timeline-dot {
    left: 94px !important;
  }
}

/* Mobile Layout (single column) */
@media (max-width: 767px) {
  .timeline::before {
    left: 20px;
    transform: none;
  }
  
  .timeline-item {
    padding-left: 50px;
  }
  
  .timeline-dot {
    left: 12px !important;
  }
  
  .timeline-content {
    padding: 20px;
  }
}

/* Animation for reveal class */
.reveal {
  transition: all 0.5s ease;
}
.reveal.show {
  opacity: 1;
  transform: translateY(0);
}