/* ============================= */
/* 🌟 PREMIUM BOOKING MODAL UI */
/* ============================= */

.booking-red{
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(135deg,#ff1744,#c51162);
  box-shadow:0 22px 55px rgba(0,0,0,0.45);
}

/* HEADER */
.booking-red .modal-header{
  padding:18px 22px;
}
.booking-red .modal-title{
  font-size:20px;
  letter-spacing:0.6px;
  text-shadow:0 3px 8px rgba(0,0,0,0.35);
}

/* BODY CARD */
.booking-red .modal-body{
  background:#ffffff;
  border-radius:20px;
  margin:0 14px 14px;
  padding:22px 20px 20px;
  animation:fadeUp 0.45s ease;
}

/* ============================= */
/* ✨ FORM ELEMENTS */
/* ============================= */

.booking-red .form-label{
  font-size:12px;
  font-weight:600;
  color:#777;
  margin-bottom:4px;
  transition:color 0.25s ease;
}

.booking-red .form-control,
.booking-red .form-select{
  border-radius:12px;
  border:1px solid #e2e2e2;
  background:#fafafa;
  padding:11px 14px;
  font-size:14px;
  transition:
    background 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.25s ease,
    transform 0.18s ease;
}

/* Hover */
.booking-red .form-control:hover,
.booking-red .form-select:hover{
  background:#fff;
  transform:translateY(-1px);
}

/* Focus */
.booking-red .form-control:focus,
.booking-red .form-select:focus{
  background:#fff;
  border-color:#ff1744;
  box-shadow:
    0 0 0 3px rgba(255,23,68,0.25),
    0 10px 22px rgba(255,23,68,0.18);
}

/* ============================= */
/* 🚀 SUBMIT BUTTON */
/* ============================= */

.submit-red{
  background:linear-gradient(135deg,#ff1744,#ff6f91);
  border:none;
  border-radius:999px;
  font-size:15px;
  letter-spacing:0.8px;
  box-shadow:0 14px 28px rgba(255,23,68,0.45);
  position:relative;
  overflow:hidden;
  transition:transform 0.25s ease, box-shadow 0.25s ease;
}

/* Shine effect */
.submit-red::after{
  content:"";
  position:absolute;
  top:0;
  left:-70%;
  width:50%;
  height:100%;
  background:linear-gradient(
    120deg,
    rgba(255,255,255,0),
    rgba(255,255,255,0.7),
    rgba(255,255,255,0)
  );
  transform:skewX(-20deg);
}

/* Hover */
.submit-red:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 20px 36px rgba(255,23,68,0.55);
}
.submit-red:hover::after{
  animation:btnShine 0.9s ease;
}

/* Active */
.submit-red:active{
  transform:scale(0.96);
  box-shadow:0 8px 16px rgba(0,0,0,0.35);
}

/* ============================= */
/* 🎬 MODAL ANIMATION */
/* ============================= */

.modal.modal-zoom.show .modal-dialog{
  animation:modalPop 0.45s cubic-bezier(0.19,1,0.22,1);
}

@keyframes modalPop{
  0%{transform:scale(0.85) translateY(40px);opacity:0;}
  60%{transform:scale(1.03) translateY(-6px);opacity:1;}
  100%{transform:scale(1) translateY(0);}
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(12px);}
  to{opacity:1;transform:translateY(0);}
}

@keyframes btnShine{
  from{left:-70%;}
  to{left:130%;}
}

/* ============================= */
/* ❌ CLOSE BUTTON */
/* ============================= */

.btn-close{
  transition:transform 0.25s ease, opacity 0.25s ease;
}
.btn-close:hover{
  transform:rotate(90deg) scale(1.15);
  opacity:0.85;
}

/* ============================= */
/* 📱 MOBILE POLISH */
/* ============================= */

@media(max-width:480px){
  .booking-red .modal-body{
    padding:18px 16px;
  }
  .booking-red .modal-title{
    font-size:18px;
  }
}
