/**
Theme Name: bookanyboat
Author: Brainstorm Force
Author URI: http://wpastra.com/about/
Description: Astra is the fastest, fully customizable & beautiful theme suitable for blogs, personal portfolios and business websites. It is very lightweight (less than 50KB on frontend) and offers unparalleled speed. Built with SEO in mind, Astra comes with schema.org code integrated so search engines will love your site. Astra offers plenty of sidebar options and widget areas giving you a full control for customizations. Furthermore, we have included special features and templates so feel free to choose any of your favorite page builder plugin to create pages flexibly. Some of the other features: # WooCommerce Ready # Responsive # Compatible with major plugins # Translation Ready # Extendible with premium addons # Regularly updated # Designed, Developed, Maintained & Supported by Brainstorm Force. Looking for a perfect base theme? Look no further. Astra is fast, fully customizable and beautiful theme!
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bookanyboat
Template: astra
*/
.search-btn{
	background-color:#007BFF;	
}

li.rez-icons.icon-boat:before{
    width: 45px;
    height: 45px;
    /*background-image: url("/wp-content/uploads/2026/03/bookanyboat-icon-boat.png");*/
    top: 10px;
    position: relative;
}
li.rez-icons.icon-fishrod:before{
    width: 30px;
    height: 35px;
    /*background-image: url("/wp-content/uploads/2026/03/bookanyboat-icon-fishrod.png");*/
    top: 5px;
    position: relative;
}
li.rez-icons.icon-mappin:before{
    width: 23px;
    height: 30px;
    /*background-image: url("/wp-content/uploads/2026/03/bookanyboat-icon-mappin.png");*/
    top: 6px;
    position: relative;
}
li.rez-icons:before {
    content: "";
    display: inline-block;
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 5px;
}
li.rez-icons {
    display: flex;
	margin: 0 12px;
}
li.rez-icons a{padding-left: 0 !important;padding-right: 0 !important;}
footer .elementor-widget.elementor-widget-heading {
    margin-bottom: 8px;
}
.cta-section li.elementor-icon-list-item a {
    background: #007BFF;
    min-height: 45px;
    min-width: 135px;
    border-radius: 8px;
}
.multi-curr-lang .currency-dropdown {
    font-weight: 700 !important;
    padding: 0 !important;
    background: none !important;
    border: 0;
    width: 55px;
    font-family: 'Nunito';
    box-shadow: none;
    color: #000;
}
.multi-curr-lang .elementor-widget-shortcode {
    width: 55px !important;
	margin: 0;
}
.multi-curr-lang .elementor-widget-wrap {
    flex-direction: row;
    justify-content: flex-end;
    column-gap: 15px;
}
.multi-curr-lang .currency-dropdown {
    margin-right: 12px;
}
.multi-curr-lang .gt_float_switcher img {
    vertical-align: middle;
    display: inline-block;
    width: 20px;
    margin: 0 5px 0 0;
    border-radius: 3px;
}
.multi-curr-lang .gt_float_switcher .gt-selected .gt-current-lang span.gt-lang-code {
    display: none;
}    
.multi-curr-lang .gt_float_switcher .gt-selected .gt-current-lang {
    padding: 0 !important;
}
.multi-curr-lang .gt_float_switcher {
    box-shadow: none !important;
}
.multi-curr-lang .gt_float_switcher .gt_options a.nturl{
    font-size: 0 !important;
    padding: 5px 5px !important;
}
.multi-curr-lang .gt_float_switcher .gt_options {
    position: absolute;
    z-index: 1;
    background: #fff;
    border: 1px solid #ccc;
	max-width: 100% !important;
}
.multi-curr-lang .gt_float_switcher .gt-selected {
    background: #f8f8f8;
}
.multi-curr-lang .gt_float_switcher .gt-selected .gt-current-lang span.gt_float_switcher-arrow {
    transform: rotate(0deg);
	font-weight: 900;
    filter: brightness(0.2);
	background-size: 9px;
 
}
.hfe-search-form__input::placeholder {
  font-weight:200;
}
input.hfe-search-form__input::placeholder {
  font-weight:200;
}
.multi-curr-lang #gt_float_wrapper {
    display: flex;
    flex-wrap: nowrap;
}
.pages-header .bab-search-container {
    margin: 0;
}
.pages-header .search-field .input-wrapper {
    top: -13px;
    position: relative;
}
.pages-header .search-field.duration {
    position: relative;
}
.pages-header .duration-wrapper {
    position: relative;
}
.pages-header .duration-wrapper {
    position: relative;
    top: -8px;
}
.pages-header .search-field.duration:after{
	content: none;	
}
.pages-header .search-field {
    position: relative;
    overflow: hidden;
}
.pages-header .search-field::after {
    content: "";
    position: absolute;
    right: 0px; /* adjust spacing */
    top: 50%;
    transform: translateY(-50%);
    height: 19px;
    width: 1px;
    background: #0000003d;
}
.pages-header #bab-search-form {
    max-height: 48px;
}
.pages-header .search-submit button {
    height: 37px;
    width: 37px;
}	
.pages-header .search-submit {
    padding-right: 0;
}
.pages-header .search-field label {
    margin-top: 30px;
}
.results-sort {
    display: none;
}
.pages-header .search-field::placeholder {
    opacity:0;
}
.pages-header .search-field input::-webkit-input-placeholder {
    opacity:0;
}
.pages-header .search-field:-ms-input-placeholder {
    opacity:0;
}
.pages-header .search-field::-ms-input-placeholder {
    opacity:0;
}
.pages-header .elementor-widget-shortcode {
    margin-bottom: 0 !important;
}
#boat-filter {
    cursor: pointer;
    background: var(--bab-bg);
    border: 1px solid #71717133;
    border-radius: 34px;
    box-shadow: -6px 3px 20px rgb(0 0 0 / 6%);
    width: 100%;
}
.mobile-filter-bar {
    display: none;
}
body { font-family: 'Nunito', sans-serif; }
.container {margin: 0 auto;padding: 0;}
.section-padding { padding: 80px 0; }
/* LISTING TITLE */
.listing-title-section {padding-top: 50px;padding-bottom: 0;}
.page-title {font-size: 24px;font-weight: 700;margin-bottom: 0;}

