/* home.css — página inicial: secções por bloco; media queries (810 / 768 / 576 / 480 / 767) ao longo do ficheiro */
/* -------------------------------------------------------------------------- */
/* Utilitários */
/* -------------------------------------------------------------------------- */
:root {
    --font-size-home-hero-title: 7rem;
    --font-size-home-hero-subtitle: 4rem;
    --font-size-home-hero-tagline: 1.5rem;
    --font-size-home-hero-description: 1.3rem;
    --font-size-home-hero-title-mobile: 3rem;
    --font-size-home-hero-subtitle-mobile: 2.5rem;
    --font-size-home-hero-tagline-mobile: 1.2rem;
    --font-size-home-hero-cta-mobile: 1.1rem;
    --font-size-home-hero-description-mobile: 1.1rem;
    --home-carousel-bubble-size: 44px;
    --home-carousel-arrow-size: 34px;
}

.invalid {
    color: #dc3545;
    font-family: "ClanOT-Book";
    font-size: 12px;
    margin: 5px 0;
}

/* Padrão compartilhado para botões circulares de navegação dos carrosséis */
.home-carousel-nav-btn {
    width: var(--home-carousel-bubble-size);
    height: var(--home-carousel-bubble-size);
    min-width: var(--home-carousel-bubble-size);
    min-height: var(--home-carousel-bubble-size);
}

.home-carousel-nav-img {
    display: block;
    width: var(--home-carousel-arrow-size);
    height: var(--home-carousel-arrow-size);
    object-fit: contain;
    margin: auto;
}

/* -------------------------------------------------------------------------- */
/* Home 2026 - Reveal de baixo para cima (somente elementos alvo)             */
/* -------------------------------------------------------------------------- */
.home-reveal-up {
    --home-reveal-delay: 0ms;
    opacity: 0;
    transform: translate3d(0, 32px, 0);
    transition: opacity 0.62s ease, transform 0.62s ease;
    transition-delay: var(--home-reveal-delay);
    will-change: opacity, transform;
}

.home-reveal-up.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce) {
    .home-reveal-up {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

.home {
    max-width: 100%;
    overflow-x: hidden;
}

.home h3 {
    font-family: var(--font-family-news);
    font-size: var(--font-size-heading-3);
    color: var(--color-highlight);
}

.home h3[data-variant] {
    font-size: calc(var(--font-size-heading-3) * attr(data-variant number, 100) / 100);
}

/* Home US hero — MAPA BANNER (Deca Serif New, Inter Light, sombra #8c9292, botão #a66b4e) */
/*
     * Evita salto visual no banner ao ativar topSite--scrolled:
     * #topSite começa fora do fluxo (absolute) e depois troca para fixed
     * sem "reflow" do hero.
     */
#homeHero.home-us-hero #topSite {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 30;
}

#homeHero.home-us-hero .banner-home-us {
    min-height: 60rem;
    width: 100%;
    position: relative;
}

#homeHero.home-us-hero .banner-home-us__media {
    z-index: 0;
}

#homeHero.home-us-hero .banner-home-us__img {
    object-fit: cover;
    object-position: center center;
    max-height: 964px;
}

#homeHero.home-us-hero .topo {
    z-index: 20;
}

#homeHero.home-us-hero .banner-home-us__inner {
    z-index: 10;
    min-height: min(65vh, 720px);
    padding-top: clamp(4.5rem, 11vh, 9rem);
}

#homeHero.home-us-hero .banner-home-us__title {
    margin-top: 6rem;
    font-weight: 400;
    font-style: normal;
    font-size: var(--font-size-home-hero-title);
    line-height: 7rem;
    text-shadow:
        0 2px 0 #8c9292,
        0 4px 14px rgba(0, 0, 0, 0.35);
}

#homeHero.home-us-hero .banner-home-us__tagline {
    font-weight: 300;
    font-size: var(--font-size-home-hero-description);
    line-height: var(--font-size-home-hero-description);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
    margin-top: 2rem;
    margin-bottom: 3rem;
}

#homeHero.home-us-hero .topo-us .menuTopo .nav-link {
    font-weight: 300;
}

.learn-more-container .learn-more {
    border: 1px solid #929d9f;
    padding: 7px 20px;
    color: var(--color-primary);
    bottom: 7px;
    text-decoration: none;
    font-size: 16px;
    font-weight: 600;
    font-family: "ClanOT-Book";
    transition: all 0.3s ease;
}

#introduction h1 {
    font-size: var(--font-size-home-hero-title);
}

/* -------------------------------------------------------------------------- */
/* Bloco modelos / catálogo (#blockModels) */
/* -------------------------------------------------------------------------- */
#blockModels {
    background: linear-gradient(to bottom, var(--color-gradient-start) 0%, var(--color-gradient-end) 100%);
    margin-top: 6rem;
}

.modelosPiscinas {
    position: relative;
    top: -50px;
}

.modelos-piscinas-block-title {
    position: absolute;
    z-index: 5;
    width: 65%;
    left: 50%;
    transform: translate(-50%);
    background: rgba(67, 187, 239, 0.7);
}

.modelos-piscinas-title {
    color: #ffffff;
    font-size: 27px;
    padding: 34px 0 55px 0;
    line-height: normal;
    margin-top: 0px;
    margin-bottom: 0px;
    font-family: "ClanOT-Book";
    text-align: center;
}

.modelos-piscinas-icon {
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    margin-top: -42px;
    width: 88px;
}

/* -------------------------------------------------------------------------- */
/* Solicitar catálogo digital */
/* -------------------------------------------------------------------------- */
#requestDigitalCatalog {
    margin-top: -40px;
    color: white;
}

#requestDigitalCatalog .textH5 {
    color: var(--color-highlight);
    text-indent: 0px;
    margin: 20px 0;
    font-size: 1.25rem;
    cursor: pointer;
    font-weight: 500;
    line-height: 1.2;
}

#requestDigitalCatalog input.send {
    background-color: #28a745;
    border-color: #28a745;
    margin-left: 10px;
}

#requestDigitalCatalog img.send {
    width: 25px;
    height: 29px;
    margin-left: 10px;
    cursor: pointer;
}

/* -------------------------------------------------------------------------- */
/* Fiberglass é o futuro */
/* -------------------------------------------------------------------------- */
#fiberglassIsTheFuture {
    margin-top: 4rem;
}

#fiberglassIsTheFuture .fiberglassIsTheFuture {
    color: #366b8e;
    font-size: 2rem;
    margin-top: 1rem;
}

#fiberglassIsTheFuture .blue-pool {
    max-width: 65%;
    position: absolute;
    right: 0;
    z-index: 999;
}

#fiberglassIsTheFuture .bestPools {
    color: #00568a;
    margin-top: 25px;
    font-size: 25px;
}

:is(#fiberglassIsTheFuture .bestPools) p {
    font-size: 20px;
    margin: 0;
    line-height: 40px;
    text-indent: 20px;
}

#fiberglassIsTheFuture .icc {
    right: 0;
    bottom: 5px;
    z-index: 9999;
    width: 220px;
}

/* -------------------------------------------------------------------------- */
/* Excelente acabado / superfície */
/* -------------------------------------------------------------------------- */
#excelenteacabado .es-el-futuro-web {
    font-size: 28px;
}

#excelenteacabado .bestPools {
    color: var(--color-primary);
    font-size: 16px;
    margin-top: calc(9vh + 5px);
}

#excelenteacabado .mapa-icc {
    margin-top: 6vh;
}

/* -------------------------------------------------------------------------- */
/* Zona de bronzeado */
/* -------------------------------------------------------------------------- */
#zonadebronceado h4 {
    font-size: 33px;
    margin-top: 50px;
    color: var(--color-primary);
}

#zonadebronceado .texto {
    font-size: 16px;
    margin-top: 50px;
    color: var(--color-primary);
}

#zonadebronceado .img-tanning-ledge {
    text-align: left;
}

:is(#zonadebronceado .img-tanning-ledge) img {
    max-width: 70%;
}

#zonadebronceado .conoce-mas {
    margin-top: 178px;
}

:is(#zonadebronceado .conoce-mas) a {
    border: 1px solid #929d9f;
    padding: 7px 20px;
    color: var(--color-primary);
    bottom: 7px;
}

