/*--------------------------------------------------------------------- File Name: style.css ---------------------------------------------------------------------*/


/*--------------------------------------------------------------------- import Files ---------------------------------------------------------------------*/

@import url(animate.min.css);
@import url(normalize.css);
@import url(icomoon.css);
@import url(css/font-awesome.min.css);
@import url(meanmenu.css);
@import url(owl.carousel.min.css);
@import url(swiper.min.css);
@import url(slick.css);
@import url(jquery.fancybox.min.css);
@import url(jquery-ui.css);
@import url(nice-select.css);

/*--------------------------------------------------------------------- skeleton ---------------------------------------------------------------------*/

* {
    box-sizing: border-box !important;
    transition: ease all 0.5s;
}

html {
    scroll-behavior: smooth;
}

body {
    color: #666666;
    font-size: 14px;
    font-family: 'Poppins', sans-serif;
    line-height: 1.80857;
    font-weight: normal;
    overflow-x: hidden;
}

a {
    color: #1f1f1f;
    text-decoration: none !important;
    outline: none !important;
    -webkit-transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    -ms-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    letter-spacing: 0;
    font-weight: normal;
    position: relative;
    padding: 0 0 10px 0;
    font-weight: normal;
    line-height: normal;
    color: #111111;
    margin: 0
}

h1 {
    font-size: 24px
}

h2 {
    font-size: 22px
}

h3 {
    font-size: 18px
}

h4 {
    font-size: 16px
}

h5 {
    font-size: 14px
}

h6 {
    font-size: 13px
}

*,
*::after,
*::before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    color: #212121;
    text-decoration: none!important;
    opacity: 1
}

button:focus {
    outline: none;
}

ul,
li,
ol {
    margin: 0px;
    padding: 0px;
    list-style: none;
}

p {
    margin: 20px;
    font-weight: 300;
    font-size: 15px;
    line-height: 24px;
}

a {
    color: #222222;
    text-decoration: none;
    outline: none !important;
}

a,
.btn {
    text-decoration: none !important;
    outline: none !important;
    -webkit-transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    -ms-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

img {
    max-width: 100%;
    height: auto;
}

 :focus {
    outline: 0;
}

.paddind_bottom_0 {
    padding-bottom: 0 !important;
}

.btn-custom {
    margin-top: 20px;
    background-color: transparent !important;
    border: 2px solid #ddd;
    padding: 12px 40px;
    font-size: 16px;
}

.lead {
    font-size: 18px;
    line-height: 30px;
    color: #767676;
    margin: 0;
    padding: 0;
}

.form-control:focus {
    border-color: #ffffff !important;
    box-shadow: 0 0 0 .2rem rgba(255, 255, 255, .25);
}

.navbar-form input {
    border: none !important;
}

.badge {
    font-weight: 500;
}

blockquote {
    margin: 20px 0 20px;
    padding: 30px;
}

button {
    border: 0;
    margin: 0;
    padding: 0;
    cursor: pointer;
}

.full {
    float: left;
    width: 100%;
}

.layout_padding {
    padding-top: 100px;
    padding-bottom: 0px;
}

.padding_0 {
    padding: 0px;
}


/* header section start */

.header_section {
    width: 100%;
    float: left;
    background-image: url(../images/banner-bg.png);
    height: auto;
    background-size: 100%;
}

.custom_nav-container {
        background-color: #fff;
        padding: 0;
        margin: 15px 0;
    }

    #navbarSupportedContent .navbar-nav {
        width: 100%;
        display: flex;
    }

    #navbarSupportedContent .nav-item {
        flex: 1;
    }

    #navbarSupportedContent .nav-link {
        text-align: center;
        text-transform: uppercase;
        color: black;
    }

    #navbarSupportedContent .nav-link.navbar-brand {
        margin: 0;
        display: flex;
        justify-content: center;
        text-transform: none;
        font-weight: bold;
        position: relative;
    }

    #navbarSupportedContent .nav-link.navbar-brand span {
        z-index: 2;
    }

    #navbarSupportedContent .nav-link.navbar-brand span span {
        color: white;
    }

    #navbarSupportedContent .nav-link.navbar-brand::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background-color: #fc9d22;
        transform: scale(1.25);
        border-radius: 5px;
    }

/* header section end */


/* banner section start */


.banner_taital_main {
    width: 100%;
    float: left;
    padding-top: 90px;
    padding-left: 100px;
}