/* LISTING GRID */
.listing-grid-section {padding-top: 0;}
.mobile-listing-nav { display: none; }
.listing-grid {display: grid;grid-template-columns: repeat(5, 1fr);gap: 10px;margin-top: 20px;}

.boat-card { 
  cursor: pointer; 
  border-radius: 21px; 
  overflow: hidden; 
  transition: transform 0.3s, box-shadow 0.3s; 
  background: #fff;
}
.boat-card-img { position: relative; width: 100%; aspect-ratio: 201/195; border-radius: 21px; overflow: hidden; background: #000; }
.nc-track {display: flex;width: auto;height: 100%;transition: transform 0.3s ease-in-out;}
.nc-track img { width: 100%; height: 100%; object-fit: cover; flex-shrink: 0; }

.nc-nav { position: absolute; top: 50%; width: 100%; transform: translateY(-50%); display: flex; justify-content: space-between; padding: 0 10px; opacity: 0; transition: opacity 0.3s; }
.boat-card:hover .nc-nav { opacity: 1; }
.nc-prev, .nc-next { background: rgba(255,255,255,0.7); border: none; width: 25px; height: 25px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center;     font-size: 23px; color: #000; padding: 0; }

.nc-dots { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); display: flex; gap: 4px; }
.nc-dots span { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,0.5); }
.nc-dots span.active { background: #FFF; }

.boat-card-info { padding: 10px 0; }
.card-title { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.card-meta { font-size: 14px; color: var(--text-muted); margin-bottom: 0px; }
.card-price { font-size: 14px; font-weight: 400; color: var(--text-muted); }
.card-price .price-val { color: var(--text-black); font-weight: 700; text-decoration: underline; text-underline-offset: 4px; }
.card-price .currency-display { text-decoration: underline; text-underline-offset: 4px; }

/* PAGINATION */
.pagination-section { padding-top: 40px; padding-bottom: 80px; }
.pagination-inner { display: flex; justify-content: center; align-items: center; gap: 20px; }
.pag-numbers { display: flex; align-items: center; gap: 15px; }
.pag-num { font-weight: 700; font-size: 13px; cursor: pointer; color: #000; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
.pag-num.active { color: #FFF; background: var(--primary-blue); border-radius: 50%; }
.pag-num:hover:not(.active) { background: #f0f0f0; border-radius: 50%; }
.pag-btn { background: none; border: none; font-size: 20px; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0 10px; transition: color 0.2s; }
.pag-btn:hover:not(:disabled) { color: var(--primary-blue); }
.pag-btn:disabled { color: #ccc; cursor: not-allowed; }
.pag-dots { font-weight: 700; color: #000; }

.offer-item img{
	box-shadow: none !important;
    -webkit-box-shadow: none !important;
}
aside.listing-sidebar.open {
    width: 300px;
    scrollbar-color: #fff #0aa7e0;
}

/*.home .elementor-section-content-middle .hfe-nav-menu ul li:first-child a::after {
    background-color: var(--e-global-color-secondary);
    border-bottom: 3px solid var(--e-global-color-secondary);
    border-radius: 999px;
    height: 3px;
    opacity: 1 !important;
}*/

.hfe-nav-menu li.rez-icons > a.hfe-menu-item{
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    width: 100%;
    height: 100%;
    padding: 10px 15px;
}

.hfe-nav-menu li.rez-icons > a.hfe-menu-item::before{
    content: "";
    display: block;
    width: 45px !important;
    height: 45px !important;
    margin-bottom: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
	opacity: 1 !important;
    position: absolute;
    left: -7px !important;
	background-color: transparent !important;
}

/* Boat */
.hfe-nav-menu li.icon-boat > a.hfe-menu-item::before{
    background-image: url("/wp-content/uploads/2026/03/bookanyboat-icon-boat.png");
	width: 45px !important;
    height: 45px !important;
	left: -15px !important;
}

/* Fishrod */
.hfe-nav-menu li.icon-fishrod > a.hfe-menu-item::before{
    background-image: url("/wp-content/uploads/2026/03/bookanyboat-icon-fishrod.png");
	width: 30px !important;
    height: 35px !important;
}

/* Map */
.hfe-nav-menu li.icon-mappin > a.hfe-menu-item::before{
    background-image: url("/wp-content/uploads/2026/03/bookanyboat-icon-mappin.png");
	width: 23px !important;
    height: 30px !important;
}

.archive .hfe-before-footer-wrap,
.archive div#content {
    background: #fff;
}
.boat-card:hover {
    box-shadow: none;
}
.pagination-section ul.page-numbers {
    display: flex;
    align-items: center;
    gap: 15px;
    list-style: none;
}
.pagination-section span.page-numbers.current {
    color: #FFF;
    background: #3e7cff;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    display: block;
    text-align: center;
}
.pagination-section a.page-numbers {
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    color: #000;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}
.pagination-section a.next.page-numbers {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    transition: color 0.2s;
}
.card-title a {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 4px;
    color: #000;
}
.page-numbers.current {
    border: 1px solid var(--bab-border);
    background:#3e7cff;
    color:#fff;
}
.page-numbers {
    padding: 10px 16px;
    background: #fff;
    cursor: pointer;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.2s;
    color: var(--bab-text);
}

.bab-close-filters-mobile {
		display: block;
}
.single-boat span.currency-display, .price-val {
    text-decoration: underline;
    font-weight: 600;
    color: #000;
}
.single-related-boats {display:none;}
.single-boat .single-related-boats {display:block;}
.search-submit span.material-symbols-outlined {
    color: #fff;
}
#bab-search-where{
   box-shadow:none; 
}
#bab-search-when{
   box-shadow:none; 
}
#bab-search-who{
   box-shadow:none; 
}
#bab-search-time{
   box-shadow:none; 
}
#bab-search-duration{
   box-shadow:none; 
}
#bab-search-duration {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: none;
	opacity:0;
}
.home #bab-search-duration {
	opacity : 1
}
/* For IE (older support) */
#bab-search-duration::-ms-expand {
    display: none;
}
.invalid-field {
        border-color: #ff4d4d !important;
        background-color: #fff9f9 !important;
        box-shadow: 0 0 0 4px rgba(255, 77, 77, 0.1) !important;
    }