/* -------------------------------------------------------------------------- */
/* Cor e textura */
/* -------------------------------------------------------------------------- */
#colorTexture .cor-textura {
    background: rgb(255, 255, 255);
    background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(174, 174, 174, 1) 0%, rgba(255, 255, 255, 1) 140%);
    padding-bottom: 3rem;
}

:is(#colorTexture .cor-textura) .piscinalancamento {
    background-image: url('../img/home/pool-granite-effect.png');
    background-repeat: no-repeat;
    background-size: 58%;
    background-position: 35% 4rem;
    padding-top: 4rem;
    height: 415px;
}

:is(:is(#colorTexture .cor-textura) .piscinalancamento) img.granitada {
    width: 80%;
}

:is(:is(#colorTexture .cor-textura) .piscinalancamento) p.sua-area-de-lazer-vai-brilhar {
    font-size: 15px;
    color: #00568a;
}

:is(:is(#colorTexture .cor-textura) .piscinalancamento) .cores {
    margin-top: 3rem;
}

:is(:is(:is(#colorTexture .cor-textura) .piscinalancamento) .cores) img {
    float: right;
}

:is(:is(#colorTexture .cor-textura) .piscinalancamento) .add-cor-luxo {
    font-size: 30px;
    color: #fff;
    line-height: 43px;
    padding-left: 80px;
}

:is(:is(#colorTexture .cor-textura) .piscinalancamento) .escolha-uma-cor {
    color: #00568a;
    padding-left: 80px;
    font-size: 16px;
}

:is(:is(#colorTexture .cor-textura) .piscinalancamento) .learn-more {
    color: #00568a;
    bottom: 1px;
    border: 1px solid;
    padding: 5px 20px;
    left: 17px;
}

/* -------------------------------------------------------------------------- */
/* Prime Line */
/* -------------------------------------------------------------------------- */
#primeline .learn-more,
#primeline .text-prime-line {
    color: #00568a;
}

#primeline .link-learn-more {
    margin-top: 5px;
    position: relative;
}

#primeline .text-prime-line {
    font-size: 16px;
}

:is(#primeline .text-prime-line) p {
    margin-bottom: 5rem;
    color: var(--color-primary);
}

#primeline .title-prime-line {
    margin-bottom: 2rem;
}

:is(#primeline .title-prime-line) h3,
:is(#primeline .title-prime-line) h4 {
    font-size: 28px;
    color: var(--color-primary);
}

:is(#primeline .title-prime-line) img {
    max-width: 75%;
}

#primeline .learn-more {
    border: 1px solid #929d9f;
    padding: 7px 20px;
    color: var(--color-primary);
    bottom: -122px;
}

/* -------------------------------------------------------------------------- */
/* Spa */
/* -------------------------------------------------------------------------- */
#spa .learn-more,
#spa .text-connect-praia {
    color: #00568a;
}

#spa .link-learn-more {
    margin-top: 85px;
    text-align: right;
}

#spa .text-connect-praia {
    font-size: 16px;
}

:is(#spa .text-connect-praia) p {
    margin-bottom: 3rem;
    color: var(--color-primary);
}

#spa .title-connect-praia {
    margin-bottom: 4rem;
}

:is(#spa .title-connect-praia) img {
    max-width: 75%;
}

#spa .learn-more {
    border: 1px solid #929d9f;
    padding: 7px 20px;
    color: var(--color-primary);
}

/* -------------------------------------------------------------------------- */
/* Destaques (carousel) */
/* -------------------------------------------------------------------------- */
#carousel .carousel-item-next,
.carousel-item-prev,
.carousel-item.active {
    display: flex !important;
    color: var(--color-white);
}

#carousel {
    background-color: var(--color-background);
}

#carousel .carousel-item {
    padding: 0 6rem;
    background-color: var(--color-background);
    color: var(--color-white);
}

#carousel .card {
    border: none;
    color: var(--color-grey);
    background-color: var(--color-white);
}

#carousel .nome-produto {
    text-align: center;
    min-height: 2.5rem;
    font-size: 12px;
}

#carousel .btn-comprar-orcar {
    color: var(--color-blue);
    border: 1px solid var(--color-blue);
    background-color: var(--color-button-send-text-info);
    text-decoration: none;
    font-size: 12px;
    padding: .2rem 1rem;
    text-align: center;
}

.dark #carousel .card {
    border: 1px solid var(--color-background);
}

/* -------------------------------------------------------------------------- */
/* Canal Fiber */
/* -------------------------------------------------------------------------- */
#canalfiber .youtube-canal-fiber {
    margin-right: 15px;
    width: 15%;
}

#canalfiber .canal-fiber h4 {
    font-size: 48px;
    color: var(--color-primary);
}

#canalfiber .description-block-canal-fiber {
    color: var(--color-primary);
    font-size: 16px;
    margin-top: 35px;
}

#canalfiber .assista-mais {
    font-size: 16px;
    color: var(--color-primary);
}

#canalfiber .curiosidades {
    color: var(--color-primary);
}

#canalfiber .nome-video {
    padding-top: 10px;
    color: var(--color-primary);
}

#canalfiber .youtube {
    width: 100%;
    max-width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    min-width: 0;
    min-height: 0;
}

/* -------------------------------------------------------------------------- */
/* Financiamento */
/* -------------------------------------------------------------------------- */
#financing {
    /* background-color: #eaf0f1; */
    padding: 0px 0;
    margin-top: 0em;
}

:is(#financing .financeYourPoll) .finance {
    font-size: 3rem;
    line-height: 4rem;
    color: var(--color-primary);
}

:is(#financing .financeYourPoll) .texto {
    font-size: 20px;
    color: var(--color-primary);
}

:is(#financing .financeYourPoll) .text-aplly-now {
    margin-top: 2rem;
    padding: 7px 0;
}

:is(#financing .financeYourPoll) .aplly-now {
    border: 1px solid;
    padding: 7px 20px;
    color: var(--color-primary);
    width: 125px;
    display: inline-block;
    text-align: center;
    cursor: pointer;
}

#financing .beginApp,
.beginApp:active,
.beginApp:hover {
    background-color: #43bbef !important;
}

#financing .lyon-financial-logo {
    width: 222px;
    margin-left: 4rem;
}

@media only screen and (max-width: 768px) {
    #excelenteacabado .bestPools {
        margin-top: 2rem;
    }

    #excelenteacabado .mapa-icc {
        margin-top: 2rem;
    }

    #excelenteacabado h4 {
        margin-bottom: 0;
        margin-top: 0;
    }

    #excelenteacabado .bestPools .list-group .list-group-item {
        line-height: 23px;
    }

    #colorTexture .linha {
        width: 63%;
    }

    #zonadebronceado .linha {
        width: 50%;
    }

    #spa .linha {
        width: 65%;
    }

    #contact .linha {
        width: 48%;
    }

    #excelenteacabado .icc {
        margin-top: 2rem;
    }

    #financing .financeYourPoll .texto {
        margin-top: 0;
    }

    #zonadebronceado h4 {
        margin-top: 0;
    }

    #zonadebronceado .texto {
        margin-top: 10px;
    }

    #spa .link-learn-more,
    #primeline .link-learn-more {
        margin-top: 51px;
    }

    #produtosemdestaque .linha {
        width: 50%;
    }

    #canalfiber .youtube {
        width: 100%;
        max-width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
        min-width: 0;
        min-height: 0;
    }

    #findStore {
        padding: 5vh;
    }

    #findStore .findStore .find {
        font-size: 31px;
        line-height: 38px;
    }

    #formHome .row {
        max-width: unset !important;
        width: auto;
    }

    .moreInformation .info {
        font-size: 1.3rem;
        line-height: 2rem;
        text-align: center;
    }
}

/* -------------------------------------------------------------------------- */
/* Find store */
/* -------------------------------------------------------------------------- */
#findStore {
    background: var(--color-background);
    padding: 30px 0;
}

.findStore a,
.findStore a:hover {
    text-decoration: none;
}

.findStore .find {
    font-size: 43px;
    line-height: 52px;
    margin-top: 75px;
    color: var(--color-highlight);
    font-family: var(--font-family-bold);
    padding-left: 5rem;
}

