.card-section{
padding-top: 0.5rem;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.section-title.head {
  text-align: center;
  padding: 80px 20px 60px;
  max-width: 900px;
  margin: 0 auto;
}

.section-title.head h1 {
  font-family: 'Montserrat', 'Arial', sans-serif;
  font-size: clamp(3rem, 7vw, 5rem); 
  font-weight: 700;
  letter-spacing: 1px;
  color: #111;
  margin-bottom: 30px;
}

.section-title.head p {
  font-size: 1.15rem;
  line-height: 1.9;
  color: #333;
  max-width: 750px;
  margin: 0 auto;
  opacity: 0.9;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.section-title.head {
  animation: fadeUp 1s ease-in-out both;
}


.costing-hero {
  background: linear-gradient(135deg, #f18701, #ffb84d);
  color: black;
  min-height: 60vh;
}


.text-gradient {
  background: linear-gradient(45deg, #f18701, #ff9f40);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}


.fade-in { opacity: 0; transform: translateY(20px); animation: fadeInUp 0.8s forwards; }
.fade-in.delay-1 { animation-delay: 0.3s; }
.fade-in.delay-2 { animation-delay: 0.6s; }

@keyframes fadeInUp {
  to { opacity: 1; transform: translateY(0); }
}

.animate-slide-up { opacity: 0; transform: translateY(50px); animation: slideUp 1s forwards; }
.animate-slide-up.delay-1 { animation-delay: 0.5s; }

@keyframes slideUp {
  to { opacity: 1; transform: translateY(0); }
}

.animate-bounce { animation: bounce 2s infinite; }
@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.pricing-card {
  border: 2px solid #f18701;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.pricing-card:hover {
  transform: translateY(-10px) scale(1.03);
  box-shadow: 0 12px 24px rgba(241, 135, 1, 0.25);
}
.pricing-card .card-header { background: #fff3e6; border-bottom: none; }
.pricing-card .pricing-card-title { font-size: 2.5rem; font-weight: bold; color: #f18701; }
.pricing-card ul li::before { content: "✔"; color: #f18701; font-weight: bold; margin-right: 8px; }

.popular-badge {
  background: #f18701;
  padding: 0.6rem 1.2rem;
  font-weight: bold;
  border-radius: 0 1rem 0 1rem;
  color: #fff;
  box-shadow: 0 4px 10px rgba(241, 135, 1, 0.3);
}


.price-block { background: #fff3e6; border-radius: 10px; padding: 0.8rem; }
.pricing-card-title { font-size: 2rem; color: #f18701; margin: 0; }


.feature-list li {
  padding: 0.4rem 0;
  border-bottom: 1px solid #f7e1c3;
  font-size: 1rem;
}
.feature-list li:last-child { border-bottom: none; }
.feature-list i { color: #f18701; margin-right: 6px; }


.btn-pricing {
  background-color: #f18701;
  color: #fff;
  font-size: 1rem;
  padding: 0.6rem 1.2rem;
  border-radius: 8px;
}
.btn-pricing:hover { background-color: #d67300; transform: translateY(-2px); }


@media (max-width: 768px) {
  .pricing-card { margin-bottom: 1rem; }
  .pricing-card .card-header i { font-size: 1.8rem; }
  .pricing-card h4 { font-size: 1.3rem; }
  .pricing-card-title { font-size: 1.8rem; }
}

.flip-card {
  --flip-h: 320px;             
  width: 100%;
  max-width: 380px;
  perspective: 1000px;
}

@media (max-width: 767.98px) {
  .flip-card { --flip-h: 280px; max-width: 90%; }
}
@media (min-width: 768px) and (max-width: 991px) {
  .flip-card { --flip-h: 340px; max-width: 360px; }
}

.flip-card-inner {
  position: relative;
  width: 100%;
  height: var(--flip-h);
  transform-style: preserve-3d;
  transition: transform 1s;
  cursor: pointer;
}

.flip-card-inner.is-flipped { transform: rotateY(180deg); }

.flip-card-front,
.flip-card-back {
  position: absolute;
  inset: 0;
  height: var(--flip-h);
  border-radius: 16px;
  border: solid 4px black;
  backface-visibility: hidden;
  box-shadow: 0px 3px 18px rgba(0, 0, 0, 0.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  text-align: center;
}


.flip-card-front {
  background-image: linear-gradient(to bottom right, #FFCE00, #f18701);
  color: black;
}


.flip-card-back {
  background-color: #212121;
  background-image: linear-gradient(145deg, #212121, #2e2e2e);
  color: #fff;
  transform: rotateY(180deg);
  padding: 1rem;

}


.flip-card .lead {
  font-size: clamp(1rem, 2.2vw, 1.125rem);
  line-height: 1.35;
  margin: 0;
}
.flip-card-back p {
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

.head .genericButton:hover{ color: white; background-color: #000; }
.head .genericButton{ background-color: #f18701; color:#000; border: solid black 3px; }


.flip-card-back h3 {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: #f18701;
}


.flip-card-back p span.gen {
  color: #f18701 !important;
  font-weight: bold;
}

@media (min-width: 768px) and (max-width: 991px) {
  .flip-card-back h3 { font-size: 1.25rem; }
}


.icon-large { font-size: 6rem; margin-bottom: 0.5rem; color: black; }
.icon-medium { font-size: 3rem; margin-bottom: 0.5rem; color: black; }
@media (min-width: 768px) and (max-width: 991px) {
  .icon-large { font-size: 4.5rem; }
  .icon-medium { font-size: 2.5rem; }
}


.carousel-indicators button {
  pointer-events: auto;
  background-color: black;
}


.icon-interactive {
  display: inline-block;  
  transform-origin: center;
  transition: color 0.4s ease, transform 0.35s ease;
  cursor: pointer;
}

.icon-interactive:hover {
  color: #0d6efd !important; 
  transform: scale(1.1);
}

.icon-interactive:active {
  color: #ffc107 !important; 
  transform: scale(0.95);
}


@media (min-width: 992px) {
  .flip-card {
    max-width: 100%;
    height: 400px;
  }
}

@keyframes gradientBG {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}