.page-template-booking-confirm .row.g-5 {
	--bs-gutter-x: 1.5rem;
	--bs-gutter-y: 0;
	display: flex;
	flex-wrap: wrap;
	margin-top: calc(-1 * var(--bs-gutter-y));
	margin-right: calc(-.5 * var(--bs-gutter-x));
	margin-left: calc(-.5 * var(--bs-gutter-x));
}

.page-template-booking-confirm .col-lg-8 {
	flex: 0 0 auto;
	width: 60%;
	padding: 0px 35px 0 24px;
}
.page-template-booking-confirm .col-lg-4 {
	flex: 0 0 auto;
	width: 40%;
	padding: 0px 24px 0 35px;
}
.page-template-booking-confirm .main-container {
	max-width: 1240px;
	margin: 0 auto;
	padding: 35px 0px 65px 0;
	width: 100%;
}

.page-template-booking-confirm .back-nav {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-bottom: 25px;
}
.page-template-booking-confirm .back-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: #F7F7F7;
	border: 1px solid var(--border-light);
	border-radius: 50%;
	color: #000;
	text-decoration: none;
	transition: background 0.2s;
}
.page-template-booking-confirm .back-btn:hover { background: #F8F8F8; }
.page-template-booking-confirm .page-title {
	font-weight: 700;
	font-size: 32px;
	margin: 0;
	letter-spacing: -0.5px;
}

.page-template-booking-confirm .checkout-step-card {
	background: #FFFFFF;
    border: 1px solid var(--border-light);
    padding: 30px;
    margin-bottom: 24px;
    transition: box-shadow 0.3s ease;
    width: 630px;
    height: auto;
    background-color: #ffffff;
    border-radius: 15px;
    /*box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.16);*/
    box-shadow: 0px 1px 2px 0px rgba(0,0,0,0.05);
    overflow: hidden;
    position: relative;
    margin-left: 50px;
}
.page-template-booking-confirm .checkout-step-card:hover { box-shadow: var(--shadow-subtle); }

.page-template-booking-confirm .step-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
}
.page-template-booking-confirm .step-title {
	font-weight: 700;
	font-size: 18px;
	margin: 0;
}

.page-template-booking-confirm .form-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
	margin-top: 30px;
}
.page-template-booking-confirm .form-group-full { grid-column: span 2; }

.page-template-booking-confirm .form-control-capsule {
	height: 52px;
	padding: 0 24px;
	font-size: 14px;
	font-weight: 600;
	color: var(--text-black);
	width: 100%;
	outline: none;
	background-color: #FFFFFF;
	border-color: #717171 !important;
    border-radius: 34px;
}
.page-template-booking-confirm .form-group input {
    border-color: #717171 !important;
    border-radius: 34px;
	border-width: 0.5px;
}
.page-template-booking-confirm textarea#user_address {
    display: none;
}
.page-template-booking-confirm .form-control-capsule::placeholder { color: #B2B2B2; }
.page-template-booking-confirm .form-control-capsule:focus { border-color: var(--primary-blue); }

.page-template-booking-confirm .phone-group { display: flex; }
.page-template-booking-confirm .phone-prefix-select { 
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 14px;
}

.page-template-booking-confirm .btn-next-step {
	background-color: #007bff;
	color: #FFF;
	border: none;
	border-radius: 8px;
	padding: 12px 45px;
	font-weight: 800;
	font-size: 16px;
	float: right;
	transition: background 0.2s;
	margin-top: 20px;
}
.page-template-booking-confirm .btn-next-step:hover { background-color: #0062cc; }
.booking-confirm-form .dropdown-menu {
    top: calc(100% + 1px);
    left: -50px;
}
.booking-confirm-form .custom-calendar-popup {
    top: calc(100% + 1px);
    left: 0;
}
.booking-confirm-form .picker-popup {
    top: calc(100% + 1px);
    left: 0;
}
.booking-confirm-form .bb-arrow::before {
    content: "Change";
    transform: rotate(0deg);
    background: none;
}
.page-template-booking-confirm .addon-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
	margin-top: 24px;
}
.page-template-booking-confirm .addon-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 20px;
	border: 0.5px solid #717171;
	border-radius: 12px;
	background: #FDFDFD;
	/*box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.16);*/
	box-shadow: 0px 1px 2px 0px rgba(0,0,0,0.05)
}
.booking-confirm-form .bb-field .dd-value {
    font-weight: 400;
}
.page-template-booking-confirm .addon-info { display: flex; flex-direction: column; }
.page-template-booking-confirm .addon-name { font-weight: 800; font-size: 15px; }
.page-template-booking-confirm .addon-price { color: var(--text-muted); font-size: 13px; font-weight: 600; }
.page-template-booking-confirm .btn-add-addon {
	background: #FFFFFF;
	border: 1.5px solid var(--primary-blue);
	color: var(--primary-blue);
	border-radius: 20px;
	padding: 6px 20px;
	font-size: 13px;
	font-weight: 800;
	transition: all 0.2s;
}
.page-template-booking-confirm .btn-add-addon.selected { background: var(--primary-blue); color: #FFF; }

.page-template-booking-confirm .booking-confirm-form,
.page-template-booking-confirm .order-summary-card {
	background: #FFFFFF;
    padding: 25px;
    width: 402px;
    background-color: transparent;
    border: 0.5px solid #AFAFAF;
    border-radius: 15px;
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.16);
    overflow: hidden;
    position: relative;
}