:is(.findStore .find) span {
    font-family: "ClanOT-Book";
}

:is(.findStore .find) h2 {
    font-size: 43px;
}

.findStore .img img {
    max-width: 45%;
}

.findStore .texto {
    color: var(--color-highlight);
    font-family: "ClanOT-Book";
    font-size: 20px;
    margin-top: 75px;
}

:is(.findStore .texto) span {
    font-family: var(--font-family-bold);
    font-size: 35px;
    margin-top: 5px;
}

.raia {
    background: url("../img/coiso.png");
    height: 42px;
}

/* -------------------------------------------------------------------------- */
/* Mais informações / formulário home */
/* -------------------------------------------------------------------------- */
.moreInformation {
    color: var(--color-highlight);
    background: var(--color-background-secondary);
}

.moreInformation.hide-bg {
    background: none;
}

.moreInformation .info {
    font-size: 2.2rem;
    line-height: 3rem;
}

.moreInformation .icons {
    text-align: center;
    font-family: "ClanOT-Book";
}

:is(.moreInformation .icons) .icon-mais-info {
    display: block;
    font-family: "fiber-icons";
    height: 65px;
}

:is(.moreInformation .icons) img {
    margin-top: 20px;
}

:is(.moreInformation .form) input,
:is(.moreInformation .form) select,
:is(.moreInformation .form) textarea {
    margin-top: 20px;
    border-radius: 0;
    border: none;
    height: 30px;
}

:is(.moreInformation .form) select {
    padding-top: 4px;
}

:is(.moreInformation .form) textarea {
    height: 90px;
}

:is(.moreInformation .form) button[type="submit"] {
    font-family: "ClanOT-Book";
    display: block;
    margin: auto;
    width: 160px;
    padding-top: 10px;
    padding-bottom: 10px;
    color: var(--color-button-send-text-info);
    background-color: var(--color-button-send-bg-info);
    border-color: var(--color-button-send-bg-info);
}

:is(:is(.moreInformation .form) button[type="submit"]):disabled {
    background-color: var(--color-disabled);
    border-color: var(--color-disabled);
}

:is(.moreInformation .chamada) a {
    color: var(--color-primary);
    text-decoration: underline;
    font-weight: bold !important;
}

:is(.moreInformation .chamada) p {
    margin-bottom: 0;
}

.icons span {
    cursor: pointer;
}

.icons .icon-piscina:before {
    content: "\0046";
    font-size: 60px;
    position: relative;
    top: -12px;
    font-weight: 600;
}

.icons .icon-spa:before {
    content: "\0047";
    font-size: 34px;
    position: relative;
    top: 7px;
    font-weight: 600;
}

.icons .icon-filtro:before {
    content: "\0048";
    font-size: 45px;
}

.icons .tanning-ledge:before {
    content: "\0049";
    font-size: 45px;
}

.icons .icon-led:before {
    content: "\0043";
    font-size: 38px;
}

.icons .active span {
    color: var(--color-blue);
}

.icons .active span:not(.icon-mais-info) {
    font-family: var(--font-family-bold);
}

.icons span:not(.icon-mais-info) {
    font-size: var(--font-size-medium-100);
}

#formHome .row {
    max-width: 91%;
}

#formHome .iti--inline-dropdown {
    margin-top: 20px !important;
}

#formHome .disabled {
    background-color: var(--color-disabled);
}

#formHome .form-control,
#formHome .form-control:focus,
#formHome .admin-form .select>select,
#formHome .admin-form .select>select:hover,
#formHome .admin-form .select>select:focus {
    font-family: var(--font-family-primary);
    background-color: var(--color-white);
    color: var(--color-primary);
}

#formHome select:invalid {
    color: var(--color-highlight);
}

#formHome input::placeholder,
#formHome select::placeholder,
#formHome textarea::placeholder {
    font-family: var(--font-family-primary);
    color: var(--color-highlight);
}

#formHome .icons8-whatsapp {
    top: 25px;
}

#form .iti input {
    padding-right: 6px;
    padding-left: 52px;
}

@media (max-width: 576px) {
    .moreInformation form {
        margin-top: 20px;
    }

    .menuTopo .nav-item {
        background: var(--color-menu-bg-scrolled);
    }
}

/* -------------------------------------------------------------------------- */
/* Media: tablet estreito */
/* -------------------------------------------------------------------------- */
@media (max-width: 810px) {

    #blockModels {
        margin-top: 6rem;
    }

    #blockModels .modelos-piscinas-title {
        font-size: 18px;
        padding-top: 20px;
        padding-bottom: 44px;
    }

    #blockModels .modelos-piscinas-icon {
        margin-top: -31px;
        width: 60px
    }

    #fiberglassIsTheFuture .blue-pool {
        max-width: 58%;
    }

    #fiberglassIsTheFuture .icc {
        max-width: 25%;
    }


    #fiberglassIsTheFuture .bestPools .list-group .list-group-item {
        font-size: 18px;
    }

    #colorTexture .cor-textura .piscinalancamento {
        background-size: 54%;
        background-position: 30% 4rem;
    }

    #colorTexture .cor-textura .piscinalancamento .add-cor-luxo {
        font-size: 21px;
        padding-left: 126px;
        line-height: 29px;
    }

    #colorTexture .cor-textura .piscinalancamento img.granitada {
        width: 85%;
    }

    #colorTexture .cor-textura .piscinalancamento .escolha-uma-cor {
        padding-left: 126px;
        font-size: 14px;
    }

    #colorTexture .cor-textura .piscinalancamento .cores img {
        max-width: 60%;
    }

    #colorTexture .cor-textura .piscinalancamento .learn-more {
        bottom: -139px;
    }

    #spa .title-connect-praia,
    #primeline .title-prime-line {
        margin-bottom: 1rem;
    }

    #spa .text-connect-praia p,
    #primeline .text-prime-line p {
        margin-bottom: 2rem;
    }


    #spa,
    #primeline,
    #colorTexture {
        margin-top: 3rem;
    }

    #financing {
        margin-top: 1rem;
    }

    .findStore .find {
        padding-left: 0rem;
        font-size: 48px;
        line-height: 48px;
    }

    .findStore .texto {
        font-size: 17px;
        margin-top: 59px;
    }

    .findStore .img img {
        padding-right: 18%;
        max-width: 70%;
    }

    #zonadebronceado .linha {
        width: 50%;
    }

    #spa .linha {
        width: 65%;
    }

    #produtosemdestaque .linha {
        width: 51%;
    }

    #contact .linha {
        width: 47%;
    }

    #formHome .row {
        max-width: 100%;
    }
}

