/* Filó Rendeira — estilos extraídos do HTML para melhorar cache e manutenção. */
:root {
            --brand-offwhite: #FAF9F6;
            --brand-pink-light: #FADADD;
            --brand-pink-dark: #D8A7B1;
            --brand-brown: #4A3728;
        }
        
        body {
            font-family: 'Montserrat', sans-serif;
            background-color: var(--brand-offwhite);
            color: var(--brand-brown);
        }

        .font-serif { font-family: 'Playfair Display', serif; }

        .section-padding {
            padding: 4rem 1.5rem;
        }
        @media (min-width: 768px) {
            .section-padding { padding: 6rem 3rem; }
        }

        .button-primary {
            background-color: var(--brand-pink-dark);
            color: white;
            padding: 1rem 2rem;
            border-radius: 9999px;
            font-weight: 500;
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            transition: all 0.3s ease;
            box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
            text-decoration: none;
        }
        .button-primary:hover {
            opacity: 0.9;
            transform: translateY(-2px);
            box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
        }
        .button-outline {
            background-color: transparent;
            color: var(--brand-pink-dark);
            border: 2px solid var(--brand-pink-dark);
        }
        .button-outline:hover {
            background-color: var(--brand-pink-dark);
            color: white;
        }

        .faq-item {
            border: 1px solid var(--brand-pink-light);
            border-radius: 1rem;
            margin-bottom: 1rem;
            overflow: hidden;
        }
        .faq-content {
            max-height: 0;
            transition: max-height 0.3s ease-out;
            background-color: white;
        }
        .faq-item.active .faq-content {
            max-height: 600px;
        }
        .faq-item.active svg {
            transform: rotate(180deg);
        }

        .portfolio-card img {
            transition: transform 0.5s ease;
        }
        .portfolio-card:hover img {
            transform: scale(1.1);
        }

        .fade-in {
            opacity: 0;
            transform: translateY(30px);
            transition: opacity 0.7s ease, transform 0.7s ease;
        }
        .fade-in.visible {
            opacity: 1;
            transform: translateY(0);
        }

        #lightbox {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.92);
            z-index: 99999;
            align-items: center;
            justify-content: center;
            padding: 1rem;
        }
        #lightbox.open { display: flex; }
        #lightbox img {
            max-width: 90vw;
            max-height: 90vh;
            object-fit: contain;
            border-radius: 1rem;
            box-shadow: 0 25px 60px rgba(0,0,0,0.5);
        }
        #lightbox-close {
            position: absolute;
            top: 1.5rem;
            right: 1.5rem;
            color: white;
            font-size: 2.5rem;
            cursor: pointer;
            opacity: 0.8;
            transition: opacity 0.2s;
        }
        #lightbox-close:hover { opacity: 1; }
        #lightbox-caption {
            position: absolute;
            bottom: 2rem;
            left: 50%;
            transform: translateX(-50%);
            color: white;
            font-family: 'Playfair Display', serif;
            font-size: 1.1rem;
            text-align: center;
            opacity: 0.9;
        }

        #popup {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.5);
            z-index: 9998;
            align-items: center;
            justify-content: center;
            padding: 1rem;
        }
        #popup.open { display: flex; }

        #back-to-top {
            position: fixed;
            bottom: 6.5rem;
            right: 2rem;
            z-index: 9997;
            width: 44px;
            height: 44px;
            border-radius: 50%;
            background: var(--brand-pink-dark);
            color: white;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            opacity: 0;
            transform: translateY(10px);
            transition: all 0.3s ease;
            box-shadow: 0 4px 15px rgba(216,167,177,0.5);
        }
        #back-to-top.visible { opacity: 1; transform: translateY(0); }
        #back-to-top:hover { background: var(--brand-brown); transform: translateY(-2px); }

        #promo-bar {
            background: var(--brand-pink-dark);
            color: white;
            text-align: center;
            padding: 0.6rem 2rem;
            font-size: 0.8rem;
            font-weight: 500;
            letter-spacing: 0.05em;
            position: relative;
        }
        #promo-close {
            position: absolute;
            right: 1rem;
            top: 50%;
            transform: translateY(-50%);
            cursor: pointer;
            opacity: 0.8;
            font-size: 1.1rem;
        }

        .counter-num {
            font-family: 'Playfair Display', serif;
            font-size: 3rem;
            font-weight: 700;
            color: var(--brand-pink-dark);
            line-height: 1;
        }

        /* Animação Guia de Medidas */
        @keyframes pulse-pink {
            0% { box-shadow: 0 0 0 0 rgba(216, 167, 177, 0.7); }
            70% { box-shadow: 0 0 0 15px rgba(216, 167, 177, 0); }
            100% { box-shadow: 0 0 0 0 rgba(216, 167, 177, 0); }
        }
        .pulse {
            animation: pulse-pink 2s infinite;
        }
        @keyframes gentle-float {
            0%, 100% { transform: translateY(0); }
            50% { transform: translateY(-6px); }
        }
        .measure-figure {
            animation: gentle-float 5s ease-in-out infinite;
            filter: drop-shadow(0 18px 30px rgba(216, 167, 177, 0.18));
        }
        .measure-line {
            stroke: var(--brand-pink-dark);
            stroke-width: 3;
            stroke-dasharray: 8 6;
            stroke-linecap: round;
            fill: none;
            opacity: 0.95;
        }

        /* Magazine grid portfólio */
        .portfolio-magazine {
            display: grid;
            grid-template-columns: 2fr 1fr;
            grid-template-rows: 1fr 1fr;
            gap: 1rem;
            height: 520px;
            margin-bottom: 1rem;
        }
        .portfolio-magazine .card-big {
            grid-row: span 2;
        }
        @media (max-width: 640px) {
            .portfolio-magazine {
                grid-template-columns: 1fr;
                grid-template-rows: auto;
                height: auto;
            }
            .portfolio-magazine .card-big { grid-row: span 1; }
        }
        .form-input { 
            width: 100%; padding: 0.8rem 1rem; border: 1px solid var(--brand-pink-light); border-radius: 12px; 
            background: white; outline: none; transition: border-color 0.3s ease;
        }
        .form-input:focus { border-color: var(--brand-pink-dark); }
        


        /* Hero premium com carrossel de imagens */
        .hero-premium {
            position: relative;
            overflow: hidden;
            background:
                radial-gradient(circle at 12% 18%, rgba(250, 218, 221, 0.85) 0, rgba(250, 218, 221, 0) 32%),
                radial-gradient(circle at 86% 12%, rgba(216, 167, 177, 0.28) 0, rgba(216, 167, 177, 0) 34%),
                linear-gradient(135deg, #FAF9F6 0%, #FFFDFC 42%, rgba(250, 218, 221, 0.42) 100%);
        }
        .hero-premium::before {
            content: '';
            position: absolute;
            inset: 0;
            background-image:
                linear-gradient(rgba(216, 167, 177, 0.08) 1px, transparent 1px),
                linear-gradient(90deg, rgba(216, 167, 177, 0.08) 1px, transparent 1px);
            background-size: 72px 72px;
            mask-image: linear-gradient(to bottom, rgba(0,0,0,0.45), transparent 75%);
            pointer-events: none;
        }
        .hero-copy-card {
            position: relative;
            z-index: 2;
        }
        .hero-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 0.9rem;
            align-items: center;
        }
        .hero-secondary-link {
            color: var(--brand-brown);
            background: rgba(255,255,255,0.75);
            border: 1px solid rgba(216, 167, 177, 0.55);
            padding: 1rem 1.5rem;
            border-radius: 9999px;
            display: inline-flex;
            align-items: center;
            gap: 0.45rem;
            font-size: 0.92rem;
            font-weight: 600;
            text-decoration: none;
            box-shadow: 0 10px 28px rgba(74,55,40,0.06);
            transition: all 0.25s ease;
        }
        .hero-secondary-link:hover {
            transform: translateY(-2px);
            border-color: var(--brand-pink-dark);
            background: white;
        }
        .hero-carousel-shell {
            position: relative;
            z-index: 2;
        }
        .hero-carousel {
            position: relative;
            aspect-ratio: 4 / 5;
            border-radius: 2rem;
            overflow: hidden;
            box-shadow: 0 28px 70px rgba(74, 55, 40, 0.22);
            border: 10px solid rgba(255,255,255,0.82);
            background: var(--brand-pink-light);
        }
        .hero-carousel::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(to top, rgba(74,55,40,0.48), transparent 48%), linear-gradient(135deg, rgba(216,167,177,0.18), transparent 48%);
            pointer-events: none;
            z-index: 2;
        }
        .hero-slide {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            opacity: 0;
            transform: scale(1.035);
            transition: opacity 0.9s ease, transform 3.8s ease;
        }
        .hero-slide.active {
            opacity: 1;
            transform: scale(1);
        }
        .hero-floating-badge {
            position: absolute;
            z-index: 4;
            left: -1.1rem;
            top: 2.3rem;
            background: rgba(255,255,255,0.94);
            color: var(--brand-brown);
            border: 1px solid rgba(216,167,177,0.5);
            border-radius: 9999px;
            padding: 0.8rem 1.1rem;
            box-shadow: 0 14px 34px rgba(74,55,40,0.14);
            font-size: 0.8rem;
            font-weight: 700;
            display: inline-flex;
            align-items: center;
            gap: 0.45rem;
        }
        .hero-caption-card {
            position: absolute;
            left: 1.1rem;
            right: 1.1rem;
            bottom: 1.1rem;
            z-index: 4;
            background: rgba(255,255,255,0.9);
            border: 1px solid rgba(255,255,255,0.65);
            backdrop-filter: blur(14px);
            border-radius: 1.3rem;
            padding: 1rem 1.1rem;
            box-shadow: 0 14px 35px rgba(0,0,0,0.12);
        }
        .hero-caption-kicker {
            font-size: 0.68rem;
            text-transform: uppercase;
            letter-spacing: 0.16em;
            color: var(--brand-pink-dark);
            font-weight: 800;
            margin-bottom: 0.2rem;
        }
        .hero-caption-title {
            font-family: 'Playfair Display', serif;
            font-size: 1.25rem;
            line-height: 1.2;
            color: var(--brand-brown);
        }
        .hero-dots {
            position: absolute;
            z-index: 5;
            right: 1.15rem;
            top: 1.15rem;
            display: flex;
            gap: 0.45rem;
            padding: 0.45rem;
            border-radius: 9999px;
            background: rgba(255,255,255,0.72);
            backdrop-filter: blur(10px);
        }
        .hero-dot {
            width: 9px;
            height: 9px;
            border-radius: 50%;
            border: 0;
            background: rgba(74,55,40,0.25);
            cursor: pointer;
            transition: all 0.25s ease;
        }
        .hero-dot.active {
            width: 26px;
            border-radius: 9999px;
            background: var(--brand-pink-dark);
        }
        .hero-mini-gallery {
            position: absolute;
            right: -1rem;
            bottom: -1.15rem;
            z-index: 5;
            display: flex;
            gap: 0.55rem;
            padding: 0.55rem;
            border-radius: 1rem;
            background: rgba(255,255,255,0.86);
            border: 1px solid rgba(216,167,177,0.35);
            box-shadow: 0 14px 30px rgba(74,55,40,0.12);
        }
        .hero-mini-gallery img {
            width: 54px;
            height: 68px;
            object-fit: cover;
            border-radius: 0.75rem;
            border: 2px solid transparent;
            opacity: 0.74;
            cursor: pointer;
            transition: all 0.25s ease;
        }
        .hero-mini-gallery img.active {
            opacity: 1;
            border-color: var(--brand-pink-dark);
            transform: translateY(-3px);
        }
        .hero-stats {
            display: flex;
            flex-wrap: wrap;
            gap: 0.75rem;
            padding-top: 0.25rem;
        }
        .hero-stat-pill {
            background: rgba(255,255,255,0.72);
            border: 1px solid rgba(216,167,177,0.38);
            border-radius: 9999px;
            padding: 0.65rem 0.9rem;
            font-size: 0.78rem;
            font-weight: 700;
            box-shadow: 0 10px 24px rgba(74,55,40,0.06);
        }
        @media (max-width: 1023px) {
            .hero-carousel-shell { max-width: 560px; margin: 0 auto; }
            .hero-floating-badge { left: 1rem; }
            .hero-mini-gallery { right: 0.7rem; }
        }
        @media (max-width: 640px) {
            .hero-premium { padding-top: 8.5rem; }
            .hero-actions { flex-direction: column; align-items: stretch; }
            .hero-actions .button-primary, .hero-secondary-link { justify-content: center; width: 100%; }
            .hero-carousel { border-width: 7px; border-radius: 1.5rem; }
            .hero-mini-gallery { display: none; }
            .hero-floating-badge { top: 1rem; left: 1rem; font-size: 0.72rem; padding: 0.65rem 0.9rem; }
            .hero-caption-card { left: 0.8rem; right: 0.8rem; bottom: 0.8rem; }
            .hero-caption-title { font-size: 1.05rem; }
        }

        /* Upsell Checkbox */
        .upsell-box { transition: all 0.3s ease; }
        .upsell-box:hover { border-color: var(--brand-pink-dark); background-color: rgba(216, 167, 177, 0.1); }

        /* Validações do formulário */
        .form-input.input-error {
            border-color: #dc2626 !important;
            background-color: #fff7f7;
            box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.08);
        }
        .form-error {
            display: none;
            margin-top: 0.55rem;
            color: #991b1b;
            background: #fef2f2;
            border: 1px solid #fecaca;
            border-radius: 0.9rem;
            padding: 0.7rem 0.9rem;
            font-size: 0.78rem;
            line-height: 1.45;
        }
        .form-error.show { display: block; }
        .form-hint {
            font-size: 0.75rem;
            color: var(--brand-pink-dark);
            margin-top: 0.5rem;
            line-height: 1.4;
        }

        .location-type-option {
            border: 1px solid var(--brand-pink-light);
            border-radius: 1rem;
            padding: 0.85rem 1rem;
            background: white;
            font-size: 0.9rem;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.25s ease;
            text-align: center;
        }
        .location-type-option.active {
            border: 2px solid var(--brand-pink-dark);
            background: rgba(250, 218, 221, 0.45);
            box-shadow: 0 10px 24px rgba(216, 167, 177, 0.14);
        }
        .location-panel {
            display: none;
        }
        .location-panel.active {
            display: block;
        }

        /* Orçamento premium */
        .peca-option {
            border-color: var(--brand-pink-light);
            background: white;
            color: var(--brand-brown);
        }
        .peca-option.active {
            border: 2px solid var(--brand-pink-dark);
            background: rgba(250, 218, 221, 0.45);
            box-shadow: 0 12px 30px rgba(216, 167, 177, 0.18);
        }
        .prazo-alert {
            border-radius: 1rem;
            padding: 0.9rem 1rem;
            font-size: 0.88rem;
            line-height: 1.5;
            border: 1px solid transparent;
        }
        .prazo-ok { background: #EAF3DE; color: #3B6D11; border-color: #C0DD97; }
        .prazo-medio { background: #FEF3C7; color: #92400E; border-color: #FCD34D; }
        .prazo-urgente { background: #FCEBEB; color: #A32D2D; border-color: #F7C1C1; }
        .resumo-card-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 0.9rem;
        }
        @media (max-width: 640px) {
            .resumo-card-grid { grid-template-columns: 1fr; }
        }
        .resumo-label {
            font-size: 0.68rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            opacity: 0.58;
            margin-bottom: 0.15rem;
        }
        .resumo-value {
            font-weight: 600;
            color: var(--brand-brown);
        }


        /* Novas seções comerciais premium */
        .premium-card {
            background: white;
            border: 1px solid rgba(250, 218, 221, 0.8);
            border-radius: 1.5rem;
            box-shadow: 0 14px 40px rgba(74, 55, 40, 0.06);
            transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
        }
        .premium-card:hover {
            transform: translateY(-4px);
            box-shadow: 0 22px 55px rgba(216, 167, 177, 0.20);
            border-color: var(--brand-pink-dark);
        }
        .mini-label-premium {
            display: inline-flex;
            align-items: center;
            gap: 0.4rem;
            background: rgba(250, 218, 221, 0.42);
            color: var(--brand-brown);
            border: 1px solid rgba(216, 167, 177, 0.38);
            border-radius: 9999px;
            padding: 0.45rem 0.9rem;
            font-size: 0.7rem;
            font-weight: 700;
            letter-spacing: 0.08em;
            text-transform: uppercase;
        }
        .portfolio-whatsapp-cta {
            position: absolute;
            left: 1rem;
            right: 1rem;
            bottom: 1rem;
            z-index: 20;
            background: #25D366;
            color: white;
            padding: 0.72rem 0.9rem;
            border-radius: 9999px;
            font-size: 0.78rem;
            font-weight: 700;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 0.45rem;
            text-decoration: none;
            box-shadow: 0 10px 30px rgba(37, 211, 102, 0.35);
            opacity: 0;
            transform: translateY(8px);
            transition: opacity 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
        }
        .portfolio-card:hover .portfolio-whatsapp-cta,
        .portfolio-card:focus-within .portfolio-whatsapp-cta {
            opacity: 1;
            transform: translateY(0);
        }
        .portfolio-whatsapp-cta:hover {
            box-shadow: 0 14px 38px rgba(37, 211, 102, 0.50);
            transform: translateY(-2px);
        }
        @media (max-width: 768px) {
            .portfolio-whatsapp-cta {
                opacity: 1;
                transform: translateY(0);
                font-size: 0.72rem;
                padding: 0.62rem 0.75rem;
            }
        }
        .floating-whatsapp-smart {
            position: fixed;
            right: 1.35rem;
            bottom: 1.35rem;
            z-index: 9999;
            background: #25D366;
            color: white;
            border-radius: 9999px;
            padding: 0.85rem 1.05rem;
            display: flex;
            align-items: center;
            gap: 0.7rem;
            box-shadow: 0 14px 35px rgba(37, 211, 102, 0.42);
            text-decoration: none;
            transition: transform 0.25s ease, box-shadow 0.25s ease;
        }
        .floating-whatsapp-smart:hover {
            transform: translateY(-3px) scale(1.02);
            box-shadow: 0 18px 45px rgba(37, 211, 102, 0.58);
        }
        .floating-whatsapp-smart .float-icon {
            width: 42px;
            height: 42px;
            border-radius: 9999px;
            background: rgba(255,255,255,0.18);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }
        .floating-whatsapp-smart .float-title {
            display: block;
            font-size: 0.72rem;
            opacity: 0.86;
            line-height: 1.1;
        }
        .floating-whatsapp-smart .float-subtitle {
            display: block;
            font-size: 0.88rem;
            font-weight: 800;
            line-height: 1.15;
        }
        @media (max-width: 640px) {
            #back-to-top { right: 1rem; bottom: 6rem; }
            .floating-whatsapp-smart {
                left: 1rem;
                right: 1rem;
                bottom: 1rem;
                justify-content: center;
                padding: 0.78rem 1rem;
            }
        }

    

        /* =========================================================
           Versão Boutique Premium — refinamento visual geral
           ========================================================= */
        :root {
            --brand-rose-deep: #C98C9C;
            --brand-rose-soft: #F7E4E7;
            --brand-cream: #FFFDFC;
            --brand-gold-soft: #D7B98C;
            --brand-shadow: rgba(74, 55, 40, 0.10);
            --brand-shadow-strong: rgba(74, 55, 40, 0.18);
        }
        html { scroll-padding-top: 112px; }
        body {
            -webkit-font-smoothing: antialiased;
            text-rendering: geometricPrecision;
            line-height: 1.6;
            background:
                radial-gradient(circle at top left, rgba(250,218,221,0.44), transparent 32rem),
                radial-gradient(circle at 85% 20%, rgba(216,167,177,0.16), transparent 28rem),
                var(--brand-offwhite);
        }
        body::before {
            content: '';
            position: fixed;
            inset: 0;
            pointer-events: none;
            z-index: -1;
            background-image:
                linear-gradient(rgba(216,167,177,0.035) 1px, transparent 1px),
                linear-gradient(90deg, rgba(216,167,177,0.035) 1px, transparent 1px);
            background-size: 58px 58px;
            mask-image: linear-gradient(to bottom, rgba(0,0,0,0.75), transparent 82%);
        }
        ::selection { background: var(--brand-pink-light); color: var(--brand-brown); }

        /* Menu refinado */
        #navbar { padding-top: 1.05rem !important; padding-bottom: 1.05rem !important; }
        #navbar > .max-w-7xl {
            border: 1px solid rgba(216,167,177,0.34);
            background: rgba(255, 253, 252, 0.72);
            backdrop-filter: blur(18px);
            -webkit-backdrop-filter: blur(18px);
            border-radius: 9999px;
            padding: 0.78rem 0.95rem 0.78rem 1.2rem;
            box-shadow: 0 16px 44px rgba(74,55,40,0.08);
            transition: all 0.35s ease;
        }
        #navbar.bg-white > .max-w-7xl,
        #navbar.nav-scrolled > .max-w-7xl {
            background: rgba(255, 255, 255, 0.92);
            border-color: rgba(216,167,177,0.52);
            box-shadow: 0 20px 55px rgba(74,55,40,0.12);
        }
        #navbar a.text-2xl,
        #navbar a.text-3xl { letter-spacing: -0.03em; position: relative; padding-left: 0.15rem; }
        #navbar a.text-2xl::after,
        #navbar a.text-3xl::after {
            content: 'atelier'; display: inline-flex; align-items: center; margin-left: 0.45rem; transform: translateY(-0.18rem);
            font-family: 'Montserrat', sans-serif; font-style: normal; font-size: 0.55rem; letter-spacing: 0.16em; text-transform: uppercase;
            color: var(--brand-pink-dark); border: 1px solid rgba(216,167,177,0.4); border-radius: 999px; padding: 0.16rem 0.42rem; background: rgba(250,218,221,0.36);
        }
        #navbar .hidden.md\:flex a:not(:last-child) { position: relative; padding: 0.45rem 0; }
        #navbar .hidden.md\:flex a:not(:last-child)::after {
            content: ''; position: absolute; left: 0; right: 0; bottom: 0.18rem; height: 1px; background: var(--brand-pink-dark);
            transform: scaleX(0); transform-origin: center; transition: transform 0.25s ease; opacity: 0.85;
        }
        #navbar .hidden.md\:flex a:not(:last-child):hover::after { transform: scaleX(1); }
        #navbar .hidden.md\:flex a:last-child {
            background: linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep));
            box-shadow: 0 12px 28px rgba(216,167,177,0.36); border: 1px solid rgba(255,255,255,0.42); transition: all 0.28s ease;
        }
        #navbar .hidden.md\:flex a:last-child:hover { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(216,167,177,0.44); }
        #mobile-menu-toggle {
            width: 44px; height: 44px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center;
            background: rgba(250,218,221,0.42); border: 1px solid rgba(216,167,177,0.44);
        }
        #mobile-menu { background: radial-gradient(circle at 20% 15%, rgba(250,218,221,0.9), transparent 18rem), linear-gradient(145deg, #FFFDFC 0%, #FAF9F6 100%) !important; }
        #mobile-menu a:not(.button-primary) {
            width: min(100%, 320px); text-align: center; border: 1px solid rgba(216,167,177,0.32); border-radius: 999px; padding: 0.8rem 1rem;
            background: rgba(255,255,255,0.72); box-shadow: 0 10px 28px rgba(74,55,40,0.05);
        }

        /* Botões padronizados */
        .button-primary, button.button-primary, a.button-primary {
            background: linear-gradient(135deg, var(--brand-pink-dark) 0%, var(--brand-rose-deep) 100%) !important; color: white !important;
            border: 1px solid rgba(255,255,255,0.42); box-shadow: 0 16px 34px rgba(216,167,177,0.34), inset 0 1px 0 rgba(255,255,255,0.25);
            letter-spacing: 0.01em; position: relative; overflow: hidden;
        }
        .button-primary::before, .hero-secondary-link::before, .portfolio-whatsapp-cta::before {
            content: ''; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.28) 38%, transparent 72%);
            transform: translateX(-120%); transition: transform 0.7s ease;
        }
        .button-primary:hover::before, .hero-secondary-link:hover::before, .portfolio-whatsapp-cta:hover::before { transform: translateX(120%); }
        .button-primary:hover { opacity: 1 !important; transform: translateY(-3px); box-shadow: 0 22px 46px rgba(216,167,177,0.45), inset 0 1px 0 rgba(255,255,255,0.3); }
        .button-outline, .hero-secondary-link {
            background: rgba(255,255,255,0.82) !important; color: var(--brand-brown) !important; border: 1px solid rgba(216,167,177,0.5) !important;
            box-shadow: 0 14px 32px rgba(74,55,40,0.07); position: relative; overflow: hidden;
        }
        .button-outline:hover, .hero-secondary-link:hover { background: #fff !important; color: var(--brand-rose-deep) !important; border-color: var(--brand-pink-dark) !important; }

        /* Seções com identidade mais consistente */
        .section-padding { position: relative; }
        .section-padding h2 { letter-spacing: -0.035em; }
        .section-padding > .max-w-7xl, .section-padding > .max-w-5xl, .section-padding > .max-w-3xl { position: relative; z-index: 1; }
        .mini-label-premium, #orcamento .inline-flex.items-center.gap-2.bg-white { box-shadow: 0 12px 26px rgba(216,167,177,0.13); background: rgba(255,255,255,0.76) !important; backdrop-filter: blur(12px); }
        #incluso, #duvidas-encomenda { background: radial-gradient(circle at 8% 20%, rgba(250,218,221,0.36), transparent 22rem), #fff !important; }
        #depoimentos, #como-tirar-medidas, #orcamento { background: radial-gradient(circle at 80% 12%, rgba(216,167,177,0.22), transparent 26rem), radial-gradient(circle at 12% 92%, rgba(250,218,221,0.38), transparent 24rem), var(--brand-offwhite) !important; }

        /* Cards premium */
        .premium-card, #como-funciona .rounded-3xl.bg-\[var\(--brand-offwhite\)\], #como-tirar-medidas .premium-card {
            border: 1px solid rgba(216,167,177,0.32) !important; background: rgba(255,255,255,0.86) !important; backdrop-filter: blur(10px); box-shadow: 0 18px 46px rgba(74,55,40,0.075);
        }
        .premium-card { position: relative; overflow: hidden; }
        .premium-card::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(140deg, rgba(255,255,255,0.42), transparent 34%); opacity: 0; transition: opacity 0.3s ease; }
        .premium-card:hover::after { opacity: 1; }
        .premium-card:hover { transform: translateY(-6px); box-shadow: 0 26px 64px rgba(216,167,177,0.22); }

        /* Portfólio mais bonito */
        #portfolio { background: linear-gradient(180deg, var(--brand-offwhite), #fff 48%, var(--brand-offwhite)); }
        #portfolio-filters {
            position: sticky; top: 5.8rem; z-index: 20; padding: 0.65rem; margin-left: auto; margin-right: auto; width: fit-content; max-width: 100%;
            border-radius: 9999px; background: rgba(255,255,255,0.75); backdrop-filter: blur(14px); box-shadow: 0 16px 42px rgba(74,55,40,0.08); border: 1px solid rgba(216,167,177,0.24);
        }
        .filter-btn { background: rgba(255,255,255,0.72) !important; border: 1px solid rgba(216,167,177,0.48) !important; box-shadow: 0 8px 18px rgba(74,55,40,0.04); color: var(--brand-rose-deep) !important; transition: all 0.24s ease !important; }
        .filter-btn:hover, .filter-btn.active-filter { background: linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep)) !important; color: white !important; transform: translateY(-1px); box-shadow: 0 12px 24px rgba(216,167,177,0.28); }
        .portfolio-card { border-radius: 1.55rem !important; border: 1px solid rgba(216,167,177,0.32); box-shadow: 0 18px 48px rgba(74,55,40,0.10) !important; background: #fff; isolation: isolate; transition: transform 0.34s ease, box-shadow 0.34s ease, border-color 0.34s ease; }
        .portfolio-card:hover { transform: translateY(-5px); border-color: rgba(216,167,177,0.78); box-shadow: 0 28px 70px rgba(74,55,40,0.16) !important; }
        .portfolio-card img { transition: transform 0.85s ease, filter 0.85s ease !important; }
        .portfolio-card:hover img { transform: scale(1.065) !important; filter: saturate(1.06) contrast(1.03); }
        .portfolio-card .absolute.inset-0.bg-gradient-to-t { background: linear-gradient(to top, rgba(74,55,40,0.66), rgba(74,55,40,0.08) 58%, transparent 100%) !important; }
        .portfolio-card .absolute.bottom-0 { z-index: 12; text-shadow: 0 2px 12px rgba(0,0,0,0.24); }
        .portfolio-whatsapp-cta { background: linear-gradient(135deg, #25D366, #159B4F) !important; border: 1px solid rgba(255,255,255,0.38); }
        .portfolio-magazine { gap: 1.25rem; }

        /* Orçamento com visual premium */
        #orcamento > .max-w-5xl > .bg-white { border-radius: 2.2rem !important; border: 1px solid rgba(216,167,177,0.42) !important; box-shadow: 0 30px 90px rgba(74,55,40,0.14) !important; overflow: hidden; background: rgba(255,255,255,0.94) !important; }
        #orcamento > .max-w-5xl > .bg-white > div:first-child { background: radial-gradient(circle at 16% 20%, rgba(255,255,255,0.26), transparent 12rem), linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep)) !important; }
        #form-orcamento { background: radial-gradient(circle at 100% 0%, rgba(250,218,221,0.28), transparent 18rem), linear-gradient(180deg, #fff, #fffdfc); }
        .form-input { min-height: 50px; border-radius: 1rem !important; border-color: rgba(216,167,177,0.55) !important; box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 10px 24px rgba(74,55,40,0.035); }
        .form-input:focus { border-color: var(--brand-rose-deep) !important; box-shadow: 0 0 0 4px rgba(216,167,177,0.16), 0 12px 28px rgba(74,55,40,0.055); }
        .peca-option, .location-type-option, .upsell-box { border-radius: 1.2rem !important; border: 1px solid rgba(216,167,177,0.46) !important; box-shadow: 0 12px 26px rgba(74,55,40,0.045); }
        .peca-option:hover, .location-type-option:hover, .upsell-box:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(216,167,177,0.15); }
        .peca-option.active, .location-type-option.active { background: linear-gradient(135deg, rgba(250,218,221,0.72), rgba(255,255,255,0.92)) !important; border-color: var(--brand-rose-deep) !important; }
        .prazo-alert, .form-error, .resumo-card-grid > div { box-shadow: 0 12px 28px rgba(74,55,40,0.045); }

        /* Depoimentos mais elegantes */
        #depoimentos .premium-card { min-height: 100%; padding-top: 2.25rem !important; }
        #depoimentos .premium-card::before { content: '“'; position: absolute; top: -0.45rem; right: 1.5rem; font-family: 'Playfair Display', serif; font-size: 6rem; line-height: 1; color: rgba(216,167,177,0.18); pointer-events: none; }
        #depoimentos .tracking-tight { letter-spacing: 0.08em; color: #C8912E !important; }



        /* Ícones de contato no topo e rodapé */
        .nav-contact-icons {
            display: inline-flex;
            align-items: center;
            gap: 0.45rem;
            padding: 0.25rem 0.4rem;
            border-radius: 999px;
            background: rgba(255,255,255,0.62);
            border: 1px solid rgba(216,167,177,0.28);
            box-shadow: 0 10px 26px rgba(74,55,40,0.055);
        }
        .nav-contact-icon {
            width: 34px;
            height: 34px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            font-size: 1rem;
            line-height: 1;
            background: #fff;
            border: 1px solid rgba(216,167,177,0.34);
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.75), 0 8px 18px rgba(74,55,40,0.055);
            transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, background 0.24s ease;
            text-decoration: none;
        }
        .nav-contact-icon:hover {
            transform: translateY(-2px);
            box-shadow: 0 14px 28px rgba(216,167,177,0.24);
            border-color: rgba(216,167,177,0.78);
            background: rgba(250,218,221,0.5);
        }
        .nav-contact-icon.whatsapp { border-color: rgba(37,211,102,0.28); background: rgba(37,211,102,0.08); }
        .nav-contact-icon.instagram { background: rgba(216,167,177,0.12); }
        .nav-contact-icon.gmail { background: rgba(234,67,53,0.08); border-color: rgba(234,67,53,0.18); }

        .mobile-social-icons {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 0.85rem;
            width: 100%;
            margin-top: 0.25rem;
            padding-top: 1rem;
            border-top: 1px solid rgba(216,167,177,0.28);
        }
        .mobile-social-icons a {
            width: 48px;
            height: 48px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: rgba(250,218,221,0.32);
            border: 1px solid rgba(216,167,177,0.36);
            box-shadow: 0 12px 26px rgba(74,55,40,0.07);
            font-size: 1.25rem;
            text-decoration: none;
        }

        .contact-social-list { gap: 0.75rem !important; }
        .contact-social-card {
            display: flex;
            align-items: center;
            gap: 0.85rem;
            padding: 0.85rem 0.95rem;
            border-radius: 1.1rem;
            background: rgba(255,255,255,0.72);
            border: 1px solid rgba(216,167,177,0.28);
            color: rgba(74,55,40,0.82);
            box-shadow: 0 12px 28px rgba(74,55,40,0.045);
            transition: all 0.24s ease;
            text-decoration: none;
        }
        .contact-social-card:hover {
            transform: translateY(-2px);
            border-color: rgba(216,167,177,0.65);
            box-shadow: 0 18px 36px rgba(216,167,177,0.18);
            color: var(--brand-brown);
        }
        .contact-social-icon {
            width: 42px;
            height: 42px;
            flex: 0 0 42px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: rgba(250,218,221,0.38);
            border: 1px solid rgba(216,167,177,0.35);
            font-size: 1.25rem;
        }
        .contact-social-card strong { display: block; font-size: 0.9rem; }
        .contact-social-card small { display: block; margin-top: 0.1rem; opacity: 0.65; font-size: 0.78rem; line-height: 1.25; }
        .contact-social-icon.whatsapp { background: rgba(37,211,102,0.10); border-color: rgba(37,211,102,0.24); }
        .contact-social-icon.instagram { background: rgba(216,167,177,0.18); }
        .contact-social-icon.gmail { background: rgba(234,67,53,0.08); border-color: rgba(234,67,53,0.18); }

        .nav-contact-icon::after, .mobile-social-icons a::after { display: none !important; }
        #mobile-menu .mobile-social-icons a { width: 48px !important; max-width: 48px !important; height: 48px !important; padding: 0 !important; border-radius: 999px !important; }
        .social-svg { display: block; width: 19px; height: 19px; }
        .mobile-social-icons .social-svg { width: 24px; height: 24px; }
        .contact-social-icon .social-svg { width: 22px; height: 22px; }
        .nav-contact-icon.whatsapp svg, .mobile-social-icons .whatsapp svg, .contact-social-icon.whatsapp svg { color: #25D366; }
        .nav-contact-icon.instagram svg, .mobile-social-icons .instagram svg, .contact-social-icon.instagram svg { color: #E1306C; }
        .nav-contact-icon.gmail svg, .mobile-social-icons .gmail svg, .contact-social-icon.gmail svg { color: #EA4335; }
        .nav-contact-icon.whatsapp, .mobile-social-icons a.whatsapp, .contact-social-icon.whatsapp { background: rgba(37,211,102,0.10) !important; border-color: rgba(37,211,102,0.28) !important; }
        .nav-contact-icon.instagram, .mobile-social-icons a.instagram, .contact-social-icon.instagram { background: linear-gradient(135deg, rgba(250,218,221,0.55), rgba(255,255,255,0.72)) !important; border-color: rgba(225,48,108,0.22) !important; }
        .nav-contact-icon.gmail, .mobile-social-icons a.gmail, .contact-social-icon.gmail { background: rgba(234,67,53,0.08) !important; border-color: rgba(234,67,53,0.22) !important; }

        /* Rodapé novo */
        .footer-premium { position: relative; overflow: hidden; background: radial-gradient(circle at 18% 10%, rgba(250,218,221,0.46), transparent 26rem), linear-gradient(135deg, #FFFDFC 0%, #FAF9F6 52%, #F7E4E7 100%); border-top: 1px solid rgba(216,167,177,0.38); }
        .footer-premium::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(216,167,177,0.055) 1px, transparent 1px), linear-gradient(90deg, rgba(216,167,177,0.055) 1px, transparent 1px); background-size: 64px 64px; mask-image: linear-gradient(to top, rgba(0,0,0,0.65), transparent 70%); pointer-events: none; }
        .footer-card { background: rgba(255,255,255,0.72); border: 1px solid rgba(216,167,177,0.34); border-radius: 1.6rem; box-shadow: 0 18px 46px rgba(74,55,40,0.08); backdrop-filter: blur(12px); }
        .footer-link { display: inline-flex; align-items: center; gap: 0.5rem; color: rgba(74,55,40,0.72); transition: all 0.24s ease; }
        .footer-link:hover { color: var(--brand-rose-deep); transform: translateX(3px); }

        /* Animações suaves e mobile */
        @keyframes softPop { from { opacity: 0; transform: translateY(14px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
        .hero-copy-card, .hero-carousel-shell { animation: softPop 0.8s ease both; }
        .hero-carousel-shell { animation-delay: 0.12s; }
        @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: 0.001ms !important; } }
        @media (max-width: 768px) {
            html { scroll-padding-top: 92px; }
            #navbar { padding: 0.75rem 0.85rem !important; }
            #navbar > .max-w-7xl { border-radius: 1.25rem; padding: 0.75rem 0.85rem; }
            #navbar a.text-2xl::after, #navbar a.text-3xl::after { display: none; }
            .section-padding { padding: 4.25rem 1rem; }
            .section-padding h2 { line-height: 1.08; }
            .hero-premium { padding-top: 8.25rem !important; }
            .hero-stats { gap: 0.55rem; }
            .hero-stat-pill { width: 100%; text-align: center; }
            #portfolio-filters { position: relative; top: auto; border-radius: 1.25rem; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; width: 100%; padding: 0.65rem; scroll-snap-type: x mandatory; }
            #portfolio-filters .filter-btn { flex: 0 0 auto; scroll-snap-align: start; }
            #portfolio-grid { gap: 1.25rem !important; }
            .portfolio-magazine { gap: 1.25rem; }
            #orcamento > .max-w-5xl > .bg-white { border-radius: 1.55rem !important; }
            #form-orcamento { padding: 1.25rem !important; }
            .button-primary, .button-outline, .hero-secondary-link { width: 100%; justify-content: center; }
            .footer-card { border-radius: 1.25rem; }
            .floating-whatsapp-smart { box-shadow: 0 14px 34px rgba(37,211,102,0.36); }
        }

    
        /* =========================================================
           Boutique Premium V2 — alinhamento visual do site inteiro
           ========================================================= */
        :root {
            --premium-ink: #3f2d22;
            --premium-muted: rgba(74, 55, 40, 0.68);
            --premium-glass: rgba(255, 255, 255, 0.78);
            --premium-border: rgba(216, 167, 177, 0.34);
            --premium-glow: rgba(216, 167, 177, 0.20);
        }

        .hero-slide { z-index: 0; }
        .hero-slide.active { z-index: 1; }
        .hero-carousel { isolation: isolate; }
        .hero-carousel-progress {
            position: absolute;
            left: 1.2rem;
            right: 1.2rem;
            top: 1.12rem;
            height: 3px;
            border-radius: 999px;
            background: rgba(255,255,255,0.56);
            z-index: 6;
            overflow: hidden;
            box-shadow: 0 8px 18px rgba(74,55,40,0.10);
        }
        .hero-carousel-progress span {
            display: block;
            height: 100%;
            width: 0%;
            border-radius: inherit;
            background: linear-gradient(90deg, #fff, var(--brand-pink-dark));
        }
        .hero-carousel-progress.running span { animation: heroProgress 5.2s linear forwards; }
        @keyframes heroProgress { from { width: 0%; } to { width: 100%; } }

        #hero + div {
            margin-top: -1px;
            background: rgba(255, 255, 255, 0.76) !important;
            backdrop-filter: blur(16px);
            border-top: 1px solid rgba(216,167,177,0.30) !important;
            border-bottom: 1px solid rgba(216,167,177,0.30) !important;
            box-shadow: 0 18px 48px rgba(74,55,40,0.06);
        }
        #hero + div .max-w-7xl > div {
            background: rgba(255,255,255,0.54);
            border: 1px solid rgba(216,167,177,0.25);
            border-radius: 999px;
            padding: 0.55rem 0.85rem;
            box-shadow: 0 10px 28px rgba(74,55,40,0.04);
        }

        section.section-padding:not(#hero) {
            overflow: hidden;
            isolation: isolate;
        }
        section.section-padding:not(#hero)::before {
            content: '';
            position: absolute;
            inset: 0;
            z-index: 0;
            pointer-events: none;
            background:
                radial-gradient(circle at 8% 18%, rgba(250,218,221,0.42), transparent 23rem),
                radial-gradient(circle at 92% 20%, rgba(216,167,177,0.15), transparent 26rem),
                radial-gradient(circle at 50% 100%, rgba(255,255,255,0.80), transparent 24rem);
            opacity: 0.95;
        }
        section.section-padding:not(#hero) > * { position: relative; z-index: 1; }
        #como-funciona, #incluso, #duvidas-encomenda, #sobre, #faq, #guia-medidas {
            background: linear-gradient(180deg, #FFFDFC 0%, #FAF9F6 100%) !important;
        }
        #portfolio, #depoimentos, #como-tirar-medidas, #orcamento {
            background: linear-gradient(180deg, #FAF9F6 0%, #FFFDFC 48%, #F7E4E7 100%) !important;
        }

        section.section-padding:not(#hero) .text-center.mb-12,
        section.section-padding:not(#hero) .text-center.mb-16 {
            background: rgba(255,255,255,0.58);
            border: 1px solid rgba(216,167,177,0.22);
            border-radius: 2rem;
            padding: clamp(1.35rem, 3vw, 2.4rem);
            box-shadow: 0 18px 48px rgba(74,55,40,0.055);
            backdrop-filter: blur(14px);
        }
        section.section-padding:not(#hero) h2 {
            color: var(--premium-ink);
            text-wrap: balance;
        }
        section.section-padding:not(#hero) p {
            color: var(--premium-muted);
        }
        .mini-label-premium {
            color: var(--premium-ink) !important;
            background: linear-gradient(135deg, rgba(250,218,221,0.72), rgba(255,255,255,0.82)) !important;
            box-shadow: 0 12px 26px rgba(216,167,177,0.13) !important;
        }

        .premium-card,
        #como-funciona .grid > div,
        #sobre .rounded-2xl,
        .faq-item,
        #guia-medidas .relative.bg-\[var\(--brand-offwhite\)\] {
            border: 1px solid var(--premium-border) !important;
            background: rgba(255,255,255,0.82) !important;
            backdrop-filter: blur(14px);
            box-shadow: 0 20px 55px rgba(74,55,40,0.08) !important;
            border-radius: 1.75rem !important;
        }
        .premium-card,
        #como-funciona .grid > div,
        .faq-item {
            transition: transform 0.32s ease, box-shadow 0.32s ease, border-color 0.32s ease;
        }
        .premium-card:hover,
        #como-funciona .grid > div:hover,
        .faq-item:hover {
            transform: translateY(-5px);
            border-color: rgba(216,167,177,0.72) !important;
            box-shadow: 0 28px 75px rgba(216,167,177,0.22) !important;
        }

        #como-funciona .bg-\[var\(--brand-pink-light\)\].bg-opacity-30,
        #como-tirar-medidas .bg-white.rounded-3xl,
        #sobre .absolute.-bottom-6,
        #resumo-pedido {
            background: linear-gradient(135deg, rgba(250,218,221,0.72), rgba(255,255,255,0.86)) !important;
            border: 1px solid rgba(216,167,177,0.36) !important;
            box-shadow: 0 18px 46px rgba(74,55,40,0.08) !important;
            backdrop-filter: blur(12px);
        }

        #portfolio .portfolio-card {
            overflow: hidden;
            border-radius: 1.85rem !important;
            background: #fff !important;
        }
        #portfolio .portfolio-card::before {
            content: '';
            position: absolute;
            inset: 0;
            z-index: 11;
            pointer-events: none;
            background: linear-gradient(to top, rgba(74,55,40,0.72), rgba(74,55,40,0.08) 48%, transparent 72%);
            opacity: 1;
        }
        #portfolio .portfolio-card .absolute.bottom-0 {
            opacity: 1 !important;
            transform: translateY(0) !important;
            z-index: 14;
        }
        #portfolio .portfolio-card .absolute.inset-0.bg-gradient-to-t {
            opacity: 0 !important;
        }
        #portfolio .portfolio-card h3 {
            text-shadow: 0 4px 20px rgba(0,0,0,0.24);
        }
        #portfolio .portfolio-whatsapp-cta {
            opacity: 0;
            z-index: 18;
            bottom: 1.05rem;
            left: 1.05rem;
            right: 1.05rem;
        }
        #portfolio .portfolio-card:hover .portfolio-whatsapp-cta,
        #portfolio .portfolio-card:focus-within .portfolio-whatsapp-cta {
            opacity: 1;
        }
        #portfolio-filters {
            border-radius: 1.4rem !important;
        }

        #depoimentos .premium-card {
            background:
                linear-gradient(145deg, rgba(255,255,255,0.88), rgba(255,253,252,0.72)),
                radial-gradient(circle at 100% 0%, rgba(250,218,221,0.55), transparent 12rem) !important;
        }
        #duvidas-encomenda .premium-card,
        .faq-item {
            box-shadow: 0 16px 42px rgba(74,55,40,0.06) !important;
        }
        #duvidas-encomenda .premium-card h3::before {
            content: '✦';
            display: inline-flex;
            margin-right: 0.45rem;
            color: var(--brand-pink-dark);
        }

        #orcamento > .max-w-5xl > .bg-white {
            background: rgba(255,255,255,0.86) !important;
            backdrop-filter: blur(18px);
        }
        #orcamento .step-indicator > div {
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.35), 0 8px 20px rgba(74,55,40,0.12);
        }
        .peca-option,
        .location-type-option,
        .upsell-box {
            background: rgba(255,255,255,0.76) !important;
        }
        .peca-option.active,
        .location-type-option.active {
            box-shadow: 0 18px 42px rgba(216,167,177,0.22) !important;
        }

        #sobre img {
            filter: saturate(0.92) contrast(1.02);
        }
        #faq .faq-content {
            background: rgba(255,255,255,0.52) !important;
        }
        .counter-num {
            text-shadow: 0 10px 28px rgba(216,167,177,0.28);
        }
        section:has(.counter-num) {
            background: linear-gradient(135deg, rgba(250,218,221,0.54), rgba(255,255,255,0.78)) !important;
        }
        section:has(.counter-num) .max-w-7xl {
            background: rgba(255,255,255,0.62);
            border: 1px solid rgba(216,167,177,0.28);
            border-radius: 2rem;
            padding: clamp(1.5rem, 4vw, 2.75rem);
            box-shadow: 0 20px 55px rgba(74,55,40,0.07);
            backdrop-filter: blur(14px);
        }

        @media (max-width: 768px) {
            #hero + div .max-w-7xl > div { border-radius: 1.1rem; width: 100%; justify-content: flex-start; }
            section.section-padding:not(#hero) .text-center.mb-12,
            section.section-padding:not(#hero) .text-center.mb-16 { border-radius: 1.35rem; padding: 1.15rem; }
            .premium-card, #como-funciona .grid > div, .faq-item { border-radius: 1.35rem !important; }
            #portfolio .portfolio-whatsapp-cta { opacity: 1; }
            #portfolio .portfolio-card .absolute.bottom-0 { padding-bottom: 4.55rem !important; }
            #portfolio-filters { border-radius: 1.1rem !important; }
            #orcamento .grid { gap: 1rem; }
        }

    

        /* =========================================================
           Otimização Mobile Pro — hero visível, seções mais limpas
           ========================================================= */
        img { max-width: 100%; }
        body { overflow-x: hidden; }

        @media (max-width: 900px) {
            .nav-social-icons { display: none !important; }
        }

        @media (max-width: 768px) {
            html { scroll-padding-top: 92px; }
            body { font-size: 15px; }

            #promo-bar {
                padding: 0.55rem 2.2rem 0.55rem 0.85rem !important;
                font-size: 0.68rem !important;
                line-height: 1.35;
                letter-spacing: 0.03em;
            }
            #promo-text { gap: 0.35rem !important; }
            #promo-close { right: 0.65rem !important; }

            #navbar {
                top: 0.45rem;
                padding: 0 0.75rem !important;
            }
            #navbar > .max-w-7xl {
                border-radius: 1.25rem !important;
                padding: 0.7rem 0.8rem !important;
            }
            #navbar a.text-2xl,
            #navbar a.text-3xl {
                font-size: 1.35rem !important;
                line-height: 1;
                max-width: 70vw;
                white-space: nowrap;
            }
            #mobile-menu {
                padding: 5.5rem 1.25rem 2rem !important;
                gap: 1.25rem !important;
            }
            #mobile-menu a:not(.button-primary):not(.whatsapp):not(.instagram):not(.gmail) {
                width: 100%;
                text-align: center;
                padding: 0.85rem 1rem;
                border-radius: 1rem;
                background: rgba(250, 218, 221, 0.22);
                border: 1px solid rgba(216, 167, 177, 0.22);
            }
            .mobile-social-icons {
                margin: 0.4rem 0 0.2rem;
                justify-content: center;
            }

            /* Hero: imagem aparece primeiro no celular */
            .hero-premium {
                min-height: auto !important;
                padding: 7.75rem 1rem 3.25rem !important;
                display: block !important;
            }
            .hero-premium > .max-w-7xl {
                display: flex !important;
                flex-direction: column !important;
                gap: 1.35rem !important;
            }
            .hero-carousel-shell {
                order: -1;
                width: 100%;
                max-width: 430px !important;
                margin: 0 auto 0.35rem !important;
            }
            .hero-carousel {
                width: 100% !important;
                height: clamp(355px, 112vw, 500px) !important;
                min-height: 355px !important;
                aspect-ratio: auto !important;
                border-width: 6px !important;
                border-radius: 1.45rem !important;
                background: var(--brand-pink-light) !important;
            }
            .hero-slide {
                display: block !important;
                visibility: visible !important;
                width: 100% !important;
                height: 100% !important;
                object-fit: cover !important;
                object-position: center center !important;
            }
            .hero-dots {
                top: 0.72rem !important;
                right: 0.72rem !important;
                padding: 0.38rem !important;
            }
            .hero-carousel-progress {
                left: 0.85rem !important;
                right: 5.4rem !important;
                top: 0.98rem !important;
            }
            .hero-floating-badge {
                top: auto !important;
                left: 0.8rem !important;
                bottom: 6.25rem !important;
                font-size: 0.66rem !important;
                padding: 0.52rem 0.75rem !important;
                max-width: calc(100% - 1.6rem);
            }
            .hero-caption-card {
                left: 0.75rem !important;
                right: 0.75rem !important;
                bottom: 0.75rem !important;
                border-radius: 1.05rem !important;
                padding: 0.75rem 0.85rem !important;
            }
            .hero-caption-kicker {
                font-size: 0.58rem !important;
                letter-spacing: 0.12em !important;
            }
            .hero-caption-title {
                font-size: 0.98rem !important;
            }
            .hero-mini-gallery { display: none !important; }

            .hero-copy-card {
                order: 2;
                text-align: center;
            }
            .hero-copy-card .inline-flex {
                justify-content: center;
                width: 100%;
                font-size: 0.76rem;
                padding: 0.62rem 0.75rem;
            }
            .hero-copy-card h1 {
                font-size: clamp(2.25rem, 11vw, 3.45rem) !important;
                line-height: 0.96 !important;
                letter-spacing: -0.04em;
                margin-top: 0.25rem;
            }
            .hero-copy-card p {
                font-size: 0.98rem !important;
                line-height: 1.65 !important;
                margin-left: auto;
                margin-right: auto;
            }
            .hero-stats {
                display: grid !important;
                grid-template-columns: 1fr !important;
                gap: 0.55rem !important;
            }
            .hero-stat-pill {
                width: 100%;
                text-align: center;
                padding: 0.62rem 0.75rem !important;
                font-size: 0.74rem !important;
            }
            .hero-actions {
                display: grid !important;
                grid-template-columns: 1fr !important;
                gap: 0.7rem !important;
            }
            .hero-actions .button-primary,
            .hero-secondary-link {
                width: 100% !important;
                justify-content: center !important;
                min-height: 50px;
                padding: 0.92rem 1rem !important;
            }

            /* Seções: mesmo estilo premium, mas mais respirável no celular */
            .section-padding {
                padding: 3.6rem 1rem !important;
            }
            section.section-padding:not(#hero) .text-center.mb-12,
            section.section-padding:not(#hero) .text-center.mb-16 {
                padding: 1rem !important;
                border-radius: 1.25rem !important;
                margin-bottom: 2rem !important;
            }
            section.section-padding:not(#hero) h2 {
                font-size: clamp(2rem, 9.5vw, 2.75rem) !important;
                line-height: 1.03 !important;
                letter-spacing: -0.03em;
            }
            section.section-padding:not(#hero) p {
                font-size: 0.94rem;
            }
            .premium-card,
            .portfolio-card,
            .faq-item,
            .footer-card {
                border-radius: 1.25rem !important;
            }
            .premium-card { padding: 1.15rem !important; }

            /* Portfólio mobile */
            #portfolio-filters {
                position: relative;
                top: auto;
                display: flex !important;
                flex-wrap: nowrap !important;
                justify-content: flex-start !important;
                overflow-x: auto;
                -webkit-overflow-scrolling: touch;
                gap: 0.55rem !important;
                width: 100%;
                padding: 0.65rem !important;
                border-radius: 1.2rem !important;
                scroll-snap-type: x proximity;
            }
            #portfolio-filters::-webkit-scrollbar { display: none; }
            #portfolio-filters .filter-btn {
                flex: 0 0 auto;
                scroll-snap-align: start;
                white-space: nowrap;
                font-size: 0.75rem !important;
                padding: 0.58rem 0.9rem !important;
            }
            .portfolio-magazine {
                grid-template-columns: 1fr !important;
                height: auto !important;
                gap: 1rem !important;
            }
            .portfolio-magazine .portfolio-card,
            #portfolio-grid .portfolio-card {
                min-height: auto;
            }
            .portfolio-magazine .portfolio-card > div:first-child,
            #portfolio-grid .portfolio-card > div:first-child {
                aspect-ratio: 3 / 4 !important;
            }
            #portfolio-grid {
                grid-template-columns: 1fr !important;
                gap: 1.1rem !important;
                margin-bottom: 2.5rem !important;
            }
            .portfolio-whatsapp-cta {
                opacity: 1 !important;
                transform: translateY(0) !important;
                left: 0.75rem !important;
                right: 0.75rem !important;
                bottom: 0.75rem !important;
                font-size: 0.72rem !important;
                padding: 0.64rem 0.75rem !important;
            }

            /* Formulário e orçamento */
            #orcamento > .max-w-5xl,
            #orcamento > .max-w-4xl,
            #orcamento > .max-w-3xl {
                max-width: 100% !important;
            }
            #orcamento .bg-\[var\(--brand-pink-dark\)\],
            #orcamento .bg-white {
                border-radius: 1.35rem !important;
            }
            #form-orcamento {
                padding: 1.15rem !important;
            }
            .form-input,
            select.form-input,
            textarea.form-input {
                min-height: 48px;
                font-size: 16px !important; /* evita zoom automático no iPhone */
            }
            .resumo-card-grid {
                grid-template-columns: 1fr !important;
            }
            .peca-option,
            .location-type-option,
            .upsell-box {
                min-height: 54px;
            }

            /* Rodapé/contatos */
            .contact-social-row,
            .footer-card .grid,
            footer .grid {
                gap: 1rem !important;
            }
            .contact-social,
            .footer-link {
                padding: 0.75rem 0;
            }

            .floating-whatsapp-smart {
                left: 0.9rem !important;
                right: 0.9rem !important;
                bottom: 0.9rem !important;
                justify-content: center;
                padding: 0.72rem 0.9rem !important;
                border-radius: 1.15rem !important;
            }
            .floating-whatsapp-smart .float-icon {
                width: 36px !important;
                height: 36px !important;
            }
            .floating-whatsapp-smart .float-title { font-size: 0.66rem !important; }
            .floating-whatsapp-smart .float-subtitle { font-size: 0.8rem !important; }
            #back-to-top { display: none !important; }
        }

        @media (max-width: 380px) {
            .hero-carousel {
                height: 350px !important;
                min-height: 350px !important;
            }
            .hero-copy-card h1 {
                font-size: 2.08rem !important;
            }
            .hero-caption-card { padding: 0.68rem 0.75rem !important; }
            .hero-floating-badge { display: none !important; }
        }

    
        /* Guia de medidas — premium frontal/lateral */
        @keyframes measure-card-in {
            0% { opacity: 0; transform: translateY(14px) scale(0.985); }
            100% { opacity: 1; transform: translateY(0) scale(1); }
        }
        .measure-card-animate {
            animation: measure-card-in 0.4s ease;
        }
        .measure-guide-wrap {
            position: relative;
            background:
                radial-gradient(circle at top left, rgba(250, 218, 221, 0.9), rgba(250, 218, 221, 0) 34%),
                linear-gradient(160deg, rgba(255,255,255,0.95), rgba(250,249,246,0.94));
            border-radius: 2rem;
            padding: 1.5rem;
            border: 1px solid rgba(216,167,177,0.25);
            box-shadow: 0 22px 55px rgba(74,55,40,0.08);
            overflow: hidden;
        }
        .measure-guide-wrap::before {
            content: '';
            position: absolute;
            inset: 0;
            background-image:
                linear-gradient(rgba(216, 167, 177, 0.05) 1px, transparent 1px),
                linear-gradient(90deg, rgba(216, 167, 177, 0.05) 1px, transparent 1px);
            background-size: 52px 52px;
            mask-image: linear-gradient(to bottom, rgba(0,0,0,0.6), transparent 90%);
            pointer-events: none;
        }
        .measure-stage-meta {
            position: relative;
            z-index: 2;
            display: flex;
            gap: 0.65rem;
            flex-wrap: wrap;
            margin-bottom: 1rem;
        }
        .measure-mini-chip {
            display: inline-flex;
            align-items: center;
            gap: 0.45rem;
            padding: 0.6rem 0.9rem;
            border-radius: 9999px;
            background: rgba(255,255,255,0.85);
            border: 1px solid rgba(216,167,177,0.28);
            box-shadow: 0 10px 24px rgba(74,55,40,0.05);
            font-size: 0.82rem;
            font-weight: 600;
            color: var(--brand-brown);
        }
        .measure-segmented {
            position: relative;
            z-index: 2;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.5rem;
            flex-wrap: wrap;
            padding: 0.45rem;
            border-radius: 9999px;
            background: rgba(255,255,255,0.82);
            border: 1px solid rgba(216,167,177,0.28);
            box-shadow: 0 16px 30px rgba(74,55,40,0.06);
            margin-bottom: 1.2rem;
        }
        .measure-view-btn {
            border: 0;
            background: transparent;
            color: rgba(74,55,40,0.76);
            border-radius: 9999px;
            padding: 0.9rem 1.2rem;
            font-size: 0.92rem;
            font-weight: 700;
            letter-spacing: 0.02em;
            transition: all 0.28s ease;
            min-width: 145px;
        }
        .measure-view-btn:hover {
            color: var(--brand-brown);
            transform: translateY(-1px);
        }
        .measure-view-btn.active {
            background: linear-gradient(135deg, var(--brand-pink-dark), #c88e9d);
            color: #fff;
            box-shadow: 0 16px 28px rgba(216,167,177,0.32);
        }
        .measure-visual-shell {
            position: relative;
            z-index: 2;
            width: 100%;
            max-width: 470px;
            margin: 0 auto;
        }
        .measure-visual-stage {
            position: relative;
            background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(250,249,246,0.94));
            border-radius: 2rem;
            overflow: hidden;
            border: 1px solid rgba(216,167,177,0.26);
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.6), 0 26px 50px rgba(74,55,40,0.08);
            padding: 1rem;
        }
        .measure-stage-glow {
            position: absolute;
            inset: auto 10% 0;
            height: 56px;
            border-radius: 9999px;
            background: rgba(216,167,177,0.2);
            filter: blur(18px);
            pointer-events: none;
        }
        .measure-view-stack {
            position: relative;
            aspect-ratio: 4 / 5;
            min-height: 540px;
        }
        .measure-view {
            position: absolute;
            inset: 0;
            opacity: 0;
            transform: translateX(18px) scale(0.985);
            transition: opacity 0.55s ease, transform 0.55s ease;
            pointer-events: none;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 0.2rem;
        }
        #measure-view-front.measure-view:not(.active) {
            transform: translateX(-18px) scale(0.985);
        }
        .measure-view.active {
            opacity: 1;
            transform: translateX(0) scale(1);
            pointer-events: auto;
        }
        .measure-photo {
            width: 100%;
            height: 100%;
            object-fit: contain;
            display: block;
            filter: drop-shadow(0 24px 34px rgba(216,167,177,0.18));
            border-radius: 1.5rem;
            user-select: none;
            -webkit-user-drag: none;
        }
        .measure-hint-badge {
            position: absolute;
            right: 1rem;
            top: 1rem;
            z-index: 3;
            font-size: 0.76rem;
            line-height: 1;
            padding: 0.62rem 0.85rem;
            border-radius: 9999px;
            background: rgba(255,255,255,0.9);
            border: 1px solid rgba(216,167,177,0.28);
            color: var(--brand-brown);
            box-shadow: 0 10px 22px rgba(74,55,40,0.08);
            font-weight: 700;
        }
        .measure-dot {
            position: absolute;
            width: 2.85rem;
            height: 2.85rem;
            border-radius: 9999px;
            background: linear-gradient(135deg, var(--brand-pink-dark), #be8796);
            color: #fff;
            font-weight: 800;
            font-size: 0.95rem;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            box-shadow: 0 16px 30px rgba(216,167,177,0.34);
            border: 3px solid rgba(255,255,255,0.95);
            transform: translate(-50%, -50%);
            transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
            z-index: 3;
            backdrop-filter: blur(6px);
        }
        .measure-dot::before {
            content: '';
            position: absolute;
            inset: -7px;
            border-radius: inherit;
            border: 1px solid rgba(216,167,177,0.35);
            opacity: 0.9;
        }
        .measure-dot:hover,
        .measure-dot.active {
            transform: translate(-50%, -50%) scale(1.08);
            background: linear-gradient(135deg, var(--brand-brown), #6f5545);
            box-shadow: 0 20px 34px rgba(74,55,40,0.22);
        }
        .measure-callout {
            position: relative;
            z-index: 2;
            margin-top: 1rem;
            background: rgba(255,255,255,0.82);
            border: 1px solid rgba(216,167,177,0.24);
            border-radius: 1.2rem;
            padding: 1rem 1.1rem;
            color: var(--brand-brown);
            box-shadow: 0 14px 28px rgba(74,55,40,0.05);
        }
        .measure-callout strong {
            color: var(--brand-pink-dark);
        }
        #instruction-card {
            position: relative;
            overflow: hidden;
            background: linear-gradient(180deg, rgba(255,255,255,1), rgba(250,249,246,0.96));
            box-shadow: 0 26px 56px rgba(74,55,40,0.09);
        }
        #instruction-card::before {
            content: '';
            position: absolute;
            inset: 0 auto 0 0;
            width: 6px;
            background: linear-gradient(180deg, var(--brand-pink-dark), rgba(216,167,177,0.2));
        }
        .measure-card-top {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 1rem;
            flex-wrap: wrap;
            margin-bottom: 0.5rem;
        }
        .measure-card-badge {
            display: inline-flex;
            align-items: center;
            gap: 0.45rem;
            padding: 0.55rem 0.8rem;
            border-radius: 9999px;
            background: rgba(250,218,221,0.3);
            color: var(--brand-pink-dark);
            font-weight: 700;
            font-size: 0.78rem;
            letter-spacing: 0.08em;
            text-transform: uppercase;
        }
        .measure-summary-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 0.85rem;
            margin-top: 1.2rem;
        }
        .measure-summary-item {
            border-radius: 1.15rem;
            background: rgba(255,255,255,0.85);
            border: 1px solid rgba(216,167,177,0.24);
            padding: 1rem;
            text-align: left;
            box-shadow: 0 12px 24px rgba(74,55,40,0.04);
        }
        .measure-summary-item span {
            display: block;
            font-size: 0.74rem;
            text-transform: uppercase;
            letter-spacing: 0.14em;
            opacity: 0.6;
            margin-bottom: 0.45rem;
        }
        .measure-summary-item strong {
            color: var(--brand-brown);
            font-size: 0.98rem;
            line-height: 1.4;
        }
        @media (max-width: 1024px) {
            .measure-view-stack {
                min-height: 500px;
            }
        }
        @media (max-width: 768px) {
            .measure-guide-wrap {
                padding: 1rem;
                border-radius: 1.6rem;
            }
            .measure-segmented {
                width: 100%;
                justify-content: center;
            }
            .measure-view-btn {
                min-width: 0;
                flex: 1 1 auto;
                padding: 0.78rem 1rem;
                font-size: 0.86rem;
            }
            .measure-visual-stage {
                padding: 0.75rem;
                border-radius: 1.5rem;
            }
            .measure-view-stack {
                min-height: 430px;
            }
            .measure-dot {
                width: 2.5rem;
                height: 2.5rem;
                font-size: 0.88rem;
            }
            .measure-hint-badge {
                right: 0.75rem;
                top: 0.75rem;
            }
            .measure-summary-grid {
                grid-template-columns: 1fr;
            }
        }

        