.page-template-booking-confirm .summary-boat-brief {
	display: flex;
	gap: 15px;
	margin-bottom: 25px;
}
.page-template-booking-confirm .boat-thumb {
	width: 140.65px;
    height: 136.07px;
    border-radius: 8px;
    object-fit: contain;
}

.phone-group {
  display: flex;
  align-items: center;
  border: 1px solid #717171;
  border-radius: 50px;
  overflow: hidden;
  background: #fff;
}

.page-template-booking-confirm #step-2, .page-template-booking-confirm #step-3 {
   border: 0.5px solid #afafaf;
}


/* Country code */
.phone-prefix-select {
  border: none;
  outline: none;
  background: transparent;
  padding: 0 15px;
  font-size: 14px;
  color: #333;
  appearance: none;
  cursor: pointer;
  position: relative;
}
select#phone-prefix {
    color: #888888;
    width: 84px;
	box-shadow: none;
}
input#phone {
    border: none;
    box-shadow: none;
	padding: 0;
}
/* Phone input */
.phone-group input {
  border: none;
  outline: none;
  flex: 1;
  padding: 0 15px;
  font-size: 14px;
  background: transparent;
}

/* Placeholder style */
.phone-group input::placeholder {
  color: #999;
}

/* Focus effect */
.phone-group:focus-within {
  border-color: #007bff;
  box-shadow: 0 0 0 2px rgba(0,123,255,0.1);
}


.page-template-booking-confirm .boat-meta { display: flex; flex-direction: column; justify-content: center; }
.page-template-booking-confirm .boat-name { 
	font-weight: 700;
    font-size: 18px;
    line-height: 21px;
    margin-bottom: 5px;
	width: 201px;
 }
.page-template-booking-confirm .boat-sub { 
	font-size: 14px;
    color: #868686;
    font-weight: 400;
    width: 194px;
    line-height: 21px;
 }
.page-template-booking-confirm .booking-bar-wrapper-form,
.page-template-booking-confirm .summary-details-list {
	border-top: 1px solid #D0D0D0; padding-top: 5px; 
}
.page-template-booking-confirm .bb-field,
.page-template-booking-confirm .summary-row {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 15px 0 15px 0;
	border-bottom: 1px solid #D0D0D0;
}
.page-template-booking-confirm .bb-field.addons-field,
.page-template-booking-confirm .summary-row:last-child { border-bottom: none; }
.page-template-booking-confirm .detail-group { display: flex; flex-direction: column; }
.page-template-booking-confirm .bb-top label,
.page-template-booking-confirm .detail-label { 
	font-weight: 700 !important;
    font-size: 15px !important;
    line-height: 20px;
    margin-bottom: 2px;
 }
 .booking-confirm-form .booking-bar-new {
    display: block;
}
.detail-val { 
	font-size: 15px;
    color: #000;
    font-weight: 400;
 }

.page-template-booking-confirm .btn-summary-change {
	background: #f2f2f2;
    border: none;
    border-radius: 8px;
    padding: 8px 18px;
    font-size: 16PX;
    font-weight: 700;
    color: #000;
    transition: background 0.2s;
    line-height: 22px;
}
.page-template-booking-confirm .btn-summary-change:hover { background: #EBEBEB; }
.booking-confirm-form .bb-arrow::before {
    content: "Change";
    transform: rotate(0deg);
    width: auto;
    height: auto;
    border: none;
}
.booking-confirm-form .bb-arrow {
    background: #f2f2f2 !important;
    border: none;
    border-radius: 8px;
    padding: 8px 18px;
    font-size: 16PX;
    font-weight: 700;
    color: #000;
    transition: background 0.2s;
    line-height: 22px;
    width: auto;
    height: auto;
	top: 30px;
    right: 0;
	font-style: normal;
}
.booking-confirm-form .bb-arrow:hover {
    background: #EBEBEB;
}
.page-template-booking-confirm .price-details-box {
	padding: 20px 0;
    margin-top: 15px;
    border-top: 1px solid #D0D0D0;
}
.page-template-booking-confirm .price-line {
	display: flex;
	justify-content: space-between;
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 10px;
}
.page-template-booking-confirm .total-line {
	display: flex;
    justify-content: space-between;
    font-weight: 700;
    font-size: 15px;
    line-height: 20px;
}

.page-template-booking-confirm .btn-book-now {
	width: 100%;
	height: 58px;
	background-color: #007bff;
	color: #FFF;
	border: none;
	border-radius: 12px;
	font-weight: 800;
	font-size: 18px;
	margin-top: 25px;
	transition: background 0.2s;
}
.page-template-booking-confirm .btn-book-now:hover { background-color: #0062cc; }

.page-template-booking-confirm .fancy-calendar-overlay {
	position: absolute;
	top: 60px;
	right: 0;
	width: 300px;
	background: #FFF;
	border-radius: 16px;
	box-shadow: 0 10px 30px rgba(0,0,0,0.15);
	padding: 20px;
	z-index: 1000;
	display: none;
	border: 1px solid #EEE;
	animation: fadeIn 0.2s ease-out;
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }

.page-template-booking-confirm .cal-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.page-template-booking-confirm .cal-title { font-weight: 800; font-size: 16px; }
.page-template-booking-confirm .cal-nav-btn { background: none; border: none; font-size: 18px; color: #777; cursor: pointer; }
.page-template-booking-confirm .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; text-align: center; }
.page-template-booking-confirm .cal-wday { font-size: 11px; font-weight: 800; color: #AAA; padding-bottom: 8px; }
.page-template-booking-confirm .cal-day { font-size: 13px; font-weight: 700; padding: 10px 0; cursor: pointer; border-radius: 50%; width: 34px; height: 34px; margin: 0 auto; display: flex; align-items: center; justify-content: center; }
.page-template-booking-confirm .cal-day:hover:not(.empty) { background: #F0F7FF; color: var(--primary-blue); }
.page-template-booking-confirm .cal-day.selected { background: var(--primary-blue); color: #FFF; }
.page-template-booking-confirm .cal-day.empty { cursor: default; }
.page-template-booking-confirm p.cart-empty {
	color: #000;
	font-family: "Nunito", Sans-serif;
	font-size: 16px;
	font-weight: 700;
	text-align: center;
}
.page-template-booking-confirm .return-to-shop a {
	font-family: "Nunito", Sans-serif;
	font-size: 16px;
	font-weight: 700;
	background: #007BFF;
	min-height: 45px;
	min-width: 135px;
	border-radius: 8px;
	padding: 15px 20px;
	color: #fff;
}
.page-template-booking-confirm .return-to-shop {
	text-align: center;
}
.page-template-booking-confirm .addon-info span.addon-price {
		display: none;
}
.page-template-booking-confirm div#addon-price-line {
	display: none !important;
}
.listing-grid .boat-card a {
    color: #000;
}
 
.listing-grid .boat-card a:hover {
    color: var(--ast-global-color-0);
}
.page-template-booking-confirm .form-grid .clearfix.first-btn {
  grid-column: 1 / -1; /* span full width */
  display: flex;
  justify-content: flex-end; /* push button to right */
}
.page-template-booking-confirm #close_payment_modal span.material-symbols-outlined {
    color: #fff;
}
.page-template-booking-confirm #close_payment_modal span.material-symbols-outlined:hover {
    color: #000;
}
/* popup start */

/* Modal Background */
#payment_modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  font-family: 'Inter', sans-serif;
}

/* Modal Box */
#payment_modal > div {
  background: #fff;
  width: 100%;
  max-width: 420px;
  border-radius: 16px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
  overflow: hidden;
  animation: zoomIn 0.25s ease;
}