@media only screen and (max-width: 480px) {

    #financing .finance {
        text-align: center;
    }

    #financing .financeYourPoll .texto {
        text-align: left;
        font-size: 17px;
    }

    #financing .financeYourPoll .finance {
        line-height: 2rem;
    }

    #excelenteacabado h4 {
        text-align: center;
    }

    #excelenteacabado .bestPools {
        margin-top: 1rem;
        text-align: center;
    }

    #excelenteacabado .mapa-icc {
        margin-top: 0rem;
    }

    #zonadebronceado h4,
    #zonadebronceado .texto {
        margin-bottom: 35px;
    }

    #zonadebronceado .conoce-mas,
    #zonadebronceado .texto {
        margin-top: 0px;
    }

    #zonadebronceado .img-tanning-ledge img {
        margin: auto;
        display: block;
        margin-bottom: 35px;
    }

    #zonadebronceado .banner {
        margin-bottom: 42px;
    }

    #spa .text-connect-praia,
    #primeline .text-prime-line {
        text-align: center;
    }

    #homeHero.home-us-hero .banner-home-us__title {
        margin-top: 12rem;
        font-size: var(--font-size-home-hero-title-mobile) !important;
        line-height: 1;
    }

    #homeHero.home-us-hero .banner-home-us {
        min-height: 42rem;
    }

    #homeHero.home-us-hero .banner-home-us__inner {
        flex-grow: 0 !important;
    }

    #homeHero.home-us-hero .banner-home-us__tagline {
        font-size: var(--font-size-home-hero-tagline-mobile) !important;
    }

    .menuTopo .dropdown:hover .menu-site {
        display: none;
    }

    .menuTopo .nav-item:hover {
        background: var(--color-menu-bg-scrolled)
    }

    .navbar-nav {
        padding-left: 10px;
    }

    .menuTopo .nav-item a.nav-link {
        font-size: 16px;
    }

    .menuTopo .nav-item span.nav-link {
        font-size: 16px;
    }

    #blockModels {
        margin-top: 0;
        background: none;
    }

    .modelos-piscinas-block-title {
        width: 80%;
    }

    #blockModels .modelos-piscinas-title {
        padding-top: 50px;
        padding-bottom: 60px;
        font-size: 25px;
    }

    #blockModels .modelos-piscinas-icon {
        margin-top: -41px;
        width: 79px
    }

    #blockModels .marginB-mobile {
        margin-bottom: 5px;
    }

    #blockModels .paddingB-mobile {
        margin-bottom: 15px;
    }

    #requestDigitalCatalog {
        margin-top: 5px;
        background-color: #d7d7d7;
        margin-bottom: 2rem;
    }

    #requestDigitalCatalog input.send {
        margin-top: 10px;
        margin-left: 0;
    }

    .modelosPiscinas {
        top: 0px;
        max-height: initial;
        overflow: hidden;
        background-color: #d7d7d7;
        margin-bottom: 0;
        margin-top: 0px !important;
        padding: 0 !important;
    }

    .modelosPiscinas .img-mobile {
        width: 100% !important;
    }

    #designed-for-real-living .dfsrl-header h2.dfsrl-title {
        font-size: var(--font-size-home-hero-subtitle-mobile) !important;
    }

    #designed-for-real-living .dfsrl-card__pill {
        padding: 0.5rem 0.5rem !important;
    }

    #fiberglassIsTheFuture .blue-pool {
        max-width: 80%;
        margin: auto;
        position: initial;
    }

    #fiberglassIsTheFuture .fiberglassIsTheFuture {
        text-align: center;
        line-height: 2.4rem;
        margin-bottom: 1.7rem;
    }

    #produtosemdestaque .linha {
        width: 16%;
    }

    #fiberglassIsTheFuture .icc {
        position: initial !important;
        max-width: 50%;
        margin: auto;
        margin-top: 2rem;
        margin-bottom: 1rem;
    }

    #fiberglassIsTheFuture {
        margin-top: 1rem;
    }

    #colorTexture .cor-textura .piscinalancamento {
        padding-top: 2rem;
        height: auto;
        background-size: contain;
        background-position: center 7rem;
    }

    #colorTexture .cor-textura .piscinalancamento img.granitada {
        width: 70%;
    }

    #colorTexture .cor-textura .piscinalancamento .add-cor-luxo {
        padding-left: 0;
        margin-top: 15rem;
        text-align: center;
    }

    #colorTexture .cor-textura .piscinalancamento .escolha-uma-cor {
        padding-left: 0;
    }

    #colorTexture .cor-textura .piscinalancamento .cores {
        margin-top: 1rem;
    }

    #colorTexture .cor-textura .piscinalancamento .cores img {
        max-width: 100%;
    }

    #colorTexture .cor-textura .piscinalancamento .learn-more {
        margin-top: 3rem;
        display: inline-block;
    }

    .coloretextura .img-granite img {
        margin-top: 1rem !important;
    }

    #spa .title-connect-praia {
        text-align: center;
        margin: 2rem 0;
        margin-top: 0;
    }

    #spa .link-learn-more {
        margin-top: 3rem;
        text-align: center;
    }

    #primeline .title-prime-line {
        margin: 0;
        margin-top: 0;
        text-align: center;
    }

    :is(#primeline .title-prime-line) h3 {
        text-align: center;
    }

    #primeline .link-learn-more {
        text-align: center;
        margin-top: 3rem;
        margin-bottom: 1rem;
    }

    #primeline .img-spa-prime-line {
        margin-bottom: 42px;
    }

    #carousel .carousel-item {
        padding: 0 4rem;
    }

    .findStore .find {
        padding-left: 0;
        font-size: 40px;
        line-height: 43px;
        margin-bottom: 20px;
        margin-top: 0px;
        text-align: center;
    }

    .findStore .img img {
        padding-right: 0;
        max-width: 50%;
    }

    .findStore .texto {
        text-align: center;
        margin-top: 20px;
    }

    #inspiration-instagran {
        margin-top: calc(2rem + 10px);
    }

    #findStore {
        margin-top: calc(2rem + 10px);
        padding-bottom: 0 !important;
    }

    #canalfiber .canal-fiber h4 {
        font-size: 28px;
    }

    .moreInformation .info {
        font-size: 1.5rem;
        line-height: 2rem;
    }

    .moreInformation .icons div {
        padding: 0;
    }

    h3.separator {
        font-size: 23px;
    }
}

/* -------------------------------------------------------------------------- */
/* Designed for Real Living — home US (carrossel ≤767px) */
/* -------------------------------------------------------------------------- */
#designed-for-real-living {
    background-color: var(--color-background);
    color: var(--color-highlight);
}

#designed-for-real-living .dfsrl-inner {
    position: relative;
    z-index: 1;
}

#designed-for-real-living .dfsrl-cards-wrap {
    isolation: isolate;
}

@media (min-width: 768px) {
    #designed-for-real-living .dfsrl-cards-wrap {
        padding-bottom: 90px;
    }
}

#designed-for-real-living .dfsrl-texture-bg {
    position: absolute;
    z-index: 0;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 100%;
    height: clamp(200px, 38vw, 440px);
    background-image: url('../img/home/designed-for-real-living/textura.webp');
    background-repeat: repeat-x;
    background-position: bottom;
    background-size: 100% auto;
    pointer-events: none;
}

#designed-for-real-living .dfsrl-cards {
    z-index: 1;
}

#designed-for-real-living .dfsrl-title {
    font-size: var(--font-size-home-hero-subtitle);
    color: var(--color-grey);
    letter-spacing: -0.02em;
    margin-bottom: 0px;
}

#designed-for-real-living .dfsrl-title-em {
    display: inline-block;
    margin-left: 0.35rem;
    font-style: italic;
}

#designed-for-real-living .dfsrl-subtitle {
    font-weight: 300;
    font-size: var(--font-size-home-hero-description);
    line-height: var(--font-size-home-hero-description);
    color: #6b7370;
}

#designed-for-real-living .dfsrl-card {
    border-radius: 18px;
    transition: box-shadow 0.25s ease, transform 0.25s ease;
}

#designed-for-real-living .dfsrl-card:focus-visible {
    outline: 3px solid var(--color-menu-text);
    outline-offset: 4px;
}

#designed-for-real-living .dfsrl-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(15, 83, 113, 0.18) !important;
}

#designed-for-real-living .dfsrl-card__media {
    position: relative;
    width: 100%;
    aspect-ratio: 3 / 4;
    max-height: 532px;
}

#designed-for-real-living .dfsrl-card__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    transition: transform 0.45s ease;
    object-fit: cover;
}

#designed-for-real-living .dfsrl-card:hover .dfsrl-card__img {
    transform: scale(1.045);
}

#designed-for-real-living .dfsrl-card__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

#designed-for-real-living .dfsrl-card__overlay--pools {
    background: linear-gradient(to top,
            rgba(18, 42, 62, 0.92) 0%,
            rgba(18, 42, 62, 0.5) 48%,
            transparent 72%);
}

#designed-for-real-living .dfsrl-card__overlay--tanning {
    background: linear-gradient(to top,
            rgba(35, 88, 98, 0.9) 0%,
            rgba(35, 88, 98, 0.42) 46%,
            transparent 70%);
}

#designed-for-real-living .dfsrl-card__overlay--spas {
    background: linear-gradient(to top,
            rgba(28, 22, 18, 0.92) 0%,
            rgba(28, 22, 18, 0.48) 46%,
            transparent 70%);
}

#designed-for-real-living .dfsrl-card__footer {
    position: absolute;
    z-index: 2;
    left: 1rem;
    right: 1rem;
    bottom: 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

#designed-for-real-living .dfsrl-card__pill {
    --dfsrl-pill-height: 56px;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: var(--dfsrl-pill-height);
    width: 100%;
    padding: 0.5rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.9);
    border-radius: 999px;
}

