@charset "UTF-8";
/*
Theme Name: Vamoos 2025 (Fully Merged & Consolidated)
Description: All theme + component styles merged; variables unified; responsive preserved (Bootstrap breakpoints).
Author: Ollie Stott
Version: 2.1.0
*/

/* ========================
   VARIABLES
======================== */
:root{
  /* Brand + base */
  --primary: #f17c46;
  --primary-2: #f17c45;
  --accent: #ea5534;
  --secondary: #03989e;
  --dark: #2e3540;
  --light: #f2f2f2;
  --menu-accent: #211357;
  --gradient-primary: linear-gradient(90deg, rgba(234,85,52,1) 0%, rgba(241,124,70,1) 100%);
  --gradient-secondary: linear-gradient(90deg, rgb(25 114 118) 0%, rgba(0,152,158,1) 100%);

  /* Typography */
  --font-body: "HelveticaNeue-Light","Helvetica Neue Light","Helvetica Neue",Helvetica,Arial,"Lucida Grande",sans-serif;
  --font-heading: "League Spartan", sans-serif;
  --font-serif: "DM Serif Display", serif;
  --font-sans: "DM Sans", serif;

  /* Radii + transitions */
  --radius-full: 50px;
  --radius-md: 25px;
  --radius-sm: 10px;
  --t: all .5s ease;

  /* Accordion icon sizing */
  --feat-icon-slot: 54px;
  --feat-icon-gap: 15px;

  /* Responsive multi-carousel */
  --rh-gap: 1rem;
  --rh-peek: clamp(40px, 10vw, 100px);
  --rh-radius: 1rem;
  --rh-shadow: 0 10px 25px rgba(0,0,0,.08);
  --rh-visible-desktop: 2;
  --rh-visible-tablet: 2;
  --rh-visible-mobile: 1;
}

/* ========================
   GENERAL
======================== */
body{ font-family:var(--font-body); font-weight:300; }

h1,h2,h3,h4,h5,h6,.readMore,
h1 b,h2 b,h3 b,h4 b,h5 b,h6 b,.readMore b,
h1 strong,h2 strong,h3 strong,h4 strong,h5 strong,h6 strong,.readMore strong,
.lead{ font-family:var(--font-heading); font-weight:500!important; }