/* Header */
#payment_modal .p-8.border-b {
  padding: 20px 24px;
  background: #f8fafc;
  border-bottom: 1px solid #e5e7eb;
}

#payment_modal h3 {
  font-size: 18px;
  font-weight: 700;
  color: #111827;
}

#payment_modal button#close_payment_modal {
  border: none;
  cursor: pointer;
  color: #ffffff;
  padding: 0;
}

#payment_modal button#close_payment_modal:hover {
  color: #374151;
}
#payment_modal .border-primary > div.relative.z-10 {
    width: 100%;
    min-width: 157px;
}
/* Body */
#payment_modal .p-8 {
  padding: 24px;
}

/* Summary Box */
#payment_modal .bg-slate-50 {
  background: #f9fafb;
  border-radius: 12px;
  padding: 16px;
  border: 1px solid #e5e7eb;
}

#payment_modal .bg-slate-50 div {
  font-size: 14px;
}

#modal-grand-total {
  font-weight: 600;
  color: #111827;
}

.text-green-600 {
  color: #16a34a;
}

#modal-amount-due {
  color: #007bff; /* blue */
  font-size: 18px;
  font-weight: 700;
}
#payment_modal .payment-option-card{
    padding: 11px 5px !important;
    flex-wrap: nowrap;
    justify-content: space-between;
    width: 50%;
    gap: 10px;
    text-align: center;
    border: 1px solid #000;
    border-radius: 10px;
}
#payment_modal .payment-option-card h4 {
    font-size: 12px;
	width: 100%;
}
#payment_modal .payment-option-card p {
    display: none;
}
#payment_modal .grid.grid-cols-2.gap-4 {
    display: flex;
    gap: 10px;
}
/* Processing Popup Overlay */
#processing_overlay {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 10000;

    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;

    transition: all 0.3s ease;
}

/* Show popup */
#processing_overlay.active {
    display: flex;
}

/* Loader circle wrapper */
#processing_overlay .loader-wrapper {
    position: relative;
    width: 100px;
    height: 100px;
    margin-bottom: 24px;
}

/* Static background ring */
#processing_overlay .loader-wrapper::before {
    content: "";
    position: absolute;
    inset: 0;
    border: 5px solid rgba(14, 165, 233, 0.15);
    border-radius: 50%;
}

/* Animated spinning ring */
#processing_overlay .loader-wrapper::after {
    content: "";
    position: absolute;
    inset: 0;
    border: 5px solid #0ea5e9;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

/* Sailing icon */
#processing_overlay .material-symbols-outlined {
    font-size: 42px;
    color: #0ea5e9;
    z-index: 2;
    position: relative;
}

/* Heading */
#processing_overlay h2 {
    font-size: 28px;
    font-weight: 800;
    color: #0f172a;
    margin-bottom: 10px;
    text-align: center;
}

/* Description */
#processing_overlay p {
    font-size: 15px;
    color: #64748b;
    font-weight: 500;
    animation: pulseText 1.5s ease-in-out infinite;
    text-align: center;
}

/* Spin animation */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Pulse animation */
@keyframes pulseText {
    0%, 100% {
        opacity: 0.5;
    }
    50% {
        opacity: 1;
    }
}

/* Input Fields */
input,
textarea {
  width: 100%;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  background: #f9fafb;
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 600;
  outline: none;
  transition: all 0.2s ease;
}