:is(#designed-for-real-living .dfsrl-card__pill) .dfsrl-card__copy {
    padding-left: 0.5rem !important;
}

#designed-for-real-living .dfsrl-card__icon-wrap {
    width: 5rem;
    height: 5rem;
    flex-shrink: 0;
}

#designed-for-real-living .dfsrl-card__icon-wrap img {
    width: 100%;
    height: 100%;
    margin: 0 auto;
    object-fit: contain;
}

#designed-for-real-living .dfsrl-card__arrow-wrap {
    width: 32px;
    height: 32px;
    margin-left: auto;
}

#designed-for-real-living .dfsrl-card__arrow-wrap img {
    width: 100%;
    height: 1.2rem;
    display: block;
}

#designed-for-real-living .dfsrl-card__heading {
    color: var(--color-white);
    line-height: 1.2;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
    font-size: 1.5rem;
}

#designed-for-real-living .dfsrl-card__tagline {
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-weight: 300;
    font-size: 1.1rem;
    line-height: 1.45;
    opacity: 0.95;
}

@media only screen and (max-width: 767px) {
    #designed-for-real-living .dfsrl-cards-wrap.mt-default-web {
        margin-top: 53px;
    }

    #designed-for-real-living .dfsrl-title {
        font-size: 2rem !important;
    }

    #designed-for-real-living .dfsrl-inner {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #designed-for-real-living .dfsrl-cards-wrap {
        overflow-x: hidden;
        padding-bottom: 0.5rem;
    }

    #designed-for-real-living #dfsrlCarouselRow.dfsrl-cards.row {
        flex-wrap: nowrap;
        justify-content: flex-start !important;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        touch-action: pan-x pan-y;
        margin-left: 0;
        margin-right: 0;
        direction: ltr;
        column-gap: 0.75rem;
    }

    #designed-for-real-living #dfsrlCarouselRow.dfsrl-cards.row::-webkit-scrollbar {
        display: none;
    }

    #designed-for-real-living #dfsrlCarouselRow>[class*="col-"] {
        flex: 0 0 calc(100% - 0.75rem);
        max-width: calc(100% - 0.75rem);
        scroll-snap-align: start;
        scroll-snap-stop: always;
    }

    #designed-for-real-living .dfsrl-card {
        touch-action: pan-x pan-y;
    }

    #designed-for-real-living .dfsrl-card__img {
        touch-action: pan-x pan-y;
        -webkit-user-drag: none;
        user-select: none;
    }

    #designed-for-real-living .dfsrl-texture-bg {
        height: clamp(160px, 48vw, 320px);
    }

    #designed-for-real-living .dfsrl-card-nav {
        position: relative;
        z-index: 2;
        margin-top: 1rem;
        padding-right: 0.125rem;
        gap: 0.65rem !important;
    }

    #designed-for-real-living .dfsrl-card-nav__btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: var(--home-carousel-bubble-size);
        height: var(--home-carousel-bubble-size);
        padding: 0;
        border: none;
        background: transparent;
        line-height: 0;
        cursor: pointer;
        border-radius: 50%;
    }

    #designed-for-real-living .dfsrl-card-nav__btn:focus-visible {
        outline: 2px solid var(--color-menu-text);
        outline-offset: 3px;
    }

    #designed-for-real-living .dfsrl-card-nav__btn .dfsrl-card-nav__img {
        display: block;
        width: var(--home-carousel-arrow-size);
        height: var(--home-carousel-arrow-size);
    }

    #designed-for-real-living .dfsrl-card-nav__img--flip {
        transform: rotate(180deg);
    }

    #designed-for-real-living .dfsrl-card-nav__btn--inactive {
        opacity: 0.5;
        cursor: default;
        pointer-events: none;
    }

    #designed-for-real-living .dfsrl-title-em {
        display: block;
        margin-left: 0;
        margin-top: 0.15rem;
    }

    #designed-for-real-living .dfsrl-card:hover {
        transform: none;
    }

    #designed-for-real-living .dfsrl-card:hover .dfsrl-card__img {
        transform: none;
    }
}

@media only screen and (max-width: 480px) {
    #designed-for-real-living .dfsrl-cards-wrap.mt-default-web {
        padding-bottom: 0;
    }

    #designed-for-real-living .dfsrl-card__heading {
        font-size: 1rem !important;
    }

    #designed-for-real-living .dfsrl-card__tagline {
        font-size: 0.8rem !important;
    }

    #designed-for-real-living .dfsrl-card__icon-wrap {
        width: 4rem;
        height: 4rem;
    }

    #designed-for-real-living .dfsrl-subtitle {
        font-size: var(--font-size-home-hero-description-mobile) !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    #designed-for-real-living .dfsrl-card:hover {
        transform: none;
    }

    #designed-for-real-living .dfsrl-card:hover .dfsrl-card__img {
        transform: none;
    }
}

/* -------------------------------------------------------------------------- */
/* Engineered Beyond Design — home US (layout ICC / Built for Living Better) */
/* -------------------------------------------------------------------------- */
#engineered-beyond-design.ebnd-section {
    --ebnd-accent: #b88e7b;
    color: var(--color-highlight);
}

#engineered-beyond-design .ebnd-title {
    font-size: var(--font-size-home-hero-subtitle);
    line-height: var(--font-size-home-hero-subtitle);
    color: #3d4340;
    letter-spacing: -0.02em;
    margin-bottom: 0;
}

#engineered-beyond-design .ebnd-subtitle {
    font-weight: 300;
    font-size: var(--font-size-home-hero-description);
    line-height: var(--font-size-home-hero-description);
    color: #6b7370;
    margin-top: calc(var(--mt-default-subtitle) + 0.5rem);
}

#engineered-beyond-design .ebnd-left-title {
    font-size: var(--font-size-home-hero-subtitle);
    line-height: 1;
    color: #3d4340;
}

#engineered-beyond-design .ebnd-rule {
    height: 3px;
    border: none;
    background-color: var(--ebnd-accent);
    border-radius: 1px;
    width: 93%;
}

#engineered-beyond-design .ebnd-left-lead {
    font-weight: 300;
    font-size: var(--font-size-home-hero-description);
    line-height: var(--font-size-home-hero-description);
    color: #5a5f5d;
    margin-top: 33px;
}

/* Desktop/tablet: mantém título no topo e mapa no fundo alinhando com o bloco ICC */
@media only screen and (min-width: 768px) {
    #engineered-beyond-design .ebnd-body {
        align-items: stretch !important;
    }

    #engineered-beyond-design .ebnd-col-left {
        display: flex;
        flex-direction: column;
        align-self: stretch;
    }

    #engineered-beyond-design .ebnd-col-left .ebnd-map {
        margin-top: auto !important;
    }
}

#engineered-beyond-design .ebnd-map-img {
    vertical-align: middle;
}

/* Foto + ICC: cantos ~16–20px */
#engineered-beyond-design .ebnd-photo-radius {
    border-radius: 18px;
}

#engineered-beyond-design .ebnd-photo-shell {
    box-shadow: 0 14px 44px rgba(15, 83, 113, 0.12);
}

#engineered-beyond-design .ebnd-photo-shell img {
    width: 100%;
    object-fit: contain;
    aspect-ratio: 778 / 485;
}

/* Até existir imagem principal: bloco com gradiente (substituir por <img> no .volt) */
#engineered-beyond-design .ebnd-photo-placeholder {
    aspect-ratio: 16 / 11;
    min-height: 260px;
    background: linear-gradient(168deg, #b9ccd8 0%, #8fa9b8 42%, #6d8798 100%);
}

