    @font-face {
      font-family: 'icomoon';
      src: url("../fonts/icomoon/icomoon.eot?srf3rx");
      src: url("../fonts/icomoon/icomoon.eot?srf3rx#iefix") format("embedded-opentype"),
        url("../fonts/icomoon/icomoon.ttf?srf3rx") format("truetype"),
        url("../fonts/icomoon/icomoon.woff?srf3rx") format("woff"),
        url("../fonts/icomoon/icomoon.svg?srf3rx#icomoon") format("svg");
      font-weight: normal;
      font-style: normal;
    }

    html,
    body {
      overflow-x: hidden !important;
    }

    body {
      font-family: "Open Sans", Arial, sans-serif;
      line-height: 1.6;
      font-size: 16px;
      background: #fff;
      color: #848484;
      font-weight: 300;
      overflow-x: hidden !important;
    }

    body.fh5co-offcanvas {
      overflow: hidden;
    }

    #loading-overlay {
      position: fixed;
      inset: 0;
      /* shorthand for top:0, left:0, right:0, bottom:0 */
      width: 100vw;
      height: 100vh;
      background-color: #ffffff;
      z-index: 9999;
      display: flex;
      justify-content: center;
      align-items: center;
      transition: opacity 0.5s ease, visibility 0.5s ease;
      overflow: hidden;
    }

    #loading-overlay.fade-out {
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
    }

    body.loading {
      overflow: hidden;
      height: 100vh;
      position: fixed;
      width: 100%;
    }



    a {
      color: #86ae81;
      -webkit-transition: 0.5s ease;
      -o-transition: 0.5s ease;
      transition: 0.5s ease;
    }

    a:hover {
      text-decoration: none;
      color: #86ae81;
    }

    p,
    ul,
    ol {
      margin-bottom: 1.5em;
      font-size: 16px;
      color: #848484;
      font-family: "Open Sans", Arial, sans-serif;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
      color: #5a5a5a;
      font-family: "Montez", cursive;
      font-weight: 400;
      margin: 0 0 30px 0;
    }

    figure {
      margin-bottom: 2em;
    }

    ::-webkit-selection {
      color: #fcfcfc;
      background: #86ae81;
    }

    ::-moz-selection {
      color: #fcfcfc;
      background: #86ae81;
    }

    ::selection {
      color: #fcfcfc;
      background: #86ae81;
    }

    section {
      padding: 80px 0;
    }

    .fh5co-cover,
    .fh5co-hero {
      position: relative;
      height: 800px;
      width: 100%;
    }

    @media screen and (max-width: 768px) {

      .fh5co-cover,
      .fh5co-hero {
        height: 100vh;
      }
    }

    .fh5co-overlay {
      position: absolute !important;
      width: 100%;
      top: 0;
      left: 0;
      bottom: 0;
      right: 0;
      z-index: 1;
      background: rgba(0, 0, 0, 0.4);
    }

    .fh5co-cover {
      background-size: cover;
      position: relative;
    }

    @media screen and (max-width: 768px) {
      .fh5co-cover {
        height: inherit;
        padding: 3em 0;
        background-position: -200px 0px;
      }
    }

    .fh5co-cover .display-t {
      display: table;
      height: 800px;
      width: 100%;
      position: relative;
      z-index: 2;
    }

    @media screen and (max-width: 768px) {
      .fh5co-cover .display-t {
        height: 600px;
      }
    }

    .fh5co-cover .display-tc {
      display: table-cell;
      vertical-align: middle;
    }

    .fh5co-cover .display-tc h1 {
      color: #fff;
    }

    .fh5co-cover .display-tc h2 {
      color: #fff;
      font-size: 80px;
      margin-bottom: 30px;
      font-weight: 300 !important;
    }

    .fh5co-cover .display-tc h2 strong {
      font-weight: 700;
    }

    @media screen and (max-width: 768px) {
      .fh5co-cover .display-tc h2 {
        font-size: 60px;
      }
    }

    .fh5co-cover .display-tc p {
      color: #fff;
      font-weight: 400;
      font-size: 16px;
      letter-spacing: 7px;
    }

    .fh5co-cover .display-tc p span {
      border-top: 2px solid #fff;
      border-bottom: 2px solid #fff;
      padding: 5px 0px;
    }

    @keyframes flipLogo {
      0% {
        transform: rotateY(0deg);
      }

      50% {
        transform: rotateY(180deg);
      }

      100% {
        transform: rotateY(360deg);
      }
    }

    .logo-flip {
      display: inline-block;
      animation: flipLogo 6s infinite linear;
      transform-style: preserve-3d;
      width: 600px;
    }

    .wedding-date {
      display: flex;
      justify-content: center;
      align-items: center;
      font-family: "Georgia", serif;
      color: #fff;
      text-align: center;
      padding: 0px;
      max-width: 400px;
      margin: 0px auto;
    }

    .side-text {
      flex: 1;
      font-size: 12px;
      letter-spacing: 2px;
      position: relative;
      padding: 0 10px;
    }

    .side-text::before,
    .side-text::after {
      content: "";
      position: absolute;
      top: 50%;
      width: 20px;
      height: 1px;
      background: #fff;
    }

    .side-text:first-child::before {
      left: 0;
    }

    .side-text:first-child::after {
      display: none;
    }

    .side-text:last-child::after {
      right: 0;
    }

    .side-text:last-child::before {
      display: none;
    }

    .center-date {
      text-align: center;
      padding: 0 20px;
    }

    .center-date .month {
      font-size: 12px;
      letter-spacing: 4px;
    }

    .center-date .day {
      font-size: 40px;
      color: #fff;
      font-weight: 600;
      line-height: 1;
    }

    .center-date .year {
      font-size: 14px;
      letter-spacing: 3px;
      margin-top: 5px;
    }

    .rsvp-btn {
      border-radius: 50px;
    }

    footer {
      padding: 40px 0;
      background: #f8f9fa;
      text-align: center;
    }

    .story-frame {
      width: 100%;
      max-width: 600px;
      height: auto;
      margin: 20px auto;
      display: block;
    }

    #story-section {
      position: relative;
      z-index: 1;
      overflow: hidden;
    }

    .svg-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 0;
      overflow: hidden;
    }

    .svg-bg svg {
      width: 100%;
      height: 100%;
    }

    .morphing-shape {
      animation: colorChange 15s infinite alternate ease-in-out;
      fill: #86ae81;
    }

    #story-section .content {
      position: relative;
      z-index: 2;
    }

    /* Color-changing keyframes */
    @keyframes colorChange {
      0% {
        fill: #86ae81;
      }

      25% {
        fill: #dfefdc;
      }

      50% {
        fill: #ceb290;
      }

      75% {
        fill: #bc9c22;
      }

      100% {
        fill: #ba893e;
      }
    }

    .entourage-section {
      background-color: #575757;
    }

    .entourage-card {
      padding: 20px;
      transition: transform 0.3s ease;
    }

    .entourage-card:hover {
      transform: scale(1.05);
    }

    .entourage-section .container {
      padding-left: 0.75rem;
      padding-right: 0.75rem;
    }

    #entourage {
      background:
        url('../images/realistic-ramadan-lantern.avif') repeat-x top center,
        url('../images/Flowers.png') repeat-x bottom center;
      background-size: auto 150px, auto 150px;
      background-color: #fffef8;
      border-top: 1px solid #b38357;
    }

    @media (min-width: 768px) {
      .entourage-section .container {
        max-width: 100%;
        padding-left: 2rem;
        padding-right: 2rem;
      }
    }

    .entourage-img {
      width: 150px;
      height: 150px;
      object-fit: cover;
      border-radius: 50%;
      border: 4px solid #f0eae0;
      /* optional decorative border */
      box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
      margin-bottom: 1rem;
    }

    #our-story p {
      color: #000;
    }

    .wedding-section {
      background: url('../images/venue.jpg') no-repeat center center/cover;
    }

    .glass-box {
      background: rgba(255, 255, 255, 0.85);
      border-radius: 20px;
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      border: 1px solid rgba(200, 200, 200, 0.3);
    }

    iframe {
      border-radius: 15px;
    }

    #faq h2 {
      font-weight: 700;
      letter-spacing: 0.5px;
    }

    #faq h5 {
      font-weight: 600;
      color: #343a40;
    }

    /* Gallery and Owl Carousel fix styles */
    #gallery {
      position: relative;
      background-color: transparent;
      /* keep it transparent for the top half */
      overflow-x: hidden !important;
      /* Hide horizontal overflow */
    }

    #gallery>.container-fluid {
      padding-left: 0 !important;
      padding-right: 0 !important;
      max-width: 100% !important;
    }

    #gallery::after {
      content: "";
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 80%;
      z-index: 0;
      pointer-events: none;

      animation: colorChange 12s infinite alternate ease-in-out;
      animation-timing-function: ease-in-out;

    }


    /* Small devices (landscape phones, ≥576px and <768px) */
    @media (min-width: 576px) and (max-width: 767.98px) {
      #last-story {
        padding-bottom: 1vh;
      }

      .gallery-section {
        margin-top: 40vh;
        background-color: transparent;
        z-index: 1;
      }

      .gallery-section .container {
        padding-top: 10vh;
        position: relative !important;
        z-index: 2;
      }
    }

    #last-story {
      padding-bottom: 10vh;
    }

    .gallery-section {
      margin-top: -10%;
      background-color: transparent;
      z-index: 1;
    }

    .gallery-section .container {
      padding-top: 3%;
      position: relative;
      z-index: 2;
    }

    /* Small devices (phones) */
    @media (max-width: 575.98px) {
      .gallery-section {
        margin-top: -15vh;
        z-index: 1;
        background-color: transparent;
      }

      .gallery-section .container {
        padding-top: 10vh;
        position: relative;
        z-index: 2;
      }

      #last-story {
        padding-bottom: 8vh;
      }
    }


    /* Large devices (desktops, ≥992px and <1200px) */
    @media (min-width: 992px) and (max-width: 1199.98px) {}

    /* Extra large devices (large desktops, ≥1200px) */
    @media (min-width: 1200px) {}

    /* Base styles: applies to all by default */
    body {
      font-size: 16px;
    }

    /* Extra small devices (portrait phones, <576px) */
    @media (max-width: 575.98px) {
      .logo-flip {
        width: 250px;
      }

      h1,
      h2 {
        font-size: 32px;
      }

      #gallery .owl-stage {
        padding-left: 30px !important;
        padding-right: 30px !important;
      }

      .gallery-carousel .item {
        margin-right: 8px;
      }

      .wedding-date {
        max-width: 100%;
        flex-direction: column;
      }

      .side-text {
        display: none;
      }
    }


    @keyframes floatUp {

      0%,
      100% {
        transform: translateY(25px);
      }

      50% {
        transform: translateY(-25px);
      }
    }

    @keyframes floatDown {

      0%,
      100% {
        transform: translateY(-25px);
      }

      50% {
        transform: translateY(25px);
      }
    }

    .float-up {
      animation: floatUp 5s ease-in-out infinite;
    }

    .float-down {
      animation: floatDown 5s ease-in-out infinite;
    }

    /* Owl carousel fixes */
    #gallery .owl-stage-outer {
      overflow: hidden !important;
    }

    #gallery .owl-item {
      margin: 0 !important;
      padding: 0 0px;
      /* padding for spacing */
      box-sizing: border-box;
    }

    #gallery .owl-carousel .item {
      padding-left: 0;
      padding-right: 0;
      padding-top: 50px;
      padding-bottom: 50px;

      margin: 0 !important;
    }

    #gallery .item img {
      border-radius: 0px !important;
      border: 20px solid #ffffff !important;
    }

    #wedding-countdown {
      background: url('../images/countdown-timer.JPG') no-repeat center center/cover;
      padding: 80px 20px;
      text-align: center;
      font-family: 'Playfair Display', serif;
      position: relative;
      overflow: hidden;
    }

    .countdown-glass-box {
      background: rgba(255, 255, 255, 0.5);
      border: 1px solid rgba(255, 255, 255, 0.3);
      border-radius: 20px;
      backdrop-filter: blur(12px);
      padding: 40px 20px;
      max-width: 700px;
      margin: 0 auto;
      box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1);
    }

    #wedding-countdown h2 {
      font-size: 2rem;
      font-weight: 700;
      margin-bottom: 30px;
      color: #5a3e36;
    }

    .countdown-timer {
      display: flex;
      justify-content: center;
      gap: 20px;
      flex-wrap: wrap;
    }

    .time-box {
      background: rgba(255, 255, 255, 0.7);
      padding: 20px 15px;
      border-radius: 15px;
      min-width: 80px;
      flex: 1 1 100px;
      box-shadow: 0 10px 15px rgba(0, 0, 0, 0.05);
    }

    .time-box .num {
      font-size: 2.5rem;
      font-weight: 800;
      color: #b46c6c;
      animation: flip 2s ease-in-out infinite alternate;
    }

    .time-box .label {
      display: block;
      font-size: 0.9rem;
      color: #6e4c4c;
      margin-top: 8px;
      font-weight: 500;
    }

    /* Optional flip effect */
    @keyframes flip {
      0% {
        transform: rotateX(0deg);
      }

      100% {
        transform: rotateX(360deg);
      }
    }

    @media (max-width: 600px) {
      .time-box .num {
        font-size: 2rem;
      }

      #wedding-countdown h2 {
        font-size: 1.5rem;
      }
    }

    #music-toggle {
      position: fixed;
      bottom: 20px;
      right: 20px;
      background: rgba(255, 255, 255, 0.8);
      border: none;
      border-radius: 50%;
      padding: 10px;
      font-size: 20px;
      cursor: pointer;
      z-index: 2147483647;
      box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    }

    #music-toggle::after {
      content: "";
      position: absolute;
      top: -5px;
      bottom: -5px;
      left: -5px;
      right: -5px;
      border-radius: 50%;
      box-shadow: 0 0 10px rgba(134, 174, 129, 0.5);
      animation: pulse-glow 2s infinite ease-in-out;
      z-index: -1;
    }

    @keyframes pulse-glow {
      0% {
        box-shadow: 0 0 0px rgba(134, 174, 129, 0.2);
      }
      50% {
        box-shadow: 0 0 15px rgba(134, 174, 129, 0.6);
      }
      100% {
        box-shadow: 0 0 0px rgba(134, 174, 129, 0.2);
      }
    }


    .sound-btn {
      position: relative;
      padding: 15px 30px;
      font-size: 18px;
      color: white;
      background: linear-gradient(135deg, #86ae8157, #4d6c41);
      border: none;
      border-radius: 50px;
      cursor: pointer;
      font-family: "Montserrat", sans-serif;
      text-transform: uppercase;
      box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2);
      overflow: hidden;
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      animation: pulse 2s infinite;
    }

    .sound-btn:hover {
      transform: scale(1.05);
      box-shadow: 0 10px 20px rgba(0, 0, 0, 0.25);
    }

    @keyframes pulse {
      0% {
        box-shadow: 0 0 0 0 rgba(134, 174, 129, 0.7);
      }
      70% {
        box-shadow: 0 0 0 15px rgba(134, 174, 129, 0);
      }
      100% {
        box-shadow: 0 0 0 0 rgba(134, 174, 129, 0);
      }
    }

    .wedding-guide-section {
      background: url('../images/jpyham.jpg') no-repeat center center/cover;
    }

    .glass-box {
      background: rgba(255, 255, 255, .95);
      backdrop-filter: blur(20px);
      border-radius: 20px;
      border: 1px solid rgba(200, 200, 200, 0.25);
    }

    .elegant-font {
      font-family: 'Playfair Display', serif;
      font-style: italic;
    }

    .color-swatch {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      border: 2px solid #fff;
      box-shadow: 0 0 4px rgba(0,0,0,0.15);
    }

    .timeline-icon {
      font-size: 1.6rem;
      line-height: 1;
    }
