body{
  font-family: "Baloo 2", sans-serif;
}

.custom-navbar {
  background-color: #a9d3eb !important; /* YOUR OWN COLOR */
  padding: 15px 0;
}

/* Brand title */
.custom-navbar .navbar-brand {
  font-weight: 900;
  font-size: 1.6rem;
  color: #4c2e92 !important;
}

/* Links */
.custom-navbar .nav-link {
  color: #4c2e92 !important;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 12px;
}

.custom-navbar .nav-link:hover{
  background-color:#ffd902;
}

/*services toggle*/
.custom-navbar .dropdown-toggle:hover {
  background-color: #ffd902;
  border-radius: 12px;
}

/* FORCE hover + focus to work */
.custom-navbar .navbar-nav .nav-link:hover,
.custom-navbar .navbar-nav .nav-link:focus {
  background-color: #ffd902 !important;
  color: #4c2e92 !important;
}

/*
   DROPDOWN MENU STYLING
*/

/* Dropdown container */
.custom-navbar .dropdown-menu {
  background: #ffcee1;  /* soft pink */
  border: none;
  border-radius: 16px;
  padding: 10px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.18);
}

/* Dropdown items */
.custom-navbar .dropdown-menu .dropdown-item {
  color: #4c2e92;
  font-weight: 600;
  border-radius: 12px;
  padding: 10px 15px;
  transition: all 0.25s ease;
}

/* Hover effect */
.custom-navbar .dropdown-menu .dropdown-item:hover,
.custom-navbar .dropdown-menu .dropdown-item:focus {
  background-color: #93bfdd;
  color: #4c2e92;
  transform: translateX(5px);
}

/* Remove Bootstrap active blue */
.custom-navbar .dropdown-menu .dropdown-item.active {
  background-color: transparent;
  color: #4c2e92;
}

/* Hover */
.custom-btn {
  background: #FF9EC4 !important;   /* pink */
  color: white !important;
  border-radius: 30px !important;
  padding: 12px 35px !important;
  border: none !important;
  font-weight: 700 !important;
  transition: 0.3s ease !important;
}
.custom-btn:hover {
  background: #ff56b4 !important;
  transform: scale(1.06) !important;
  box-shadow: 0 8px 20px rgba(255,120,196,0.4) !important;
}

.custom-btn:focus,
.custom-btn:active,
.custom-btn:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  text-decoration: none !important;
}

.info-link {
  text-decoration: none;
  color: inherit; /* text stays same color */
}

.info-link .info-box {
  cursor: pointer;
  transition: transform .3s ease, box-shadow .3s ease;
}

.info-link .info-box:hover {
  transform: scale(1.07);
  box-shadow: 0 12px 35px rgba(0,0,0,0.2);
}
.info-link {
  text-decoration: none !important;   /* removes underline */
  color: inherit !important;          /* keeps  text color */
  display: block;                     /* making gthewhole box clickable */
}

.info-link:hover {
  text-decoration: none !important;   /* no underline on hover */
  color: inherit !important;
}
.info-link .info-box {
  background: #ffffffdd;
  transition: 0.3s ease;
}

.info-link .info-box:hover {
  background: #aed2e7; /* soft pink/purple hover */
  transform: scale(1.06);
  box-shadow: 0 12px 30px rgba(0,0,0,0.2);
}

.hero-banner video {
    width: 100%;
    height: 80vh;
    object-fit: cover;
}

.hero-banner .overlay {
    color: white;
    text-shadow: 2px 2px 8px rgba(0,0,0,0.7);
}

/* MAIN TITLE - GLOSSY & GLAM */
.glam-title {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.2;
  background: linear-gradient(45deg, #ff4fb2, #ffca2c, #55d3ff);
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color:transparent;
  display:inline-block;
  animation: glowPulse 3s infinite ease-in-out;
}

@keyframes glowPulse {
  0% { text-shadow: 0 0 10px rgba(65, 57, 57, 0.3); }
  50% { text-shadow: 0 0 25px rgba(255, 255, 255, .6); }
  100% { text-shadow: 0 0 10px rgba(255, 255, 255, .3); }
}

/* SUBTITLE */
.glam-subtitle {
  font-size: 1.2rem;
  color: #444;
  font-weight: 500;
}

/* ACCORDION STYLING */
.glam-accordion .accordion-item {
  border-radius: 15px;
  overflow: hidden;
  border: none;
  box-shadow: 0 4px 15px rgba(0,0,0,0.1);
  transition: transform .2s ease, box-shadow .2s ease;
}

.glam-accordion .accordion-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
}