/* =========================================================
   FILÓ RENDEIRA — POLIMENTO FINAL V4
   Objetivo: modernizar sem quebrar o HTML/JS original.
   Pode ficar no final do CSS atual.
   ========================================================= */

:root {
    --brand-offwhite: #FAF9F6;
    --brand-pink-light: #FADADD;
    --brand-pink-dark: #D8A7B1;
    --brand-brown: #4A3728;
    --brand-rose-deep: #C98C9C;
    --brand-rose-soft: #F7E4E7;
    --brand-cream: #FFFDFC;
    --brand-gold-soft: #D7B98C;
    --brand-green-whatsapp: #25D366;
    --brand-line: rgba(216, 167, 177, 0.32);
    --brand-glass: rgba(255, 255, 255, 0.78);
    --brand-shadow-soft: 0 16px 45px rgba(74, 55, 40, 0.08);
    --brand-shadow-premium: 0 28px 80px rgba(74, 55, 40, 0.14);
    --brand-radius-lg: 1.35rem;
    --brand-radius-xl: 2rem;
}

html {
    scroll-padding-top: 116px;
}

body {
    min-width: 320px;
    color: var(--brand-brown);
    background:
        radial-gradient(circle at 12% 6%, rgba(250, 218, 221, 0.58), transparent 34rem),
        radial-gradient(circle at 88% 18%, rgba(216, 167, 177, 0.18), transparent 30rem),
        linear-gradient(180deg, #FFFDFC 0%, #FAF9F6 42%, #FFFDFC 100%);
}

a, button {
    -webkit-tap-highlight-color: transparent;
}

img {
    max-width: 100%;
    height: auto;
}

:focus-visible {
    outline: 3px solid rgba(201, 140, 156, 0.45);
    outline-offset: 4px;
    border-radius: 0.85rem;
}

/* Navbar mais estável em telas menores */
#navbar {
    transition: transform 0.25s ease, opacity 0.25s ease;
}