.banner_taital {
    width: 100%;
    font-size: 50px;
    color: #ffffff;
    font-weight: bold;
    line-height: 60px;
}

.banner_text{
    width: 100%;
    font-size: 16px;
    color: #ffffff;
    margin: 0px;
}

.form-group {
    margin-bottom: 1rem;
    display: flex;
    width: 90%;
    margin: 0 auto;
    float: left;
}

.update_mail {
    color: #b6b5b5;
    width: 100%;
    height: auto;
    font-size: 16px;
    padding: 0px 20px 0px 20px;
    background-color: #e1e1e1;
    margin: 0 auto;
    justify-content: center;
    align-items: center;
    display: block;
    margin-top: 20px;
    border: 0px;
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
}

.subscribe_bt {
    width: 60px;
    float: left;
    padding-top: 20px;
    position: relative;
    left: -3px;
}

.subscribe_bt a {
    width: 100%;
    float: left;
    color: #ffffff;
    font-size: 16px;
    padding: 14px 0px 13px 0px;
    background-color: #fc9d22;
    text-align: center;
    border-radius: 4px;
}
.subscribe_bt a:hover {
    color: #ffffff;
    background-color: #fc9d22;
}

.search_bt {
    width: 175px;
    float: left;
    padding-top: 40px;
}

.search_bt a {
    width: 100%;
    float: left;
    font-size: 16px;
    background-color: #de6624;
    color: #fefefd;
    text-align: center;
    padding: 12px;
    border-radius: 5px;
    text-transform: uppercase;
}

.search_bt a:hover {
    color: #fefefd;
    background-color: #474646;
}


#banner_slider .carousel-control-next, 
#banner_slider .carousel-control-prev {
    width: 55px;
    height: 55px;
    opacity: 1;
    font-size: 30px;
    color: #ffffff;
    background-color: #fc9d22;
    border-radius: 100%;
    z-index: 1;
}

#banner_slider .carousel-control-next {
    right: -105%;
    top: 400px;
    color: #252525;
    background-color: #e1e1e1
}

#banner_slider .carousel-control-prev {
    left: 0px;
    top: 400px;
}

#banner_slider .carousel-control-next:focus, 
#banner_slider .carousel-control-next:hover, 
#banner_slider .carousel-control-prev:focus, 
#banner_slider .carousel-control-prev:hover {
    color: #252525;
    background-color: #e1e1e1
}

.padding_right0 {
    padding-right: 0;
}




/* banner section end */


/* about section start */

.about_section {
    width: 100%;
    float: left;
}

.about_taital {
    width: 100%;
    font-size: 36px;
    color: #1b1b1b;
    font-weight: bold;
    text-transform: uppercase;
    padding-top: 50px;
}

.about_taital::after {
    position: absolute;
    content: '';
    width: 80px;
    border: 4px solid #fc9d22;
    left: 0px;
    right: initial;
    bottom: 0px;
}

.about_text {
    width: 70%;
    font-size: 14px;
    color: #1b1b1b;
    margin: 0px;
    padding-top: 40px;
}

.readmore_btn {
    width: 170px;
    float: left;
    padding-top: 40px;
}

.readmore_btn a {
    width: 100%;
    float: left;
    font-size: 18px;
    color: #fefefd;
    background-color: #fc9d22;
    padding: 10px;
    border-radius: 5px;
    text-align: center;
}

.readmore_btn a:hover {
    color: #fefefd;
    background-color: #474646;
}

.arrow_icon {
    padding-left: 15px;
}

#main_slider a.carousel-control-prev {
    left: -90px;
    top: 150px;
}

#main_slider a.carousel-control-next {
    right: -90px;
    top: 150px;
    color: #ffffff;
    background-color: #474646;
}

#main_slider .carousel-control-next,
#main_slider .carousel-control-prev {
    width: 50px;
    height: 50px;
    opacity: 1;
    font-size: 40px;
    color: #ffffff;
    background-color: #de6624;
    border-radius: 5px;
    margin: 0 auto;
    text-align: center;
    box-shadow: 0px 0px 20px 0px #dedede;
}

#main_slider .carousel-control-next:focus,
#main_slider .carousel-control-next:hover,
#main_slider .carousel-control-prev:focus,
#main_slider .carousel-control-prev:hover {
    color: #ffffff;
    background-color: #474646;
}