input:focus,
textarea:focus {
  border-color: #2563eb;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* AED Prefix */
.relative span {
  font-size: 13px;
  font-weight: 600;
  color: #6b7280;
}

/* Percentage Box */
#payment_percent_input {
  text-align: center;
}

/* Payment Method Box */
#payment_modal .border-primary {
  border: 2px solid #2563eb;
  background: #eff6ff;
  border-radius: 12px;
  padding: 14px;
}

#payment_modal .border-primary span {
  font-weight: 600;
}

/* Notes */
textarea {
  resize: none;
}

/* Button */
#confirm-record-payment {
  width: 100%;
  background: #007bff;
  color: white;
  padding: 14px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 16px;
  border: none;
  cursor: pointer;
  transition: all 0.25s ease;
}

#confirm-record-payment span.material-symbols-outlined {
    color: #fff;
}

#confirm-record-payment:hover {
  background: #0aa7e0;
  box-shadow: 0 8px 20px rgba(10, 167, 224, 0.3);
}
.order-msg {
    text-align: center;
    font-weight: bold;
    margin-top: 50px;
}
.order-msg .flex.items-center {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-direction: row;
    justify-content: center;
}
/* Animation */
@keyframes zoomIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
/* ============================= */
/* HEADER FIX */
/* ============================= */
.cursor-pointer {
    cursor: pointer;
}
#payment_modal .relative span {
    display: none;
}
#payment_modal .flex.items-center.justify-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 28px;
}

#payment_modal h3 {
  display: flex;
  align-items: center;
  gap: 8px;
}

#close_payment_modal {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: 0.2s;
}

#close_payment_modal:hover {
  background: #f1f5f9;
}

/* ============================= */
/* PAYMENT AMOUNT (2 COLUMN FIX) */
/* ============================= */

#payment_modal .flex.gap-3 {
  display: flex;
  gap: 10px;
}

/* AED input */
#payment_amount_input {
  padding-left: 42px !important;
  height: 48px;
  border-radius: 12px;
}

/* AED label inside input */
#payment_modal .relative span {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 13px;
  font-weight: 600;
  color: #6b7280;
}

/* Percentage input */
#payment_percent_input {
  height: 48px;
  border-radius: 12px;
  text-align: center;
}

/* Percentage symbol */
#payment_modal .relative.w-28 span {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 600;
  color: #6b7280;
}

/* Make both equal height */
#payment_modal input {
  display: block;
  width: 100%;
}

/* ============================= */
/* STRIPE BOX FIX */
/* ============================= */

#payment_modal .border-primary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 2px solid #2563eb;
  background: #eef4ff;
  border-radius: 14px;
  padding: 14px 16px;
}

/* Left content */
#payment_modal .border-primary > div {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Icon */
#payment_modal .border-primary .material-symbols-outlined {
  font-size: 20px;
  color: #2563eb;
}

/* Text */
#payment_modal .border-primary span.font-bold {
  font-size: 14px;
  font-weight: 600;
  color: #1e293b;
}

/* Right check icon */
#payment_modal .border-primary .material-symbols-outlined:last-child {
  font-size: 20px;
  color: #2563eb;
}

/* ============================= */
/* NOTES FIX */
/* ============================= */

textarea {
  border-radius: 14px;
  min-height: 100px;
}

/* ============================= */
/* BUTTON FIX */
/* ============================= */

#confirm-record-payment {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 52px;
  border-radius: 14px;
}
.material-symbols-outlined {
    color: #3e7cff;
}
button#bab-close-filters:hover {
    background: #3e7cff;
    color: #fff;
}
button#bab-close-filters{
    padding: 5px 10px;
}
button#bab-close-filters:hover span {
    color: #fff;
}
.boat-card-info span.cm-loc {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;

    line-height: 1.4;
    max-height: calc(1.4em * 3);
}

/* popup end */

.gt_float_switcher .gt-selected .gt-current-lang span.gt_float_switcher-arrow {
    background-image: url('https://bookanyboatstg.wpenginepowered.com/wp-content/uploads/2026/04/Down-arrow.png') !important;
    background-repeat: no-repeat !important;
}
.elementor-shortcode select.currency-dropdown {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-image: url("https://bookanyboatstg.wpenginepowered.com/wp-content/uploads/2026/04/Down-arrow.png") !important;
  background-repeat: no-repeat !important;
  background-position: right 5px center !important;
  background-size: 9px !important;
  padding-right: 10px !important;
}

/* Flatpickr Calendar CSS */

/* Calendar Wrapper */
.flatpickr-calendar {
    width: 340px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 20px !important;
    font-family: inherit;
}

/* Month Header */
.flatpickr-months {
    margin-bottom: 15px;
}

.flatpickr-current-month {
    font-size: 16px !important;
    font-weight: 700 !important;
    padding-top: 0 !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
    font-size: 16px !important;
    font-weight: 700 !important;
}

/* Prev / Next Buttons */
.flatpickr-prev-month,
.flatpickr-next-month {
    top: 18px !important;
    padding: 6px !important;
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
    width: 14px !important;
    height: 14px !important;
}

/* Weekdays */
.flatpickr-weekdays {
    margin-bottom: 10px !important;
}

.flatpickr-weekday {
    color: #7c7c7c !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}

/* Days Grid */
.flatpickr-days {
    width: 100% !important;
}

.dayContainer {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
}

/* Day Cell */
.flatpickr-day {
    border-radius: 6px !important;
    border: none !important;
    color: #111827 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    height: 42px !important;
    line-height: 42px !important;
}

/* Hover */
.flatpickr-day:hover {
    background: #f3f4f6 !important;
}

/* Selected Day */
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
    background: #f3f4f6 !important;
    color: #111827 !important;
    border-color: transparent !important;
}

/* Today */
.flatpickr-day.today {
    border: 1px solid #d1d5db !important;
}