#navbar > .max-w-7xl {
    max-width: 1180px;
}

#mobile-menu {
    overscroll-behavior: contain;
}

/* Botões mais consistentes */
.button-primary,
.hero-secondary-link,
.button-outline,
button.button-primary,
a.button-primary {
    min-height: 50px;
    line-height: 1.1;
}

.button-primary {
    background: linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep)) !important;
}

.button-primary,
.hero-secondary-link,
.portfolio-whatsapp-cta,
.floating-whatsapp-smart {
    will-change: transform;
}

/* Hero: melhora leitura, reduz cortes e deixa o carrossel mais confiável */
.hero-premium {
    min-height: clamp(720px, 100vh, 920px);
}

.hero-copy-card h1,
#hero h1 {
    text-wrap: balance;
}

.hero-copy-card p,
#hero p {
    text-wrap: pretty;
}

.hero-carousel {
    background:
        linear-gradient(135deg, rgba(250, 218, 221, 0.8), rgba(255, 255, 255, 0.72)),
        var(--brand-pink-light);
}

.hero-slide {
    background-color: var(--brand-pink-light);
}

.hero-carousel-progress {
    top: 1rem;
    left: 1rem;
    right: 1rem;
}

.hero-dots {
    top: 1.75rem;
}

/* Seções: título mais limpo e cartões com profundidade controlada */
.section-padding {
    isolation: isolate;
}