.glam-accordion .accordion-button {
  background: linear-gradient(135deg, #7ECFFF, #ffca2c);
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
}

.glam-accordion .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #ffca2c, #ff78c4);
  box-shadow: inset 0 0 10px rgba(255,255,255,0.4);
}

.accordion-body {
  background: #fff;
  color: #444;
  font-size: 1rem;
  padding: 20px;
}

/* IMAGE ANIMATION */
.glam-img {
  filter: drop-shadow(0 5px 20px rgba(0,0,0,.25));
  animation: floaty 4s ease-in-out infinite;
}

@keyframes floaty {
  0% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
  100% { transform: translateY(0); }
}

/* Fancy Background */
.info-section {
    background: linear-gradient(135deg, #FFE3B3, #ff9ec4);
    padding: 80px 0;
    position: relative;
    overflow: hidden;
    border-radius: 0 0 80px 80px;
}

/* Staggered animated boxes */
.info-box {
    background: #ffffffdd;
    padding: 20px 25px;
    width: 80%;
    border-radius: 15px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
    backdrop-filter: blur(4px);
    transition: 0.3s;
}

.info-box h4 {
    font-weight: 700;
    font-size: 22px;
}

.info-box:hover {
    transform: scale(1.05);
}

/* Stagger alignment */
.box-1 {
    margin-left: 0;
}
.box-2 {
    margin-left: 40px;
    margin-top: 25px;
}
.box-3 {
    margin-left: 0;
    margin-top: 25px;
}

/* Floating image animation */
.info-img {
    max-width: 350px;
    border-radius: 25px;
    animation: floatImg 4s ease-in-out infinite;
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
}

@keyframes floatImg {
    0% { transform: translateY(0px); }
    50% { transform: translateY(-12px); }
    100% { transform: translateY(0px); }
}

/* Make the balloon area match the height of the content on the left */
.balloon-area {
  position: relative;
  width: 100%;
  height: 100%; /* will stretch to match column height */
  min-height: 380px; /* adjust to match the height of your three boxes */
  overflow: hidden;
  display: flex;
  justify-content: center;
}

/* Each balloon bubble */
.balloon {
  position: absolute;
  bottom: -150px;
  width: 55px;
  height: 70px;
  border-radius: 50%;
  animation: floatUp 7s linear infinite;
}

/* Balloon string */
.balloon::after {
  content: "";
  position: absolute;
  width: 3px;
  height: 50px;
  background: #555;
  left: 50%;
  bottom: -50px;
  transform: translateX(-50%);
}

/* Floating animation */
@keyframes floatUp {
  0% {
    transform: translateY(0) translateX(0) scale(1);
    opacity: 1;
  }
  100% {
    transform: translateY(-550px) translateX(-40px) scale(1.2);
    opacity: 0;
  }
}

/* Random positions + delays + colors */
.balloon:nth-child(1) {
  left: 20%;
  background: #e94040;
  animation-delay: 0s;
}
.balloon:nth-child(2) {
  left: 45%;
  background: #fff458;
  animation-delay: 1.5s;
}
.balloon:nth-child(3) {
  left: 70%;
  background: #74b9ff;
  animation-delay: 3s;
}
.balloon:nth-child(4) {
  left: 30%;
  background: #a29bfe;
  animation-delay: 2s;
}
.balloon:nth-child(5) {
  left: 60%;
  background: #55efc4;
  animation-delay: 0.7s;
}
.balloon:nth-child(6) {
  left: 60%;
  background: #ff32a9;
  animation-delay: 0.7s;
}
.balloon:nth-child(7) {
  left: 60%;
  background: #32ff5e;
  animation-delay: 0.7s;
}
/* FOOTER STYLING */
.play-footer {
  background: linear-gradient(135deg, #609fc4, #7c59be);
  color: white;
  padding: 80px 0;
  border-radius: 60px 60px 0 0;
  box-shadow: 0 -5px 30px rgba(0,0,0,0.25);
  margin-top: 50px;
}

/* Titles */
.footer-title {
  font-size: 1.8rem;
  font-weight: 800;
  margin-bottom: 15px;
  color: #ffffff;
}

.footer-subtitle {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 15px;
  color: #ffd86f; /* gold accent */
}

/* Body text */
.footer-text {
  font-size: 1.1rem;
  opacity: 0.9;
  margin-bottom: 8px;
}

/* Divider line */
.footer-divider {
  border-color: rgba(255,255,255,0.2);
  margin: 30px 0;
}

/* Copyright */
.footer-copy {
  text-align: center;
  font-size: 1rem;
  opacity: 0.8;
}
/* SECTION TITLE */
.wp-title {
  font-size: 2.4rem;
  font-weight: 800;
  color: #5A3CE8;
}

/* TEXT STYLING */
.wp-text {
  font-size: 1.1rem;
  color: #444;
  margin-bottom: 15px;
}

.wp-list {
  padding-left: 20px;
  font-size: 1.1rem;
  color: #333;
}

.wp-list li {
  margin-bottom: 8px;
}
/*--------------About us---------*/
/* CLOUD IMAGE STYLE */
.cloud-img {
  width: 90%;
  max-width: 420px;
  border-radius: 50%;
  background: #fff;
  padding: 25px;
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  animation: floatCloud 5s ease-in-out infinite;
}

/* FLOATING CLOUD ANIMATION */
@keyframes floatCloud {
  0% { transform: translateY(0px); }
  50% { transform: translateY(-12px); }
  100% { transform: translateY(0px); }
}

/* SECTION SPACING */
.why-parents {
  background: #f5f2ff;
  padding: 80px 0;
  border-radius: 0 0 80px 80px;
}

/* PARTY BANNER */
.party-hero-img {
  width: 100%;
  height: 60vh;
  object-fit: cover;
  filter: brightness(65%);
}

.party-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 60vh;
}

/* FORM STYLE */
.party-form {
  background: #ffffffcc;
  backdrop-filter: blur(5px);
  border-radius: 20px;
  border: 2px solid #ffb4e6;
}

.party-form .form-control {
  border-radius: 12px;
  padding: 10px;
  border: 1px solid #ff9cd6;
}

.party-form .form-control:focus {
  border-color: #ff5fa2;
  box-shadow: 0 0 5px #ff5fa2;
}

/* SECTION BACKGROUND */
.party-section {
  background: linear-gradient(135deg, #ffefd7, #ffe3fb);
}

/* 
   FLOATING BALLOON BACKGROUND
 */
.balloon-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  z-index: -1; /* behind everything */
  pointer-events: none; /* ignore mouse */
}

/* Balloon shape */
.balloon {
  position: absolute;
  width: 60px;
  height: 75px;
  border-radius: 50%;
  opacity: 0.7;
  animation: floatUp 8s linear infinite;
  filter: drop-shadow(0 8px 12px rgba(0,0,0,0.2));
}

/* Balloon string */
.balloon::after {
  content: "";
  position: absolute;
  width: 3px;
  height: 50px;
  background: rgba(80,80,80,0.6);
  left: 50%;
  transform: translateX(-50%);
  bottom: -50px;
}

/* Animation */
@keyframes floatUp {
  0% {
    transform: translateY(0) scale(1);
    opacity: 0.9; /* visible */
  }
  100% {
    transform: translateY(-110vh) scale(1.15);
    opacity: 0.9; /* NO fading */
  }
}


/* 
   RANDOM POSITIONS + COLORS
 */
.b1 { left: 10%; background:#ff9acb; animation-delay: 0s; }
.b2 { left: 25%; background:#9b7a21; animation-delay: 2s; }
.b3 { left: 40%; background:#8ec6ff; animation-delay: 1s; }
.b4 { left: 55%; background:#b49cff; animation-delay: 3s; }
.b5 { left: 70%; background:#20523c; animation-delay: 0.5s; }
.b6 { left: 85%; background:#ff7d7d; animation-delay: 4s; }
.b7 { left: 50%; background:#ffc2e2; animation-delay: 2.5s; }

/* SECTION BACKGROUND */
.contact-section {
  position: relative;
  min-height: 100vh;
  background: linear-gradient(135deg, #ffdee9, #b5fffc);
  overflow: hidden;
}

/* PAGE TITLE */
.contact-title {
  font-size: 3rem;
  font-weight: 800;
  color: #ff0066;
  text-shadow: 2px 2px 10px rgba(0,0,0,0.2);
}

/* FORM CARD */
.contact-form-card {
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(6px);
  border: 2px solid white;
  border-radius: 20px;
}

/* INPUT STYLING */
.fancy-input {
  border-radius: 12px;
  border: 1px solid #ffc1e3;
  box-shadow: 0px 3px 8px rgba(255,0,100,0.2);
  transition: 0.3s;
}

.fancy-input:focus {
  border-color: #ff57a6;
  box-shadow: 0px 3px 12px rgba(255,0,100,0.35);
}

/* BUTTON */
.fancy-btn {
  padding: 12px;
  background: linear-gradient(45deg, #ff4da6, #ff85c0);
  border: none;
  color: white;
  font-size: 1.1rem;
  font-weight: 700;
  border-radius: 14px;
  transition: 0.3s;
}

.fancy-btn:hover {
  transform: scale(1.03);
  background: linear-gradient(45deg, #ff0d78, #ff5fbf);
}

/* CONTACT INFO BOX */
.contact-info-card {
  background: rgba(255, 255, 255, 0.75);
  border-radius: 20px;
  border: 2px solid white;
  backdrop-filter: blur(6px);
  font-size: 1.1rem;
  line-height: 1.7rem;
}

/* FLOATING BALLOONS */
.floating-balloons .balloon {
  position: absolute;
  width: 80px;
  height: 110px;
  background: pink;
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  opacity: 0.8;
  animation: floatUp 8s infinite ease-in-out;
}

.b1 { left: 5%; bottom: -120px; animation-delay: 0s; background:#ff7cc8; }
.b2 { left: 40%; bottom: -140px; animation-delay: 2s; background:#ffb3db; }
.b3 { left: 75%; bottom: -100px; animation-delay: 4s; background:#ffa6e1; }

@keyframes floatUp {
  0% { transform: translateY(0) scale(1); opacity: 0.8; }
  50% { transform: translateY(-250px) scale(1.05); opacity: 1; }
  100% { transform: translateY(-500px) scale(1); opacity: 0; }
}
/*--------------------------------------- party package page----------------------------------------------------*/
/* The main card  */
.bunny-card{
  position: relative;        /* the texts are fixed on the card*/
  width: 420px;             
  height: 720px;
   animation: floatBunny 5s ease-in-out infinite;
}

/* The bunny image */
.bunny-img{
  width: 100%;               /* fill the card */
  height: 100%;
  object-fit: contain;       /* the whole is properly in the card, it isnt ovrlaying outside */
}

/* The text ON TOP of the bunny */
.bunny-text{
  position: absolute;        /* floats over the image */
  top: 150px;                /* move text downy */
  left: 50%;                 /* center horizontally */
  transform: translateX(-50%);
  width: 260px;              /* width of the text */
  text-align: center;
}

/* Price */
.price{
  font-weight: bold;
  font-size: 20px;
  margin-bottom: 10px;
}

/* List */
.bunny-text ul{
  text-align: left;
  padding-left: 18px;
  font-size: 18px;
  line-height: 1.6;
}

/* Button */
.bunny-text button{
  margin-top: 15px;
  padding: 10px 22px;
  border-radius: 20px;
  border: none;
  background-color: #4c2e92;
  color: white;
  font-weight: bold;
  cursor: pointer;
}

/* FLOATING BUNNY CARD */
@keyframes floatBunny {
  0%   { transform: translateY(0px); }
  50%  { transform: translateY(-10px); }
  100% { transform: translateY(0px); }
}


select, option{
   color: #000 !important;
  background: #fff !important;
}
/*---------------------------------------------- Beaumont Playhouse - name color ---------------------------------------------------*/
.p { color: red; }
.l { color: orange; }
.a { color: yellow; }
.y { color: green; }
.h { color: blue; }
.o { color: indigo; }
.u { color: purple; }
.s { color: rgb(206, 136, 147); }
.e { color: rgb(189, 0, 31); }

.Party{
  text-shadow: #609fc4;
  color: rgb(29, 155, 149);
  text-align: center;
  text-transform: capitalize;
  
}

/*-------------Activities page--------------------*/
/* Activities Section */

#activities{
  background: linear-gradient(135deg, #ffefd7, #ffe3fb);
}

.activity-card{
background:white;
padding:30px;
border-radius:20px;
box-shadow:0 8px 20px rgba(0,0,0,0.08);
transition:transform 0.3s ease, box-shadow 0.3s ease;
height:100%;
}

.activity-card:hover{
transform:translateY(-10px);
box-shadow:0 15px 35px rgba(0,0,0,0.15);
}

.activity-icon{
font-size:40px;
margin-bottom:15px;
}

.activity-card h4{
font-weight:600;
margin-bottom:10px;
}

.activity-card p{
font-size:15px;
color:#555;
}

/*-- shaopes ---*/

#activities{
position:relative;
background: linear-gradient(135deg, #ffefd7, #ffe3fb);
overflow:hidden;
}

/* base shape */
.shape{
position:absolute;
border-radius:50%;
opacity:0.25;
animation:float 6s ease-in-out infinite;
}

/* shape 1 */
.shape1{
width:180px;
height:180px;
background:#ff9f1c;
top:50px;
left:-60px;
animation-duration:6s;
}

/* shape 2 */
.shape2{
width:220px;
height:220px;
background:#2ec4b6;
bottom:60px;
right:-80px;
animation-duration:8s;
}

/* shape 3 */
.shape3{
width:120px;
height:120px;
background:#ffbf69;
top:200px;
right:120px;
animation-duration:7s;
}

@keyframes float{
0%{
transform:translateY(0px);
}
50%{
transform:translateY(-20px);
}
100%{
transform:translateY(0px);
}
}