/* Disabled */
.flatpickr-day.flatpickr-disabled {
    color: #d1d5db !important;
}

/* Remove blue focus */
.flatpickr-day:focus {
    outline: none !important;
}

/* Month dropdown remove ugly style */
.flatpickr-monthDropdown-months {
    border: none !important;
    background: transparent !important;
}

/* END Flatpickr Calendar CSS */

/* --- RESPONSIVE --- */
@media (max-width: 1200px) {
  .listing-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 991px) {
	.page-template-booking-confirm .order-summary-card { position: static; margin-top: 40px; }
	.page-template-booking-confirm .form-grid { grid-template-columns: 1fr; }
	.page-template-booking-confirm .form-group-full { grid-column: auto; }
	.listing-grid { grid-template-columns: repeat(2, 1fr); }
	.page-template-booking-confirm .booking-confirm-form,
	.page-template-booking-confirm .checkout-step-card, .page-template-booking-confirm .order-summary-card {
		margin-left: 0;
		width:100%;
	}
	.page-template-booking-confirm .col-lg-8.bc-left-col, .page-template-booking-confirm .col-lg-4.bc-right-col {
		width: 100%; padding: 0px 35px 0 24px;
	}
	.page-template-booking-confirm .boat-sub { 
		width: 90%;
	}
}

@media (min-width: 768px) and (max-width: 991px) {  
	.page-template-booking-confirm .form-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 767px) {
	
	.hfe-nav-menu li.rez-icons > a.hfe-menu-item {
		width:auto;
		height:auto;
	}
	
	.hfe-nav-menu li.rez-icons > a.hfe-menu-item::before{ 
		left: 0px !important; 
		top: 0px !important;
		margin-bottom: 0 !important;
	}
	
	.hfe-nav-menu li.icon-boat > a.hfe-menu-item::before {
		top: 10px !important;
	}
	
	.hfe-nav-menu li.icon-fishrod > a.hfe-menu-item::before {		
		left: 18px !important;
		top: 10px !important;
		width: 40px !important;
	}
	
	.hfe-nav-menu li.icon-mappin > a.hfe-menu-item::before {
		left: 18px !important;
		top: 15px !important;
	}
	
	.mobile-search-wrapper .search-input { border: 1px solid #71717133 !important; }
	
	section.listing-title-section.section-padding {
		padding: 35px 17px 25px 17px;
	}
	section.listing-title-section .page-title {
		font-size: 15px;
	}
	.listing-grid-section .listing-layout {
		margin-top: 0;
	}
	.card-title a {
		font-size: 15px;
	}
	a.next.page-numbers,
	a.prev.page-numbers {
		background: #0F75BC;
		color: #fff;
		display: flex;
	}

	a.page-numbers {
		display: none;
	}

	span.page-numbers.current {
		display: none;
	}

	span.page-numbers.dots {
		display: none;
	}
	button.pagi-btn.next,
	button.pagi-btn.prev {
		background: #0F75BC;
		color: #fff;
		display: flex;
	}
	.bab-search-pagination .pagi-btn {
		display: none;
	}
	.bab-search-pagination .pagi-dots {
		display: none;
	}
	.mobile-listing-nav {
		display: none;
	}
	.bab-search-results-container {
		padding-top: 0;
		margin-top: 0;
	}
	.bab-search-results-container .results-header {
		margin-bottom: 25px;
	}
	.bab-search-results-container .results-header h2 {
		font-size: 15px;
	 }
	 section.listing-grid-section {
		padding: 0 17px 70px 17px;
	}
	section.listing-grid-section .listing-grid {
		margin-top: 0;
	}
	.pages-header .elementor-widget-hfe-search-button {
		margin-bottom: 0;
	}
	
	/* Revie Slider */
	.swiper-wrapper {
  		touch-action: pan-y;
	}
	.hfe-search-form__container{
		height:53px;
		width:346px;
		background: #ffffff !important;
	   }
	input[type="search"].hfe-search-form__input{
		box-shadow: none !important;
	}
	.hfe-search-submit {
		min-width: 43px !important;
	}
	button.hfe-search-submit {
		color: #fff;
		min-width: 43px !important;
	}
	
	.csf-testi-slider.swiper {
		overflow: visible !important;
		padding-right: 20px;
	}

	.csf-testi-slider .swiper-wrapper {
		padding-left: 10px;
	}

	.csf-testi-slider .swiper-slide {
		width: 85% !important;  /* show partial next card */
		margin-right: 12px;
	}
	
	/* boat Slider */
	
	.csf-boat-slider.swiper {
		overflow: visible !important;
		padding-right: 20px;
	}

	.csf-boat-slider .swiper-wrapper {
		padding-left: 10px;
	}

	.csf-boat-slider .swiper-slide {
		width: 50% !important;  /* show partial next card */
		margin-right: 12px;
	}
	
   .section-padding { padding-top: 40px; padding-bottom: 40px; }
    /* Mobile Listing Slider */
	.listing-grid { 
		display: block; /* Stack vertically */
		overflow: visible; 
		gap: 0; 
		width: 100%;
	}

	#boat-filter {
		cursor: pointer;
		background: transparent;
		border: none;
		border-radius: 34px;
		box-shadow: none;
		width: 100%;
	}
	.boat-card { 
		width: 100%;
		margin-bottom: 30px;
		display: none; /* Hidden by default, shown by JS */
	}
  .boat-card.visible-mobile { display: block; }
  .listing-grid .boat-card { display: block; }
 
  .mobile-listing-nav {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 30px;
    margin-bottom: 40px;
  }
  .ml-nav-btn {
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--primary-blue); color: #fff;
    border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: opacity 0.2s;
  }
  .ml-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }
  .ml-nav-btn svg { width: 10px; height: 18px; }

  /* Hide Desktop Pagination */
  .pagination-section { display: none; }
  
	.home .hfe-nav-menu ul li:first-child a::after {
		/*background-color: var(--e-global-color-secondary);
		border-bottom: 3px solid var(--e-global-color-secondary);
		border-radius: 999px;
		height: 3px;
		opacity: 1 !important;*/
	}
	
	.elementor-section.elementor-top-section {
		overflow:hidden;
	}
	.mobile-listing-nav {
		display: none;
	}
	#bab-search-pagination .material-symbols-outlined {
		color: #ffffff;
	}
	#user-registration #ur-frontend-form {
		padding: 23px;
	}
	#user-registration {
		margin-bottom: 25px !important;
	}
	h1.entry-title {
		margin-top: 20px;
	}
}