.section-padding h2 {
    text-wrap: balance;
}

.section-padding p {
    text-wrap: pretty;
}

.premium-card,
.faq-item,
#como-funciona .grid > div,
#duvidas-encomenda .premium-card,
#orcamento > .max-w-5xl > .bg-white {
    box-shadow: var(--brand-shadow-soft) !important;
}

.premium-card:hover,
.faq-item:hover,
#como-funciona .grid > div:hover {
    box-shadow: 0 24px 64px rgba(216, 167, 177, 0.20) !important;
}

/* Portfolio: filtros e cards melhores no mobile */
#portfolio-filters {
    scrollbar-width: thin;
    scrollbar-color: rgba(216, 167, 177, 0.65) transparent;
}

#portfolio-filters::-webkit-scrollbar {
    height: 6px;
}

#portfolio-filters::-webkit-scrollbar-thumb {
    background: rgba(216, 167, 177, 0.65);
    border-radius: 999px;
}

.portfolio-card {
    contain: layout paint;
}

.portfolio-card img {
    backface-visibility: hidden;
}

.portfolio-whatsapp-cta {
    min-height: 44px;
}

/* Formulário: mais claro, legível e menos apertado */
#form-orcamento label {
    line-height: 1.35;
}

.form-input,
select.form-input,
textarea.form-input {
    font-size: 16px;
}

