/* ─── FOOTER ─── */

#footer { background: #fff; border-top: none; }

#footer_before_container .elementor-container { padding: 0 !important; max-width: 100% !important; }
#footer_before_container .elementor-section { margin-top: 0 !important; }
#footer_before_container .elementor-section > .elementor-container {
  padding: 60px 40px 40px !important;
}
#footer_before_container .elementor-widget-container { padding: 0; }

.footer-brand .logo-text { display: block; font-size: 22px; font-weight: 800; color: #111; letter-spacing: 1px; margin-bottom: 14px; }
.footer-brand p { font-size: 13px; line-height: 1.8; color: #666; max-width: 260px; margin-bottom: 20px; }
.footer-social { display: flex; gap: 10px; }
.footer-social a { width: 34px; height: 34px; border-radius: 50%; border: 1px solid #ddd; display: flex; align-items: center; justify-content: center; color: #666; text-decoration: none; font-size: 13px; transition: .2s; }
.footer-social a:hover { background: #333; border-color: #333; color: #fff; }

.footer-col h5 { color: #111; font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 20px; }
.footer-col a { display: block; color: #666; text-decoration: none; font-size: 13px; padding: 4px 0; transition: .2s; }
.footer-col a:hover { color: #111; padding-left: 4px; }

.newsletter-form { display: flex; flex-direction: column; gap: 8px; }
.newsletter-form input { background: #f5f5f5; border: 1px solid #ddd; border-radius: 4px; padding: 10px 14px; color: #222; font-size: 13px; outline: none; width: 100%; }
.newsletter-form input::placeholder { color: #aaa; }
.newsletter-form button { background: #111; color: #fff; border: none; padding: 11px 16px; border-radius: 4px; font-weight: 700; font-size: 12px; cursor: pointer; width: 100%; letter-spacing: .5px; transition: background .2s; }
.newsletter-form button:hover { background: #333; }

#footer-bottom {
  border-top: 1px solid #e0e0e0;
  background: #fff;
  padding: 16px 40px;
}
#footer-bottom .wide_container_box,
#footer-bottom .wide_container { width: 100%; max-width: 100%; margin: 0; padding: 0; }
#footer-bottom #footer-bottom-container.container { padding: 0; max-width: 100% !important; width: 100%; }
#footer-bottom .row { margin: 0; }

#footer-bottom .col-12 {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0;
}
#footer-bottom .col-12::before,
#footer-bottom .col-12::after { display: none !important; }

#footer_bottom_left,
#footer_bottom_right { float: none !important; width: auto !important; }
#footer_bottom_left { order: 1; }
#footer_bottom_right { order: 2; display: flex; align-items: center; }

#footer-bottom .copyright_text { font-size: 12px; color: #999; }
#footer-bottom .copyright_text a { color: #555 !important; text-decoration: none; }
#footer_bottom_right .st_payment_icon { height: 24px; width: auto; display: block; }

@media (max-width: 992px) {
  #footer_before_container .elementor-section > .elementor-container { padding: 40px 24px 32px !important; }
}
@media (max-width: 576px) {
  #footer_before_container .elementor-section > .elementor-container { padding: 32px 20px !important; }
  #footer-bottom { padding: 16px 20px; }
  #footer-bottom .col-12 { flex-direction: column; align-items: flex-start; }
}


/* ─── VIDEO SECTION ─── */

.elementor-section:has(.video-content) {
  background: #111 !important;
}
.elementor-section:has(.video-content),
.elementor-section:has(.video-content) > .elementor-container {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.elementor-section:has(.video-content) > .elementor-container {
  padding: 80px 40px !important;
}
.elementor-section:has(.video-content) > .elementor-container > .elementor-row {
  max-width: 100% !important;
  width: 100% !important;
  padding: 80px 40px !important;
  margin: 0 !important;
}
.elementor-section:has(.video-content) .elementor-column {
  display: flex;
  align-items: center;
}

.video-section {
  background: #111;
  padding: 100px 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.video-frame {
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 16 / 9;
  background: rgba(0,0,0,.4);
  display: flex;
  align-items: center;
  justify-content: center;
}
.video-frame-bg { position: absolute; inset: 0; background: #2a2a2a; }

.video-play {
  position: relative;
  z-index: 2;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: #555;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 0 0 16px rgba(85,85,85,.12);
  transition: background .2s, box-shadow .2s;
}
.video-play:hover {
  background: #777;
  box-shadow: 0 0 0 20px rgba(85,85,85,.18);
}

.video-content .section-tag { text-align: left; color: #888; display: block; margin-bottom: 12px; }
.video-content .section-title { text-align: left; color: #fff; font-size: 36px; margin-bottom: 20px; }
.video-content > p { color: rgba(255,255,255,.65); font-size: 15px; line-height: 1.8; margin-bottom: 32px; }

.video-features { display: flex; flex-direction: column; gap: 14px; margin-bottom: 36px; }
.video-feature { display: flex; align-items: center; gap: 12px; color: rgba(255,255,255,.8); font-size: 14px; }
.video-feature .check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #555;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: #fff;
  flex-shrink: 0;
  line-height: 1;
}

.video-content .btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  color: #111;
  padding: 16px 32px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .5px;
  text-decoration: none;
  transition: background .2s, transform .2s;
}
.video-content .btn-primary:hover { background: #e8e8e8; color: #111; transform: translateY(-2px); }

@media (max-width: 992px) {
  .elementor-section:has(.video-content) > .elementor-container { padding: 60px 24px !important; }
  .elementor-section:has(.video-content) > .elementor-container > .elementor-row { padding: 60px 24px !important; }
}
@media (max-width: 576px) {
  .elementor-section:has(.video-content) > .elementor-container { padding: 48px 20px !important; }
  .elementor-section:has(.video-content) > .elementor-container > .elementor-row { padding: 48px 20px !important; }
  .video-content .section-title { font-size: 26px; }
  .video-play { width: 56px; height: 56px; font-size: 22px; }
}