@media only screen and (max-width: 767px) {
    #engineered-beyond-design.ebnd-section {
        background-image: url('../img/home/engineered-beyond-design/bg-mobile.webp');
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top center;
    }

    #engineered-beyond-design .ebnd-inner {
        padding-left: 0;
        padding-right: 0;
    }

    #engineered-beyond-design .ebnd-header {
        max-width: 100%;
        margin-bottom: 1.75rem !important;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #engineered-beyond-design .ebnd-title {
        line-height: 1.1;
    }

    #engineered-beyond-design .ebnd-subtitle {
        text-align: center;
        max-width: 21rem;
        margin-left: auto;
        margin-right: auto;
        line-height: 1.35;
    }

    #engineered-beyond-design .ebnd-col-right {
        order: 1;
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }

    #engineered-beyond-design .ebnd-col-left {
        order: 2;
        padding-left: 1rem;
        padding-right: 1rem;
        text-align: center;
    }

    #engineered-beyond-design .ebnd-photo-radius {
        border-radius: 0;
    }

    #engineered-beyond-design .ebnd-photo-shell {
        box-shadow: none;
    }

    #engineered-beyond-design .ebnd-map {
        margin-top: 1.25rem !important;
    }

    #engineered-beyond-design .ebnd-map-frame {
        border-radius: 0 !important;
        overflow: visible !important;
    }

    #engineered-beyond-design .ebnd-map-img {
        max-width: 92%;
        margin-left: auto;
        margin-right: auto;
    }

    #engineered-beyond-design .ebnd-rule {
        max-width: 280px;
        margin-left: auto;
        margin-right: auto;
    }

    #engineered-beyond-design .ebnd-footer {
        margin-top: 2rem !important;
        padding-left: 1rem;
        padding-right: 1rem;
        padding-bottom: 2.5rem;
    }

    #engineered-beyond-design .cta_buttom {
        min-width: min(270px, 100%);
    }

    #engineered-beyond-design .ebnd-photo-placeholder {
        aspect-ratio: 4 / 3;
        min-height: 220px;
    }

    #engineered-beyond-design .ebnd-icc-logo {
        max-width: min(120px, 42vw);
    }
}

@media only screen and (max-width: 480px) {

    #engineered-beyond-design.ebnd-section .ebnd-inner {
        padding-top: var(--mt-default-web-mobile);
        padding-bottom: 0;
    }

    #engineered-beyond-design.ebnd-section .ebnd-title {
        font-size: var(--font-size-home-hero-subtitle-mobile) !important;
    }

    #engineered-beyond-design.ebnd-section .ebnd-left-title {
        text-align: center;
        font-size: var(--font-size-home-hero-subtitle-mobile) !important;
    }

    #engineered-beyond-design.ebnd-section .ebnd-left-lead {
        text-align: center;
        font-size: var(--font-size-home-hero-description-mobile) !important;
        margin-top: 0;
    }

    #engineered-beyond-design.ebnd-section .ebnd-subtitle {
        font-size: var(--font-size-home-hero-description-mobile) !important;
    }

    #engineered-beyond-design.ebnd-section .ebnd-icc-logo {
        max-width: 100%;
        margin: 0 auto;
    }

    #engineered-beyond-design.ebnd-section .ebnd-photo-shellr {
        padding: 0 1rem;
    }

    #engineered-beyond-design.ebnd-section .ebnd-col-left {
        margin-top: var(--mt-default-subtitle-mobile);
    }

    #engineered-beyond-design.ebnd-section .ebnd-footer {
        margin-top: var(--mt-default-divider-mobile) !important;
        padding-bottom: 0;
    }

    #engineered-beyond-design.ebnd-section .ebnd-rule {
        max-width: 100%;
        margin-top: calc(var(--mt-default-subtitle-mobile) / 2);
        margin-bottom: calc(var(--mt-default-subtitle-mobile) / 2);
    }

    #engineered-beyond-design.ebnd-section .ebnd-map {
        margin-top: var(--mt-default-divider-mobile);
    }
}

/* -------------------------------------------------------------------------- */
/* Life Style — banner full-width (home US) */
/* -------------------------------------------------------------------------- */
#life-style.ls-banner {
    --ls-cta: #b88e7b;
    color: #fff;
}

#life-style .ls-banner__bg {
    position: absolute;
    inset: 0;
    background-image: url('../img/home/life-style/family-pool-experience-backyard-lifestyle-fiber.webp');
    background-repeat: no-repeat, no-repeat;
    background-size: cover, cover;
    background-position: center, center right;
    aspect-ratio: 1920 / 800;
}

#life-style .ls-banner__inner {
    z-index: 1;
}

#life-style .ls-banner__row {
    min-height: clamp(320px, 69vh, 646px);
}

#life-style .ls-banner__title {
    font-size: var(--font-size-home-hero-subtitle);
    line-height: var(--font-size-home-hero-subtitle);
    letter-spacing: -0.02em;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35);
    margin-bottom: 4.2rem;
}

#life-style .ls-banner__lead {
    font-weight: 300;
    font-size: var(--font-size-home-hero-description);
    max-width: 26rem;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
    line-height: 1.2;
    margin-bottom: 4.2rem !important;
}

@media only screen and (max-width: 991px) {
    #life-style .ls-banner__copy {
        text-align: center;
    }

    #life-style .ls-banner__lead {
        margin-left: auto;
        margin-right: auto;
    }

    #life-style .ls-banner__bg {
        background-position: center, 70% center;
    }
}

@media only screen and (max-width: 767px) {
    #life-style .ls-banner__bg {
        background-image: url('../img/home/life-style/family-relaxing-fiber-swimming-pool.webp');
    }

    #life-style .ls-banner__inner {
        display: flex;
        flex-direction: column;
        min-height: clamp(520px, 88vh, 780px);
        padding-bottom: 1.5rem;
    }

    #life-style .ls-banner__row {
        flex: 1 1 auto;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        min-height: 0;
    }

    #life-style .ls-banner__copy {
        flex: 1 1 auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding-top: clamp(2.5rem, 10vw, 4rem);
        padding-bottom: 1rem;
    }

    #life-style .ls-banner__lead {
        max-width: 22rem;
    }
}

@media only screen and (min-width: 768px) {
    #life-style .ls-banner__inner {
        display: block;
        min-height: 0;
        padding-bottom: 0;
    }

    #life-style .ls-banner__row {
        display: flex;
        flex-direction: row;
    }

    #life-style .ls-banner__copy {
        display: block;
    }
}

/* -------------------------------------------------------------------------- */
/* Introducing Collections — home new */
/* -------------------------------------------------------------------------- */

#introducing-collections .ic-title {
    color: #414854;
    font-size: var(--font-size-home-hero-subtitle);
    line-height: 1.1;
    letter-spacing: -0.02em;
}

#introducing-collections .ic-card {
    border-radius: 22px;
    max-width: 653px;
}

#introducing-collections .ic-card__img {
    width: 100%;
    max-width: 653px;
    height: auto;
    aspect-ratio: 1 / 1;
    min-height: 0;
    object-fit: cover;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

#introducing-collections .ic-card__overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

#introducing-collections .ic-card__top {
    position: absolute;
    top: 1.25rem;
    left: 1.25rem;
    right: 1.25rem;
    z-index: 2;
}

#introducing-collections .ic-card__kicker {
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-weight: 300;
    font-size: clamp(1.05rem, 1.7vw, 2rem);
    line-height: 1.2;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.35);
    text-indent: 2.5rem;
}

#introducing-collections .ic-card__name {
    font-size: clamp(2.2rem, 4vw, 3.9rem);
    line-height: 0.95;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.35);
}

#introducing-collections .ic-card__cta-wrap {
    position: absolute;
    left: 1.5rem;
    right: 1.5rem;
    bottom: 1.5rem;
    z-index: 2;
}

#introducing-collections .ic-card__cta {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.62);
    border-radius: 999px;
    padding: 0.7rem 1.15rem;
    color: #fff;
    font-size: 1.5rem;
    line-height: 1.1;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(1px);
}

#introducing-collections .ic-card__arrow {
    width: 30px;
    height: 30px;
    margin-left: 0.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#introducing-collections .ic-card__arrow img {
    width: 100%;
    height: 100%;
    display: block;
}

#introducing-collections .ic-footnote {
    font-size: var(--font-size-home-hero-description);
    line-height: 1.4;
    color: #6b7179;
    max-width: 52rem;
    margin-left: auto;
    margin-right: auto;
}