.form-input::placeholder,
textarea.form-input::placeholder {
    color: rgba(74, 55, 40, 0.42);
}

.form-error.show {
    animation: filoErrorIn 0.22s ease both;
}

@keyframes filoErrorIn {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

.peca-option,
.location-type-option,
.upsell-box {
    user-select: none;
}

.peca-option.active,
.location-type-option.active {
    outline: 3px solid rgba(216, 167, 177, 0.18);
}

/* Rodapé e contatos */
.footer-premium,
.footer-card {
    text-wrap: pretty;
}

.contact-social-card {
    min-height: 68px;
}

/* Lightbox e popup com backdrop mais suave */
#lightbox,
#popup,
#exit-popup {
    backdrop-filter: blur(8px);
}

/* Barra flutuante: evita sobrepor conteúdo em telas pequenas */
.floating-whatsapp-smart {
    border: 1px solid rgba(255, 255, 255, 0.36);
}

@media (max-width: 1024px) {
    #navbar .nav-contact-icons {
        display: none;
    }

    .hero-premium {
        min-height: auto;
    }
}

@media (max-width: 768px) {
    html {
        scroll-padding-top: 96px;
    }

    body {
        font-size: 15px;
    }

    #navbar {
        top: 0.55rem !important;
    }

    #navbar > .max-w-7xl {
        max-width: calc(100vw - 1.4rem);
    }

    .hero-premium {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .hero-copy-card {
        text-align: center;
    }

    .hero-copy-card .hero-actions,
    .hero-copy-card .hero-stats {
        justify-content: center;
    }

    .hero-carousel-shell {
        max-width: 430px !important;
    }

    .hero-carousel {
        min-height: 360px !important;
        height: clamp(360px, 112vw, 500px) !important;
    }

    .hero-caption-card {
        padding: 0.85rem 0.95rem;
    }

    .hero-floating-badge {
        max-width: calc(100% - 2rem);
        white-space: normal;
    }

    .section-padding {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .section-padding h2 {
        font-size: clamp(2.05rem, 10vw, 3.1rem) !important;
    }

    #portfolio-filters {
        display: flex;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.75rem !important;
    }

    .filter-btn {
        white-space: nowrap;
    }

    .portfolio-card {
        min-height: 380px;
    }

    .portfolio-whatsapp-cta {
        opacity: 1 !important;
        transform: translateY(0) !important;
    }

    #form-orcamento {
        padding: 1.15rem !important;
    }

    .resumo-card-grid {
        grid-template-columns: 1fr !important;
    }

    .floating-whatsapp-smart {
        bottom: 0.85rem !important;
        left: 0.85rem !important;
        right: 0.85rem !important;
        width: auto;
        border-radius: 1.15rem !important;
    }

    #back-to-top {
        bottom: 5.85rem !important;
        right: 1rem !important;
    }
}