h6{ text-transform:uppercase; color:#aaa; }

.bg-primary{ background:var(--gradient-primary)!important; }
.bg-dark{ background:#2e3540!important; color:#fff!important; }
.bg-secondary{ background:var(--gradient-secondary)!important; color:#fff!important; }
.bg-light{ background:#f2f2f2!important; }

.btn,.fasc-button,input[type=submit]{ font-family:var(--font-heading); border-radius:var(--radius-full); padding:10px 20px 6px; text-decoration:none; font-weight:500; font-size:1.1em; }
.btn-primary,.fasc-button,input[type=submit]{ background:var(--primary)!important; border-color:var(--primary)!important; color:#fff; }
.btn-outline-primary{ background:none!important; border-color:var(--primary)!important; color:var(--primary); }
.btn.btn-outline-primary:hover{ background:var(--primary-2)!important; color:#fff!important; }
.btn.disabled{ color:var(--primary); }
.btn-check:checked+.btn,.btn.active,.btn.show,.btn:first-child:active,:not(.btn-check)+.btn:active{ background:var(--primary)!important; }

.text-secondary{ color:var(--secondary)!important; }

a{ color:var(--primary); }
a.readMore{ text-decoration:none; color:var(--primary); margin:0 0 10px!important; display:inline-block; font-size:1.2em; }

.lead{ font-size:1.75em; }
.intro{ font-size:1.05em; }
#intro .lead:before,#intro .lead:after{ content:'"'; }

b, strong {
    font-weight: 600;
}

/* Scoped transitions (avoid global *) */
nav,.nav-item *,#masblock img,.readMore:after,.btn{ transition:var(--t); }


/* ========================
   HEADER
======================== */
.navbar-nav .nav-link,.navbar-nav .nav-link.active,.navbar-nav .nav-link.show{ color:#fff; }
.navbar-toggler{ border:none; }
.navbar-toggler:focus{ box-shadow:none!important; }
.dropdown-menu .nav-link{ color:#000; }

.nav-link{ font-weight:500; font-family:var(--font-heading); text-transform:none; font-size:1em; }
.dropdown-toggle::after{ display:none; }

#menu-main-menu>li>a,#menu-login-demo-buttons-1>li>a,.dropdown>.dropdown-menu{ font-weight:500; font-size:1em; }
#menu-login-demo-buttons-1>li>a{ padding-top:10px; }

nav.headroom--unpinned{ top:-66px; }
nav.headroom--not-top{ background:rgba(46,53,64,1); }
nav.headroom--top{ background:rgba(46,53,64,0.2); }

/* ========================
   MEGA MENU
======================== */
@media (min-width: 768px){
  .vh-lg-100{ height:100vh!important; }
  .carousel-control-prev{ left:-15%; }
  .carousel-control-next{ right:-15%; }

  .mega-menu-parent.dropdown .dropdown-menu{
    position:absolute!important; left:50%; background:rgba(242,242,242,.95); transform:translateX(-50%); top:auto!important;
  }
  .dropdown:hover>.dropdown-menu{
    visibility:visible; display:block; opacity:1; margin-top:-1px!important; border-radius:8px; transition:all .2s ease-in-out;
  }
  .dropdown>.dropdown-menu{
    position:absolute; top:100%; left:auto; z-index:1000; float:none; min-width:150px; padding:1rem; list-style:none; border:none; border-radius:0; box-shadow:none; opacity:0; margin-top:10px!important; display:block; visibility:hidden; transition:all .2s ease-in-out;
  }
  ul.dropdown-menu::before{
    content:''; width:0; height:0; border-left:8px solid transparent; border-right:8px solid transparent; border-bottom:8px solid #fff; position:absolute; top:-8px; left:25px;
  }
  .navbar-nav,.navbar .collapse,.navbar-nav li{ position:static; }
  header ul.menu{ list-style:none; padding-left:0; }
  header ul.menu>li{ float:left; width:20%; margin:0; padding-right:20px; }
  header ul.sub-menu{ padding:0 0 15px; list-style:none; }
  .mega-menu-wrapper a,.nav-item ul.sub-menu a,header ul.sub-menu ul.sub-menu li>a{ display:block; }
}

.mega-menu-wrapper li>a{ display:none; }
.mega-menu-wrapper.show li>a{ display:block; }
.mega-menu-wrapper li.hide>a{ display:none; }

.mega-menu-wrapper a,.nav-item ul.sub-menu a{ font-family:var(--font-heading); text-decoration:none!important; color:#666; font-size:1em; padding:5px 0; }

header ul.sub-menu>li>a{ font-family:var(--font-serif)!important; color:var(--menu-accent)!important; font-size:1.2em!important; }
header ul.sub-menu ul.sub-menu li>a{ font-family:var(--font-sans)!important; text-decoration:none!important; color:#666!important; font-size:.9em!important; }

.login{ font-weight:600; }
.login a{ padding:.5rem; position:relative; }
.login>a::before{ font-family:'Font Awesome 5 Pro'; content:'\f2f5'; position:absolute; left:-15px; margin-top:2px; }
ul#menu-login-demo-buttons{ font-weight:500; font-family:var(--font-heading); }

/* ========================
   ANIMATE BURGER
======================== */
.animated-bar{ width:30px; height:20px; position:relative; margin:0; transform:rotate(0deg); transition:.5s ease-in-out; cursor:pointer; }
.animated-bar span{ display:block; position:absolute; height:3px; width:100%; border-radius:9px; opacity:1; left:0; background:#fff; transition:.25s ease-in-out; }
.animated-bar span:nth-child(1){ top:0; }
.animated-bar span:nth-child(2){ top:10px; }
.animated-bar span:nth-child(3){ top:20px; }
.animated-bar.closer{ margin:15px 5px; }
.animated-bar.closer span:nth-child(1){ top:11px; transform:rotate(135deg); }
.animated-bar.closer span:nth-child(2){ opacity:0; left:-60px; }
.animated-bar.closer span:nth-child(3){ top:11px; transform:rotate(-135deg); }

/* ========================
   FORMS
======================== */
input,textarea{ height:50px; padding:10px 15px!important; border-radius:var(--radius-md)!important; }
input,select,textarea{ border:thin solid #ccc; }
.nf-form-fields-required{ font-size:.8em; margin:0 5px 20px; }
.hbspt-form .field,.actions{ margin:0!important; padding:0!important; }

/* ========================
   SIDEBAR
======================== */
/* #features .sticky-top{ height:calc(100vh - 150px); } */
.single-casestudy .sticky-top{ top:50px; margin-top:-120px; }

/* ========================
   MODULES
======================== */
/* Multi-Thumb Carousel */
#thumbGalleryCarousel img{ max-height:150px; }
#thumbGalleryCarousel .col{ text-align:center; }
#thumbGalleryCarousel i{ color:#000; font-size:2.5em; }

/* Features */
.max-75{ max-width:75%; display:block; margin:0 auto; max-height:300px; }
.fade-collapse{ opacity:0; visibility:hidden; transition:opacity .3s ease; height:0; overflow:hidden; }
#featIcon i{ cursor:pointer; z-index:999999; }
.fade-collapse.show{ opacity:1; visibility:visible; height:auto; overflow:visible; }
.featLi ul{ list-style:none; margin-top:25px; }
.featLi li{ margin-bottom:20px; position:relative; }
.featLi li:before{ font-family:'Font Awesome 5 Pro'; content:'\f058'; position:absolute; margin-left:-30px; font-weight:600; font-size:1.2em; color:var(--secondary); }

/* TXT modules */
#txt li{ text-align:left; padding-left:20px; }

/* Calendly */
#calendly{ background:linear-gradient(180deg,rgba(242,242,242,1) 0%, rgba(242,242,242,1) 40%, rgba(255,255,255,1) 40%); }

/* Base Calendly iframe styling */
.calendly-inline-widget iframe {
  width: 100%;
  border: none;
  display: block;
}


/* Desktop (≥1200px) */
@media (min-width: 1200px) {
  .calendly-inline-widget iframe {
    min-height: 850px; /* Most space for large screens */
  }
	#titleTxt p {
		margin-bottom: 0;
	}	
}

/* Tablets (≥768px and <1200px) */
@media (min-width: 768px) and (max-width: 1199px) {
  .calendly-inline-widget iframe {
    min-height: 1100px; /* Slightly taller for narrower screens */
  }
}

/* Mobile (<768px) */
@media (max-width: 767px) {
  .calendly-inline-widget iframe {
    min-height: 1050px; /* Extra height for long vertical mobile layouts */
  }
}	

/* Title/Text */
.secBord{ border-top:thin solid #ccc; }

/* FAQs */
.list-group{ border-top:thin solid #aaa; border-bottom:thin solid #aaa; border-radius:0!important; }
.list-group-item.active{ background:none; color:var(--primary); border:none; }
.list-group-item{ border:none; border-radius:0!important; font-weight:500; border-top:thin solid; border-color:#aaa; }
.list-group-item:last-of-type{ border-top:thin solid #aaa!important; }
.list-group-item:first-child{ border-top:none; }
#accordionFaqs .card{ border:none; border-radius:0!important; margin-bottom:4px; }
.card-header{ border:none; background:#eee; text-decoration:none; font-weight:500; border-radius:10px!important; font-family:var(--font-heading); font-size:1.1em; }

/* ACCORDION FEATURES */
.accordion-button:not(.collapsed){ background:#eee!important; }

/* STORIES */
#stories .btn-group .btn{ border-radius:30px; }

/* QUOTE */
#quote{ position:relative; }
#carouselQuote .lead{ width:80%; margin:0 auto; }
#carouselQuote h6,#carouselQuote .lead *{ color:#fff; }
#overlay{ position:absolute; width:100%; height:100%; background-color:rgba(0,0,0,.5); left:0; top:0; }
#carouselQuote .carousel-control-next,#carouselQuote .carousel-control-prev{ width:10%; }

/* Videos */
#videoWrapper{ position:relative; padding-bottom:56.25%; height:0; }
#videoWrapper iframe{ position:absolute; top:0; left:0; width:100%; height:100%; }
#video-viewport{ width:100%; height:100%; position:absolute; top:0; overflow:hidden; }
#video-viewport video{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); min-width:100%; min-height:100%; width:100%; height:auto; z-index:-1; -o-object-fit:cover; object-fit:cover; }
#videoWrapperFull{ width:100vw; height:56.25vw; min-height:100vh; min-width:177.77vh; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
#videoWrapperFull iframe,#videoWrapperFull video{ position:fixed; top:0; left:0; width:100%; height:100%; z-index:-1; pointer-events:none; overflow:hidden; }
.vimeoWrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 0;
	height: 0;
	margin: 30px 0;
}
.vimeoWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/* ========================
   Pricing
======================== */
.pricetable-part ul{ float:left; width:50%; list-style:none; padding:0; margin:0; }
.pricetable-part{ font-family:var(--font-heading); float:left; width:100%; border:1px solid #c3c3c3; border-top:none; margin:70px 0 40px; font-weight:500; }
.pricetable-part h2{ background-color:#ff7c46; color:#fff; float:left; width:100%; padding:15px 10px; font-size:1.25em; }
.pricetable-part h2 span{ float:left; width:100%; display:inline-block; }
.pricetable-part ul li{ float:left; width:100%; padding:20px; height:70px; border-bottom:1px solid #c3c3c3; }
.pricetable-part ul li p{ padding:0; }
.pricetable-part ul li:last-child{ border-bottom:none; }
.pricetable-part .frt_ul li{ border-right:1px solid #c3c3c3; }
ul.frt_ul h2{ border-right:1px solid #ffffff; }
.relocation-price.full-w.text-center{ padding:40px 0; }
.relocation-price .pricetable-part ul li{ background-color:#ffffff; }
.relocation-price .pricetable-part ul li p{ display:inline-block; width:auto; float:none; }
.relocation-price .pricetable-part h2{ height:65px; }
.select_img.pull-right img{ width:auto; float:right; margin-bottom:30px; }
.select_img.pull-right{ position:relative; margin-bottom:60px; float:none; text-align:center; }

ul.list-unstyled{ height:42px; width:100px; border:1px #323840 solid; background-position:right center; background-repeat:no-repeat; right:0; position:relative; border-radius:5px; margin:0 auto; }
ul.list-unstyled li{ padding:10px 10px; z-index:2!important; margin:0; height:42px; }
ul.list-unstyled li:hover{ background:transparent; cursor:pointer; }
ul.list-unstyled li:not(.init){ float:left; width:102px; display:none; background:#ffffff; }
ul.list-unstyled li:not(.init):hover, ul.list-unstyled li.selected:not(.init){ background:#323840; }
li.init{ cursor:pointer; }
a#submit{ z-index:1; }
/* ul.list-unstyled::be { background-color:#000000; width:30px; height:30px; content:''; position:absolute; right:0; top:0; } */
.select_img.pull-right img{ margin-bottom:10px; max-width:40px; float:left; margin-left:20px; }

.currency-price{ display:none; width:100%; table-layout:fixed; background:#f1f1f1; border-radius:25px; overflow:hidden; }
.currency-price td,.currency-price th{ padding:20px; font-weight:500; font-family:var(--font-heading); }
.currency-price td+td,.currency-price th+th{ text-align:center; }
.currency-price tr{ border-bottom:thin solid #ccc; }
.currency-price tr:last-of-type{ border-bottom:none; }
.relocation-price-inner table:first-of-type{ display:table; }
#free_currency-uk{ display:table; }

/* ========================
   ROI Calculator
======================== */
#proi_section p.Calc_txt,#proi_section ul.Calc_list li{ text-align:left; color:#000; width:100%; float:left; line-height:1.5; padding:20px 0; }
#proi_section ul.Calc_list{ margin:0; padding-left:20px; }
#proi_section ul.Calc_list li{ padding:10px 0!important; color:#ff874b; }
#proi_section ul.Calc_list li span{ color:#000; }

/* this second list-unstyled block intentionally overrides the earlier to position the UI as per original */
ul.list-unstyled{ position:absolute; left:0; z-index:999; margin-top:10px; }

#Roi_Calculator .roi_contentsec p{ text-align:center; color:#000; width:100%; float:left; padding:20px 0; }
#Roi_Calculator .roi_contentsec .research_Btn{ width:100%; float:left; text-align:center; margin-top:20px; }
#Roi_Calculator .roi_contentsec .research_Btn .roi_resrch_btn{ background-color:#ff7c46; color:#ffffff; border-radius:4px; max-width:300px; padding:10px 0; border:0!important; outline:none!important; width:100%; }
#Roi_Calculator .roi_calc_Wrapper{ width:100%; float:left; text-align:center; margin-top:30px; }
#Roi_Calculator .roi_calc_Wrapper .calc_field{ width:100%; text-align:center; float:left; padding:10px 0; display:flex; flex-wrap:wrap; align-items:center; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .field_title{ font-family:var(--font-heading); width:45%; float:left; text-align:right; padding-right:10px; font-weight:500; font-size:1.1em; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .field_title small{ font-family:var(--font-body); display:block; width:100%; font-weight:300; font-size:.75em; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .value_box{ width:10%; float:left; text-align:center; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .value_box .form-control{ outline:none!important; box-shadow:none!important; width:100%; height:40px; padding:5px; font-size:14px; font-weight:500; color:#000; background:#fff; border:1px solid #ddd; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .calc_bar{ width:calc(45% - 40px); float:left; text-align:left; padding-left:10px; color:#000; margin:0 20px; }
#Roi_Calculator .roi_calc_Wrapper .Bar_Value{ padding-bottom:25px; }
#Roi_Calculator .roi_calc_Wrapper .Bar_Value,#Roi_Calculator .roi_calc_Wrapper .Numb_Value{ width:100%; float:left; }
#Roi_Calculator .roi_calc_Wrapper .Numb_Value .value_box{ width:55%; float:left; text-align:left; padding:0; }
#Roi_Calculator .roi_calc_Wrapper .Numb_Value .value_box .form-control{ outline:none!important; box-shadow:none!important; max-width:130px; height:40px; padding:5px; font-size:14px; font-weight:500; color:#000; background:#fff; border:1px solid #ddd; width:100%; display:inline; }
#Roi_Calculator .roi_calc_Wrapper .Numb_Value .value_box span{ padding:0 10px; font-size:14px; font-weight:500; }
#Roi_Calculator .roi_calc_Wrapper .Numb_Value .value_box span.frst_chld{ max-width:30px; display:inline-block; width:100%; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .calc_bar .ui-state-default,
#Roi_Calculator .roi_calc_Wrapper .calc_field .calc_bar .ui-widget-content .ui-state-default,
#Roi_Calculator .roi_calc_Wrapper .calc_field .calc_bar .ui-widget-header .ui-state-default{
  border:0!important; background:#fff!important; font-weight:500!important; color:#1c94c4; box-shadow:0 0 8px 0 rgba(0,0,1,.3); width:32px!important; height:32px!important; border-radius:50%; position:absolute!important; top:-10px!important; outline:none!important; cursor:pointer!important; transition:none!important; z-index:1!important;
}
#Roi_Calculator .roi_calc_Wrapper .calc_field .calc_bar #eq span{ width:100%; float:left; margin:0; border:1px solid #f76e1d!important; background:#fff!important; color:#fff!important; height:20px; border-radius:25px!important; }
#Roi_Calculator .roi_calc_Wrapper .calc_field .calc_bar .ui-widget-header{ background-image:none!important; background-color:#f76e1d!important; }

.select_img_cstm{ position:relative; text-align:center; }
.select_img_cstm label{ margin-bottom:10px; }

/* ========================
   Blog
======================== */
a.title{ color:#000; text-decoration:none; }
a.page-link{ color:var(--primary); font-weight:500; font-family:var(--font-heading); border:none; }
li.page-item .current{ padding:10px 15px; line-height:1em; background:var(--primary); border-radius:25px!important; color:#fff; font-weight:500; font-family:var(--font-heading); width:35px!important; height:35px!important; border:none; }
.page-link{ border:none; color:var(--dark); }
a.page-link:hover{ background:none; color:var(--dark); }

/* ========================
   HubSpot & Mailchimp
======================== */
.hs-error-msgs label{ color:#fff!important; }
.actions{ margin:0!important; padding:0!important; }
#mc_embed_signup_scroll label{ margin:10px 0; }
#mc_embed_signup_scroll input{ width:400px; max-width:100%; }

/* ========================
   Scroll Gallery
======================== */
.logo-item img {
  max-height: 100px;
}

/* Container */
.logo-scroller {
  width: 100%;
  overflow: hidden;
  position: relative;
  white-space: nowrap;
}

/* Track */
.logo-track {
  display: inline-flex;
  animation: logo-scroll 30s linear infinite;
  will-change: transform;
}

/* Pause on hover */
.logo-scroller:hover .logo-track {
  animation-play-state: paused;
}

/* Logos per row */
#icons .logo-item { flex: 0 0 calc(100% / 6); }
@media (max-width: 1199.98px){ #icons .logo-item{ flex:0 0 calc(100% / 5); } }
@media (max-width: 991.98px){  #icons .logo-item{ flex:0 0 calc(100% / 4); } }
@media (max-width: 767.98px){  #icons .logo-item{ flex:0 0 calc(100% / 3); } }
@media (max-width: 575.98px){  #icons .logo-item{ flex:0 0 calc(100% / 2); } }

/* Infinite loop: move full width back to start */
@keyframes logo-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-100%); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .logo-track { animation: none; }
}


/* ========================
   Contact Form
======================== */
.acf-map{ height:420px; }
#phone a,#email a{ text-decoration:none; color:var(--dark); }
#phone:before{ font-family:'Font Awesome 5 Pro'; content:'\f095'; position:absolute; margin-left:-25px; color:var(--primary); }
#email:before{ font-family:'Font Awesome 5 Pro'; content:'\f0e0'; position:absolute; margin-left:-25px; color:var(--primary); }
#location:before{ font-family:'Font Awesome 5 Pro'; content:'\f3c5'; position:absolute; margin-left:-25px; color:var(--primary); }
#social{ list-style:none; }
#social li{ display:inline-block; height:30px; width:30px; padding:5px; border-radius:25px; background:var(--dark); text-align:center; line-height:1.2em; }
#social li a{ color:#fff!important; }

/* ========================
   Team
======================== */
.card-body a img{ cursor:pointer; }
a.close{ top:20px; right:20px; position:absolute; color:#000; }

/* Team Grid / Text */
.team-card{ text-align:center; }
.team-card .name{ margin-bottom:0; }
.team-card .title{ color:#6c757d; margin-bottom:.5rem; }

/* Portrait Image + Overlay */
.avatar{ position:relative; width:100%; max-width:280px; height:360px; margin:0 auto .9rem; overflow:hidden; border-radius:10px; }
.avatar img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .25s ease; }

.avatar .overlay{ position:absolute; inset:0; transform:translateY(100%); transition:transform .5s ease;
  background: linear-gradient(135deg, rgb(25 114 118) 0%, rgba(0, 152, 158, 1) 100%) !important;
  color:#fff; padding:25px 20px; display:flex; flex-direction:column; justify-content:space-between; align-items:center; text-align:center; height:100%;
}
.avatar .overlay .overlay-text{ flex:1 1 auto; width:100%; margin-bottom:12px; font-size:.95rem; line-height:1.45; overflow-y:auto; scrollbar-width:thin; }
.avatar .overlay .overlay-text::-webkit-scrollbar{ width:6px; }
.avatar .overlay .overlay-text::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.3); border-radius:3px; }
.avatar .overlay .overlay-social{ flex-shrink:0; margin-top:12px; }
.avatar .overlay .overlay-social a{ color:#fff; font-size:1.2rem; text-decoration:none; }
.avatar .overlay .overlay-social a:hover{ color:#0A66C2; }

.avatar.has-bio:hover .overlay,
.team-card:focus-within .avatar.has-bio .overlay,
.avatar.has-bio.show .overlay{ transform:translateY(0%); }
.avatar.has-bio:hover img,
.team-card:focus-within .avatar.has-bio img,
.avatar.has-bio.show img{ transform:scale(1.02); }

.avatar-btn{ appearance:none; background:transparent; border:0; padding:0; margin:0; width:100%; height:100%; cursor:pointer; }
.avatar-btn:focus{ outline:2px solid #222; outline-offset:4px; }

@media (max-width: 991.98px){ .avatar{ max-width:100%; height:320px; } }
@media (prefers-reduced-motion: reduce){ .avatar img,.avatar .overlay{ transition:none; } }

/* ========================
   FOOTER
======================== */
footer h4{ padding-top:10px; }
footer a{ color:#fff!important; text-decoration:none; }
footer ul{ padding-left:0; list-style:none; }
footer ul li{ padding:3px; }
footer ul li li{ padding-left:15px; }
footer ul li ul{ padding-bottom:10px; }
#subscribe{ position:relative; overflow:hidden; padding-top:100px!important; }
/* Inside top radius cutout */
.cutout{ position:absolute; top:-150px; left:50%; transform:translateX(-50%); width:120%; height:200px; background-color:#fff; border-radius:50%; }
footer a{ color:#fff!important; }


@media (min-width: 992px){
  .dropdown-menu .nav-link i,.dropdown-menu .nav-link svg{ display:none; }
  .dropdown-menu.sub-menu{ padding:0 15px; margin-top:0!important; }
  header .sub-menu a{ text-transform:uppercase; font-size:1.2em; }
  .hero-video { height: 100vh; }
}

@media (max-width: 991px){
  .offcanvas-body{ background:var(--dark)!important; }
  .lead{ font-size:1.35em; }
  .vh-75{ height:75vh!important; }

  /* Hide any nested submenu inside the main left drawer */
  #offcanvasMenu .dropdown-menu,
  #offcanvasMenu .sub-menu{ display:none!important; }

  /* Basic vertical list look in the submenu drawer */
  #offcanvasSub .dropdown-menu,
  #offcanvasSub .sub-menu{
    display:none; position:static; margin:0; padding:0 25px; border:0; box-shadow:none; background:none;
  }
  #offcanvasSub .navbar-nav>li>a,
  #offcanvasSub .dropdown-menu>li>a,
  #offcanvasSub .sub-menu>li>a{
    display:block; padding:.5rem 0; color:#fff; font-size:1em;
  }
  #offcanvasSub .navbar-nav{ gap:.25rem; }

  nav .dropdown-toggle i, nav .dropdown-toggle svg{ transform:rotate(-90deg); }
  .offcanvas-header{ background:var(--primary); color:#fff; }
  .demo{ border-top:thin solid #aaa; }
  .hero-video { height: 80vh; }
}

/* ========================
   NEW COMPONENTS MERGED
======================== */
/* ACCORDION HEADERS (icon slot + title alignment) */
.accordion-button{ display:flex; align-items:center; }
.accordion-button::after{ margin-left:auto; }
.accordion-button .feat-icon-slot{
  flex:0 0 var(--feat-icon-slot);
  width:var(--feat-icon-slot);
  height:var(--feat-icon-slot);
  margin-right:var(--feat-icon-gap);
  display:inline-flex; align-items:center; justify-content:center;
}
.accordion-button .feat-icon{
  width:100%; height:100%; object-fit:contain; border-radius:8px;
}
.accordion-button .feat-icon.placeholder{ background:#f1f3f5; }
.accordion-button .feat-title{ margin:0; line-height:1.2; display:inline-block; }

/* RESPONSIVE MULTI-CAROUSEL (rh-multi) */
.rh-multi{ position:relative; }
.rh-multi .rh-stage{ position:relative; overflow:hidden; padding:0 var(--rh-peek); }
.rh-multi .rh-fade{
  position:absolute; top:0; bottom:0; width:var(--rh-peek); z-index:2;
  pointer-events:none; transition:opacity .3s ease;
}
.rh-multi .rh-fade-left{ left:0; background:linear-gradient(to right,#fff,rgba(255,255,255,0)); }
.rh-multi .rh-fade-right{ right:0; background:linear-gradient(to left,#fff,rgba(255,255,255,0)); }
.rh-multi.no-left .rh-fade-left,
.rh-multi.no-right .rh-fade-right{ opacity:0; visibility:hidden; }
.rh-multi .rh-track{ display:flex; gap:var(--rh-gap); will-change:transform; transition:transform .5s ease; transform:translate3d(0,0,0); }
.rh-multi .rh-item{ flex:0 0 auto; box-sizing:border-box; }

@media (min-width: 992px){
  .rh-multi .rh-item{
    flex:0 0 calc((100% - 2 * var(--rh-peek) - (var(--rh-gap) * (var(--rh-visible-desktop) - 1))) / var(--rh-visible-desktop));
  }
}
@media (min-width: 768px) and (max-width: 991.98px){
  .rh-multi .rh-item{
    flex:0 0 calc((100% - 2 * var(--rh-peek) - (var(--rh-gap) * (var(--rh-visible-tablet) - 1))) / var(--rh-visible-tablet));
  }
}
@media (max-width: 767.98px){
  .rh-multi .rh-item{
    flex:0 0 calc((100% - 2 * var(--rh-peek) - (var(--rh-gap) * (var(--rh-visible-mobile) - 1))) / var(--rh-visible-mobile));
  }
}

/* Card styling inside rh-multi */
.rh-multi .rh-card{ border:0; border-radius:var(--rh-radius); overflow:hidden; box-shadow:var(--rh-shadow); height:100%; background:#fff; }
.rh-multi .rh-card .card-img-top{ height:280px; object-fit:cover; }
@media (max-width: 767.98px){ .rh-multi .rh-card .card-img-top{ height:200px; } }

/* Controls alignment for carousel control groups */
.rh-multi .btn-group .btn{ line-height:1; }

/* FILTER CAROUSEL toggling */
.feature-carousel{ opacity:0; transition:opacity .5s ease-in-out; }
.feature-carousel.active-carousel{ opacity:1; }
.filter-buttons button{ border:none!important; background:#fff; }
#filterCarousel .carousel-control-next,#filterCarousel .carousel-control-prev{ color:#000; font-size:2.5em; }

/* ===== Vamoos Latest Articles (scoped) ===== */
.va-articles{ position:relative; overflow:hidden; padding:4rem 0; }
.va-articles::before{ content:""; position:absolute; left:0; right:0; top:0; height:300px; background:#2f3640; }
.va-articles .section-head{ position:relative; z-index:1; }
.va-articles .eyebrow{ text-transform:uppercase; letter-spacing:.08em; font-size:.8rem; color: var(--bs-warning); opacity:.9; }
.va-articles h2{ color:#fff; font-weight:800; }

.va-articles .card-article{
  border:0; border-radius:1.25rem; overflow:hidden; background:#f3f4f5; box-shadow:0 12px 28px rgba(0,0,0,.18);
  transition:transform .2s, box-shadow .2s; position:relative; z-index:1;
}
.va-articles .card-article:hover{ transform:translateY(-4px); box-shadow:0 18px 40px rgba(0,0,0,.22); }

.va-articles .media-wrap{ position:relative; }
.va-articles .media-wrap .ratio>img{ width:100%; height:100%; object-fit:cover; }
.va-articles .img-overlay{
  position:absolute; inset:0; display:flex; align-items:flex-start; padding:1.25rem;
  background:linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,0) 60%);
}
.va-articles .img-overlay h3{ color:#fff; margin:0; font-weight:700; font-size:clamp(1.1rem,2vw,1.4rem); }

.va-articles .card-body{ background:#eceff1; padding:1.5rem 1.5rem 1.75rem; }
.va-articles .entry-title{ font-weight:800; color:#111; margin-bottom:.5rem; }
.va-articles .excerpt{ color:#333; }
.va-articles .more{ display:inline-flex; align-items:center; gap:.5rem; font-weight:700; color:var(--bs-teal, #0aa6a6); text-decoration:none; }
.va-articles .more .arrow{ transition:transform .15s; }
.va-articles .more:hover .arrow{ transform:translateX(4px); }

/* ===== Integration Partners ===== */
#integration-partners .partner-item{ padding:2rem 0; border-top:1px solid #e9ecef; }
#integration-partners .partner-item:first-child{ border-top:0; }
#integration-partners .logo-wrap{ max-width:320px; }
#integration-partners .logo-wrap img{ max-height:90px; width:auto; height:auto; }

#integration-partners .partner-url{ display:inline-flex; align-items:center; gap:.5rem; margin-top:.25rem; }
#integration-partners .partner-url .label{ text-transform:uppercase; letter-spacing:.06em; font-size:.75rem; color:#6c757d; }
#integration-partners .partner-url a{ font-weight:600; text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:2px; }
#integration-partners .partner-url a:hover,
#integration-partners .partner-url a:focus{ text-decoration-thickness:3px; }
#integration-partners .partner-url svg{ width:1em; height:1em; flex:0 0 auto; transform:translateY(1px); transition:transform .18s ease; }
@media (prefers-reduced-motion: reduce){ #integration-partners .partner-url svg{ transition:none; } }
#integration-partners .partner-url a:hover svg,
#integration-partners .partner-url a:focus svg{ transform:translate(2px,1px); }

/* ===== Misc ===== */
#select-session1 li{ position:relative; z-index:9999; }
.childli{ display:none; }
.frst_chld.cur_class{ margin-left:8px; font-size:15px; }

#case-study-results{ opacity:1; transition:opacity .3s ease-in-out; }
#case-study-results.fade-out{ opacity:0; }
#case-study-results.fade-in{ opacity:1; }

/* Normal dropdowns (nested under li) */
.navbar-nav > li > .dropdown-menu.sub-menu {
  position:absolute;
  top:100%;
  left:0;
  min-width:200px;
}

/* Mega menu (centered full width) */
.navbar-nav > li > .dropdown-menu.mega-menu {
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  width:100%;
  background:rgba(242,242,242,.95);
}

ul.sub-menu {
    list-style: none;
    padding-left: 15px;
}