/* about section end */

/* models section start */

.models_section {
    width: 100%;
    float: left;
}

.models_taital {
    width: 100%;
    font-size: 40px;
    color: #1b1b1b;
    font-weight: bold;
    text-transform: uppercase;
    padding-top: 50px;
    text-align: center;
}

.models_taital::after {
    position: absolute;
    content: '';
    width: 80px;
    border: 4px solid #fc9d22;
    left: 0px;
    right: 0px;
    bottom: 0px;
    margin: 0 auto;
    text-align: center;
}

.models_section_2 {
    width: 100%;
    background-color: #ffffff;
    border-radius: 5px;
    height: auto;
    padding: 20px;
    box-shadow: 0px 0px 20px 10px #e9e9e8;
    margin-top: 60px;
}

.carolo_text {
    width: 100%;
    font-size: 20px;
    color: #262625;
    font-weight: bold;
    padding-top: 60px;
}

.number_text{
    padding-right: 10px;
    color: #e9e9e8;
}

.ullamco_text{
    width: 100%;
    font-size: 16px;
    color: #4e4e4e;
    margin: 30px 0px 0px 0px;
}

.price_main {
    width: 100%;
    display: flex;
}

.price_text{
    width: 100%;
    float: left;
    font-size: 16px;
    color: #3e3e3d;
    margin: 0px;
    padding-top: 50px;
}

.read_btn {
    width: 250px;
    float: left;
    padding-top: 30px;
}

.read_btn a {
    width: 100%;
    float: left;
    font-size: 18px;
    color: #fefefd;
    background-color: #fc9d22;
    padding: 10px;
    border-radius: 5px;
    text-align: center;
}

.read_btn a:hover {
    color: #fefefd;
    background-color: #474646;
}

.arrow_icon {
    padding-left: 15px;
}

/* models section end */

.choose_section_2 {
    width: 100%;
    float: left;
    background-color: #fc9d22;
    height: auto;
    padding: 90px 0px;
    margin-top: 30px;
}

.rated_text {
    width: 100%;
    float: left;
    font-size: 30px;
    color: #fefefd;
    font-weight: bold;
    padding-bottom: 0px;
}

.house_text {
    width: 100%;
    float: left;
    font-size: 20px;
    color: #fefefd;
    font-weight: bold;
    margin: 0px;
    text-transform: uppercase;
}

.padding_10{
    padding-right: 15px;
}

/* blog section start */

.blog_section {
    width: 100%;
    float: left;
}

.blog_taital {
    width: 100%;
    float: left;
    font-size: 40px;
    color: #262626;
    font-weight: bold;
    text-align: center;
    text-transform: uppercase;
}

.blog_taital::after {
    position: absolute;
    content: '';
    width: 80px;
    border: 4px solid #fc9d22;
    left: 0px;
    right: 0px;
    bottom: 0px;
    margin: 0 auto;
    text-align: center;
}

.blog_section_2 {
    width: 100%;
    float: left;
    padding-top: 30px;
}

.blog_box {
    width: 100%;
    background-color: #fefefd;
    height: auto;
}

.blog_text {
    width: 100%;
    font-size: 24px;
    color: #2d2d2d;
    padding: 0px 0px 10px 0px;
    font-weight: bold;
    text-align: center;
}

.lorem_text {
    width: 70%;
    font-size: 16px;
    color: #3c3c3c;
    margin: 0 auto;
    text-align: center;
}

.read_bt {
    width: 175px;
    margin: 0 auto;
    text-align: center;
    padding-top: 30px;
}

.read_bt a {
    width: 100%;
    float: left;
    font-size: 18px;
    color: #fefefd;
    background-color: #fc9d22;
    padding: 10px;
    border-radius: 5px;
    text-align: center;

}

.read_bt a:hover {
    color: #fefefd;
    background-color: #474646;
}

.blog_img {
    width: 100%;
    text-align: center;
}

.btn_main {
    width: 100%;
    position: relative;
    top: -30px;
}

.date_text {
    width: 320px;
    margin: 0 auto;
    text-align: center;
    display: flex;
}

.date_text a {
    width: 100%;
    float: left;
    font-size: 18px;
    color: #fefefd;
    text-align: center;
    background-color: #fc9d22;
    padding: 10px;
}

.date_text a:hover {
    color: #000000;
    background-color: #fefefd;
    box-shadow: 0px 5px 20px 3px #e9e9e8;
}