@media (max-width: 480px) {
    #promo-bar {
        font-size: 0.68rem !important;
    }

    #navbar a.text-2xl,
    #navbar a.text-3xl {
        max-width: 64vw;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .hero-caption-title {
        font-size: 0.98rem !important;
    }

    .hero-dots {
        top: 1.4rem;
        right: 0.85rem;
    }

    .hero-carousel-progress {
        right: 4.9rem;
    }

    .counter-num {
        font-size: 2.35rem !important;
    }

    .footer-card {
        padding: 1.15rem !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero-slide,
    .fade-in,
    .measure-figure,
    .button-primary,
    .portfolio-card img,
    .floating-whatsapp-smart {
        animation: none !important;
        transition: none !important;
        transform: none !important;
    }
}



/* =========================================================
   Ajuste final do cabeçalho — menu sem quebra e sem aviso
   ========================================================= */
#promo-bar {
    display: none !important;
}

html {
    scroll-padding-top: 94px !important;
}

#navbar {
    top: 0.75rem !important;
    padding: 0 0.9rem !important;
}

#navbar > .max-w-7xl {
    max-width: 1180px !important;
    width: 100% !important;
    min-height: 74px;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1rem !important;
    padding: 0.78rem 1rem 0.78rem 1.35rem !important;
    border-radius: 999px !important;
    background: rgba(255, 253, 252, 0.92) !important;
    border: 1px solid rgba(216, 167, 177, 0.46) !important;
    box-shadow: 0 18px 48px rgba(74, 55, 40, 0.10) !important;
}

#navbar a.text-2xl,
#navbar a.text-3xl {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 0.25rem !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    font-size: clamp(1.55rem, 2.35vw, 2.05rem) !important;
    line-height: 0.95 !important;
    letter-spacing: -0.055em !important;
    padding-left: 0 !important;
}

#navbar a.text-2xl::after,
#navbar a.text-3xl::after {
    content: 'ATELIER' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    transform: none !important;
    padding: 0.28rem 0.58rem !important;
    border-radius: 999px !important;
    border: 1px solid rgba(216, 167, 177, 0.42) !important;
    background: rgba(250, 218, 221, 0.34) !important;
    color: var(--brand-rose-deep) !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 0.54rem !important;
    font-style: normal !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: 0.12em !important;
}

#navbar .hidden.md\:flex {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: clamp(0.72rem, 1.22vw, 1.35rem) !important;
}

#navbar .hidden.md\:flex > a:not(.nav-contact-icon) {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    line-height: 1 !important;
    font-size: clamp(0.66rem, 0.76vw, 0.78rem) !important;
    letter-spacing: 0.13em !important;
}

#navbar .hidden.md\:flex > a:not(.nav-contact-icon):not(:last-child) {
    padding-top: 0.55rem !important;
    padding-bottom: 0.55rem !important;
}

#navbar .nav-contact-icons {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    padding: 0.24rem 0.4rem !important;
    gap: 0.42rem !important;
}

#navbar .nav-contact-icon {
    flex: 0 0 36px !important;
    width: 36px !important;
    height: 36px !important;
}

#navbar .hidden.md\:flex > a:last-child {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 152px !important;
    min-height: 46px !important;
    padding: 0.78rem 1.35rem !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
    font-size: 0.76rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    background: linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep)) !important;
    box-shadow: 0 12px 28px rgba(216, 167, 177, 0.35) !important;
}

#mobile-menu-toggle {
    display: none !important;
}

@media (max-width: 1180px) {
    #navbar .nav-contact-icons {
        display: none !important;
    }

    #navbar > .max-w-7xl {
        max-width: calc(100vw - 1.6rem) !important;
    }

    #navbar .hidden.md\:flex {
        gap: clamp(0.72rem, 1.55vw, 1.15rem) !important;
    }
}

@media (max-width: 920px) {
    #navbar .hidden.md\:flex > a:not(.nav-contact-icon) {
        font-size: 0.64rem !important;
        letter-spacing: 0.10em !important;
    }

    #navbar .hidden.md\:flex > a:last-child {
        min-width: 132px !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
}

@media (max-width: 767px) {
    html {
        scroll-padding-top: 86px !important;
    }

    #navbar {
        top: 0.55rem !important;
        padding: 0 0.75rem !important;
    }

    #navbar > .max-w-7xl {
        min-height: 66px !important;
        border-radius: 1.25rem !important;
        padding: 0.72rem 0.82rem !important;
    }

    #navbar .hidden.md\:flex {
        display: none !important;
    }

    #mobile-menu-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 0 0 46px !important;
        width: 46px !important;
        height: 46px !important;
        border-radius: 999px !important;
        background: rgba(250, 218, 221, 0.42) !important;
        border: 1px solid rgba(216, 167, 177, 0.44) !important;
    }

    #navbar a.text-2xl,
    #navbar a.text-3xl {
        font-size: clamp(1.42rem, 7vw, 1.78rem) !important;
    }

    #navbar a.text-2xl::after,
    #navbar a.text-3xl::after {
        font-size: 0.48rem !important;
        padding: 0.24rem 0.5rem !important;
    }

    .hero-premium {
        padding-top: 7rem !important;
    }
}



/* =========================================================
   Correção final — cabeçalho alinhado e sem sobreposição
   ========================================================= */
#promo-bar {
    display: none !important;
}

html {
    scroll-padding-top: 96px !important;
}

#navbar {
    top: 0.75rem !important;
    padding: 0 1rem !important;
}

#navbar > .max-w-7xl {
    width: min(1180px, calc(100vw - 2rem)) !important;
    min-height: 74px !important;
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: center !important;
    column-gap: clamp(1.35rem, 2vw, 2.25rem) !important;
    padding: 0.72rem 1rem 0.72rem 1.35rem !important;
    border-radius: 999px !important;
    background: rgba(255, 253, 252, 0.94) !important;
    border: 1px solid rgba(216, 167, 177, 0.46) !important;
    box-shadow: 0 18px 48px rgba(74, 55, 40, 0.10) !important;
}

#navbar a.text-2xl,
#navbar a.text-3xl {
    align-self: center !important;
    flex: 0 0 auto !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 0.25rem !important;
    width: max-content !important;
    min-width: 180px !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    font-size: clamp(1.55rem, 2.35vw, 2.05rem) !important;
    line-height: 0.92 !important;
    letter-spacing: -0.055em !important;
    padding: 0 !important;
    margin: 0 !important;
}

#navbar a.text-2xl::after,
#navbar a.text-3xl::after {
    content: 'ATELIER' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    transform: none !important;
    padding: 0.27rem 0.58rem !important;
    border-radius: 999px !important;
    border: 1px solid rgba(216, 167, 177, 0.42) !important;
    background: rgba(250, 218, 221, 0.34) !important;
    color: var(--brand-rose-deep) !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 0.52rem !important;
    font-style: normal !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: 0.12em !important;
}

#navbar .hidden.md\:flex {
    justify-self: end !important;
    align-self: center !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 50px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: clamp(0.72rem, 1.15vw, 1.22rem) !important;
}

#navbar .hidden.md\:flex > a:not(.nav-contact-icon) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 0.02rem !important;
    margin: 0 !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    line-height: 1 !important;
    font-size: clamp(0.65rem, 0.75vw, 0.76rem) !important;
    font-weight: 800 !important;
    letter-spacing: 0.13em !important;
    transform: none !important;
}

#navbar .hidden.md\:flex > a:not(.nav-contact-icon):not(:last-child)::after {
    bottom: 0.24rem !important;
}

#navbar .nav-contact-icons {
    flex: 0 0 auto !important;
    height: 46px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.42rem !important;
    padding: 0.24rem 0.4rem !important;
    margin: 0 0.1rem !important;
    white-space: nowrap !important;
    border-radius: 999px !important;
}

#navbar .nav-contact-icons .nav-contact-icon,
#navbar .nav-contact-icons .nav-contact-icon:last-child {
    flex: 0 0 36px !important;
    width: 36px !important;
    min-width: 36px !important;
    height: 36px !important;
    min-height: 36px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.75), 0 8px 18px rgba(74,55,40,0.055) !important;
    transform: none !important;
}

#navbar .nav-contact-icons .nav-contact-icon::after,
#navbar .nav-contact-icons .nav-contact-icon::before {
    display: none !important;
}

#navbar .nav-contact-icons .nav-contact-icon.whatsapp,
#navbar .nav-contact-icons .nav-contact-icon.whatsapp:last-child {
    background: rgba(37,211,102,0.10) !important;
    border-color: rgba(37,211,102,0.28) !important;
}

#navbar .nav-contact-icons .nav-contact-icon.instagram,
#navbar .nav-contact-icons .nav-contact-icon.instagram:last-child {
    background: linear-gradient(135deg, rgba(250,218,221,0.55), rgba(255,255,255,0.72)) !important;
    border-color: rgba(225,48,108,0.22) !important;
}

#navbar .nav-contact-icons .nav-contact-icon.gmail,
#navbar .nav-contact-icons .nav-contact-icon.gmail:last-child {
    background: rgba(234,67,53,0.08) !important;
    border-color: rgba(234,67,53,0.22) !important;
}

#navbar .hidden.md\:flex > a:last-child {
    flex: 0 0 auto !important;
    height: 48px !important;
    min-height: 48px !important;
    min-width: 152px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 1.45rem !important;
    margin: 0 !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
    font-size: 0.74rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    color: #fff !important;
    background: linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep)) !important;
    box-shadow: 0 12px 28px rgba(216, 167, 177, 0.35) !important;
    transform: none !important;
}

#navbar .hidden.md\:flex > a:last-child:hover {
    transform: translateY(-2px) !important;
}