/* Introducing Collections — mobile: cards empilhados (sem carrossel) */
@media only screen and (max-width: 767.98px) {
    #introducing-collections .ic-cards-wrap {
        overflow: visible;
    }

    #introducing-collections .ic-cards {
        flex-wrap: wrap;
        margin-left: 0;
        margin-right: 0;
        overflow: visible;
    }

    #introducing-collections .ic-cards>[class*="col-"] {
        flex: 0 0 100%;
        max-width: 100%;
        padding: 0;
    }

    #introducing-collections .ic-card__img--mobile {
        min-height: unset;
        object-fit: cover;
        height: auto;
        width: 100%;
    }
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    #introducing-collections .ic-card__img {
        aspect-ratio: 1 / 1;
        min-height: 420px;
    }

    #introducing-collections .ic-card__cta {
        font-size: clamp(1.4rem, 4.2vw, 2rem);
    }
}


/* -------------------------------------------------------------------------- */
/* Finance Your New Pool — home new */
/* -------------------------------------------------------------------------- */
#finance-your-new-pool.fynp-section {
    background-image: url('../img/home/finance/finance-background.webp');
    background-repeat: no-repeat, no-repeat;
    background-size: cover, cover;
    background-position: center, center right;
    padding-top: var(--mt-default-web);
    padding-bottom: calc(var(--mt-default-web) + 4rem);
}

#finance-your-new-pool .fynp-title {
    color: #414854;
    font-size: var(--font-size-home-hero-subtitle);
    letter-spacing: -0.02em;
    line-height: 1.1;
}

#finance-your-new-pool .fynp-description {
    font-weight: 300;
    font-size: var(--font-size-home-hero-description);
    line-height: 1.3;
    color: #666d75;
}

#finance-your-new-pool .fynp-copy .div-cta_buttom {
    margin-top: 3rem;
}

@media only screen and (max-width: 991px) {
    #finance-your-new-pool .fynp-title {
        text-align: center;
    }

    #finance-your-new-pool .fynp-copy {
        max-width: 100%;
        text-align: center;
    }
}

/* Finance — mobile only (desktop / lg+ unchanged) */
@media only screen and (max-width: 767.98px) {
    #finance-your-new-pool.fynp-section {
        padding-top: var(--mt-default-subtitle-mobile);
        padding-bottom: var(--mt-default-divider-mobile);
    }

    #finance-your-new-pool .fynp-inner {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #finance-your-new-pool .fynp-title {
        margin-bottom: 1rem;
        font-size: clamp(1.85rem, 9.5vw, 2.65rem);
    }

    #finance-your-new-pool .fynp-copy {
        margin-top: 0;
    }

    #finance-your-new-pool .fynp-description {
        font-size: 1rem;
        line-height: 1.45;
        max-width: 21rem;
        margin-left: auto;
        margin-right: auto;
    }
}


/* -------------------------------------------------------------------------- */
/* Check Out Instagram — home new */
/* -------------------------------------------------------------------------- */
#check-out-instagram.coi-section {
    margin-top: 0;
}

#check-out-instagram .coi-bg {
    position: absolute;
    inset: 0;
    background-image: url('../img/home/check-out-instagram/pool-inspiration-backyard-lifestyle-fiber-instagram.webp');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 800px;
}

#check-out-instagram .coi-inner {
    z-index: 1;
    padding-top: var(--mt-default-web);
    padding-bottom: var(--mt-default-web);
}

#check-out-instagram .coi-title {
    font-size: var(--font-size-home-hero-subtitle);
    line-height: 0.98;
    letter-spacing: -0.02em;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
    max-width: 28rem;
}

#check-out-instagram .coi-description {
    font-size: var(--font-size-home-hero-description);
    line-height: 1.24;
    max-width: 34rem;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.35);
    margin-top: 5.6rem;
    padding-right: 1.2rem;
}

#check-out-instagram .cta_buttom {
    margin-top: 5.6rem;
}

/* Check Out Instagram — mobile only (foto 596px de altura; desktop inalterado acima) */
@media only screen and (max-width: 767.98px) {
    #check-out-instagram.coi-section {
        background-color: #ececec;
    }

    /* Camada de foto com altura fixa igual ao asset mobile (596px) */
    #check-out-instagram .coi-bg {
        inset: auto;
        top: 0;
        left: 0;
        right: 0;
        width: 100%;
        height: 596px;
        min-height: 596px;
        max-height: 596px;
        background-image: url('../img/home/check-out-instagram/pool-inspiration-backyard-lifestyle-fiber-instagram-mobile.webp');
        background-repeat: no-repeat;
        background-position: center top;
        background-size: cover;
    }

    /*
     * Conteúdo em coluna: bloco de texto no topo do quadro 596px e CTA na base
     * (mesma lógica do mock mobile: título + texto acima, botão abaixo).
     */
    #check-out-instagram .coi-inner {
        min-height: 596px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        box-sizing: border-box;
    }

    #check-out-instagram .coi-inner>.row:first-child {
        flex-shrink: 0;
    }

    #check-out-instagram .coi-inner>.row:last-child {
        flex-shrink: 0;
        margin-top: 0;
    }

    #check-out-instagram .coi-inner .coi-row>.col-12 {
        text-align: center;
    }

    #check-out-instagram h2#coi-heading.coi-title.mb-4 {
        font-size: clamp(1.95rem, 12.5vw, 2.85rem) !important;
        line-height: 1.02;
        padding: 0 9vw;
        ;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 0.65rem !important;
    }

    #check-out-instagram .coi-description {
        font-size: 0.98rem;
        line-height: 1.32;
        max-width: 19.5rem;
        margin-left: auto;
        margin-right: auto;
        margin-top: 42vh;
        text-align: center;
    }
}

/* -------------------------------------------------------------------------- */
/* FAQ + Form — home new */
/* -------------------------------------------------------------------------- */
#faq-form.faq-form-section {
    background-color: #ececec;
    padding: clamp(2.8rem, 6vw, 5rem) 0;
}

#faq-form .faq-form-inner {
    max-width: 760px;
}

#faq-form .faq-form-title {
    color: #5f6d72;
    font-size: 2.5rem;
    line-height: 1.1;
}

#faq-form .faq-form-subtitle {
    color: #6b757b;
    font-size: var(--font-size-home-hero-description);
}

#faq-form .faq-form-accordion {
    border: 1px solid #d2d6d8;
    background: transparent;
    padding: 0.35rem 0.85rem;
}

#faq-form .faq-form-accordion .accordion-item {
    border: 0;
    border-bottom: 1px solid #b9c0c4;
    background: transparent;
}

#faq-form .faq-form-accordion .accordion-item:last-child {
    border-bottom: 0;
}

#faq-form .faq-form-accordion .accordion-button {
    background: transparent;
    box-shadow: none;
    color: #6d757b;
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-size: clamp(0.95rem, 1.35vw, 1.35rem);
    padding: 0.85rem 0.4rem;
}

#faq-form .faq-form-accordion .accordion-button:not(.collapsed) {
    color: #4e5960;
}

#faq-form .faq-form-accordion .accordion-button::after {
    width: 16px;
    height: 16px;
    background-size: 16px;
    opacity: 0.6;
}

#faq-form .faq-form-accordion .accordion-body {
    color: #687278;
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-size: 0.97rem;
    line-height: 1.45;
    padding: 0 0.4rem 1rem;
}

#faq-form .faq-form-contact-title {
    color: #6d757b;
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-size: clamp(1.05rem, 1.45vw, 1.45rem);
}

#faq-form .faq-form-actions {
    gap: 0.75rem;
}

#faq-form .faq-form-btn {
    border-radius: 999px;
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-size: clamp(1rem, 1.1vw, 1.2rem);
    line-height: 1;
    padding: 0.72rem 1.45rem;
}

#faq-form .faq-form-btn--ghost {
    border: 1px solid #b7bec2;
    background: transparent;
    color: #6a7379;
}

#faq-form .faq-form-btn--solid {
    border: 1px solid #ae7451;
    background: var(--color-background-button-cta);
    color: #fff !important;
}

#faq-form .faq-form-helper {
    color: #7c8489;
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-size: 0.98rem;
    line-height: 1.45;
}

#faq-form .faq-form-reveal {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(8px);
    transition: max-height 0.55s ease, opacity 0.35s ease, transform 0.35s ease;
}

#faq-form .faq-form-reveal.is-visible {
    max-height: 920px;
    opacity: 1;
    transform: translateY(0);
}

