/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */

html {
  scroll-behavior: auto !important;
}

.elementor-button-icon svg {
    width: 1.51vw !important;
}

.elementor-counter-title {
    text-align: center;
}

.elementor-field-type-textarea textarea {
	border-radius: 1.042vw !important;
	padding-top: 1vw !important;
}

.services-card {
	transition: 0.5s ease;
} 

.services-btn {
	transform: translatey(4vw);
}

.services-card:hover .services-btn {
	transform: translatey(0vw);
}

.elementor-widget-theme-post-content .wp-block-gallery {
	display: none;
}

::-webkit-scrollbar{
    width: 0.5vw;
    background: white;
	box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
}
::-webkit-scrollbar-thumb{
    background: #A9E522;
    border-radius: 0px;
}

.leaflet-control-attribution {
	display: none;
}

.leaflet-top.leaflet-left {
    position: absolute;
	bottom: 1vw;
	left: 0;
    display: flex;
    align-items: flex-end;
}

.RssGrid {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
}

.contact-form option {
	color: black !important;
}

.news-content-img .wp-block-media-text__media img {
	border-radius: 2vw;
}


.ltr .wp-block-media-text__content {
	padding-left: 0 !important;
}

/* Tabs container */
.locator-tab-buttons {
    display: flex;
    width: 100%;
    gap: 1vw;
}

/* Base tab style */
.loc-tab {
    flex: 1;
    padding: 1.2vw 1vw !important;
    border: 0.1vw solid #A9E522 !important;
    background: transparent !important; 
    color: #000 !important; 
    font-size: 2vw !important;
    text-align: center;
    cursor: pointer;
    border-radius: 1vw !important;
    transition: all 0.25s ease;
}

/* Active tab style */
.loc-tab.active {
    background: #A9E522 !important; 
    color: #000 !important; 
    border-color: #A9E522 !important;
}

/* Hover effect */
.loc-tab:not(.active):hover {
    background: #A9E522 !important;
    color: #000 !important;
}

/* Charts Styling */

/* === BankPacific Checking Charts === */

/* Table wrapper for scroll on mobile */
.bp-table-wrapper {
  overflow-x: auto;
  scrollbar-width: thin; 
  scrollbar-color: #a5e13f #f0f0f0; 
}

.bp-table-wrapper::-webkit-scrollbar {
  height: 1vw;
}

.bp-table-wrapper::-webkit-scrollbar-thumb {
  background: #a5e13f;
  border-radius: 1vw;
}

.bp-table {
  border-collapse: collapse;
  width: 100%;
  min-width: 80vw;
  text-align: left;
  background: #fff;
  overflow: hidden;
}

.bp-table thead {
  background: #F2F5F7;
}

.bp-table th {
  font-family: "Neue Montreal", "Poppins", sans-serif;
  font-weight: 500;
  font-size: 1.1vw;
  color: #000;
  padding: 1.5vw 1vw;
  white-space: nowrap;
}

.bp-table td {
  font-family: "Manrope", "Inter", "Segoe UI", sans-serif;
  font-size: 1vw;
  line-height: 1.4;
  color: #333;
  padding: 1.2vw 1vw;
  border-top: 0.05vw solid #e4e7ea;
  background: #fff;
}

.bp-table td:first-child {
  font-weight: bold;
}

.bp-table tbody tr {
  background: #fff !important;
}

table tbody>tr:nth-child(odd)>td, table tbody>tr:nth-child(odd)>th,
table tbody>tr:nth-child(even)>td, table tbody>tr:nth-child(even)>th {
    background-color: white !important;
}

/* MILESTONES TIMELINE */

.twae-content {
  padding: 2vw !important;
}

.twae-title, .twae-label-big {
  font-size: 1.8vw !important;
}

.igf-prev, .igf-next {
    font-size: 2vw !important;
	padding: 2vw 1vw !important;
}

.igf-prev:hover, .igf-next:hover {
    background-color: black !important;
	color: #A9E522 !important;
	border-color: black !important;
}

/* Responsive typography */
@media (max-width: 900px) {
  .bp-chart-heading {
    font-size: 4.5vw;
  }

  .bp-table th,
  .bp-table td {
    font-size: 2.8vw;
    padding: 2.5vw 2vw;
  }
}

@media (max-width: 600px) {
  .bp-checking-charts {
    padding: 6vw 4vw;
  }

  .bp-table {
    min-width: 120vw;
  }

  .bp-chart-heading {
    font-size: 5vw;
    margin-bottom: 3vw;
  }
}

@media only screen and (max-width:600px) {
.elementor-button {
	border-radius: 1vw !important;
}

.elementor-button-icon svg {
    width: 3.51vw !important;
}

.services-btn {
	transform: translatey(8vw);
}
	
.mob-flex ul {
	gap: 2vw;
    flex-direction: column;
}
	
.bp-checking-charts {
    padding: 6vw 4vw;
}

.bp-table {
    min-width: 120vw;
}

.bp-chart-heading {
    font-size: 5vw;
    margin-bottom: 3vw;
}

.loc-tab {
    flex: 1;
    padding: 2vw;
    font-size: 3vw !important;
    border-radius: 2vw !important;
}

.news-content-img .wp-block-media-text__content {
	padding: 0 !important;
	margin-top: 4vw;
}
	
/* MILESTONES TIMELINE */

.twae-content {
  padding: 3vw !important;
}

.twae-title, .twae-label-big {
  font-size: 4vw !important;
}
	

.igf-prev, .igf-next {
    font-size: 6vw !important;
}

}

/* Animations */

.rotating-title {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.8s ease-in-out;
}

.rotating-title.active {
  opacity: 1;
  transform: translateY(0);
}

.swiper-wrapper {
  transition-timing-function: linear !important; 
}

/*Executive Members Loop CSS*/

.exec-grid{
  display:grid;
  gap: 80px 40px;
  align-items: stretch;
}

.exec-cols-2{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
.exec-cols-3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
.exec-cols-4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (max-width: 1024px){
  .exec-cols-3, .exec-cols-4{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .exec-cols-2, .exec-cols-3, .exec-cols-4{ grid-template-columns: 1fr; }
}

.exec-card{
  position: relative;
  background: #fff;
  border-radius: 18px;
  padding: 56px 22px 22px; /* top padding avatar ke liye */
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  text-align: center;
}

.exec-avatar-wrap{
  position: absolute;
  top: -42px;
  left: 50%;
  transform: translateX(-50%);
  width: 92px;
  height: 92px;
  border-radius: 999px;
  background: #fff;
  padding: 0;
  box-shadow: 0 10px 25px rgba(0,0,0,.12);
  overflow: hidden;
}

.exec-avatar{
  width: 100% !important;
  height: 100% !important;
  border-radius: 999px !important;
  object-fit: cover;
  display:block;
}

.exec-avatar--placeholder{
  background: #f2f2f2;
}

.exec-name{
  margin: 6px 0 10px;
  font-size: 22px !important;
  line-height: 1.2;
  font-weight: 400;
}

.exec-desc{
  display: flex;
  font-size: 14px;
  line-height: 1.5;
  opacity: .85;
  white-space: pre-line;
  justify-content: center;
}