#mobile-menu-toggle {
    display: none !important;
}

@media (max-width: 1180px) {
    #navbar > .max-w-7xl {
        width: calc(100vw - 1.6rem) !important;
        column-gap: 1.05rem !important;
    }

    #navbar .nav-contact-icons {
        display: none !important;
    }

    #navbar .hidden.md\:flex {
        gap: clamp(0.62rem, 1.35vw, 1rem) !important;
    }

    #navbar a.text-2xl,
    #navbar a.text-3xl {
        min-width: 168px !important;
    }
}

@media (max-width: 960px) {
    #navbar a.text-2xl,
    #navbar a.text-3xl {
        min-width: 154px !important;
        font-size: 1.45rem !important;
    }

    #navbar .hidden.md\:flex > a:not(.nav-contact-icon) {
        font-size: 0.62rem !important;
        letter-spacing: 0.095em !important;
    }

    #navbar .hidden.md\:flex > a:last-child {
        min-width: 128px !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
}

@media (max-width: 767px) {
    html {
        scroll-padding-top: 86px !important;
    }

    #navbar {
        top: 0.55rem !important;
        padding: 0 0.75rem !important;
    }

    #navbar > .max-w-7xl {
        width: calc(100vw - 1.5rem) !important;
        min-height: 66px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        border-radius: 1.25rem !important;
        padding: 0.72rem 0.82rem !important;
    }

    #navbar .hidden.md\:flex {
        display: none !important;
    }

    #mobile-menu-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 0 0 46px !important;
        width: 46px !important;
        height: 46px !important;
        border-radius: 999px !important;
        background: rgba(250, 218, 221, 0.42) !important;
        border: 1px solid rgba(216, 167, 177, 0.44) !important;
    }

    #navbar a.text-2xl,
    #navbar a.text-3xl {
        min-width: 0 !important;
        font-size: clamp(1.42rem, 7vw, 1.78rem) !important;
    }

    #navbar a.text-2xl::after,
    #navbar a.text-3xl::after {
        font-size: 0.48rem !important;
        padding: 0.24rem 0.5rem !important;
    }

    .hero-premium {
        padding-top: 7rem !important;
    }
}



        /* =========================================================
           Correção mobile: cookies acima do botão do WhatsApp
           ========================================================= */
        #cookie-banner {
            z-index: 10050 !important;
        }

        @media (max-width: 768px) {
            body.cookie-banner-open .floating-whatsapp-smart {
                opacity: 0 !important;
                pointer-events: none !important;
                transform: translateY(18px) !important;
            }

            body.cookie-banner-open #back-to-top {
                display: none !important;
            }

            #cookie-banner {
                left: 0.75rem !important;
                right: 0.75rem !important;
                bottom: 0.75rem !important;
                width: auto !important;
                border-radius: 1.25rem !important;
                padding: 1rem !important;
                padding-bottom: calc(1rem + env(safe-area-inset-bottom)) !important;
                align-items: stretch !important;
                justify-content: center !important;
                gap: 0.85rem !important;
                box-shadow: 0 -8px 34px rgba(0,0,0,0.22) !important;
            }

            #cookie-banner p {
                max-width: none !important;
                width: 100% !important;
                font-size: 0.78rem !important;
                line-height: 1.45 !important;
                text-align: center !important;
            }

            #cookie-banner > div {
                width: 100% !important;
                display: grid !important;
                grid-template-columns: 1fr 1fr !important;
                gap: 0.7rem !important;
            }

            #cookie-banner button {
                width: 100% !important;
                min-height: 44px !important;
                padding: 0.72rem 0.9rem !important;
                font-size: 0.82rem !important;
            }
        }


        /* =========================================================
           Ajustes solicitados — Experiência + Guia de medidas mobile
           ========================================================= */
        @media (max-width: 768px) {
            #guia-medidas {
                scroll-margin-top: 96px;
            }
            #guia-medidas .text-center.mb-16 {
                margin-bottom: 1.15rem !important;
            }
            #guia-medidas .grid.grid-cols-1.lg\:grid-cols-2 {
                gap: 1rem !important;
            }
            #guia-medidas .measure-guide-wrap {
                padding: 0.85rem !important;
                border-radius: 1.35rem !important;
            }
            #guia-medidas .measure-stage-meta {
                gap: 0.45rem !important;
                margin-bottom: 0.75rem !important;
            }
            #guia-medidas .measure-mini-chip {
                font-size: 0.72rem !important;
                padding: 0.48rem 0.62rem !important;
            }
            #guia-medidas .text-center.mb-5 {
                margin-bottom: 0.75rem !important;
            }
            #guia-medidas .measure-segmented {
                border-radius: 1.1rem !important;
                padding: 0.35rem !important;
            }
            #guia-medidas .measure-view-btn {
                padding: 0.72rem 0.65rem !important;
                font-size: 0.82rem !important;
            }
            #guia-medidas .measure-visual-stage {
                padding: 0.55rem !important;
                border-radius: 1.2rem !important;
            }
            #guia-medidas .measure-view-stack {
                min-height: clamp(300px, 88vw, 370px) !important;
            }
            #guia-medidas .measure-hint-badge {
                right: 0.55rem !important;
                top: 0.55rem !important;
                padding: 0.52rem 0.7rem !important;
                font-size: 0.7rem !important;
            }
            #guia-medidas .measure-dot {
                width: 2.35rem !important;
                height: 2.35rem !important;
                font-size: 0.82rem !important;
            }
            #guia-medidas .measure-callout {
                margin-top: 0.7rem !important;
                padding: 0.78rem 0.85rem !important;
                border-radius: 1rem !important;
                font-size: 0.82rem !important;
                line-height: 1.45 !important;
            }
            #instruction-card {
                scroll-margin-top: 106px;
                padding: 1.15rem !important;
                border-radius: 1.35rem !important;
                margin-top: 0 !important;
            }
            #instruction-card .measure-card-top {
                gap: 0.6rem !important;
                margin-bottom: 0.25rem !important;
            }
            #instruction-card .measure-card-badge {
                font-size: 0.68rem !important;
                padding: 0.45rem 0.65rem !important;
            }
            #instrucao-placeholder .text-center {
                padding-top: 0.75rem !important;
                padding-bottom: 0.75rem !important;
            }
            #instrucao-placeholder .text-6xl {
                font-size: 3rem !important;
            }
            #instrucao-ativa {
                gap: 0.95rem !important;
            }
            #instrucao-ativa .flex.items-start.gap-5 {
                gap: 0.85rem !important;
            }
            #measure-num {
                font-size: 2.75rem !important;
            }
            #measure-title {
                font-size: 1.45rem !important;
                line-height: 1.15 !important;
            }
            #measure-text {
                font-size: 0.98rem !important;
                line-height: 1.58 !important;
            }
            #measure-tip {
                font-size: 0.86rem !important;
                line-height: 1.48 !important;
            }
        }
        @media (max-width: 380px) {
            #guia-medidas .measure-view-stack {
                min-height: 286px !important;
            }
            #guia-medidas .measure-dot {
                width: 2.15rem !important;
                height: 2.15rem !important;
            }
        }


/* =========================================================
   Filó Rendeira — ajustes finais de base visual/técnica
   Aplicados para uma experiência mais premium antes da divulgação.
   ========================================================= */
.static-counter {
    font-size: clamp(1.25rem, 2.4vw, 2.1rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.03em !important;
    text-transform: none !important;
}

#popup,
#exit-popup {
    pointer-events: none;
}

#popup.open,
#exit-popup.flex {
    pointer-events: auto;
}

.button-primary {
    letter-spacing: 0.01em;
}

.hero-secondary-link {
    white-space: nowrap;
}

.portfolio-card-cta {
    border: 1px solid rgba(255,255,255,0.45);
    backdrop-filter: blur(8px);
}

@media (max-width: 640px) {
    .hero-secondary-link {
        white-space: normal;
    }

    .static-counter {
        font-size: 1.15rem !important;
    }
}

/* =========================================================
   Correção do menu desktop/tablet — evita "Início" colado no logo
   ========================================================= */
#navbar > .max-w-7xl {
    gap: clamp(1rem, 2.4vw, 2.4rem) !important;
}

#navbar > .max-w-7xl > a:first-child {
    flex: 0 0 auto !important;
    margin-right: clamp(1.2rem, 2.4vw, 2.8rem) !important;
    white-space: nowrap !important;
    z-index: 2;
}

#navbar .hidden.md\:flex {
    flex: 1 1 auto !important;
    justify-content: flex-end !important;
    min-width: 0 !important;
    gap: clamp(0.85rem, 1.25vw, 1.65rem) !important;
}

#navbar .hidden.md\:flex a:not(:last-child) {
    white-space: nowrap !important;
}

@media (max-width: 1280px) {
    #navbar .hidden.md\:flex {
        gap: 0.85rem !important;
        font-size: 0.66rem !important;
    }

    #navbar .hidden.md\:flex a:last-child {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .nav-contact-icons {
        display: none !important;
    }
}

@media (max-width: 1180px) {
    #navbar .hidden.md\:flex {
        display: none !important;
    }

    #mobile-menu-toggle {
        display: inline-flex !important;
    }

    #navbar > .max-w-7xl {
        justify-content: space-between !important;
    }

    #navbar > .max-w-7xl > a:first-child {
        margin-right: 0 !important;
    }
}

@media (min-width: 1181px) {
    #mobile-menu-toggle {
        display: none !important;
    }
}

/* =========================================================
   CORREÇÃO DEFINITIVA DO MENU — evita sobreposição do "Início"
   ========================================================= */
#navbar > .max-w-7xl {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1rem !important;
}
#navbar .nav-brand {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    margin-right: 0 !important;
    z-index: 2 !important;
}
#navbar .desktop-nav {
    display: none !important;
    min-width: 0 !important;
}
#mobile-menu-toggle {
    display: inline-flex !important;
    flex: 0 0 auto !important;
}
@media (min-width: 1360px) {
    #navbar .desktop-nav {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        margin-left: auto !important;
        gap: clamp(0.85rem, 1.05vw, 1.45rem) !important;
        white-space: nowrap !important;
        font-size: 0.68rem !important;
    }
    #mobile-menu-toggle {
        display: none !important;
    }
    #navbar .desktop-nav a:not(:last-child) {
        position: relative !important;
        padding: 0.45rem 0 !important;
        white-space: nowrap !important;
    }
    #navbar .desktop-nav a:not(:last-child)::after {
        content: '' !important;
        position: absolute !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0.18rem !important;
        height: 1px !important;
        background: var(--brand-pink-dark) !important;
        transform: scaleX(0) !important;
        transform-origin: center !important;
        transition: transform 0.25s ease !important;
        opacity: 0.85 !important;
    }
    #navbar .desktop-nav a:not(:last-child):hover::after {
        transform: scaleX(1) !important;
    }
    #navbar .desktop-nav a:last-child {
        background: linear-gradient(135deg, var(--brand-pink-dark), var(--brand-rose-deep)) !important;
        color: #fff !important;
        box-shadow: 0 12px 28px rgba(216,167,177,0.36) !important;
        border: 1px solid rgba(255,255,255,0.42) !important;
        transition: all 0.28s ease !important;
        padding-left: 1.15rem !important;
        padding-right: 1.15rem !important;
        border-radius: 9999px !important;
    }
    #navbar .desktop-nav a:last-child:hover {
        transform: translateY(-2px) !important;
        box-shadow: 0 18px 40px rgba(216,167,177,0.44) !important;
    }
}
@media (min-width: 1360px) and (max-width: 1510px) {
    #navbar .nav-contact-icons {
        display: none !important;
    }
    #navbar .desktop-nav {
        gap: 0.78rem !important;
        font-size: 0.64rem !important;
        letter-spacing: 0.18em !important;
    }
    #navbar .desktop-nav a:last-child {
        padding-left: 0.95rem !important;
        padding-right: 0.95rem !important;
    }
    #navbar a.text-2xl::after,
    #navbar a.text-3xl::after {
        display: none !important;
    }
}
@media (max-width: 1359px) {
    #navbar .desktop-nav {
        display: none !important;
    }
    #mobile-menu-toggle {
        display: inline-flex !important;
    }
    #navbar > .max-w-7xl {
        justify-content: space-between !important;
    }
    #navbar .nav-brand {
        max-width: calc(100vw - 7rem) !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
}
#mobile-menu:not(.hidden) {
    display: flex !important;
}

/* =========================================================
   AJUSTE FINAL DO MENU — desktop com espaçamento real e
   mobile em tela cheia, sem cortar ao rolar a página.
   ========================================================= */
#navbar {
    z-index: 99990 !important;
    overflow: visible !important;
}

#navbar > .max-w-7xl {
    overflow: visible !important;
}

#navbar .nav-brand {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
}

/* Por padrão, usa menu mobile/hambúrguer. O menu horizontal só entra
   quando houver largura suficiente para não esmagar os links. */
#navbar .desktop-nav {
    display: none !important;
}

#mobile-menu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 46px !important;
    width: 46px !important;
    height: 46px !important;
    border-radius: 999px !important;
    background: rgba(250, 218, 221, 0.42) !important;
    border: 1px solid rgba(216, 167, 177, 0.44) !important;
    color: var(--brand-brown) !important;
}

/* Menu aberto: fica preso à janela, não ao ponto de rolagem da página. */
#mobile-menu {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 999999 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-width: none !important;
    max-height: none !important;
    padding: calc(4.5rem + env(safe-area-inset-top)) 1.35rem calc(2rem + env(safe-area-inset-bottom)) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 1.05rem !important;
    background: radial-gradient(circle at 20% 12%, rgba(250,218,221,0.95), transparent 18rem), linear-gradient(145deg, #FFFDFC 0%, #FAF9F6 100%) !important;
}

#mobile-menu.hidden {
    display: none !important;
}

#mobile-menu:not(.hidden) {
    display: flex !important;
}