.date_text.active a {
    color: #000000;
    background-color: #fefefd;
    box-shadow: 0px 5px 20px 3px #e9e9e8;
}


/* blog section end */

/* client section start */

.client_section {
    width: 100%;
    float: left;
    padding-bottom: 90px;
}
.client_taital{
    width: 100%;
    float: left;
    font-size: 40px;
    color: #000;
    text-transform: uppercase;
    font-weight: bold;
    text-align: center;
}
.client_text{
    width: 100%;
    float: left;
    font-size: 16px;
    color: #000;
    margin: 0px;
    text-align: center;
}

.customer_section_2 {
    width: 100%;
    float: left;
    padding-top: 100px;
}

.box_main {
    width: 90%;
    float: right;
    background-color: #ffffff;
    padding: 0px 50px 0px 50px;
    box-shadow: 0px 0px 18px -6px;
    margin-bottom: 10px;
}

.customer_text {
    width: 100%;
    font-size: 14px;
    color: #737372;
    margin: 0 auto;
}

.quick_icon {
    text-align: center;
    position: relative;
    top: 10px;
}

.customer_main {
    width: 100%;
    display: flex;
    margin-top: 50px;
}

.customer_left {
    width: 30%;
    float: left;
}

.customer_right {
    width: 100%;
    float: left;
    margin-top: 0px;
    padding-left: 200px;
}

.customer_name {
    width: 100%;
    float: left;
    font-size: 26px;
    font-weight: bold;
    color: #001431;
}
.enim_text {
    width: 100%;
    float: left;
    font-size: 16px;
    color: #737372;
    margin: 0px;
}

.customer_img {
    position: absolute;
    top: -60px;
    left: 60px;
}

/* client section end */

/* contact section start */

.contact_section {
    width: 100%;
    float: left;
    background-color: #161616;
    height: auto;
    background-size: 100%;
}

.contact_taital{
    width: 100%;
    float: left;
    font-size: 40px;
    color: #ffffff;
    font-weight: bold;
    text-transform: uppercase;
    text-align: center;
}

.contact_section_2 {
    width: 60%;
    margin: 0 auto;
}

 .contact_section .map_form_container .map_container { display: none; } 
 .contact_section .map_form_container.map_show form { display: none; } 
 .contact_section .map_form_container.map_show .map_container { display: block; }

.mail_section {
    width: 100%;
    float: left;
    margin-top: 30px;
}

.mail_text {
    width: 100%;
    float: left;
    font-size: 16px;
    color: #929191;
    border-bottom: 1px solid #6f6f6f !important;
    background-color: transparent;
    padding: 14px 15px 0px 0px;
    margin-bottom: 10px;
    border: 0px;
}

input.mail_text::placeholder {
    color: #929191;
}

.massage-bt {
    width: 100%;
    height: 50px;
    font-size: 16px;
    color: #929191;
    border-bottom: 1px solid #6f6f6f !important;
    background-color: transparent;
    padding: 20px 15px 0px 0px;
    margin-bottom: 10px;
    border: 0px;
}
textarea#comment::placeholder {
    color: #929191;
}

.map_btn_main {
    width: 100%;
    float: right;
}

.send_bt {
    width: 160px;
    float: right;
}

.send_bt a {
    width: 100%;
    text-align: center;
    font-size: 18px;
    color: #fc9d22;
    border: 3px solid #fc9d22;
    padding: 10px;
    text-transform: uppercase;
    margin-top: 10px;
    display: block;
    font-weight: bold;
}

.send_bt a:hover {
    color: #ffffff;
    border: 3px solid #ffffff;
}

.map_bt {
    width: 160px;
    float: right;
    margin-right: 15px;
}

.map_bt a {
    width: auto;
    text-align: center;
    font-size: 18px;
    color: #fc9d22;
    border: 3px solid #fc9d22;
    padding: 10px 10px;
    text-transform: uppercase;
    margin-top: 10px;
    display: block;
    font-weight: bold;
}

.map_bt a:hover {
    color: #ffffff;
    border: 3px solid #ffffff;
}

.map_center{
    width: auto;
}
.map_main {
    width: 100%;
    float: left;
    padding-top: 40px;
}

.contact_img img {
    height: 390px;
}


