
/* banner.css - external stylesheet for the hero banner */
:root{
  --accent-1: #206abd;
  --accent-2: #0a3d62;
  --white: #ffffff;
  --text: #eaeaea;
  --font: 'Poppins', sans-serif;
}

*{box-sizing:border-box}
body{font-family:var(--font);margin:0;background:#fff;color:#222}

/* container */
.slideshow-container-banner{
  position: relative;
  width: 100%;
  height: 85vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background: #000;
}

/* background image */
.slide-banner img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform-origin: center;
  animation: zoomIn 12s ease-in-out infinite alternate;
  will-change: transform;
}

/* dark overlay for readability */
.overlay-banner{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55); /* slightly darker overlay */
  z-index: 1;
}

/* text panel (left aligned) */
.slide-content-banner{
  position: relative;
  z-index: 2;
  color: var(--white);
  max-width: 680px;
  padding: 40px 6% 40px 8%;
  text-align: left;
  align-self: center;
  opacity: 0;
  transform: translateY(30px);
  animation: fadeSlideUp 1s ease forwards;
}

/* heading / paragraph / button */
.slide-content-banner h2{
  font-size: 52px;
  line-height: 1.08;
  margin: 0 0 14px 0;
  font-weight:700;
  color: var(--white);
  letter-spacing: .2px;
  animation: fadeInLeft 1s ease forwards;
}

.slide-content-banner p{
  font-size: 18px;
  color: var(--text);
  margin: 0 0 28px 0;
  line-height: 1.6;
  animation: fadeInLeft 1.3s ease forwards;
}

/* CTA button */
.slide-content-banner button{
  background: linear-gradient(135deg,var(--accent-1),var(--accent-2));
  color: var(--white);
  border: 0;
  padding: 14px 30px;
  border-radius: 8px;
  font-weight:600;
  font-size: 15px;
  cursor:pointer;
  transition: transform .25s ease, box-shadow .25s ease;
  animation: fadeInLeft 1.6s ease forwards;
}
.slide-content-banner button:hover{
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 12px 30px rgba(32,106,189,0.35);
}

/* subtle text reveal and motion keyframes */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-40px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes zoomIn {
  from { transform: scale(1); }
  to   { transform: scale(1.08); }
}

/* responsive tweaks */
@media (max-width: 992px){
  .slide-content-banner { padding-left: 6%; padding-right: 6%; max-width: 70%; }
  .slide-content-banner h2{ font-size: 40px; }
  .slide-content-banner p{ font-size: 16px; }
}

@media (max-width: 600px){
  .slideshow-container-banner { height: 66vh; align-items: flex-start; }
  .slide-content-banner { padding-left: 5%; padding-top: 36px; max-width: 92%; }
  .slide-content-banner h2{ font-size: 28px; }
  .slide-content-banner p{ font-size: 14px; }
  .slide-content-banner button{ padding: 10px 20px; font-size: 14px; }
}