#faq-form .faq-form-field {
    border: 1px solid #b9c0c4;
    border-radius: 999px;
    background-color: var(--color-white);
    color: #6b757b;
    font-size: 1.02rem;
    height: 46px;
    padding: 0.45rem 1rem;
}

#faq-form .faq-form-field::placeholder {
    color: #6b757b;
}

#faq-form .faq-form-field:focus {
    background-color: transparent;
    border-color: #a8b1b6;
    box-shadow: none;
    color: #5e666b;
}

#faq-form .faq-form-field--textarea {
    border-radius: 18px;
    height: auto;
    min-height: 66px;
    resize: vertical;
}

#faq-form .cta_buttom {
    border: 0;
    border-radius: 999px;
    font-size: clamp(1rem, 1.15vw, 1.22rem);
    line-height: 1;
    padding: 0.78rem 1.45rem;
}

#faq-form .faq-form-btn--ghost[aria-expanded="true"] {
    background: #f4f5f6;
}

#faq-form .faq-form-success {
    color: #7c8489;
    font-family: 'InterTight-Light', 'Inter', system-ui, sans-serif;
    font-size: 0.96rem;
    line-height: 1.5;
}

/* FAQ + Form — mobile only (desktop: regras base acima) */
@media only screen and (max-width: 767.98px) {
    #faq-form.faq-form-section {
        padding-top: var(--mt-default-web-mobile);
        padding-bottom: var(--mt-default-web-mobile);
    }

    #faq-form .faq-form-inner {
        max-width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #faq-form .faq-form-header {
        text-align: center;
        padding: 0 0.15rem;
    }

    #faq-form .faq-form-title {
        font-size: clamp(1.85rem, 8.5vw, 2.65rem) !important;
        line-height: 1.12;
    }

    #faq-form .faq-form-subtitle {
        font-size: 0.98rem;
        line-height: 1.4;
        margin-top: 0.35rem;
    }

    #faq-form .faq-form-faq {
        margin-top: 1.25rem !important;
    }

    #faq-form .faq-form-accordion {
        padding: 0.28rem 0.55rem 0.35rem;
        border-radius: 2px;
    }

    #faq-form .faq-form-accordion .accordion-button {
        padding: 0.72rem 0.3rem;
        font-size: 0.96rem;
        line-height: 1.35;
        text-align: left;
        white-space: normal;
    }

    #faq-form .faq-form-accordion .accordion-button::after {
        flex-shrink: 0;
        margin-left: 0.5rem;
    }

    #faq-form .faq-form-accordion .accordion-body {
        padding: 0 0.3rem 0.85rem;
        font-size: 0.94rem;
        line-height: 1.42;
    }

    #faq-form .faq-form-contact {
        margin-top: 1.5rem !important;
    }

    #faq-form .faq-form-contact-title {
        text-align: center;
        font-size: 1.04rem;
        line-height: 1.35;
        margin-bottom: 0.85rem !important;
    }

    /* Contact Us primeiro, Request a Quote ao lado — largura reduzida em cada um */
    #faq-form .faq-form-actions {
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: center;
        gap: 0.45rem;
        width: 100%;
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    #faq-form .faq-form-btn {
        flex: 1 1 calc(45% - 0.225rem);
        min-width: 0;
        max-width: calc(50% - 0.225rem);
        justify-content: center;
        text-align: center;
        box-sizing: border-box;
        padding: 0.58rem 0.45rem;
        font-size: clamp(0.72rem, 2.8vw, 0.82rem);
        line-height: 1.15;
        white-space: normal;
        hyphens: auto;
        font-size: 1.02rem;
    }

    #faq-form .faq-form-btn--solid {
        display: flex;
        align-items: center;
        justify-content: center;
    }

    #faq-form .faq-form-helper {
        text-align: center;
        margin-left: auto;
        margin-right: auto;
        max-width: 22rem;
        font-size: 0.95rem;
        line-height: 1.42;
    }

    #faq-form .faq-form-form-wrap {
        margin-top: 1rem !important;
    }

    #faq-form .faq-form-field {
        font-size: 1rem;
        height: 48px;
        background-color: #fff !important;
    }

    #faq-form .faq-form-field:focus {
        background-color: #fff !important;
    }

    #faq-form .faq-form-field--textarea {
        min-height: 72px;
    }

    #faq-form .cta_buttom {
        width: auto;
        max-width: 13.5rem;
        min-width: 0;
        margin-left: auto;
        margin-right: auto;
        display: block;
        padding: 0.78rem 1.35rem;
        font-size: 1.02rem;
    }

    #faq-form .faq-form-success {
        text-align: center;
        font-size: 0.94rem;
        max-width: 22rem;
        margin-left: auto;
        margin-right: auto;
    }

    #faq-form .faq-form-reveal.is-visible {
        max-height: 1100px;
    }
}

@media only screen and (max-width: 575px) {

    /* Life Style */
    #life-style .ls-banner__row {
        min-height: 0;
    }

    #life-style .ls-banner__title {
        font-size: 3rem !important;
        line-height: 1.1;
        margin-bottom: 0;
        /*margin-right: auto;*/
    }

    #life-style .ls-banner__bg {
        background-position: center top;
        aspect-ratio: unset;
    }

    #life-style .ls-banner__inner {
        min-height: clamp(32rem, 100vh, 56rem);
        min-height: clamp(32rem, 100dvh, 56rem);
    }

    #life-style .ls-banner__copy {
        padding-top: var(--mt-default-web-mobile);
        padding-bottom: var(--mt-default-web-mobile);
        padding-left: 0;
        padding-right: 0;
        margin-bottom: 0;
        flex: 1;
        display: flex;
        flex-direction: column;
    }

    #life-style .ls-banner__lead {
        font-size: var(--font-size-home-hero-description-mobile) !important;
        line-height: 1.1;
        margin-top: var(--mt-default-subtitle-mobile);
        text-align: center;
        max-width: 75vw;
    }

    #life-style .cta_buttom {
        margin-top: auto;
    }

    /* Introducing Collections */

    #introducing-collections .ic-title {
        font-size: var(--font-size-home-hero-subtitle-mobile) !important;
    }

    #introducing-collections .ic-card {
        border-radius: 16px;
    }

    #introducing-collections .ic-cards-wrap {
        overflow: initial !important;
    }

    #introducing-collections .ic-card__img {
        min-height: auto;
        width: 100%;
        height: auto;
    }

    #introducing-collections .ic-card__kicker {
        font-size: 1rem;
        text-indent: 0;
        text-align: start;
    }

    #introducing-collections .ic-card__name {
        font-size: 2.05rem !important;
        text-align: center !important;
    }

    #introducing-collections .ic-card__cta-wrap {
        left: 1rem;
        right: 1rem;
        bottom: 1rem;
    }

    #introducing-collections .ic-card__cta {
        font-size: 0.8rem !important;
        padding: 0.62rem 0.95rem;
    }

    #introducing-collections .ic-footnote {
        font-size: 0.98rem;
        max-width: 92%;
    }

    #introducing-collections .ic-card__arrow img {
        width: 70%;
        height: 70%;
    }

    /* Finance Your New Pool */
    #finance-your-new-pool.fynp-section {
        padding-top: calc(var(--mt-default-web-mobile) / 2);
        padding-bottom: var(--mt-default-web-mobile);
    }

    #finance-your-new-pool .fynp-title {
        font-size: var(--font-size-home-hero-subtitle-mobile) !important;
        text-align: left;
    }

    #finance-your-new-pool .fynp-description {
        font-size: var(--font-size-home-hero-description-mobile) !important;
        line-height: 1.1;
    }

    #finance-your-new-pool .fynp-copy .div-cta_buttom {
        margin-top: var(--mt-default-divider-mobile) !important;
    }

    #check-out-instagram .coi-bg {
        max-height: none;
        height: -webkit-fill-available;
    }

    #check-out-instagram .coi-description {
        margin-top: 27vh;
        max-width: 100%;
    }

    #check-out-instagram .coi-inner {
        padding-bottom: 5rem;
    }

    #check-out-instagram .cta_buttom {
        margin-top: var(--mt-default-divider-mobile) !important;
    }
}