.social_icon {
    width: 100%;
    display: inline-block;
    text-align: center;
    margin-top: 40px;
}
.social_icon ul {
    margin: 0px;
    padding: 0px;
    display: inline-block;
}

.social_icon li {
    float: left;
}

.social_icon li a {
    float: left;
    padding: 5px 15px;
    background-color: #ffffff;
    color: #000;
    border-radius: 100%;
    font-size: 22px;
    margin-right: 5px;
    width: 50px;
    text-align: center;
    margin-top: 10px;
}

.social_icon li a:hover {
    background-color: #fc9d22;
    color: #ffffff;
}

.location_main {
    width: 100%;
    float: left;
    padding-top: 50px;
}

.location_text {
    width: 100%;
    text-align: center;
}

.location_text ul {
    margin: 0px;
    padding: 0px;
    display: inline-block;
}

.location_text li {
    float: left;
    color: #ffffff;
    font-size: 16px;
    padding: 0px 20px;
}

.location_text a {
    color: #ffffff;
}

.location_text li a:hover {
    color: #fc9d22;
}

.padding_left_15 {
    padding-left: 10px;
}

/* contact section end */



/* copyright section start */

.copyright_section {
    width: 100%;
    float: left;
    background-color: #161616;
    height: auto;
}

.copyright_text {
    width: 100%;
    float: left;
    font-size: 16px;
    color: #fff;
    text-align: center;
    margin-left: 0px;
}

.copyright_text a {
    color: #fff;
}

.copyright_text a:hover {
    color: #fc9d22;
}

/* copyright section end */

.margin_top90 {
    margin-top: 90px;
}



  /* Links del menú: compactos y legibles */
  .lb-link{
    color: rgba(255,255,255,.85);
    padding: .45rem .9rem;        /* <— más compacto */
    border-radius: 9999px;
    font-size: .95rem;
    line-height: 1;
    transition: background .2s ease, color .2s ease, box-shadow .2s ease, opacity .2s ease;
  }
  .lb-link:hover{
    color: #fff;
    background: rgba(255,255,255,.10);
    box-shadow: 0 0 0 1px rgba(255,255,255,.12) inset;
  }
  /* Estado activo (añade aria-current="page" al link actual) */
  .lb-link[aria-current="page"]{
    color: #fff;
    background: rgba(166,196,208,.18);
    box-shadow: 0 0 0 1px rgba(166,196,208,.35) inset;
  }
  /* Sutil línea inferior del navbar */
  .lb-nav{ box-shadow: 0 1px 0 0 rgba(255,255,255,.08); }


  /* HERO */
.banner_section { position: relative; }
.hero-img{
  height: clamp(60vh, 78vh, 86vh);         /* adaptable */
  object-fit: cover;
  object-position: center;
  filter: saturate(1.05);
}
.hero-overlay{
  position:absolute; inset:0;
  /* degradé superior/medio para legibilidad de textos y navbar */
  background:
    linear-gradient(180deg, rgba(16,22,27,.85) 0%, rgba(16,22,27,.55) 24%, rgba(16,22,27,.18) 55%, rgba(16,22,27,.55) 100%);
  pointer-events:none;
}
.hero-caption{
  position: absolute; left: 0; right: 0;
  bottom: clamp(48px, 10vh, 120px);
  max-width: 840px;
  color: #e9eae3;
}
.hero-title{
  font-size: clamp(28px, 5vw, 56px);
  line-height: 1.05;
  font-weight: 700;
  margin-bottom: .5rem;
  letter-spacing: .3px;
}
.hero-text{
  font-size: clamp(14px, 1.6vw, 18px);
  opacity: .92;
  max-width: 60ch;
}

/* Indicadores más discretos */
.carousel-indicators li{
  width: 10px; height: 10px; border-radius: 9999px;
  background-color: rgba(255,255,255,.45);
}
.carousel-indicators .active{
  background-color: rgba(166,196,208,.95); /* acento #a6c4d0 */
}

/* Controles */
.carousel-control-prev-icon,
.carousel-control-next-icon{
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.35));
}