/* ============================= */
/* MOBILE FIX */
/* ============================= */

@media (max-width: 480px) {
  #payment_modal .flex.gap-3 {
    
  }

  #payment_percent_input {
    width: 100%;
  }
}

#user-registration input#rememberme {
    width: auto;
}

/* Contact page */
.gform_heading {
	display: none;
}
/* ============================================
   BOOK ANY BOAT — CONTACT FORM STYLING
   Gravity Forms (Form ID: 1) in Elementor
   Two-column name + stacking already handled
   by the orbital theme — not duplicated here.
   ============================================ */

/* --- Outer card wrapper (the Elementor column) --- */
.elementor-element-51e6799 {
  background: transparent;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none;
}

#gform_1 {
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 20px;
  padding: 40px 44px;
  box-shadow: 0 2px 12px rgba(27, 27, 55, 0.06);
}

/* --- Base font --- */
#gform_wrapper_1,
#gform_wrapper_1 input,
#gform_wrapper_1 textarea,
#gform_wrapper_1 label,
#gform_wrapper_1 legend {
  color: #26212b;
}

/* --- Hide the duplicate GF heading (keep your Elementor one) --- */
#gform_wrapper_1 .gform_heading {
  display: none;
}

/* ============================================
   FIELD SPACING
   ============================================ */
#gform_wrapper_1 .gform_fields {
  row-gap: 24px;
}

/* ============================================
   MAIN LABELS (Name / Email / Message)
   ============================================ */
#gform_wrapper_1 .gfield_label,
#gform_wrapper_1 legend.gfield_label {
  font-size: 22px;
  font-weight: 700;
  color: #26212b;
  margin-bottom: 10px;
  padding: 0;
}

/* Sub-labels (First / Last) — currently visible.
   Uncomment to hide them and rely on placeholders instead: */
#gform_wrapper_1 .gform-field-label--type-sub {
  display: none;
}

/* "(Required)" text — currently visible.
   Uncomment to hide and use asterisks in placeholders instead: */
#gform_wrapper_1 .gfield_required_text {
  display: none;
}

/* ============================================
   TEXT & EMAIL INPUTS (pill-shaped)
   ============================================ */
#gform_wrapper_1 input[type="text"],
#gform_wrapper_1 input[type="email"] {
  width: 100%;
  height: 45px;
  padding: 0 28px;
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 40px;          /* fully rounded / pill */
  font-size: 17px;
  font-weight: 400;
  color: #1b1b37;
  box-shadow: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

/* ============================================
   MESSAGE TEXTAREA (rounded rectangle)
   ============================================ */
#gform_wrapper_1 textarea {
  width: 100%;
  min-height: 175px;
  padding: 22px 28px;
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 18px;
  font-size: 17px;
  font-weight: 400;
  color: #26212b;
  resize: vertical;
  box-shadow: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

/* ============================================
   PLACEHOLDERS
   ============================================ */
#gform_wrapper_1 input::placeholder,
#gform_wrapper_1 textarea::placeholder {
  color: #8a8a99;
  font-weight: 400;
  opacity: 1;
}

/* ============================================
   FOCUS STATES (subtle)
   ============================================ */
#gform_wrapper_1 input[type="text"]:focus,
#gform_wrapper_1 input[type="email"]:focus,
#gform_wrapper_1 textarea:focus {
  border-color: #1b1b37;
  outline: none;
  box-shadow: 0 0 0 1px #1b1b37;
}

/* ============================================
   CHARACTER COUNTER
   ============================================ */
#gform_wrapper_1 .ginput_counter {
  color: #8a8a99;
  font-size: 15px;
  margin-top: 12px;
}

/* ============================================
   SUBMIT BUTTON (electric blue, right-aligned)
   ============================================ */
#gform_wrapper_1 .gform_footer {
  display: flex;
  justify-content: flex-end;
  padding: 8px 0 0;
  margin-top: 24px;
}

#gform_wrapper_1 #gform_submit_button_1 {
  background: #007BFF;
  color: #ffffff;
  font-family: 'Poppins', Helvetica, Arial, sans-serif;
  font-size: 18px;
  font-weight: 600;
  padding: 16px 44px;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.15s ease;
}

#gform_wrapper_1 #gform_submit_button_1:hover {
  background: #0056b3;
}

#gform_wrapper_1 #gform_submit_button_1:focus {
  outline: none;
  box-shadow: 0 0 0 2px rgba(69, 65, 254, 0.35);
}

/* ============================================
   VALIDATION STATES
   ============================================ */
#gform_wrapper_1 .gfield_error input,
#gform_wrapper_1 .gfield_error textarea {
  border-color: #FF6B6B !important;
}
#gform_wrapper_1 .validation_message {
  color: #FF6B6B;
  font-size: 14px;
  margin-top: 8px;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 640px) {
  #gform_1 {
    padding: 28px 20px;
  }
  #gform_wrapper_1 textarea {
    min-height: 300px;
  }
  #gform_wrapper_1 .gfield_label,
  #gform_wrapper_1 legend.gfield_label {
    font-size: 19px;
  }
}