#mobile-menu > button[aria-label="Fechar menu"] {
    position: fixed !important;
    top: calc(1rem + env(safe-area-inset-top)) !important;
    right: 1rem !important;
    z-index: 1000000 !important;
    width: 44px !important;
    height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.82) !important;
    border: 1px solid rgba(216,167,177,0.35) !important;
    box-shadow: 0 12px 26px rgba(74,55,40,0.08) !important;
}

#mobile-menu a.font-serif {
    width: min(100%, 360px) !important;
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: 1.14rem !important;
    line-height: 1.2 !important;
    color: var(--brand-brown) !important;
}

#mobile-menu .mobile-social-icons {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.8rem !important;
    margin: 0.35rem 0 0.15rem !important;
    flex-wrap: nowrap !important;
}

#mobile-menu .button-primary {
    width: min(100%, 360px) !important;
    max-width: 360px !important;
    margin-top: 0.25rem !important;
}

/* Desktop grande: menu horizontal volta com espaçamento confortável. */
@media (min-width: 1500px) {
    #navbar > .max-w-7xl {
        width: min(1320px, calc(100vw - 2rem)) !important;
        max-width: 1320px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 2.1rem !important;
    }

    #navbar .desktop-nav {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        flex: 1 1 auto !important;
        min-width: 0 !important;
        margin-left: auto !important;
        column-gap: clamp(1.15rem, 1.35vw, 1.9rem) !important;
        row-gap: 0 !important;
        white-space: nowrap !important;
    }

    #navbar .desktop-nav > a:not(.nav-contact-icon) {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 0 0 auto !important;
        white-space: nowrap !important;
        word-break: keep-all !important;
        overflow-wrap: normal !important;
        line-height: 1 !important;
        padding-left: 0.08rem !important;
        padding-right: 0.08rem !important;
        letter-spacing: 0.16em !important;
    }

    #navbar .nav-contact-icons {
        display: inline-flex !important;
        flex: 0 0 auto !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.48rem !important;
        margin-left: 0.1rem !important;
        margin-right: 0.1rem !important;
    }

    #navbar .desktop-nav > a:last-child {
        min-width: 184px !important;
        padding-left: 1.25rem !important;
        padding-right: 1.25rem !important;
    }

    #mobile-menu-toggle {
        display: none !important;
    }
}

/* Em desktops não tão largos, esconde os ícones para o texto respirar. */
@media (min-width: 1500px) and (max-width: 1690px) {
    #navbar .nav-contact-icons {
        display: none !important;
    }

    #navbar .desktop-nav {
        column-gap: clamp(1rem, 1.18vw, 1.45rem) !important;
    }

    #navbar .desktop-nav > a:not(.nav-contact-icon) {
        font-size: 0.66rem !important;
        letter-spacing: 0.14em !important;
    }
}

@media (max-width: 1499px) {
    #navbar .desktop-nav {
        display: none !important;
    }

    #mobile-menu-toggle {
        display: inline-flex !important;
    }

    #navbar > .max-w-7xl {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 1rem !important;
    }
}

@media (max-width: 420px) {
    #navbar .nav-brand {
        font-size: clamp(1.25rem, 7vw, 1.62rem) !important;
        max-width: calc(100vw - 6.5rem) !important;
    }

    #mobile-menu {
        gap: 0.88rem !important;
        padding-top: calc(4.1rem + env(safe-area-inset-top)) !important;
    }

    #mobile-menu a.font-serif {
        min-height: 40px !important;
        font-size: 1.04rem !important;
    }
}


/* =========================================================
   FIX CRÍTICO V2 — menu mobile/desktop
   Motivo: evitar menu horizontal no celular e menu mobile cortado ao rolar.
   ========================================================= */
#navbar { z-index: 2147483000 !important; overflow: visible !important; pointer-events: auto !important; }
#navbar > .max-w-7xl { width: min(1280px, calc(100vw - 1.5rem)) !important; max-width: 1280px !important; display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 0.85rem !important; overflow: visible !important; }
#navbar .nav-brand, #navbar > .max-w-7xl > a:first-child { flex: 0 1 auto !important; min-width: 0 !important; max-width: calc(100vw - 7rem) !important; overflow: hidden !important; text-overflow: ellipsis !important; white-space: nowrap !important; line-height: 1.05 !important; z-index: 2 !important; }
#navbar .desktop-nav, #navbar .hidden.md\:flex { display: none !important; visibility: hidden !important; pointer-events: none !important; }
#mobile-menu-toggle { display: inline-flex !important; flex: 0 0 54px !important; width: 54px !important; height: 54px !important; align-items: center !important; justify-content: center !important; border-radius: 999px !important; background: rgba(250, 218, 221, 0.58) !important; border: 1px solid rgba(216, 167, 177, 0.42) !important; color: var(--brand-brown) !important; box-shadow: 0 12px 30px rgba(74,55,40,0.08) !important; position: relative !important; z-index: 2147483001 !important; }
#mobile-menu { position: fixed !important; inset: 0 !important; width: 100vw !important; height: 100vh !important; height: 100dvh !important; max-width: none !important; max-height: none !important; z-index: 2147483647 !important; padding: calc(5rem + env(safe-area-inset-top)) 1.25rem calc(2rem + env(safe-area-inset-bottom)) !important; overflow-y: auto !important; overscroll-behavior: contain !important; background: radial-gradient(circle at 20% 12%, rgba(250,218,221,0.98), transparent 18rem), linear-gradient(145deg, #FFFDFC 0%, #FAF9F6 100%) !important; flex-direction: column !important; align-items: center !important; justify-content: flex-start !important; gap: 1rem !important; }
#mobile-menu.hidden { display: none !important; }
#mobile-menu:not(.hidden), #mobile-menu.open { display: flex !important; }
#mobile-menu > button[aria-label="Fechar menu"] { position: fixed !important; top: calc(1rem + env(safe-area-inset-top)) !important; right: 1rem !important; z-index: 2147483647 !important; width: 48px !important; height: 48px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; border-radius: 999px !important; background: rgba(255,255,255,0.92) !important; border: 1px solid rgba(216,167,177,0.40) !important; box-shadow: 0 12px 30px rgba(74,55,40,0.12) !important; }
#mobile-menu a.font-serif, #mobile-menu > a:not(.button-primary):not(.whatsapp):not(.instagram):not(.gmail) { width: min(100%, 380px) !important; min-height: 44px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; text-align: center !important; font-size: 1.08rem !important; line-height: 1.2 !important; color: var(--brand-brown) !important; }
#mobile-menu .mobile-social-icons { display: inline-flex !important; gap: 0.8rem !important; align-items: center !important; justify-content: center !important; }
#mobile-menu .button-primary { width: min(100%, 380px) !important; justify-content: center !important; }
@media (max-width: 520px) {
  #navbar { padding: 0.75rem 0.75rem !important; }
  #navbar > .max-w-7xl { width: calc(100vw - 1rem) !important; padding: 0.85rem 0.85rem !important; border-radius: 1.25rem !important; }
  #navbar .nav-brand, #navbar > .max-w-7xl > a:first-child { font-size: clamp(1.42rem, 7.2vw, 2rem) !important; max-width: calc(100vw - 7.4rem) !important; }
  #mobile-menu-toggle { width: 52px !important; height: 52px !important; flex-basis: 52px !important; }
}
@media (min-width: 1280px) {
  #navbar .desktop-nav { display: flex !important; visibility: visible !important; pointer-events: auto !important; align-items: center !important; justify-content: flex-end !important; flex: 1 1 auto !important; min-width: 0 !important; margin-left: auto !important; gap: clamp(0.85rem, 1vw, 1.35rem) !important; white-space: nowrap !important; font-size: 0.68rem !important; letter-spacing: 0.16em !important; }
  #navbar .desktop-nav > a, #navbar .desktop-nav > a:not(.nav-contact-icon) { display: inline-flex !important; align-items: center !important; justify-content: center !important; white-space: nowrap !important; word-break: keep-all !important; overflow-wrap: normal !important; flex: 0 0 auto !important; }
  #navbar .desktop-nav > a:last-child { min-width: 176px !important; padding-left: 1rem !important; padding-right: 1rem !important; border-radius: 999px !important; }
  #navbar .desktop-nav .nav-contact-icons { display: none !important; }
  #mobile-menu-toggle { display: none !important; }
}
@media (min-width: 1536px) {
  #navbar .desktop-nav .nav-contact-icons { display: inline-flex !important; }
  #navbar .desktop-nav { gap: clamp(1rem, 1.15vw, 1.6rem) !important; }
}

/* =========================================================
   MENU ESTÁVEL V3 — correção definitiva do botão hambúrguer
   ========================================================= */
@media (max-width: 1499px) {
  #navbar .desktop-nav, #desktop-nav, #navbar .hidden.md\:flex {
    display: none !important; visibility: hidden !important; opacity: 0 !important; pointer-events: none !important;
  }
  #mobile-menu-toggle {
    display: inline-flex !important; visibility: visible !important; opacity: 1 !important; pointer-events: auto !important;
    flex: 0 0 52px !important; width: 52px !important; height: 52px !important;
    align-items: center !important; justify-content: center !important; border-radius: 999px !important;
    background: rgba(250,218,221,0.62) !important; border: 1px solid rgba(216,167,177,0.46) !important;
    color: var(--brand-brown) !important; box-shadow: 0 12px 30px rgba(74,55,40,0.08) !important;
    position: relative !important; z-index: 2147483001 !important;
  }
  #navbar { z-index: 2147483000 !important; overflow: visible !important; }
  #navbar > .max-w-7xl { overflow: visible !important; display: flex !important; align-items: center !important; justify-content: space-between !important; gap: .75rem !important; }
  #navbar .nav-brand, #navbar > .max-w-7xl > a:first-child { max-width: calc(100vw - 7.5rem) !important; min-width: 0 !important; overflow: hidden !important; white-space: nowrap !important; text-overflow: ellipsis !important; line-height: 1.05 !important; }
}
#mobile-menu {
  position: fixed !important; inset: 0 !important; width: 100vw !important; height: 100vh !important; height: 100dvh !important;
  max-width: none !important; max-height: none !important; z-index: 2147483647 !important;
  background: radial-gradient(circle at 20% 12%, rgba(250,218,221,0.98), transparent 18rem), linear-gradient(145deg, #FFFDFC 0%, #FAF9F6 100%) !important;
  padding: calc(5rem + env(safe-area-inset-top)) 1.25rem calc(2rem + env(safe-area-inset-bottom)) !important;
  overflow-y: auto !important; overscroll-behavior: contain !important; flex-direction: column !important;
  align-items: center !important; justify-content: flex-start !important; gap: .95rem !important;
}
#mobile-menu.hidden { display: none !important; visibility: hidden !important; opacity: 0 !important; pointer-events: none !important; }
#mobile-menu.mobile-menu-open, #mobile-menu:not(.hidden) { display: flex !important; visibility: visible !important; opacity: 1 !important; pointer-events: auto !important; }
#mobile-menu.mobile-menu-open *, #mobile-menu:not(.hidden) * { visibility: visible !important; opacity: 1 !important; }
#mobile-menu > button[aria-label="Fechar menu"] {
  position: fixed !important; top: calc(1rem + env(safe-area-inset-top)) !important; right: 1rem !important;
  z-index: 2147483647 !important; width: 48px !important; height: 48px !important; display: inline-flex !important;
  align-items: center !important; justify-content: center !important; border-radius: 999px !important;
  background: rgba(255,255,255,.94) !important; border: 1px solid rgba(216,167,177,.42) !important;
  box-shadow: 0 12px 30px rgba(74,55,40,.12) !important; color: var(--brand-brown) !important;
  font-size: 1.65rem !important; line-height: 1 !important;
}
#mobile-menu a.font-serif, #mobile-menu > a:not(.button-primary):not(.whatsapp):not(.instagram):not(.gmail) {
  width: min(100%, 380px) !important; min-height: 46px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; text-align: center !important; font-size: 1.18rem !important; line-height: 1.18 !important; color: var(--brand-brown) !important; text-decoration: none !important; border-radius: 999px !important;
}
#mobile-menu a.font-serif:active, #mobile-menu a.font-serif:hover { background: rgba(250,218,221,.55) !important; color: var(--brand-brown) !important; }
#mobile-menu .mobile-social-icons { display: inline-flex !important; gap: .85rem !important; align-items: center !important; justify-content: center !important; margin: .35rem 0 .2rem !important; flex-wrap: nowrap !important; }
#mobile-menu .mobile-social-icons a { width: 48px !important; height: 48px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; border-radius: 999px !important; }
#mobile-menu .button-primary { width: min(100%, 380px) !important; max-width: 380px !important; min-height: 50px !important; justify-content: center !important; margin-top: .15rem !important; }
@media (min-width: 1500px) {
  #mobile-menu-toggle { display: none !important; }
  #navbar .desktop-nav, #desktop-nav { display: flex !important; visibility: visible !important; opacity: 1 !important; pointer-events: auto !important; align-items: center !important; justify-content: flex-end !important; gap: clamp(1.1rem, 1.35vw, 1.8rem) !important; white-space: nowrap !important; }
}


/* MENU LIMPO V4 também no CSS externo; estilo principal está no index.html para vencer cache/conflitos. */


/* Links individuais do portfólio */
.portfolio-detail-link {
    position: absolute;
    inset: 0;
    z-index: 18;
    border-radius: inherit;
    text-decoration: none;
}
.portfolio-detail-link:focus-visible {
    outline: 3px solid rgba(216, 167, 177, 0.95);
    outline-offset: -6px;
}
.portfolio-detail-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.7rem;
    padding: 0.46rem 0.82rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.88);
    color: var(--brand-brown);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-shadow: none;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14);
}
@media (hover: none) {
    #portfolio .portfolio-card .absolute.inset-0.bg-gradient-to-t {
        opacity: 0.44 !important;
    }
    #portfolio .portfolio-card .absolute.bottom-0 {
        opacity: 1 !important;
        transform: translateY(0) !important;
    }
}