.leading-tight {
    color: #e1f9ff;
}

  /* Bullets a la paleta */
  .swiper-pagination-bullet{ background: rgba(255,255,255,.6); opacity: 1; }
  .swiper-pagination-bullet-active{ background: #a6c4d0; }

  /* Flechas redondas, translúcidas */
  .swiper-button-next, .swiper-button-prev{
    color: #fff;
    width: 40px; height: 40px;
    border-radius: 9999px;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(4px);
    transition: background .2s ease;
  }
  .swiper-button-next:hover, .swiper-button-prev:hover{
    background: rgba(255,255,255,.25);
  }

  /* Zoom/soft cuando el slide está activo */
  .swiper-slide .relative > .absolute:first-child{ /* la imagen de fondo */
    transition: transform 1.2s ease, filter 1.2s ease, opacity 1.2s ease;
  }
  .swiper-slide-active .relative > .absolute:first-child{
    transform: scale(1.035);
    filter: saturate(1.05);
  }

  .swiper-button-next, .swiper-button-prev {
    color: #e1f9ff !important;
    background-color: transparent !important;
  }

  .swiper-button-next::before, .swiper-button-prev::before {
    font-size: 5px !important;
  }



   

   /* Logo más grande y centrado en mobile */
.footer-logo{
  width: clamp(180px, 28vw, 340px);
  max-width: 100%;
}

.footer-social {
    padding-left: 50px;
}
/* Botones de redes: redondos, grandes y consistentes */
.footer-social .social-btn{
  --c-text: #d1ddd5;
  --c-ring: rgba(255,255,255,.2);
  --c-hover: #a6c4d0;

  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px; border: 1px solid var(--c-ring);
  color: var(--c-text); text-decoration: none;
  font-size: 20px; line-height: 1;
  transition: transform .2s ease, background-color .2s ease, border-color .2s ease, color .2s ease;
  background: transparent;
}
.footer-social .social-btn:hover{
  transform: translateY(-1px);
  border-color: var(--c-hover);
  background: rgba(166,196,208,.12); /* #a6c4d0/12% */
  color: #e1f9ff;
}

/* Un poco más grandes en desktop */
@media (min-width: 992px){
  .footer-social .social-btn{ width: 48px; height: 48px; font-size: 20px; }
  .footer-logo{ width: clamp(220px, 22vw, 360px); }
}


/* ⬆️ Iconos de redes más grandes */
.footer-social .social-btn{
  width: 24px; 
  height: 24px;
  font-size: 20px;   /* tamaño del ícono */
}

@media (min-width: 992px){
  .footer-social .social-btn{
    width: 34px;
    height: 34px;
    font-size: 14px;
  }
}


  /* Links estilo limpio */
.lb-pill-link {
  color: rgba(255,255,255,.9);
  padding: .4rem .8rem;
  border-radius: 9999px;
  font-size: .95rem;
  font-weight: 500;
  transition: color .2s ease, background .2s ease;
}

.lb-pill-link:hover {
  color: #091016;
  background: rgba(166,196,208,.12);
}


  /* CTA Teléfono en píldora */
  .lb-cta{
    color:#fff;
    padding: .55rem 1.05rem;
    border-radius: 9999px;
    border: 1px solid rgba(166,196,208,.22);
    background: rgba(255,255,255,.06);
    box-shadow: inset 0 0 0 1px rgba(166,196,208,.08);
    transition: background .2s ease, box-shadow .2s ease;
  }
  .lb-cta:hover{
    background: rgba(166,196,208,.18);
    box-shadow: inset 0 0 0 1px rgba(166,196,208,.35);
  }

  /* Ajustes de sticky + logo ↔ texto (siguen igual que tu versión) */
  .lb-nav-wrap.is-fixed{
    position: fixed; top:0; left:0; right:0; z-index:40;
    box-shadow: 0 1px 0 0 rgba(255,255,255,.08);
  }
  .lb-logo, .lb-brand-text{ transition: opacity .25s ease, transform .25s ease; }
  .lb-nav-wrap.is-fixed .lb-logo{
    opacity: 0; transform: translate(-50%, -6px) scale(.94); pointer-events:none;
  }
  .lb-nav-wrap.is-fixed .lb-brand-text{
    display: inline-block !important; opacity: 1; transform: translateY(0);
  }
  .lb-brand-text{ opacity: 0; transform: translateY(-4px); }
  @media (prefers-reduced-motion: reduce){ .lb-logo, .lb-brand-text{ transition:none; } }

  /* Tu .lb-link para móvil ya existe arriba, lo dejamos */



  /* --- Ajustes del logo SOLO cuando el navbar está fijo --- */
  .lb-nav-wrap.is-fixed .lb-logo{
    /* Ignora el -top-9 de Tailwind y entra al navbar */
    top: 50% !important;
    transform: translate(-50%, -50%) scale(.92);
    /* opcional: fondo un pelín más opaco al fijarse */
    background: rgba(16,22,27,.95);
  }

  /* Transición suave de tamaño del logo al fijarse */
  .lb-nav-wrap .lb-logo img{
    transition: max-height .25s ease, transform .25s ease, opacity .25s ease;
  }

  /* Tamaño más contenido del logo dentro del navbar fijo (desktop) */
  .lb-nav-wrap.is-fixed .lb-logo img{
    max-height: 64px; /* prueba 56–68px según gusto */
  }

  /* En móviles: un poco más chico para que respire */
  @media (max-width: 768px){
    .lb-nav-wrap.is-fixed .lb-logo img{
      max-height: 52px;
    }
  }



  
   /* contenedor estilo píldora */
   .lb-pills{
      padding: 4px;
      border-radius: 9999px;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(166,196,208,.22);
      box-shadow: inset 0 0 0 1px rgba(166,196,208,.08);
   }
   /* links de píldora */
   .lb-pill-link{
      color: rgba(255,255,255,.88);
      padding: .55rem 1.05rem;
      border-radius: 9999px;
      display: inline-block;
      transition: background .2s ease, color .2s ease, box-shadow .2s ease;
   }
   .lb-pill-link:hover{
      color:#fff;
      background: rgba(166,196,208,.18);
      box-shadow: inset 0 0 0 1px rgba(166,196,208,.35);
   }

   /* links móviles (ya existentes) */
   .lb-link{
      color: rgba(255,255,255,.86);
      padding: .45rem .9rem;
      border-radius: 9999px;
      font-size: .95rem; line-height: 1;
      transition: background .2s ease, color .2s ease, box-shadow .2s ease, opacity .2s ease;
   }
   .lb-link:hover{ color:#fff; background:rgba(255,255,255,.10); box-shadow:0 0 0 1px rgba(255,255,255,.12) inset; }

   /* sticky */
   .lb-nav-wrap.is-fixed{
      position: fixed; top:0; left:0; right:0; z-index:40;
      box-shadow: 0 1px 0 0 rgba(255,255,255,.08);
   }

   /* logo SIEMPRE visible (quitamos swaps) */
   .lb-logo{ transition: transform .25s ease, opacity .25s ease; }
   .lb-nav-wrap.is-fixed .lb-logo{
      opacity: 1; transform: translate(-50%, -6px) scale(.95); /* leve compactado al fijarse */
   }


   /* ========== BLOQUEO DE ANCHO / ANTI-DESFASE ========== */

/* 1) Nunca más ancho que el viewport */
html, body { width: 100%; max-width: 100vw; overflow-x: hidden; }

/* 2) Igualar anchos del topbar (usa .container) y del navbar */
#topbar, #lbNavWrap { width: 100vw; }
#topbar .container{
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 1.25rem;  /* px-5 */
  padding-right: 1.25rem; /* px-5 */
}

@media only screen and (max-width: 550px) {
    #topbar .container {
        margin: 0px !important;
    }


    .more {
        gap: 83px !important;
        width: 400px;
        margin-left: 45px;

    }

    .lb-nav-wrap .lb-logo img {
        height: 57px;
    }   

    .footer-logo {
        margin: 0 auto !important;
    }

    .footer-social {
        padding-left: 0px !important;
        margin-bottom: 20px !important;
        margin-top: 35px !important;
    }
}


.swiper-button-next:after, .swiper-button-prev:after {
    font-size: 10px !important;
}


/* 3) Ningún wrapper debe exceder el viewport */
header, main, section, footer, nav, .max-w-7xl{
  max-width: 100vw;
  overflow-x: clip; /* evita scroll lateral; fallback a hidden si prefieres */
}

/* 4) Medios responsivos (evita desborde por imágenes) */
img, svg, video, canvas{ max-width: 100%; height: auto; }

/* 5) Swiper/Hero: cortar derrames por transforms */
#hero, #hero .swiper, #hero .swiper-wrapper{
  max-width: 100vw;
  overflow: hidden;
}

/* 6) Si hay .w-screen en móvil, redúcelo al viewport */
@media (max-width: 768px){
  .w-screen{ width: 100% !important; }
}

/* 7) Por si algún borde/transform genera 1px de overflow */
*{ box-sizing: border-box; }
