/*=============== GOOGLE FONTS ===============*/
@import url('https://fonts.googleapis.com/css2?family=Joti+One&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

/* =============== BASE =============== */
  *{box-sizing:border-box;padding:0;margin:0}
  html{scroll-behavior:smooth}
  body{
    margin: 3.5rem 0 0 0;
    font-family:'Poppins',sans-serif;
    font-size: .938rem;
    background:#0B2962;
    color:#fff;
  }
  h1,h2,h3,h4{font-family:'Joti One',serif;color:#fff;font-weight:600}
  a{text-decoration:none;color:inherit}
  img{max-width:100%;height:auto}
  button{border:none;outline:none;cursor:pointer;font-family:'Poppins',sans-serif}

  /* =============== LAYOUT =============== */
  .container{
    max-width:1100px;
    margin: 0 auto;
    padding: 0 1.5rem;
  }
  .main{overflow:hidden}

  /* =============== SNOW FALL =============== */
  .snow-fall{
    position:fixed;
    top:0;left:0;
    width:100vw;height:100vh;
    pointer-events:none;
    z-index:-1;
  }
  .snowFlake{
    position:absolute;
    color:#fff;
    user-select:none;
    animation: fall linear forwards;
    opacity:.9;
  }
  @keyframes fall{
    0%{transform:translateY(-100px);opacity:0}
    10%,70%{opacity:1}
    100%{transform:translateY(100vh);opacity:0}
  }

  /* =============== HEADER / NAV =============== */
  .header{
    width:100%;
    position:fixed;
    top:0;left:0;
    z-index:100;
  }
  .nav{
    width: calc(100% - 2rem);
    max-width:1100px;
    margin: 1rem auto 0 auto;
    padding: 0 2rem;
    height:3.5rem;
    display:flex;
    justify-content:space-between;
    align-items:center;
    font-family:'Joti One',serif;
    background:rgba(255,255,255,0.08);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,0.2);
    border-radius:.5rem;
    box-shadow:0 4px 30px rgba(0,0,0,0.1);
  }
  .nav__logo{
    display:flex;
    align-items:center;
    gap:.5rem;
    font-size:1.1rem;
  }
  .nav__logo-img{width:2.5rem;height:2.5rem}
  .nav__link{font-size:1.2rem}

  /* =============== MOBILE BOTTOM NAV =============== */
  .mobile-bottom-nav{
    position:fixed;
    bottom:1rem;
    left:50%;
    transform:translateX(-50%);
    width: calc(100% - 2rem);
    max-width:500px;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,0.2);
    box-shadow: 0 4px 30px rgba(0,0,0,0.1);
    border-radius:.5rem;
    padding: 0.75rem 1rem;
    display:flex;
    justify-content:space-around;
    align-items:center;
    z-index:999;
  }
  .mobile-bottom-nav a{color:#fff;font-size:1.5rem}

  @media (min-width:768px){
    .mobile-bottom-nav{display:none !important;}
    body{margin:0}
  }

  /* =============== PRICING SECTION =============== */
  .pricing-section{
    padding: 6.5rem 1rem 4rem;
    text-align:center;
  }
  .pricing-title{
    font-size:2.4rem;
    margin-bottom: 2.5rem;
  }

  /* =============== TICKET CARDS (DESKTOP: HORIZONTAL) =============== */
  .ticket-row{
    width: min(1100px, 92%);
    margin: 0 auto;
    display:flex;
    gap:18px;
    align-items:stretch;
    justify-content:center;
    flex-wrap:wrap;
    margin-top: 18px;
  }

  .ticket-card{
    position:relative;
    width: 320px;
    padding: 25px 18px 25px;
    border-radius: 18px;
    background: rgba(255,255,255,0.06);
    box-shadow: 0 10px 30px rgba(0,0,0,0.22);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow:hidden;
    text-align:center;
  }

  /* ticket notches */
  .ticket-card::before,
  .ticket-card::after{
    content:"";
    position:absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    background: #092558;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.10);
  }
  .ticket-card::before{left:-18px}
  .ticket-card::after{right:-18px}

  /* dotted tear line */
  .ticket-tear{
    margin: 14px 0 16px;
    border-top: 2px dashed rgba(255,255,255,0.22);
    opacity: .9;
  }

  .ticket-title{
    font-family: 'Joti One', serif;
    font-size: 1.6rem;
  }

  .ticket-bottom{
    display:flex;
    flex-direction:column;
    gap:12px;
    align-items:center;
  }

  .pill{
    display:flex;
    align-items:center;
    justify-content:center;
    padding: .65rem 1rem;
    border-radius: .6rem;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.22);
    width: 220px;
    font-size: .95rem;
  }

  /* Discount note */
  .discount-note{
    max-width: 900px;
    margin: 3rem auto 2.5rem;
    font-size: 1.05rem;
    color: rgba(255,255,255,0.92);
    line-height: 1.6;
  }

  /* Info box outside cards */
  .info-box{
    max-width: 900px;
    margin: 18px auto 0;
    padding: 18px 18px;
    border-radius: 14px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    text-align: left;
    line-height: 1.7;
    color: rgba(255,255,255,0.90);
  }
  .info-box p{margin-bottom: 10px}
  .info-box p:last-child{margin-bottom: 0}

  /* ✅ MOBILE: STACK VERTICALLY (NO HORIZONTAL SCROLL, NO SCROLLBAR) */
  @media (max-width: 768px){
    .ticket-row{
      flex-wrap: wrap;          /* stack normally */
      overflow: visible;        /* remove scroll */
      justify-content: center;  /* keep centered */
      padding: 0;              /* remove extra padding */
      scroll-snap-type: none;  /* disable snap */
    }
    .ticket-card{
      width: 100%;
      max-width: 420px;        /* clean width on mobile */
      margin: 0 auto;
    }
    .ticket-row::-webkit-scrollbar{display:none;} /* just in case */
  }

  /* =============== FOOTER =============== */
  .footer{
    position:relative;
    overflow:hidden;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,0.2);
    color:#fff;
    border-radius:.5rem;
    margin: 1rem;
    margin-bottom: 6rem;
    padding: 2rem 1rem;
  }
  @media(min-width:768px){
    .footer{margin-bottom:3rem;}
  }

  .footer__container{
    max-width:1100px;
    margin: 0 auto;
    display:grid;
    gap: 2rem;
  }
  @media(min-width:900px){
    .footer__container{
      grid-template-columns: 1.2fr 1.2fr 1fr 1fr;
      align-items:start;
    }
  }

  .footer__logo{
    display:flex;
    align-items:center;
    gap:.5rem;
    margin-bottom: .8rem;
    font-family:'Joti One',serif;
    font-size: 1.2rem;
  }
  .footer__logo-img{width:2.5rem;height:2.5rem}
  .footer__description{font-weight:200;font-size:.92rem;opacity:.95;margin-bottom:1.2rem}
  .footer__social{display:flex;gap:.6rem}
  .footer__social-link{
    display:inline-flex;
    width: 34px;height:34px;
    align-items:center;justify-content:center;
    border-radius:.5rem;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.2);
  }

  .footer__title{font-size:1rem;margin-bottom:.8rem}
  .footer__links{display:grid;gap:.4rem}
  .footer__link{font-size:.9rem;font-weight:200}

  .footer__copy{
    display:block;
    text-align:center;
    font-size:.78rem;
    margin-top: 2.2rem;
    opacity:.9;
  }

  /* Scroll up */
  .scrollup{
    position:fixed;
    right:1rem;
    bottom: 6rem;
    display:inline-flex;
    padding:.6rem;
    border-radius:.5rem;
    z-index:100;
    opacity:.85;
    transition:.25s;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border:1px solid rgba(255,255,255,0.2);
  }
  .scrollup__icon{font-size:1.25rem;color:#fff}
  .scrollup:hover{opacity:1; transform: translateY(-2px);}
  @media(min-width:768px){ .scrollup{bottom:3.5rem;} }