:root {
    --cream-light: #f7f6fc;
    --brown-dark: #4a4780;
    --bronze: #807dc2;
    --cream-light-hover: #efeef8;
    --brown-dark-light: #5a5599;
    --bronze-light: #9a97d4;
    --bronze-dark: #6663a8;
    --white: #FFFFFF;
    --gray-light: #F5F5F5;
    --gray-medium: #CCCCCC;
    --shadow: rgba(128, 125, 194, .1);
    --shadow-strong: rgba(128, 125, 194, .2);
    --transition: all .3s cubic-bezier(.4, 0, .2, 1)
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

body {
    font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, sans-serif;
    line-height: 1.6;
    color: var(--brown-dark);
    background-color: var(--cream-light)
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 3rem
}

@media (min-width: 1400px) {
    .container {
        padding: 0 4rem
    }
}

.hero-section-clean {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    background: linear-gradient(135deg, var(--cream-light) 0%, rgba(255, 255, 255, .95) 50%, var(--white) 100%);
    padding: 2rem 0;
    overflow: hidden
}

.hero-section-clean:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(circle at 20% 80%, rgba(128, 125, 194, .1) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(128, 125, 194, .08) 0%, transparent 50%), radial-gradient(circle at 40% 40%, rgba(128, 125, 194, .05) 0%, transparent 50%);
    animation: backgroundPulse 8s ease-in-out infinite;
    z-index: 1
}

.hero-section-clean:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: linear-gradient(45deg, transparent 40%, rgba(128, 125, 194, .03) 50%, transparent 60%), linear-gradient(-45deg, transparent 40%, rgba(128, 125, 194, .02) 50%, transparent 60%);
    background-size: 60px 60px, 40px 40px;
    animation: textureMove 20s linear infinite;
    z-index: 1
}

.hero-floating-elements {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    pointer-events: none;
    opacity: 0;
    animation: heroBackgroundFadeIn 1.5s ease-out .5s forwards
}

.floating-shape {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(45deg, #807dc21a, #807dc20d);
    animation: floatUpDown 6s ease-in-out infinite
}

.floating-shape:nth-child(1) {
    width: 80px;
    height: 80px;
    top: 20%;
    left: 10%;
    animation-delay: 0s;
    animation-duration: 8s
}

.floating-shape:nth-child(2) {
    width: 60px;
    height: 60px;
    top: 60%;
    right: 15%;
    animation-delay: -2s;
    animation-duration: 10s
}

.floating-shape:nth-child(3) {
    width: 40px;
    height: 40px;
    top: 80%;
    left: 20%;
    animation-delay: -4s;
    animation-duration: 7s
}

.floating-shape:nth-child(4) {
    width: 100px;
    height: 100px;
    top: 10%;
    right: 25%;
    animation-delay: -1s;
    animation-duration: 9s
}

.hero-waves {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 200px;
    z-index: 1;
    opacity: 0;
    animation: heroWavesFadeIn 1.8s ease-out 1s forwards
}

.wave-layer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(128, 125, 194, .1), transparent);
    border-radius: 50% 50% 0 0/100% 100% 0 0;
    animation: waveMove 15s ease-in-out infinite
}

.wave-layer:nth-child(2) {
    animation-delay: -5s;
    animation-duration: 18s;
    opacity: .7
}

.wave-layer:nth-child(3) {
    animation-delay: -10s;
    animation-duration: 12s;
    opacity: .5
}

@keyframes backgroundPulse {

    0%,
    to {
        opacity: 1;
        transform: scale(1)
    }

    50% {
        opacity: .8;
        transform: scale(1.05)
    }
}

@keyframes textureMove {
    0% {
        background-position: 0 0, 0 0
    }

    to {
        background-position: 60px 60px, -40px -40px
    }
}

@keyframes floatUpDown {

    0%,
    to {
        transform: translateY(0) rotate(0)
    }

    33% {
        transform: translateY(-20px) rotate(120deg)
    }

    66% {
        transform: translateY(10px) rotate(240deg)
    }
}

@keyframes waveMove {

    0%,
    to {
        transform: translate(0) scaleY(1)
    }

    50% {
        transform: translate(-50px) scaleY(1.1)
    }
}

@keyframes imageFloat {

    0%,
    to {
        transform: translateY(0) rotate(0)
    }

    33% {
        transform: translateY(-10px) rotate(1deg)
    }

    66% {
        transform: translateY(5px) rotate(-.5deg)
    }
}

@keyframes borderGlow {

    0%,
    to {
        background-position: 0% 50%;
        opacity: .8
    }

    50% {
        background-position: 100% 50%;
        opacity: 1
    }
}

@keyframes pulseRing {
    0% {
        transform: translate(-50%, -50%) scale(0);
        opacity: 1
    }

    50% {
        transform: translate(-50%, -50%) scale(1);
        opacity: .6
    }

    to {
        transform: translate(-50%, -50%) scale(1.5);
        opacity: 0
    }
}

@keyframes imageShine {

    0%,
    to {
        filter: brightness(1) saturate(1)
    }

    50% {
        filter: brightness(1.05) saturate(1.1)
    }
}

@keyframes orbitRotate {
    0% {
        transform: rotate(0) translate(200px) rotate(0)
    }

    to {
        transform: rotate(360deg) translate(200px) rotate(-360deg)
    }
}

.hero-artistic-bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1
}

.hero-geometric-shapes {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.geometric-shape {
    position: absolute;
    opacity: .1
}

.shape-hexagon {
    top: 10%;
    left: 5%;
    width: 80px;
    height: 80px;
    background: var(--bronze);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    animation: floatHexagon 8s ease-in-out infinite
}

.shape-triangle {
    top: 20%;
    right: 10%;
    width: 60px;
    height: 60px;
    background: var(--bronze-light);
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
    animation: floatTriangle 6s ease-in-out infinite reverse
}

.shape-circle {
    bottom: 30%;
    left: 8%;
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, var(--bronze) 0%, var(--bronze-light) 100%);
    border-radius: 50%;
    animation: floatCircle 10s ease-in-out infinite
}

.shape-square {
    bottom: 15%;
    right: 15%;
    width: 70px;
    height: 70px;
    background: var(--bronze);
    transform: rotate(45deg);
    animation: floatSquare 7s ease-in-out infinite
}

.hero-fluid-waves {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 200px;
    overflow: hidden
}

.wave {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none
}

.wave-1 {
    animation: waveMove1 15s ease-in-out infinite
}

.wave-2 {
    animation: waveMove2 12s ease-in-out infinite reverse
}

.wave-3 {
    animation: waveMove3 18s ease-in-out infinite
}

.hero-particles {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.particle {
    position: absolute;
    width: 4px;
    height: 4px;
    background: var(--bronze);
    border-radius: 50%;
    opacity: .6
}

.particle-1 {
    top: 20%;
    left: 15%;
    animation: particleFloat1 12s linear infinite
}

.particle-2 {
    top: 40%;
    left: 80%;
    animation: particleFloat2 15s linear infinite
}

.particle-3 {
    top: 60%;
    left: 25%;
    animation: particleFloat3 10s linear infinite
}

.particle-4 {
    top: 30%;
    left: 70%;
    animation: particleFloat4 14s linear infinite
}

.particle-5 {
    top: 80%;
    left: 40%;
    animation: particleFloat5 11s linear infinite
}

.particle-6 {
    top: 10%;
    left: 60%;
    animation: particleFloat6 13s linear infinite
}

.hero-grid-pattern {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: linear-gradient(rgba(128, 125, 194, .03) 1px, transparent 1px), linear-gradient(90deg, rgba(128, 125, 194, .03) 1px, transparent 1px);
    background-size: 50px 50px;
    animation: gridMove 25s linear infinite
}

.hero-main-content {
    position: relative;
    z-index: 10;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
    min-height: 80vh;
    opacity: 0;
    animation: heroContentFadeIn 1.2s ease-out .3s forwards
}

.hero-text-area {
    position: relative;
    padding-left: 2rem;
    padding-top: 3rem;
    opacity: 0;
    transform: translate(-50px);
    animation: heroTextSlideIn 1s ease-out .6s forwards
}

.hero-badge-floating {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #807dc21a;
    border: 1px solid rgba(128, 125, 194, .2);
    color: var(--bronze);
    padding: .75rem 1.25rem;
    border-radius: 25px;
    font-size: .9rem;
    font-weight: 600;
    margin-bottom: 2rem;
    animation: badgeFloat 3s ease-in-out infinite, heroBadgeEntrance .8s ease-out .9s both;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    opacity: 0;
    transform: translateY(-20px) scale(.8)
}

.badge-icon {
    font-size: 1.1rem;
    animation: iconSpin 4s linear infinite
}

.hero-title-new {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: 1.5rem;
    color: var(--brown-dark);
    opacity: 0;
    transform: translateY(30px);
    animation: heroTitleSlideUp 1s ease-out 1.2s forwards
}

.title-line-1,
.title-line-3 {
    display: block;
    color: var(--brown-dark);
    opacity: 0;
    transform: translate(-30px)
}

.title-line-1 {
    animation: heroLineSlideIn .8s ease-out 1.4s forwards
}

.title-line-3 {
    animation: heroLineSlideIn .8s ease-out 1.8s forwards
}

.title-line-2 {
    display: block;
    margin: .5rem 0;
    opacity: 0;
    transform: scale(.8);
    animation: heroHighlightPop .8s ease-out 1.6s forwards
}

.title-highlight {
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    position: relative;
    animation: titleGlow 2s ease-in-out infinite
}

.hero-description-new {
    font-size: 1.2rem;
    line-height: 1.6;
    color: var(--brown-dark-light);
    margin-bottom: 2rem;
    max-width: 500px;
    opacity: 0;
    transform: translateY(20px);
    animation: heroDescriptionFadeIn .8s ease-out 2s forwards
}

.hero-description-new strong {
    color: var(--bronze);
    font-weight: 600
}

.hero-quick-stats {
    display: flex;
    gap: 2rem;
    margin-bottom: 3rem;
    opacity: 0;
    transform: translateY(30px);
    animation: heroStatsSlideUp .8s ease-out 2.3s forwards
}

.quick-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    opacity: 0;
    transform: translateY(20px) scale(.8)
}

.quick-stat:nth-child(1) {
    animation: heroStatPop .6s ease-out 2.5s forwards
}

.quick-stat:nth-child(2) {
    animation: heroStatPop .6s ease-out 2.7s forwards
}

.quick-stat:nth-child(3) {
    animation: heroStatPop .6s ease-out 2.9s forwards
}

.stat-number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--bronze);
    line-height: 1;
    animation: statPulse 2s ease-in-out infinite
}

.stat-label {
    font-size: .9rem;
    color: var(--brown-dark-light);
    font-weight: 500;
    margin-top: .25rem
}

.hero-actions-new {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    opacity: 0;
    transform: translateY(30px);
    animation: heroActionsSlideUp .8s ease-out 3.1s forwards
}

.hero-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: 1rem 2rem;
    border-radius: 25px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    transition: all .3s ease;
    overflow: hidden;
    border: none;
    cursor: pointer
}

.hero-btn-primary {
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: #fff;
    box-shadow: 0 4px 15px #25d3664d
}

.hero-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px #25d36666
}

.hero-btn-secondary {
    background: #807dc21a;
    color: var(--bronze);
    border: 2px solid rgba(128, 125, 194, .3)
}

.hero-btn-secondary:hover {
    background: #807dc233;
    border-color: var(--bronze);
    transform: translateY(-2px)
}

.btn-content {
    display: flex;
    align-items: center;
    gap: .75rem;
    position: relative;
    z-index: 2
}

.btn-icon {
    width: 1.2rem;
    height: 1.2rem
}

.btn-shine {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .3), transparent);
    transition: left .6s ease
}

.hero-btn-primary:hover .btn-shine {
    left: 100%
}

.hero-visual-animated {
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transform: translate(50px) scale(.9);
    animation: heroVisualSlideIn 1.2s ease-out .8s forwards
}

.hero-image-container {
    position: relative;
    width: 400px;
    height: 400px;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 40px #3f200026;
    animation: imageFloat 6s ease-in-out infinite
}

.hero-image-container:before {
    content: "";
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(45deg, var(--bronze), var(--bronze-light), var(--bronze), var(--bronze-light));
    background-size: 400% 400%;
    border-radius: 22px;
    z-index: -1;
    animation: borderGlow 4s ease-in-out infinite
}

.hero-image-container:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 60px;
    height: 60px;
    background: #fff3;
    border-radius: 50%;
    transform: translate(-50%, -50%) scale(0);
    animation: pulseRing 3s ease-in-out infinite;
    z-index: 2
}

.hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all .4s cubic-bezier(.4, 0, .2, 1);
    animation: imageShine 8s ease-in-out infinite
}

.hero-image-container:hover .hero-image {
    transform: scale(1.08) rotate(2deg);
    filter: brightness(1.1) contrast(1.05)
}

.hero-image-container:hover:after {
    animation-duration: 1.5s
}

.hero-image-container .orbital-dots {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 120%;
    height: 120%;
    transform: translate(-50%, -50%);
    z-index: 3;
    pointer-events: none
}

.orbital-dot {
    position: absolute;
    width: 8px;
    height: 8px;
    background: var(--bronze);
    border-radius: 50%;
    opacity: .6
}

.orbital-dot:nth-child(1) {
    top: 0;
    left: 50%;
    transform: translate(-50%);
    animation: orbitRotate 10s linear infinite
}

.orbital-dot:nth-child(2) {
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    animation: orbitRotate 10s linear infinite -2.5s
}

.orbital-dot:nth-child(3) {
    bottom: 0;
    left: 50%;
    transform: translate(-50%);
    animation: orbitRotate 10s linear infinite -5s
}

.orbital-dot:nth-child(4) {
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    animation: orbitRotate 10s linear infinite -7.5s
}

.hero-image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(45deg, #807dc2cc, #807dc299);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .3s ease
}

.hero-image-container:hover .hero-image-overlay {
    opacity: 1
}

.overlay-content {
    text-align: center;
    color: #fff
}

.overlay-icon {
    font-size: 3rem;
    margin-bottom: 1rem
}

.overlay-content h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: .5rem
}

.overlay-content p {
    font-size: 1rem;
    opacity: .9
}

.morphing-container {
    position: relative;
    width: 400px;
    height: 400px;
    max-width: 100%;
    overflow: hidden
}

.morphing-shape {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.morph-layer {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    opacity: .1
}

.morph-layer-1 {
    width: 300px;
    height: 300px;
    background: linear-gradient(45deg, var(--bronze), var(--bronze-light));
    animation: morphLayer1 8s ease-in-out infinite
}

.morph-layer-2 {
    width: 250px;
    height: 250px;
    background: linear-gradient(135deg, var(--bronze-light), var(--bronze));
    animation: morphLayer2 6s ease-in-out infinite reverse
}

.morph-layer-3 {
    width: 200px;
    height: 200px;
    background: linear-gradient(225deg, var(--bronze), var(--bronze-light));
    animation: morphLayer3 10s ease-in-out infinite
}

.visual-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    z-index: 3
}

.visual-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 1rem;
    color: var(--bronze);
    animation: iconPulse 2s ease-in-out infinite
}

.visual-icon svg {
    width: 100%;
    height: 100%
}

.visual-text h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: .5rem;
    line-height: 1.2
}

.visual-text p {
    font-size: .95rem;
    color: var(--brown-dark-light);
    line-height: 1.4
}

.orbital-elements {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
    pointer-events: none
}

.orbital-item {
    position: absolute;
    width: 50px;
    height: 50px;
    background: #807dc21a;
    border: 2px solid rgba(128, 125, 194, .3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px)
}

.orbital-1 {
    top: 10%;
    left: 10%;
    animation: orbital1 12s linear infinite
}

.orbital-2 {
    top: 10%;
    right: 10%;
    animation: orbital2 15s linear infinite reverse
}

.orbital-3 {
    bottom: 10%;
    left: 10%;
    animation: orbital3 10s linear infinite
}

.orbital-4 {
    bottom: 10%;
    right: 10%;
    animation: orbital4 18s linear infinite reverse
}

.orbital-icon {
    font-size: 1.2rem
}

.hero-section {
    min-height: 100vh;
    display: flex;
    align-items: center;
    background: linear-gradient(135deg, var(--cream-light) 0%, var(--cream-light-hover) 100%);
    position: relative;
    overflow: hidden
}

.hero-background {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    overflow: hidden
}

.hero-stripe {
    position: absolute;
    background: linear-gradient(45deg, transparent 0%, rgba(128, 125, 194, .05) 20%, rgba(128, 125, 194, .15) 40%, rgba(128, 125, 194, .25) 50%, rgba(128, 125, 194, .15) 60%, rgba(128, 125, 194, .05) 80%, transparent 100%);
    transform: rotate(15deg);
    animation: slideStripe 15s linear infinite, pulseStripe 8s ease-in-out infinite;
    filter: blur(.5px);
    box-shadow: 0 0 20px #807dc21a
}

.hero-stripe-1 {
    width: 200px;
    height: 120vh;
    top: -10vh;
    right: 10%;
    animation-delay: 0s, -2s;
    animation-duration: 15s, 8s
}

.hero-stripe-2 {
    width: 150px;
    height: 120vh;
    top: -10vh;
    right: 25%;
    animation-delay: -5s, -4s;
    animation-duration: 18s, 10s;
    opacity: .8
}

.hero-stripe-3 {
    width: 100px;
    height: 120vh;
    top: -10vh;
    right: 35%;
    animation-delay: -10s, -6s;
    animation-duration: 12s, 6s;
    opacity: .6
}

.hero-shapes {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.hero-shape {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(135deg, #807dc21a, #e6944a0d);
    animation: floatShape 15s ease-in-out infinite
}

.hero-shape-1 {
    width: 120px;
    height: 120px;
    top: 15%;
    right: 5%;
    animation-delay: 0s
}

.hero-shape-2 {
    width: 80px;
    height: 80px;
    top: 60%;
    right: 15%;
    animation-delay: -5s
}

.hero-shape-3 {
    width: 60px;
    height: 60px;
    top: 25%;
    left: 5%;
    animation-delay: -10s
}

.hero-shape-4 {
    width: 40px;
    height: 40px;
    top: 70%;
    left: 15%;
    animation-delay: -2s
}

.hero-dots {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.dot-pattern {
    position: absolute;
    width: 200px;
    height: 200px;
    background-image: radial-gradient(circle, rgba(128, 125, 194, .15) 2px, transparent 2px);
    background-size: 20px 20px;
    animation: rotateDots 30s linear infinite
}

.dot-pattern-1 {
    top: 10%;
    right: 8%;
    animation-delay: 0s
}

.dot-pattern-2 {
    bottom: 15%;
    left: 10%;
    animation-delay: -15s;
    opacity: .6
}

.hero-lines {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.animated-line {
    position: absolute;
    background: linear-gradient(90deg, transparent 0%, rgba(128, 125, 194, .3) 50%, transparent 100%);
    border-radius: 2px;
    animation: moveLine 12s ease-in-out infinite
}

.line-1 {
    width: 300px;
    height: 2px;
    top: 30%;
    left: -300px;
    animation-delay: 0s
}

.line-2 {
    width: 200px;
    height: 1px;
    top: 70%;
    right: -200px;
    animation-delay: -4s;
    animation-direction: reverse
}

.line-3 {
    width: 150px;
    height: 1px;
    top: 50%;
    left: -150px;
    animation-delay: -8s
}

.hero-container {
    width: 100%;
    position: relative;
    z-index: 2
}

.hero-content {
    display: flex;
    align-items: flex-start;
    gap: 5rem;
    max-width: 1200px;
    margin: 0 auto;
    min-height: 80vh;
    padding: 0 1rem
}

.hero-text {
    max-width: 600px;
    padding-left: 3rem;
    margin-left: 8rem;
    justify-self: start;
    width: 100%
}

.hero-title {
    font-size: 3.5rem;
    font-weight: 700;
    line-height: 1.1;
    margin-bottom: 1.5rem;
    color: var(--brown-dark)
}

.hero-highlight {
    color: var(--bronze);
    position: relative
}

.hero-highlight:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: linear-gradient(90deg, var(--bronze), var(--bronze-light));
    border-radius: 2px
}

.hero-description {
    font-size: 1.25rem;
    line-height: 1.7;
    margin-bottom: 2.5rem;
    color: var(--brown-dark-light)
}

.hero-cta {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap
}

.cta-section-new {
    position: relative;
    overflow: hidden
}

.cta-main-content {
    opacity: 0;
    transform: translate(-60px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.cta-main-content.animate-in {
    opacity: 1;
    transform: translate(0)
}

.cta-action-card {
    opacity: 0;
    transform: translate(60px) scale(.95);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .2s
}

.cta-action-card.animate-in {
    opacity: 1;
    transform: translate(0) scale(1)
}

.cta-eyebrow {
    opacity: 0;
    transform: translateY(-20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .3s
}

.cta-eyebrow.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-mega-title {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .5s
}

.cta-mega-title.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-subtitle {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .7s
}

.cta-subtitle.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-quick-stats {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .9s
}

.cta-quick-stats.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-stat {
    opacity: 0;
    transform: translateY(20px) scale(.8);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.cta-stat:nth-child(1) {
    transition-delay: 1.1s
}

.cta-stat:nth-child(2) {
    transition-delay: 1.3s
}

.cta-stat:nth-child(3) {
    transition-delay: 1.5s
}

.cta-stat.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.cta-card-header {
    opacity: 0;
    transform: translateY(-30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .4s
}

.cta-card-header.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-card-features {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .6s
}

.cta-card-features.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-feature-item {
    opacity: 0;
    transform: translate(20px);
    transition: all .5s cubic-bezier(.4, 0, .2, 1)
}

.cta-feature-item:nth-child(1) {
    transition-delay: .8s
}

.cta-feature-item:nth-child(2) {
    transition-delay: 1s
}

.cta-feature-item:nth-child(3) {
    transition-delay: 1.2s
}

.cta-feature-item.animate-in {
    opacity: 1;
    transform: translate(0)
}

.cta-card-actions {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1.4s
}

.cta-card-actions.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.cta-card-footer {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 1.6s
}

.cta-card-footer.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.hero-cta-card {
    position: relative;
    background: linear-gradient(135deg, var(--white) 0%, #fcf8f4 100%);
    border-radius: 24px;
    padding: 2rem;
    box-shadow: 0 20px 60px #3f20001a, 0 8px 25px #3f20000d;
    border: 1px solid rgba(128, 125, 194, .1);
    overflow: hidden;
    transition: var(--transition);
    max-width: 400px;
    margin-right: 2rem;
    margin-left: 2rem
}

.hero-cta-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 30px 80px #3f200026, 0 12px 35px #3f200014;
    border-color: #807dc233
}

.cta-decorations {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    z-index: 1
}

.cta-circle {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(135deg, #807dc21a, #e6944a0d);
    animation: ctaFloat 8s ease-in-out infinite
}

.cta-circle-1 {
    width: 80px;
    height: 80px;
    top: -20px;
    right: -20px;
    animation-delay: 0s
}

.cta-circle-2 {
    width: 60px;
    height: 60px;
    bottom: -15px;
    left: -15px;
    animation-delay: -4s
}

.cta-sparkle {
    position: absolute;
    font-size: 1.2rem;
    animation: ctaSparkle 3s ease-in-out infinite;
    opacity: .7
}

.cta-sparkle-1 {
    top: 20px;
    left: 20px;
    animation-delay: 0s
}

.cta-sparkle-2 {
    bottom: 30px;
    right: 30px;
    animation-delay: -1.5s
}

.cta-content {
    position: relative;
    z-index: 2
}

.cta-badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    color: var(--white);
    padding: .5rem 1rem;
    border-radius: 20px;
    font-size: .875rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
    animation: ctaPulse 2s ease-in-out infinite
}

.cta-badge-icon {
    font-size: 1rem
}

.cta-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 1rem;
    line-height: 1.3
}

.cta-description {
    color: var(--brown-dark-light);
    line-height: 1.6;
    margin-bottom: 1.5rem;
    font-size: .95rem
}

.cta-description strong {
    color: var(--bronze);
    font-weight: 600
}

.cta-features {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    margin-bottom: 2rem
}

.cta-feature-icon {
    font-size: 1rem;
    flex-shrink: 0
}

.cta-whatsapp-btn {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1rem;
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: var(--white);
    padding: 1rem 1.5rem;
    border-radius: 16px;
    text-decoration: none;
    font-weight: 600;
    transition: all .3s ease;
    box-shadow: 0 8px 25px #25d3664d;
    overflow: hidden
}

.cta-whatsapp-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px #25d36666;
    background: linear-gradient(135deg, #128c7e, #25d366)
}

.whatsapp-icon {
    width: 2.5rem;
    height: 2.5rem;
    background: #fff3;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.whatsapp-icon svg {
    width: 1.5rem;
    height: 1.5rem
}

.whatsapp-content {
    flex: 1
}

.whatsapp-text {
    display: block;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.2
}

.whatsapp-subtext {
    display: block;
    font-size: .8rem;
    opacity: .9;
    font-weight: 400
}

.whatsapp-pulse {
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
    width: 12px;
    height: 12px;
    background: #fffc;
    border-radius: 50%;
    animation: whatsappPulse 2s ease-in-out infinite
}

@keyframes ctaFloat {

    0%,
    to {
        transform: translateY(0) rotate(0);
        opacity: .1
    }

    50% {
        transform: translateY(-10px) rotate(180deg);
        opacity: .2
    }
}

@keyframes ctaSparkle {

    0%,
    to {
        transform: scale(1) rotate(0);
        opacity: .7
    }

    50% {
        transform: scale(1.2) rotate(180deg);
        opacity: 1
    }
}

@keyframes ctaPulse {

    0%,
    to {
        transform: scale(1);
        box-shadow: 0 4px 15px #807dc24d
    }

    50% {
        transform: scale(1.05);
        box-shadow: 0 6px 20px #807dc266
    }
}

@keyframes whatsappPulse {

    0%,
    to {
        transform: translateY(-50%) scale(1);
        opacity: .8
    }

    50% {
        transform: translateY(-50%) scale(1.5);
        opacity: .4
    }
}

@keyframes ctaBgFloat {

    0%,
    to {
        transform: translateY(0) rotate(0);
        opacity: .1
    }

    50% {
        transform: translateY(-20px) rotate(180deg);
        opacity: .2
    }
}

@keyframes ctaPatternMove {
    0% {
        background-position: 0 0, 0 0
    }

    to {
        background-position: 50px 50px, 30px 30px
    }
}

@keyframes ctaBadgePulse {

    0%,
    to {
        transform: scale(1);
        box-shadow: 0 4px 15px #fff3
    }

    50% {
        transform: scale(1.05);
        box-shadow: 0 6px 20px #ffffff4d
    }
}

@keyframes ctaUrgencyPulse {

    0%,
    to {
        transform: scale(1);
        box-shadow: 0 4px 15px #ff57224d
    }

    50% {
        transform: scale(1.02);
        box-shadow: 0 6px 20px #ff572266
    }
}

@keyframes ctaFireFlicker {
    0% {
        transform: scale(1) rotate(-2deg)
    }

    to {
        transform: scale(1.1) rotate(2deg)
    }
}

@keyframes ctaArrowBounce {

    0%,
    to {
        transform: translate(0)
    }

    50% {
        transform: translate(5px)
    }
}

@keyframes ctaEyebrowGlow {

    0%,
    to {
        box-shadow: 0 0 10px #807dc24d
    }

    50% {
        box-shadow: 0 0 20px #807dc280
    }
}

@keyframes ctaIconSpark {

    0%,
    to {
        transform: scale(1) rotate(0)
    }

    50% {
        transform: scale(1.2) rotate(180deg)
    }
}

@keyframes ctaGradientShift {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    to {
        background-position: 0% 50%
    }
}

@keyframes ctaStatPulse {

    0%,
    to {
        transform: scale(1)
    }

    50% {
        transform: scale(1.05)
    }
}

@keyframes ctaCardTopGlow {
    0% {
        background-position: -200% 0
    }

    to {
        background-position: 200% 0
    }
}

@keyframes ctaPulseDot {

    0%,
    to {
        transform: scale(1);
        opacity: 1
    }

    50% {
        transform: scale(1.5);
        opacity: .7
    }
}

.cta-section-new {
    position: relative;
    padding: 6rem 0;
    background: linear-gradient(135deg, #1a1a2e, #16213e, #0f3460);
    overflow: hidden
}

.cta-background-video {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1
}

.cta-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, #807dc21a, #1a1a2ecc, #0f3460e6);
    -webkit-backdrop-filter: blur(1px);
    backdrop-filter: blur(1px)
}

.cta-content-grid {
    display: grid;
    grid-template-columns: 1.3fr .7fr;
    gap: 4rem;
    align-items: center;
    position: relative;
    z-index: 2
}

.cta-main-content {
    color: var(--white)
}

.cta-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #807dc233;
    border: 1px solid rgba(128, 125, 194, .3);
    color: var(--bronze-light);
    padding: .5rem 1rem;
    border-radius: 20px;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: 2rem;
    animation: ctaEyebrowGlow 3s ease-in-out infinite
}

.cta-eyebrow-icon {
    font-size: 1rem;
    animation: ctaIconSpark 2s ease-in-out infinite
}

.cta-mega-title {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: 1.5rem;
    color: var(--white)
}

.cta-gradient-text {
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light), #ffd700);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-size: 200% 200%;
    animation: ctaGradientShift 4s ease-in-out infinite
}

.cta-subtitle {
    font-size: 1.2rem;
    line-height: 1.6;
    color: #ffffffe6;
    margin-bottom: 3rem
}

.cta-subtitle strong {
    color: var(--bronze-light);
    font-weight: 600
}

.cta-quick-stats {
    display: flex;
    gap: 2rem;
    margin-top: 2rem
}

.cta-stat {
    text-align: center
}

.cta-stat-number {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--bronze);
    line-height: 1;
    margin-bottom: .5rem;
    animation: ctaStatPulse 3s ease-in-out infinite
}

.cta-stat-label {
    font-size: .9rem;
    color: #ffffffb3;
    font-weight: 500
}

.cta-action-card {
    background: #fffffff2;
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    border-radius: 24px;
    padding: 2.5rem;
    box-shadow: 0 25px 80px #0000004d, 0 10px 40px #807dc233;
    border: 1px solid rgba(255, 255, 255, .2);
    position: relative;
    overflow: hidden
}

.cta-action-card:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--bronze), var(--bronze-light), #ffd700);
    background-size: 200% 100%;
    animation: ctaCardTopGlow 3s ease-in-out infinite
}

.cta-card-header {
    text-align: center;
    margin-bottom: 2rem
}

.cta-card-badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #22c55e1a;
    color: #059669;
    padding: .5rem 1rem;
    border-radius: 20px;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: 1rem
}

.cta-pulse-dot {
    width: 8px;
    height: 8px;
    background: #10b981;
    border-radius: 50%;
    animation: ctaPulseDot 2s ease-in-out infinite
}

.cta-card-title {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: .5rem
}

.cta-card-subtitle {
    color: var(--brown-dark-light);
    font-size: 1rem
}

.cta-card-features {
    margin-bottom: 2rem
}

.cta-feature-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1rem;
    color: var(--brown-dark)
}

.cta-feature-check {
    width: 1.5rem;
    height: 1.5rem;
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 700;
    flex-shrink: 0
}

.cta-card-actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 2rem
}

.cta-primary-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: #fff;
    padding: 1rem 1.5rem;
    border-radius: 16px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    transition: all .3s ease;
    overflow: hidden;
    box-shadow: 0 8px 25px #25d3664d
}

.cta-primary-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px #25d36666
}

.cta-btn-content {
    display: flex;
    align-items: center;
    gap: .5rem;
    position: relative;
    z-index: 2
}

.cta-btn-icon {
    width: 1.2rem;
    height: 1.2rem
}

.cta-btn-shine {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .3), transparent);
    transition: left .6s ease
}

.cta-primary-btn:hover .cta-btn-shine {
    left: 100%
}

.cta-secondary-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    background: transparent;
    color: var(--brown-dark);
    padding: 1rem 1.5rem;
    border: 2px solid rgba(128, 125, 194, .3);
    border-radius: 16px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    transition: all .3s ease
}

.cta-secondary-btn:hover {
    background: #807dc21a;
    border-color: var(--bronze);
    color: var(--bronze)
}

.cta-card-footer {
    border-top: 1px solid rgba(128, 125, 194, .1);
    padding-top: 1.5rem
}

.cta-trust-indicators {
    display: flex;
    justify-content: space-between;
    gap: 1rem
}

.cta-trust-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: var(--brown-dark-light);
    font-size: .85rem
}

.cta-trust-icon {
    font-size: 1rem
}

.contact-section-new {
    position: relative;
    padding: 5rem 0;
    background: var(--cream-light);
    overflow: hidden
}

.contact-background {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1
}

.contact-pattern {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: radial-gradient(circle at 20% 20%, rgba(128, 125, 194, .05) 2px, transparent 2px), radial-gradient(circle at 80% 80%, rgba(128, 125, 194, .03) 1px, transparent 1px);
    background-size: 60px 60px, 40px 40px;
    animation: contactPatternMove 25s linear infinite
}

.contact-gradient-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, #fcf8f4cc, #ffffffe6, #fcf8f4cc)
}

.contact-wrapper {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 4rem;
    align-items: center;
    position: relative;
    z-index: 2
}

.contact-hero {
    color: var(--brown-dark)
}

.contact-badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #807dc21a;
    border: 1px solid rgba(128, 125, 194, .2);
    color: var(--bronze);
    padding: .5rem 1rem;
    border-radius: 20px;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: 2rem;
    animation: contactBadgeGlow 3s ease-in-out infinite
}

.contact-badge-icon {
    font-size: 1rem;
    animation: contactIconBounce 2s ease-in-out infinite
}

.contact-title {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1.5rem;
    color: var(--brown-dark)
}

.contact-highlight {
    color: var(--bronze);
    position: relative
}

.contact-highlight:after {
    content: "";
    position: absolute;
    bottom: 2px;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--bronze), var(--bronze-light));
    border-radius: 2px;
    animation: contactHighlightGlow 2s ease-in-out infinite
}

.contact-description {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--brown-dark-light);
    margin-bottom: 3rem
}

.contact-description strong {
    color: var(--bronze);
    font-weight: 600
}

.contact-methods {
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.contact-method {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: var(--white);
    border-radius: 16px;
    text-decoration: none;
    transition: all .3s ease;
    box-shadow: 0 4px 15px #3f200014;
    border: 1px solid rgba(128, 125, 194, .1);
    position: relative;
    overflow: hidden
}

.contact-method:before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(128, 125, 194, .1), transparent);
    transition: left .6s ease
}

.contact-method:hover:before {
    left: 100%
}

.contact-method:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px #3f20001f;
    border-color: var(--bronze)
}

.contact-whatsapp {
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: #fff
}

.contact-whatsapp:hover {
    box-shadow: 0 8px 25px #25d3664d
}

.contact-phone {
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    color: #fff
}

.contact-phone:hover {
    box-shadow: 0 8px 25px #807dc24d
}

.contact-method-icon {
    width: 3rem;
    height: 3rem;
    background: #fff3;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.contact-method-icon svg {
    width: 1.5rem;
    height: 1.5rem
}

.contact-method-content {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    flex: 1
}

.contact-method-title {
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.2
}

.contact-method-subtitle {
    font-size: .9rem;
    opacity: .9
}

.contact-method-arrow {
    font-size: 1.5rem;
    font-weight: 700;
    animation: contactArrowBounce 1.5s ease-in-out infinite
}

.contact-info-card {
    background: var(--white);
    border-radius: 20px;
    padding: 2rem;
    box-shadow: 0 15px 40px #3f20001a;
    border: 1px solid rgba(128, 125, 194, .1)
}

.contact-card-header {
    text-align: center;
    margin-bottom: 2rem
}

.contact-card-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: .5rem
}

.contact-card-subtitle {
    color: var(--brown-dark-light);
    font-size: .95rem
}

.contact-info-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-bottom: 2rem
}

.contact-info-item {
    display: flex;
    align-items: center;
    gap: 1rem
}

.contact-info-icon {
    width: 2.5rem;
    height: 2.5rem;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.contact-info-icon svg {
    width: 1.2rem;
    height: 1.2rem;
    color: #fff
}

.contact-info-content {
    display: flex;
    flex-direction: column;
    gap: .25rem
}

.contact-info-label {
    font-size: .85rem;
    color: var(--brown-dark-light);
    font-weight: 500
}

.contact-info-value {
    font-size: 1rem;
    color: var(--brown-dark);
    font-weight: 600
}

.contact-guarantees {
    display: flex;
    gap: 1rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(128, 125, 194, .1)
}

.contact-guarantee {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .85rem;
    color: var(--brown-dark-light);
    font-weight: 500
}

.guarantee-icon {
    font-size: 1rem
}

@keyframes contactPatternMove {
    0% {
        background-position: 0 0, 0 0
    }

    to {
        background-position: 60px 60px, 40px 40px
    }
}

@keyframes contactBadgeGlow {

    0%,
    to {
        box-shadow: 0 0 10px #807dc233
    }

    50% {
        box-shadow: 0 0 20px #807dc266
    }
}

@keyframes contactIconBounce {

    0%,
    to {
        transform: translateY(0)
    }

    50% {
        transform: translateY(-3px)
    }
}

@keyframes contactHighlightGlow {

    0%,
    to {
        opacity: 1;
        transform: scaleX(1)
    }

    50% {
        opacity: .8;
        transform: scaleX(1.05)
    }
}

@keyframes contactArrowBounce {

    0%,
    to {
        transform: translate(0)
    }

    50% {
        transform: translate(5px)
    }
}

.gallery-section {
    position: relative;
    padding: 5rem 0;
    background: var(--white);
    overflow: hidden
}

.gallery-background {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1
}

.gallery-pattern {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: linear-gradient(45deg, rgba(128, 125, 194, .02) 25%, transparent 25%), linear-gradient(-45deg, rgba(128, 125, 194, .02) 25%, transparent 25%), linear-gradient(45deg, transparent 75%, rgba(128, 125, 194, .02) 75%), linear-gradient(-45deg, transparent 75%, rgba(128, 125, 194, .02) 75%);
    background-size: 40px 40px;
    background-position: 0 0, 0 20px, 20px -20px, -20px 0px;
    animation: galleryPatternMove 30s linear infinite
}

.section-header-gallery {
    text-align: center;
    margin-bottom: 4rem;
    position: relative;
    z-index: 2
}

.gallery-badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #807dc21a;
    border: 1px solid rgba(128, 125, 194, .2);
    color: var(--bronze);
    padding: .5rem 1rem;
    border-radius: 20px;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
    animation: galleryBadgeGlow 3s ease-in-out infinite
}

.gallery-badge-icon {
    font-size: 1rem;
    animation: galleryIconFloat 2s ease-in-out infinite
}

.gallery-title {
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1rem;
    color: var(--brown-dark)
}

.gallery-highlight {
    color: var(--bronze);
    position: relative
}

.gallery-highlight:after {
    content: "";
    position: absolute;
    bottom: 2px;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--bronze), var(--bronze-light));
    border-radius: 2px;
    animation: galleryHighlightPulse 2s ease-in-out infinite
}

.gallery-subtitle {
    font-size: 1.2rem;
    color: var(--brown-dark-light);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(4, 200px);
    gap: 1rem;
    position: relative;
    z-index: 2;
    height: auto
}

.gallery-item {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    transition: all .3s ease;
    box-shadow: 0 4px 15px #3f20001a
}

.gallery-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px #3f200033
}

.gallery-item-large {
    grid-column: span 2;
    grid-row: span 2
}

.gallery-item-tall {
    grid-row: span 2
}

.gallery-item-wide {
    grid-column: span 2
}

.gallery-item img {
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    object-fit: cover;
    object-position: center;
    transition: transform .3s ease;
    display: block;
    margin: 4px;
    border-radius: 12px
}

.gallery-item:hover img {
    transform: scale(1.05)
}

.gallery-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, #3f2000cc, #807dc2e6);
    opacity: 0;
    transition: all .3s ease;
    display: flex;
    align-items: center;
    justify-content: center
}

.gallery-overlay-content {
    text-align: center;
    color: #fff;
    padding: 1.5rem
}

.gallery-overlay-content h4 {
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: .5rem
}

.gallery-overlay-content p {
    font-size: .95rem;
    margin-bottom: 1.5rem;
    opacity: .9
}

.gallery-cta {
    text-align: center;
    background: linear-gradient(135deg, var(--cream-light), var(--white));
    padding: 3rem 2rem;
    border-radius: 20px;
    border: 1px solid rgba(128, 125, 194, .1);
    position: relative;
    z-index: 2
}

.gallery-cta-title {
    font-size: 2rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 1rem
}

.gallery-cta-text {
    font-size: 1.1rem;
    color: var(--brown-dark-light);
    margin-bottom: 2rem
}

.gallery-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: #fff;
    padding: 1rem 2rem;
    border-radius: 25px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1.1rem;
    transition: all .3s ease;
    box-shadow: 0 4px 15px #25d3664d
}

.gallery-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px #25d36666
}

.gallery-cta-btn svg {
    width: 1.2rem;
    height: 1.2rem
}

@keyframes galleryPatternMove {
    0% {
        background-position: 0 0, 0 20px, 20px -20px, -20px 0px
    }

    to {
        background-position: 40px 40px, 40px 60px, 60px 20px, 20px 40px
    }
}

@keyframes galleryBadgeGlow {

    0%,
    to {
        box-shadow: 0 0 10px #807dc233
    }

    50% {
        box-shadow: 0 0 20px #807dc266
    }
}

@keyframes galleryIconFloat {

    0%,
    to {
        transform: translateY(0)
    }

    50% {
        transform: translateY(-3px)
    }
}

@keyframes galleryHighlightPulse {

    0%,
    to {
        opacity: 1;
        transform: scaleX(1)
    }

    50% {
        opacity: .8;
        transform: scaleX(1.05)
    }
}

@keyframes floatHexagon {

    0%,
    to {
        transform: translateY(0) rotate(0)
    }

    50% {
        transform: translateY(-20px) rotate(180deg)
    }
}

@keyframes floatTriangle {

    0%,
    to {
        transform: translateY(0) rotate(0)
    }

    50% {
        transform: translateY(-15px) rotate(120deg)
    }
}

@keyframes floatCircle {

    0%,
    to {
        transform: translateY(0) scale(1)
    }

    50% {
        transform: translateY(-25px) scale(1.1)
    }
}

@keyframes floatSquare {

    0%,
    to {
        transform: rotate(45deg) translateY(0)
    }

    50% {
        transform: rotate(225deg) translateY(-20px)
    }
}

@keyframes waveMove1 {

    0%,
    to {
        transform: translate(0)
    }

    50% {
        transform: translate(-50px)
    }
}

@keyframes waveMove2 {

    0%,
    to {
        transform: translate(0)
    }

    50% {
        transform: translate(30px)
    }
}

@keyframes waveMove3 {

    0%,
    to {
        transform: translate(0)
    }

    50% {
        transform: translate(-30px)
    }
}

@keyframes particleFloat1 {
    0% {
        transform: translateY(0) translate(0);
        opacity: .6
    }

    50% {
        transform: translateY(-100px) translate(20px);
        opacity: 1
    }

    to {
        transform: translateY(-200px) translate(0);
        opacity: 0
    }
}

@keyframes particleFloat2 {
    0% {
        transform: translateY(0) translate(0);
        opacity: .6
    }

    50% {
        transform: translateY(-80px) translate(-15px);
        opacity: 1
    }

    to {
        transform: translateY(-160px) translate(0);
        opacity: 0
    }
}

@keyframes particleFloat3 {
    0% {
        transform: translateY(0) translate(0);
        opacity: .6
    }

    50% {
        transform: translateY(-120px) translate(25px);
        opacity: 1
    }

    to {
        transform: translateY(-240px) translate(0);
        opacity: 0
    }
}

@keyframes particleFloat4 {
    0% {
        transform: translateY(0) translate(0);
        opacity: .6
    }

    50% {
        transform: translateY(-90px) translate(-20px);
        opacity: 1
    }

    to {
        transform: translateY(-180px) translate(0);
        opacity: 0
    }
}

@keyframes particleFloat5 {
    0% {
        transform: translateY(0) translate(0);
        opacity: .6
    }

    50% {
        transform: translateY(-110px) translate(15px);
        opacity: 1
    }

    to {
        transform: translateY(-220px) translate(0);
        opacity: 0
    }
}

@keyframes particleFloat6 {
    0% {
        transform: translateY(0) translate(0);
        opacity: .6
    }

    50% {
        transform: translateY(-95px) translate(-10px);
        opacity: 1
    }

    to {
        transform: translateY(-190px) translate(0);
        opacity: 0
    }
}

@keyframes gridMove {
    0% {
        background-position: 0 0
    }

    to {
        background-position: 50px 50px
    }
}

@keyframes badgeFloat {

    0%,
    to {
        transform: translateY(0)
    }

    50% {
        transform: translateY(-5px)
    }
}

@keyframes iconSpin {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

@keyframes titleGlow {

    0%,
    to {
        filter: brightness(1)
    }

    50% {
        filter: brightness(1.2)
    }
}

@keyframes statPulse {

    0%,
    to {
        transform: scale(1)
    }

    50% {
        transform: scale(1.05)
    }
}

@keyframes morphLayer1 {

    0%,
    to {
        border-radius: 50%;
        transform: translate(-50%, -50%) rotate(0) scale(1)
    }

    25% {
        border-radius: 30% 70% 70% 30%/30% 30% 70% 70%;
        transform: translate(-50%, -50%) rotate(90deg) scale(1.1)
    }

    50% {
        border-radius: 70% 30% 30% 70%/70% 70% 30% 30%;
        transform: translate(-50%, -50%) rotate(180deg) scale(.9)
    }

    75% {
        border-radius: 40% 60% 60% 40%/60% 40%;
        transform: translate(-50%, -50%) rotate(270deg) scale(1.05)
    }
}

@keyframes morphLayer2 {

    0%,
    to {
        border-radius: 60% 40% 30% 70%/60% 30% 70% 40%;
        transform: translate(-50%, -50%) rotate(0) scale(1)
    }

    33% {
        border-radius: 30% 60% 70% 40%/50% 60% 30%;
        transform: translate(-50%, -50%) rotate(120deg) scale(1.1)
    }

    66% {
        border-radius: 70% 30% 40% 60%/40% 70% 60% 50%;
        transform: translate(-50%, -50%) rotate(240deg) scale(.95)
    }
}

@keyframes morphLayer3 {

    0%,
    to {
        border-radius: 40% 60% 60% 40%/70% 30% 30% 70%;
        transform: translate(-50%, -50%) rotate(0) scale(1)
    }

    20% {
        border-radius: 60% 40% 30% 70%/40% 60% 70% 30%;
        transform: translate(-50%, -50%) rotate(72deg) scale(1.08)
    }

    40% {
        border-radius: 30% 70% 40% 60%/60% 40%;
        transform: translate(-50%, -50%) rotate(144deg) scale(.92)
    }

    60% {
        border-radius: 70% 30% 60% 40%/30% 70% 40% 60%;
        transform: translate(-50%, -50%) rotate(216deg) scale(1.05)
    }

    80% {
        border-radius: 50%;
        transform: translate(-50%, -50%) rotate(288deg) scale(.98)
    }
}

@keyframes iconPulse {

    0%,
    to {
        transform: scale(1)
    }

    50% {
        transform: scale(1.1)
    }
}

@keyframes orbital1 {
    0% {
        transform: rotate(0) translate(120px) rotate(0)
    }

    to {
        transform: rotate(360deg) translate(120px) rotate(-360deg)
    }
}

@keyframes orbital2 {
    0% {
        transform: rotate(0) translate(140px) rotate(0)
    }

    to {
        transform: rotate(360deg) translate(140px) rotate(-360deg)
    }
}

@keyframes orbital3 {
    0% {
        transform: rotate(0) translate(100px) rotate(0)
    }

    to {
        transform: rotate(360deg) translate(100px) rotate(-360deg)
    }
}

@keyframes orbital4 {
    0% {
        transform: rotate(0) translate(160px) rotate(0)
    }

    to {
        transform: rotate(360deg) translate(160px) rotate(-360deg)
    }
}

.about-section {
    padding: 5rem 0;
    background: var(--cream-light)
}

.about-content-new {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 4rem;
    align-items: center;
    margin-top: 3rem
}

.about-videos,
.video-showcase {
    position: relative
}

.main-video-container {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 25px 60px #3f200026;
    background: var(--brown-dark)
}

.showcase-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity .5s ease
}

.showcase-video.active {
    opacity: 1
}

.video-zoom {
    transform: scale(1.1);
    transform-origin: center center
}

.video-info-overlay-new {
    position: absolute;
    top: 1.5rem;
    left: 1.5rem;
    z-index: 2
}

.video-badge-new {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #000000b3;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    color: var(--white);
    padding: .75rem 1.25rem;
    border-radius: 20px;
    font-size: .9rem;
    font-weight: 600
}

.video-badge-icon {
    font-size: 1rem
}

.video-thumbnails {
    display: flex;
    gap: 1rem;
    margin-top: 1.5rem
}

.video-thumb {
    flex: 1;
    background: var(--white);
    border-radius: 12px;
    padding: 1rem;
    cursor: pointer;
    transition: all .3s ease;
    border: 2px solid transparent;
    box-shadow: 0 4px 15px #3f200014
}

.video-thumb:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px #3f20001f
}

.video-thumb.active {
    border-color: var(--bronze);
    background: linear-gradient(135deg, var(--white), #fcf8f4)
}

.thumb-preview {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    text-align: center
}

.thumb-icon {
    font-size: 1.5rem;
    margin-bottom: .25rem
}

.thumb-preview span {
    font-size: .9rem;
    font-weight: 600;
    color: var(--brown-dark)
}

.about-content-text {
    display: flex;
    flex-direction: column;
    gap: 3rem
}

.about-highlights {
    display: flex;
    flex-direction: column;
    gap: 2rem
}

.highlight-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem
}

.highlight-icon {
    width: 3rem;
    height: 3rem;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.highlight-icon svg {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--white)
}

.highlight-content h4 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: .5rem
}

.highlight-content p {
    color: var(--brown-dark-light);
    line-height: 1.6;
    font-size: .95rem
}

.about-stats-new {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    padding: 2rem;
    background: var(--white);
    border-radius: 16px;
    box-shadow: 0 8px 25px #3f200014
}

.stat-item-new {
    text-align: center
}

.stat-number-new {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--bronze);
    line-height: 1;
    margin-bottom: .5rem;
    display: block
}

.stat-label-new {
    font-size: .9rem;
    color: var(--brown-dark-light);
    font-weight: 500
}

@keyframes slideStripe {
    0% {
        transform: rotate(15deg) translateY(100vh) scaleX(.8)
    }

    50% {
        transform: rotate(15deg) translateY(0) scaleX(1.2)
    }

    to {
        transform: rotate(15deg) translateY(-100vh) scaleX(.8)
    }
}

@keyframes pulseStripe {

    0%,
    to {
        opacity: .3;
        filter: blur(.5px) brightness(1)
    }

    25% {
        opacity: .8;
        filter: blur(.2px) brightness(1.3)
    }

    50% {
        opacity: .5;
        filter: blur(.8px) brightness(.8)
    }

    75% {
        opacity: .9;
        filter: blur(.1px) brightness(1.5)
    }
}

@keyframes floatShape {

    0%,
    to {
        transform: translateY(0) rotate(0)
    }

    25% {
        transform: translateY(-20px) rotate(90deg)
    }

    50% {
        transform: translateY(-10px) rotate(180deg)
    }

    75% {
        transform: translateY(-30px) rotate(270deg)
    }
}

@keyframes rotateDots {
    0% {
        transform: rotate(0) scale(1)
    }

    50% {
        transform: rotate(180deg) scale(1.1)
    }

    to {
        transform: rotate(360deg) scale(1)
    }
}

@keyframes moveLine {
    0% {
        transform: translate(0);
        opacity: 0
    }

    20% {
        opacity: 1
    }

    80% {
        opacity: 1
    }

    to {
        transform: translate(calc(100vw + 300px));
        opacity: 0
    }
}

@keyframes rotateContainer {
    0% {
        transform: translateY(-5px) scale(1.02) rotateY(0)
    }

    50% {
        transform: translateY(-10px) scale(1.05) rotateY(180deg)
    }

    to {
        transform: translateY(-5px) scale(1.02) rotateY(360deg)
    }
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: 1rem 2rem;
    border-radius: 12px;
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none;
    transition: var(--transition);
    border: 2px solid transparent;
    cursor: pointer
}

.btn-primary {
    background: var(--bronze);
    color: var(--white);
    box-shadow: 0 4px 12px #807dc24d
}

.btn-primary:hover {
    background: var(--bronze-dark);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px #807dc266
}

.btn-secondary {
    background: var(--white);
    color: var(--brown-dark);
    border-color: var(--brown-dark)
}

.btn-secondary:hover {
    background: var(--brown-dark);
    color: var(--white);
    transform: translateY(-2px)
}

.btn-whatsapp {
    background: #25d366;
    color: var(--white);
    box-shadow: 0 4px 12px #25d3664d
}

.btn-whatsapp:hover {
    background: #128c7e;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px #25d36666
}

.btn-icon {
    width: 1.25rem;
    height: 1.25rem
}

.services-section,
.about-section,
.contact-section {
    padding: 6rem 0
}

.services-section {
    background: var(--white)
}

.about-section {
    background: var(--cream-light)
}

.contact-section {
    background: var(--white)
}

.section-header {
    text-align: center;
    margin-bottom: 4rem
}

.section-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 1rem
}

.section-subtitle {
    font-size: 1.25rem;
    color: var(--brown-dark-light);
    max-width: 600px;
    margin: 0 auto
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto
}

.service-card {
    background: var(--white);
    border-radius: 15px;
    padding: 30px;
    box-shadow: 0 10px 30px var(--shadow-strong);
    transition: all .3s ease;
    border: 1px solid var(--gray-light);
    position: relative;
    overflow: hidden
}

.service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px var(--shadow-strong);
}

.service-card.featured {
    border: 2px solid var(--bronze-light);
    background: linear-gradient(135deg, var(--white), var(--cream-light-hover));
}

.service-card.featured:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--bronze), var(--bronze-light));
}

.service-card-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    border-radius: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px
}

.service-card-icon svg {
    width: 30px;
    height: 30px;
    color: var(--white);
}

.service-card-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 15px;
    line-height: 1.3
}

.service-card-description {
    color: var(--brown-dark-light);
    line-height: 1.6;
    margin-bottom: 20px
}

.service-card-features {
    list-style: none;
    padding: 0;
    margin: 0 0 25px
}

.service-card-features li {
    color: var(--brown-dark-light);
    position: relative;
    padding: 8px 0 8px 20px
}

.service-card-features li:before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--bronze);
    font-weight: 700
}

.service-card-price {
    padding-top: 20px;
    border-top: 1px solid var(--gray-light);
    text-align: center
}

.service-card-content {
    position: relative;
    z-index: 1;
}

/* Service Card com Imagem */
.service-card-image {
    padding: 0;
    position: relative;
    min-height: 350px;
    overflow: hidden;
}

.service-card-image .service-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    transition: transform 0.5s ease;
}

.service-card-image:hover .service-image {
    transform: scale(1.1);
}

.service-card-image .service-image-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
    padding: 30px;
    z-index: 2;
}

.service-card-image .service-image-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--white);
    margin: 0;
}

.service-icon {
    width: 4rem;
    height: 4rem;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.5rem
}

.service-icon svg {
    width: 2rem;
    height: 2rem;
    color: var(--white)
}

.service-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--brown-dark);
    margin-bottom: 1rem
}

.service-description {
    color: var(--brown-dark-light);
    line-height: 1.6
}

.about-content {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 4rem;
    align-items: center
}

.about-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 1.5rem
}

.about-description {
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--brown-dark-light);
    margin-bottom: 2rem
}

.about-features {
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.feature-item {
    display: flex;
    align-items: center;
    gap: 1rem
}

.feature-icon {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--bronze)
}

.feature-item span {
    font-weight: 600;
    color: var(--brown-dark)
}

.about-stats {
    display: flex;
    flex-direction: column;
    gap: 2rem
}

.stat-item {
    text-align: center;
    padding: 2rem;
    background: var(--white);
    border-radius: 16px;
    box-shadow: 0 4px 20px var(--shadow)
}

.stat-number {
    font-size: 3rem;
    font-weight: 700;
    color: var(--bronze);
    margin-bottom: .5rem
}

.stat-label {
    font-weight: 600;
    color: var(--brown-dark)
}

.contact-content {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 4rem;
    align-items: start
}

.contact-info {
    display: flex;
    flex-direction: column;
    gap: 2rem
}

.contact-item {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    padding: 2rem;
    background: var(--cream-light);
    border-radius: 16px;
    border-left: 4px solid var(--bronze)
}

.contact-icon {
    width: 3rem;
    height: 3rem;
    background: var(--bronze);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.contact-icon svg {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--white)
}

.contact-details h4 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--brown-dark);
    margin-bottom: .5rem
}

.contact-details p {
    color: var(--brown-dark-light);
    line-height: 1.6
}

.contact-details a {
    color: var(--bronze);
    text-decoration: none;
    font-weight: 600
}

.contact-details a:hover {
    text-decoration: underline
}

.contact-cta {
    background: var(--brown-dark);
    color: var(--white);
    padding: 3rem;
    border-radius: 20px;
    text-align: center
}

.contact-cta h3 {
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 1rem
}

.contact-cta p {
    margin-bottom: 2rem;
    opacity: .9;
    line-height: 1.6
}

@media (max-width: 768px) {
    .container {
        padding: 0 2rem
    }

    .hero-section {
        padding: 6rem 0 4rem
    }

    .hero-container {
        grid-template-columns: 1fr;
        gap: 3rem;
        text-align: center
    }

    .hero-content {
        padding: 0 1rem;
        grid-template-columns: 1fr
    }

    .hero-text {
        padding-left: 0;
        margin-left: 0;
        max-width: none
    }

    .hero-stripe {
        width: 80px !important
    }

    .hero-shape {
        transform: scale(.7)
    }

    .dot-pattern {
        width: 120px;
        height: 120px;
        background-size: 15px 15px
    }

    .animated-line {
        display: none
    }

    .hero-title {
        font-size: 2.5rem
    }

    .hero-description {
        font-size: 1.125rem
    }

    .hero-cta {
        flex-direction: column;
        align-items: center
    }

    .hero-content {
        flex-direction: column;
        gap: 2rem;
        text-align: center
    }

    .hero-cta-card {
        margin-left: 0;
        max-width: 100%
    }

    .cta-title {
        font-size: 1.3rem
    }

    .cta-features {
        gap: .5rem
    }

    .cta-content-wrapper {
        grid-template-columns: 1fr;
        gap: 2.5rem;
        text-align: center
    }

    .cta-main-title {
        font-size: 2rem
    }

    .cta-main-description {
        font-size: 1rem
    }

    .cta-benefits {
        gap: 1rem
    }

    .cta-benefit {
        justify-content: center
    }

    .cta-content-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
        text-align: center
    }

    .cta-mega-title {
        font-size: 2.5rem
    }

    .cta-quick-stats {
        justify-content: center;
        gap: 1.5rem
    }

    .cta-action-card {
        padding: 2rem;
        margin: 0 1rem
    }

    .cta-trust-indicators {
        flex-direction: column;
        gap: .75rem;
        align-items: center
    }

    .contact-wrapper {
        grid-template-columns: 1fr;
        gap: 3rem;
        text-align: center
    }

    .contact-title {
        font-size: 2.2rem
    }

    .contact-methods {
        gap: .75rem
    }

    .contact-info-card {
        padding: 1.5rem;
        margin: 0 1rem
    }

    .contact-guarantees {
        flex-direction: column;
        gap: .75rem;
        align-items: center
    }

    .gallery-title {
        font-size: 2.2rem
    }

    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(8, 180px);
        gap: .75rem
    }

    .gallery-item img {
        width: calc(100% - 6px);
        height: calc(100% - 6px);
        margin: 3px;
        border-radius: 8px
    }

    .gallery-item-large {
        grid-column: span 2;
        grid-row: span 2
    }

    .gallery-item-tall {
        grid-row: span 2
    }

    .gallery-item-wide {
        grid-column: span 2;
        grid-row: span 1
    }

    .gallery-cta {
        padding: 2rem 1.5rem;
        margin: 0 1rem
    }

    .gallery-cta-title {
        font-size: 1.6rem
    }

    .hero-section-clean {
        padding: 6rem 0 4rem;
        min-height: 100vh
    }

    .hero-main-content {
        grid-template-columns: 1fr;
        gap: 3rem;
        text-align: center;
        min-height: auto;
        padding: 0 1rem
    }

    .hero-text-area {
        padding-left: 0;
        padding-top: 1rem
    }

    .hero-title-new {
        font-size: 2.5rem;
        line-height: 1.2
    }

    .hero-quick-stats {
        justify-content: center;
        gap: 1.5rem;
        flex-wrap: wrap
    }

    .hero-actions-new {
        justify-content: center;
        gap: .75rem;
        flex-direction: column;
        align-items: center
    }

    .hero-visual-simple {
        order: -1
    }

    .hero-image-container {
        width: 280px;
        height: 280px;
        margin: 0 auto
    }

    .floating-shape {
        transform: scale(.6)
    }

    .hero-waves {
        height: 120px
    }

    .hero-section-clean:after {
        background-size: 40px 40px, 30px 30px
    }

    .orbital-dots {
        width: 110%;
        height: 110%
    }

    .orbital-dot {
        width: 6px;
        height: 6px
    }

    .hero-image-container:after {
        width: 40px;
        height: 40px
    }

    .about-content-new {
        grid-template-columns: 1fr;
        gap: 2.5rem
    }

    .video-thumbnails {
        flex-direction: column;
        gap: .75rem
    }

    .video-thumb {
        padding: .75rem
    }

    .about-stats-new {
        grid-template-columns: 1fr;
        gap: 1rem;
        padding: 1.5rem
    }

    .stat-number-new,
    .section-title {
        font-size: 2rem
    }

    .services-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .service-card {
        padding: 2rem
    }
    
    .service-card-image {
        min-height: 300px;
    }

    .about-stats {
        flex-direction: column
    }

    .contact-cta {
        padding: 2rem
    }
}

/* Tablets */
@media (max-width: 1024px) and (min-width: 769px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 1.5rem
    }
}

@media (max-width: 480px) {
    .hero-title {
        font-size: 2rem
    }

    .btn {
        padding: .875rem 1.5rem;
        font-size: .9rem
    }

    .service-card,
    .contact-item {
        padding: 1.5rem
    }
}

.hero-visual-animated {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative
}

.hero-animation-container {
    position: relative;
    width: 450px;
    height: 450px;
    max-width: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.gate-animation {
    position: relative;
    width: 350px;
    height: 280px;
    perspective: 1000px;
    transform-style: preserve-3d
}

.gate-base {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 20px;
    background: linear-gradient(135deg, var(--bronze-dark), var(--bronze));
    border-radius: 4px;
    box-shadow: 0 4px 15px #807dc24d;
    animation: baseGlow 4s ease-in-out infinite
}

.gate-pillar {
    position: absolute;
    bottom: 20px;
    width: 25px;
    height: 260px;
    background: linear-gradient(180deg, var(--bronze) 0%, var(--bronze-dark) 50%, var(--bronze) 100%);
    border-radius: 8px 8px 4px 4px;
    box-shadow: 0 8px 25px #807dc233, inset 0 2px #ffffff1a;
    animation: pillarFloat 6s ease-in-out infinite
}

.gate-pillar-left {
    left: 0;
    animation-delay: 0s
}

.gate-pillar-right {
    right: 0;
    animation-delay: -3s
}

.gate-leaves {
    position: absolute;
    top: 20px;
    left: 25px;
    right: 25px;
    height: 240px;
    display: flex;
    gap: 4px
}

.gate-leaf {
    flex: 1;
    height: 100%;
    background: linear-gradient(135deg, var(--bronze-light) 0%, var(--bronze) 30%, var(--bronze-dark) 70%, var(--bronze) 100%);
    border-radius: 6px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 10px 30px #807dc240, inset 0 1px #ffffff1a, inset 0 -1px #0000001a;
    animation: leafFloat 8s ease-in-out infinite
}

.gate-leaf-left {
    transform-origin: left center;
    animation-delay: 0s
}

.gate-leaf-right {
    transform-origin: right center;
    animation-delay: -4s
}

.gate-leaf:hover {
    animation-duration: 4s
}

.gate-pattern {
    position: absolute;
    top: 20px;
    left: 10px;
    right: 10px;
    bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 15px;
    justify-content: center
}

.pattern-line {
    height: 3px;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, .3) 20%, rgba(255, 255, 255, .1) 80%, transparent 100%);
    border-radius: 2px;
    animation: patternGlow 3s ease-in-out infinite
}

.pattern-line:nth-child(1) {
    animation-delay: 0s
}

.pattern-line:nth-child(2) {
    animation-delay: -1s
}

.pattern-line:nth-child(3) {
    animation-delay: -2s
}

.security-shield {
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translate(-50%);
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    border-radius: 50%/60% 60% 40% 40%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 25px #807dc266;
    animation: shieldFloat 5s ease-in-out infinite
}

.shield-icon {
    font-size: 1.8rem;
    animation: shieldPulse 2s ease-in-out infinite
}

.shield-pulse {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    border: 2px solid var(--bronze-light);
    border-radius: 50%;
    animation: pulseRing 3s ease-in-out infinite
}

.quality-particles {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none
}

.particle {
    position: absolute;
    font-size: 1.2rem;
    opacity: .8;
    animation: particleFloat 12s linear infinite
}

.particle-1 {
    top: 10%;
    left: 10%;
    animation-delay: 0s
}

.particle-2 {
    top: 20%;
    right: 15%;
    animation-delay: -2.4s
}

.particle-3 {
    bottom: 30%;
    left: 20%;
    animation-delay: -4.8s
}

.particle-4 {
    bottom: 20%;
    right: 10%;
    animation-delay: -7.2s
}

.particle-5 {
    top: 50%;
    left: 5%;
    animation-delay: -9.6s
}

.energy-waves {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 400px;
    height: 400px;
    pointer-events: none
}

.energy-wave {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border: 2px solid rgba(128, 125, 194, .3);
    border-radius: 50%;
    animation: energyPulse 4s ease-in-out infinite
}

.wave-1 {
    width: 200px;
    height: 200px;
    animation-delay: 0s
}

.wave-2 {
    width: 300px;
    height: 300px;
    animation-delay: -1.3s
}

.wave-3 {
    width: 400px;
    height: 400px;
    animation-delay: -2.6s
}

.floating-info {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none
}

.info-badge {
    position: absolute;
    background: #fffffff2;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(128, 125, 194, .2);
    border-radius: 20px;
    padding: .75rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    box-shadow: 0 8px 25px #807dc226;
    animation: badgeFloat 6s ease-in-out infinite
}

.info-badge-1 {
    top: 15%;
    right: -10%;
    animation-delay: 0s
}

.info-badge-2 {
    bottom: 25%;
    left: -15%;
    animation-delay: -2s
}

.info-badge-3 {
    top: 60%;
    right: -5%;
    animation-delay: -4s
}

.badge-number {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--bronze);
    line-height: 1
}

.badge-text {
    font-size: .8rem;
    color: var(--brown-dark-light);
    font-weight: 500;
    margin-top: .2rem
}

.badge-icon {
    font-size: 1.5rem;
    margin-bottom: .2rem
}

@keyframes baseGlow {

    0%,
    to {
        box-shadow: 0 4px 15px #807dc24d
    }

    50% {
        box-shadow: 0 6px 25px #807dc280
    }
}

@keyframes pillarFloat {

    0%,
    to {
        transform: translateY(0) rotateX(0)
    }

    50% {
        transform: translateY(-5px) rotateX(2deg)
    }
}

@keyframes leafFloat {

    0%,
    to {
        transform: rotateY(0) translateZ(0)
    }

    25% {
        transform: rotateY(-2deg) translateZ(5px)
    }

    75% {
        transform: rotateY(2deg) translateZ(5px)
    }
}

@keyframes patternGlow {

    0%,
    to {
        opacity: .3;
        background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, .3) 20%, rgba(255, 255, 255, .1) 80%, transparent 100%)
    }

    50% {
        opacity: .8;
        background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, .6) 20%, rgba(255, 255, 255, .3) 80%, transparent 100%)
    }
}

@keyframes shieldFloat {

    0%,
    to {
        transform: translate(-50%) translateY(0) rotate(0)
    }

    33% {
        transform: translate(-50%) translateY(-8px) rotate(2deg)
    }

    66% {
        transform: translate(-50%) translateY(4px) rotate(-1deg)
    }
}

@keyframes shieldPulse {

    0%,
    to {
        transform: scale(1);
        filter: brightness(1)
    }

    50% {
        transform: scale(1.1);
        filter: brightness(1.2)
    }
}

@keyframes particleFloat {
    0% {
        transform: translateY(0) rotate(0);
        opacity: 0
    }

    10% {
        opacity: .8
    }

    90% {
        opacity: .8
    }

    to {
        transform: translateY(-100px) rotate(360deg);
        opacity: 0
    }
}

@keyframes energyPulse {
    0% {
        transform: translate(-50%, -50%) scale(.8);
        opacity: .6;
        border-color: #807dc299
    }

    50% {
        transform: translate(-50%, -50%) scale(1);
        opacity: .3;
        border-color: #807dc24d
    }

    to {
        transform: translate(-50%, -50%) scale(1.2);
        opacity: 0;
        border-color: #807dc21a
    }
}

@keyframes badgeFloat {

    0%,
    to {
        transform: translateY(0) rotate(0)
    }

    33% {
        transform: translateY(-10px) rotate(1deg)
    }

    66% {
        transform: translateY(5px) rotate(-.5deg)
    }
}

@media (max-width: 768px) {
    .hero-animation-container {
        width: 350px;
        height: 350px
    }

    .gate-animation {
        width: 280px;
        height: 220px
    }

    .gate-pillar {
        width: 20px;
        height: 200px
    }

    .gate-leaves {
        top: 15px;
        left: 20px;
        right: 20px;
        height: 185px
    }

    .security-shield {
        width: 50px;
        height: 50px;
        top: -25px
    }

    .shield-icon {
        font-size: 1.5rem
    }

    .energy-waves {
        width: 300px;
        height: 300px
    }

    .wave-1 {
        width: 150px;
        height: 150px
    }

    .wave-2 {
        width: 225px;
        height: 225px
    }

    .wave-3 {
        width: 300px;
        height: 300px
    }

    .info-badge {
        padding: .5rem .75rem;
        border-radius: 15px
    }

    .badge-number {
        font-size: 1rem
    }

    .badge-text {
        font-size: .7rem
    }
}

@media (max-width: 480px) {
    .hero-animation-container {
        width: 280px;
        height: 280px
    }

    .gate-animation {
        width: 220px;
        height: 170px
    }

    .gate-pillar {
        width: 15px;
        height: 155px
    }

    .gate-leaves {
        top: 10px;
        left: 15px;
        right: 15px;
        height: 145px
    }

    .security-shield {
        width: 40px;
        height: 40px;
        top: -20px
    }

    .shield-icon {
        font-size: 1.2rem
    }

    .particle {
        font-size: 1rem
    }

    .energy-waves {
        width: 250px;
        height: 250px
    }

    .wave-1 {
        width: 120px;
        height: 120px
    }

    .wave-2 {
        width: 180px;
        height: 180px
    }

    .wave-3 {
        width: 250px;
        height: 250px
    }

    .floating-info {
        display: none
    }
}

@keyframes heroContentFadeIn {
    0% {
        opacity: 0;
        transform: translateY(20px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes heroTextSlideIn {
    0% {
        opacity: 0;
        transform: translate(-50px)
    }

    to {
        opacity: 1;
        transform: translate(0)
    }
}

@keyframes heroBadgeEntrance {
    0% {
        opacity: 0;
        transform: translateY(-20px) scale(.8)
    }

    60% {
        transform: translateY(5px) scale(1.05)
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1)
    }
}

@keyframes heroTitleSlideUp {
    0% {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes heroLineSlideIn {
    0% {
        opacity: 0;
        transform: translate(-30px)
    }

    to {
        opacity: 1;
        transform: translate(0)
    }
}

@keyframes heroHighlightPop {
    0% {
        opacity: 0;
        transform: scale(.8)
    }

    60% {
        transform: scale(1.05)
    }

    to {
        opacity: 1;
        transform: scale(1)
    }
}

@keyframes heroDescriptionFadeIn {
    0% {
        opacity: 0;
        transform: translateY(20px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes heroStatsSlideUp {
    0% {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes heroStatPop {
    0% {
        opacity: 0;
        transform: translateY(20px) scale(.8)
    }

    60% {
        transform: translateY(-5px) scale(1.1)
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1)
    }
}

@keyframes heroActionsSlideUp {
    0% {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes heroVisualSlideIn {
    0% {
        opacity: 0;
        transform: translate(50px) scale(.9)
    }

    to {
        opacity: 1;
        transform: translate(0) scale(1)
    }
}

@keyframes heroBackgroundFadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes heroWavesFadeIn {
    0% {
        opacity: 0;
        transform: translateY(20px)
    }

    to {
        opacity: .3;
        transform: translateY(0)
    }
}

.hero-btn:nth-child(1) {
    animation-delay: 3.2s
}

.hero-btn:nth-child(2) {
    animation-delay: 3.4s
}

.floating-shape:nth-child(1) {
    animation-delay: .7s
}

.floating-shape:nth-child(2) {
    animation-delay: .9s
}

.floating-shape:nth-child(3) {
    animation-delay: 1.1s
}

.floating-shape:nth-child(4) {
    animation-delay: 1.3s
}

.hero-section-clean * {
    animation-fill-mode: both
}

@media (max-width: 768px) {
    .hero-text-area {
        animation-delay: .4s;
        animation-duration: .8s
    }

    .hero-visual-animated {
        animation-delay: .6s;
        animation-duration: 1s
    }

    .hero-badge-floating {
        animation-delay: .7s
    }

    .hero-title-new {
        animation-delay: 1s
    }

    .title-line-1 {
        animation-delay: 1.2s
    }

    .title-line-2 {
        animation-delay: 1.4s
    }

    .title-line-3 {
        animation-delay: 1.6s
    }
}

@media (max-width: 480px) {
    .hero-main-content {
        animation-duration: 1s;
        animation-delay: .2s
    }

    .hero-text-area {
        animation-duration: .6s;
        animation-delay: .3s
    }

    .hero-visual-animated {
        animation-duration: .8s;
        animation-delay: .4s
    }

    .hero-badge-floating {
        animation-delay: .5s
    }

    .hero-title-new {
        animation-delay: .7s
    }

    .hero-description-new {
        animation-delay: 1.2s
    }

    .hero-quick-stats {
        animation-delay: 1.5s
    }

    .hero-actions-new {
        animation-delay: 1.8s
    }
}

.about-section {
    position: relative;
    overflow: hidden
}

.section-header {
    opacity: 0;
    transform: translateY(40px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.section-header.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.section-title {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .2s
}

.section-title.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.section-subtitle {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .4s
}

.section-subtitle.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.about-content-new {
    opacity: 0;
    transform: translateY(50px);
    transition: all 1s cubic-bezier(.4, 0, .2, 1) .6s
}

.about-content-new.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.about-videos {
    opacity: 0;
    transform: translate(-60px) scale(.95);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .8s
}

.about-videos.animate-in {
    opacity: 1;
    transform: translate(0) scale(1)
}

.video-showcase {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1s
}

.video-showcase.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.main-video-container {
    opacity: 0;
    transform: scale(.9);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1.2s
}

.main-video-container.animate-in {
    opacity: 1;
    transform: scale(1)
}

.video-thumbnails {
    opacity: 0;
    transform: translateY(30px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 1.4s
}

.video-thumbnails.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.video-thumb {
    opacity: 0;
    transform: translate(20px);
    transition: all .5s cubic-bezier(.4, 0, .2, 1)
}

.video-thumb:nth-child(1) {
    transition-delay: 1.6s
}

.video-thumb:nth-child(2) {
    transition-delay: 1.8s
}

.video-thumb.animate-in {
    opacity: 1;
    transform: translate(0)
}

.about-content-text {
    opacity: 0;
    transform: translate(60px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1s
}

.about-content-text.animate-in {
    opacity: 1;
    transform: translate(0)
}

.about-highlights {
    opacity: 0;
    transform: translateY(40px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1.2s
}

.about-highlights.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.highlight-item {
    opacity: 0;
    transform: translateY(30px) scale(.9);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.highlight-item:nth-child(1) {
    transition-delay: 1.4s
}

.highlight-item:nth-child(2) {
    transition-delay: 1.6s
}

.highlight-item:nth-child(3) {
    transition-delay: 1.8s
}

.highlight-item.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.highlight-icon {
    opacity: 0;
    transform: scale(.5) rotate(-180deg);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.highlight-icon.animate-in {
    opacity: 1;
    transform: scale(1) rotate(0)
}

.highlight-content {
    opacity: 0;
    transform: translate(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.highlight-content.animate-in {
    opacity: 1;
    transform: translate(0)
}

.about-stats-new {
    opacity: 0;
    transform: translateY(50px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 2s
}

.about-stats-new.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.stat-item-new {
    opacity: 0;
    transform: translateY(30px) scale(.8);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.stat-item-new:nth-child(1) {
    transition-delay: 2.2s
}

.stat-item-new:nth-child(2) {
    transition-delay: 2.4s
}

.stat-item-new:nth-child(3) {
    transition-delay: 2.6s
}

.stat-item-new.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.stat-number-new {
    opacity: 0;
    transform: scale(.5);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.stat-number-new.animate-in {
    opacity: 1;
    transform: scale(1)
}

.stat-label-new {
    opacity: 0;
    transform: translateY(10px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.stat-label-new.animate-in {
    opacity: 1;
    transform: translateY(0)
}

@media (max-width: 768px) {
    .cta-main-content {
        transform: translateY(30px);
        transition-duration: .6s
    }

    .cta-action-card {
        transform: translateY(40px) scale(.95);
        transition-duration: .6s;
        transition-delay: .1s
    }

    .cta-eyebrow {
        transition-delay: .2s;
        transition-duration: .4s
    }

    .cta-mega-title {
        transition-delay: .3s;
        transition-duration: .6s
    }

    .cta-subtitle {
        transition-delay: .4s;
        transition-duration: .5s
    }

    .cta-quick-stats {
        transition-delay: .5s;
        transition-duration: .6s
    }

    .cta-stat:nth-child(1) {
        transition-delay: .6s
    }

    .cta-stat:nth-child(2) {
        transition-delay: .7s
    }

    .cta-stat:nth-child(3) {
        transition-delay: .8s
    }

    .cta-card-header {
        transition-delay: .3s;
        transition-duration: .6s
    }

    .cta-card-features {
        transition-delay: .4s;
        transition-duration: .5s
    }

    .cta-feature-item:nth-child(1) {
        transition-delay: .5s
    }

    .cta-feature-item:nth-child(2) {
        transition-delay: .6s
    }

    .cta-feature-item:nth-child(3) {
        transition-delay: .7s
    }

    .cta-card-actions {
        transition-delay: .8s;
        transition-duration: .6s
    }

    .cta-card-footer {
        transition-delay: .9s;
        transition-duration: .5s
    }
}

@media (max-width: 480px) {

    .cta-main-content,
    .cta-action-card {
        transition-duration: .5s
    }

    .cta-eyebrow,
    .cta-subtitle,
    .cta-card-features,
    .cta-card-footer {
        transition-duration: .4s
    }

    .cta-mega-title,
    .cta-quick-stats,
    .cta-card-header,
    .cta-card-actions {
        transition-duration: .5s
    }

    .cta-feature-item {
        transition-duration: .4s
    }

    .cta-stat {
        transition-duration: .5s
    }

    .cta-action-card {
        transition-delay: .05s
    }

    .cta-eyebrow {
        transition-delay: .1s
    }

    .cta-mega-title {
        transition-delay: .2s
    }

    .cta-subtitle {
        transition-delay: .3s
    }

    .cta-quick-stats {
        transition-delay: .4s
    }

    .cta-stat:nth-child(1) {
        transition-delay: .45s
    }

    .cta-stat:nth-child(2) {
        transition-delay: .5s
    }

    .cta-stat:nth-child(3) {
        transition-delay: .55s
    }

    .cta-card-header {
        transition-delay: .2s
    }

    .cta-card-features {
        transition-delay: .3s
    }

    .cta-feature-item:nth-child(1) {
        transition-delay: .35s
    }

    .cta-feature-item:nth-child(2) {
        transition-delay: .4s
    }

    .cta-feature-item:nth-child(3) {
        transition-delay: .45s
    }

    .cta-card-actions {
        transition-delay: .5s
    }

    .cta-card-footer {
        transition-delay: .55s
    }
}

@media (max-width: 768px) {
    .about-videos {
        transform: translateY(30px) scale(.95);
        transition-duration: .6s;
        transition-delay: .5s
    }

    .about-content-text {
        transform: translateY(40px);
        transition-duration: .6s;
        transition-delay: .7s
    }

    .video-showcase {
        transition-delay: .6s;
        transition-duration: .6s
    }

    .main-video-container {
        transition-delay: .7s;
        transition-duration: .6s
    }

    .video-thumbnails {
        transition-delay: .8s;
        transition-duration: .5s
    }

    .video-thumb:nth-child(1) {
        transition-delay: .9s
    }

    .video-thumb:nth-child(2) {
        transition-delay: 1s
    }

    .about-highlights {
        transition-delay: .8s;
        transition-duration: .6s
    }

    .highlight-item:nth-child(1) {
        transition-delay: .9s
    }

    .highlight-item:nth-child(2) {
        transition-delay: 1s
    }

    .highlight-item:nth-child(3) {
        transition-delay: 1.1s
    }

    .about-stats-new {
        transition-delay: 1.2s;
        transition-duration: .6s
    }

    .stat-item-new:nth-child(1) {
        transition-delay: 1.3s
    }

    .stat-item-new:nth-child(2) {
        transition-delay: 1.4s
    }

    .stat-item-new:nth-child(3) {
        transition-delay: 1.5s
    }
}

@media (max-width: 480px) {
    .section-header {
        transition-duration: .6s
    }

    .section-title {
        transition-duration: .6s;
        transition-delay: .1s
    }

    .section-subtitle {
        transition-duration: .5s;
        transition-delay: .2s
    }

    .about-content-new {
        transition-duration: .8s;
        transition-delay: .3s
    }

    .about-videos {
        transform: translateY(20px);
        transition-duration: .5s;
        transition-delay: .4s
    }

    .about-content-text {
        transform: translateY(30px);
        transition-duration: .5s;
        transition-delay: .5s
    }

    .video-showcase {
        transition-delay: .5s;
        transition-duration: .5s
    }

    .main-video-container {
        transition-delay: .6s;
        transition-duration: .5s
    }

    .video-thumbnails {
        transition-delay: .7s;
        transition-duration: .4s
    }

    .video-thumb:nth-child(1) {
        transition-delay: .75s
    }

    .video-thumb:nth-child(2) {
        transition-delay: .8s
    }

    .about-highlights {
        transition-delay: .6s;
        transition-duration: .5s
    }

    .highlight-item:nth-child(1) {
        transition-delay: .7s
    }

    .highlight-item:nth-child(2) {
        transition-delay: .75s
    }

    .highlight-item:nth-child(3) {
        transition-delay: .8s
    }

    .highlight-icon {
        transition-duration: .6s
    }

    .highlight-content {
        transition-duration: .5s
    }

    .about-stats-new {
        transition-delay: .9s;
        transition-duration: .5s
    }

    .stat-item-new:nth-child(1) {
        transition-delay: 1s
    }

    .stat-item-new:nth-child(2) {
        transition-delay: 1.05s
    }

    .stat-item-new:nth-child(3) {
        transition-delay: 1.1s
    }

    .stat-number-new {
        transition-duration: .6s
    }

    .stat-label-new {
        transition-duration: .5s
    }
}

.gallery-section {
    position: relative;
    overflow: hidden
}

.gallery-background {
    opacity: 0;
    transform: scale(1.1);
    transition: all 1.5s cubic-bezier(.4, 0, .2, 1)
}

.gallery-background.animate-in {
    opacity: 1;
    transform: scale(1)
}

.section-header-gallery {
    opacity: 0;
    transform: translateY(50px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.section-header-gallery.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.gallery-badge {
    opacity: 0;
    transform: translateY(-30px) scale(.8);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .2s
}

.gallery-badge.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.gallery-title {
    opacity: 0;
    transform: translateY(40px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .4s
}

.gallery-title.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.gallery-highlight {
    opacity: 0;
    transform: scale(.8);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .6s
}

.gallery-highlight.animate-in {
    opacity: 1;
    transform: scale(1)
}

.gallery-subtitle {
    opacity: 0;
    transform: translateY(30px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .8s
}

.gallery-subtitle.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.gallery-grid {
    opacity: 0;
    transform: translateY(60px);
    transition: all 1s cubic-bezier(.4, 0, .2, 1) 1s
}

.gallery-grid.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.gallery-item {
    opacity: 0;
    transform: translateY(50px) scale(.9);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.gallery-item.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.gallery-item-large {
    transform: translateY(60px) scale(.85) rotateY(-5deg);
    transition: all 1s cubic-bezier(.4, 0, .2, 1)
}

.gallery-item-large.animate-in {
    transform: translateY(0) scale(1) rotateY(0)
}

.gallery-item:nth-child(1) {
    transition-delay: 1.2s
}

.gallery-item:nth-child(2) {
    transition-delay: 1.4s
}

.gallery-item:nth-child(3) {
    transition-delay: 1.6s
}

.gallery-item:nth-child(4) {
    transition-delay: 1.8s
}

.gallery-item:nth-child(5) {
    transition-delay: 2s
}

.gallery-item:nth-child(6) {
    transition-delay: 2.2s
}

.gallery-item img {
    opacity: 0;
    transform: scale(1.1);
    transition: all .8s cubic-bezier(.4, 0, .2, 1)
}

.gallery-item.animate-in img {
    opacity: 1;
    transform: scale(1)
}

.gallery-overlay {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.gallery-item.animate-in .gallery-overlay {
    opacity: 0;
    transform: translateY(0)
}

.gallery-overlay-content {
    opacity: 0;
    transform: translateY(30px) scale(.9);
    transition: all .5s cubic-bezier(.4, 0, .2, 1)
}

.gallery-item:hover .gallery-overlay {
    opacity: 1
}

.gallery-item:hover .gallery-overlay-content {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.gallery-pattern {
    opacity: 0;
    transform: scale(.8) rotate(45deg);
    transition: all 1.2s cubic-bezier(.4, 0, .2, 1) .5s
}

.gallery-pattern.animate-in {
    opacity: 1;
    transform: scale(1) rotate(0)
}

.gallery-item-large:before {
    content: "";
    position: absolute;
    top: -5px;
    left: -5px;
    right: -5px;
    bottom: -5px;
    background: linear-gradient(45deg, var(--bronze), var(--bronze-light), var(--bronze), var(--bronze-light));
    background-size: 400% 400%;
    border-radius: inherit;
    z-index: -1;
    opacity: 0;
    animation: galleryItemGlow 3s ease-in-out infinite;
    transition: opacity .6s ease
}

.gallery-item-large.animate-in:before {
    opacity: .3
}

.gallery-item-large:hover:before {
    opacity: .6
}

@keyframes galleryItemGlow {

    0%,
    to {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }
}

@media (max-width: 768px) {
    .section-header-gallery {
        transform: translateY(30px);
        transition-duration: .6s
    }

    .gallery-badge {
        transform: translateY(-20px) scale(.9);
        transition-duration: .5s;
        transition-delay: .1s
    }

    .gallery-title {
        transform: translateY(25px);
        transition-duration: .6s;
        transition-delay: .2s
    }

    .gallery-highlight {
        transition-delay: .3s;
        transition-duration: .5s
    }

    .gallery-subtitle {
        transform: translateY(20px);
        transition-duration: .5s;
        transition-delay: .4s
    }

    .gallery-grid {
        transform: translateY(40px);
        transition-duration: .8s;
        transition-delay: .5s
    }

    .gallery-item {
        transform: translateY(30px) scale(.95);
        transition-duration: .6s
    }

    .gallery-item-large {
        transform: translateY(40px) scale(.9);
        transition-duration: .8s
    }

    .gallery-item:nth-child(1) {
        transition-delay: .6s
    }

    .gallery-item:nth-child(2) {
        transition-delay: .7s
    }

    .gallery-item:nth-child(3) {
        transition-delay: .8s
    }

    .gallery-item:nth-child(4) {
        transition-delay: .9s
    }

    .gallery-item:nth-child(5) {
        transition-delay: 1s
    }

    .gallery-item:nth-child(6) {
        transition-delay: 1.1s
    }

    .gallery-pattern {
        transition-delay: .3s;
        transition-duration: 1s
    }
}

@media (max-width: 480px) {
    .section-header-gallery {
        transform: translateY(20px);
        transition-duration: .5s
    }

    .gallery-badge {
        transform: translateY(-15px) scale(.95);
        transition-duration: .4s;
        transition-delay: .05s
    }

    .gallery-title {
        transform: translateY(20px);
        transition-duration: .5s;
        transition-delay: .1s
    }

    .gallery-highlight {
        transition-delay: .15s;
        transition-duration: .4s
    }

    .gallery-subtitle {
        transform: translateY(15px);
        transition-duration: .4s;
        transition-delay: .2s
    }

    .gallery-grid {
        transform: translateY(30px);
        transition-duration: .6s;
        transition-delay: .25s
    }

    .gallery-item {
        transform: translateY(25px) scale(.95);
        transition-duration: .5s
    }

    .gallery-item-large {
        transform: translateY(30px) scale(.9);
        transition-duration: .6s
    }

    .gallery-item:nth-child(1) {
        transition-delay: .3s
    }

    .gallery-item:nth-child(2) {
        transition-delay: .35s
    }

    .gallery-item:nth-child(3) {
        transition-delay: .4s
    }

    .gallery-item:nth-child(4) {
        transition-delay: .45s
    }

    .gallery-item:nth-child(5) {
        transition-delay: .5s
    }

    .gallery-item:nth-child(6) {
        transition-delay: .55s
    }

    .gallery-pattern {
        transition-delay: .15s;
        transition-duration: .8s
    }

    .gallery-item {
        transform: none !important
    }

    .gallery-item-large:before {
        display: none
    }
}

.footer {
    position: relative;
    overflow: hidden
}

.footer-container {
    opacity: 0;
    transform: translateY(60px);
    transition: all 1s cubic-bezier(.4, 0, .2, 1)
}

.footer-container.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-content {
    opacity: 0;
    transform: translateY(40px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .2s
}

.footer-content.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-section {
    opacity: 0;
    transform: translateY(30px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.footer-section.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-main {
    transition-delay: .4s
}

.footer-brand {
    opacity: 0;
    transform: translate(-30px) scale(.9);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .6s
}

.footer-brand.animate-in {
    opacity: 1;
    transform: translate(0) scale(1)
}

.footer-logo {
    opacity: 0;
    transform: scale(.5) rotate(-180deg);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) .8s
}

.footer-logo.animate-in {
    opacity: 1;
    transform: scale(1) rotate(0)
}

.footer-brand-name {
    opacity: 0;
    transform: translate(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 1s
}

.footer-brand-name.animate-in {
    opacity: 1;
    transform: translate(0)
}

.footer-description {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 1.2s
}

.footer-description.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-contact-compact {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1.4s
}

.footer-contact-compact.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.contact-compact-item {
    opacity: 0;
    transform: translate(-20px);
    transition: all .5s cubic-bezier(.4, 0, .2, 1)
}

.contact-compact-item:nth-child(1) {
    transition-delay: 1.6s
}

.contact-compact-item:nth-child(2) {
    transition-delay: 1.8s
}

.contact-compact-item:nth-child(3) {
    transition-delay: 2s
}

.contact-compact-item.animate-in {
    opacity: 1;
    transform: translate(0)
}

.contact-compact-icon {
    opacity: 0;
    transform: scale(.5) rotate(45deg);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.contact-compact-icon.animate-in {
    opacity: 1;
    transform: scale(1) rotate(0)
}

.footer-social {
    opacity: 0;
    transform: translateY(20px) scale(.8);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 2.2s
}

.footer-social.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.social-link {
    opacity: 0;
    transform: translateY(20px) scale(.7);
    transition: all .5s cubic-bezier(.4, 0, .2, 1)
}

.social-link:nth-child(1) {
    transition-delay: 2.4s
}

.social-link:nth-child(2) {
    transition-delay: 2.6s
}

.social-link.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.footer-links-combined {
    transition-delay: .6s
}

.footer-title {
    opacity: 0;
    transform: translateY(-20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) .8s
}

.footer-title.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-links-grid {
    opacity: 0;
    transform: translateY(30px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 1s
}

.footer-links-grid.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-links-column {
    opacity: 0;
    transform: translate(30px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1)
}

.footer-links-column:nth-child(1) {
    transition-delay: 1.2s
}

.footer-links-column:nth-child(2) {
    transition-delay: 1.4s
}

.footer-links-column.animate-in {
    opacity: 1;
    transform: translate(0)
}

.footer-links li {
    opacity: 0;
    transform: translate(15px);
    transition: all .4s cubic-bezier(.4, 0, .2, 1)
}

.footer-links li.animate-in {
    opacity: 1;
    transform: translate(0)
}

.footer-bottom {
    opacity: 0;
    transform: translateY(40px);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 2.8s
}

.footer-bottom.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-bottom-content {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 3s
}

.footer-bottom-content.animate-in {
    opacity: 1;
    transform: translateY(0)
}

.footer-copyright {
    opacity: 0;
    transform: translate(-30px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 3.2s
}

.footer-copyright.animate-in {
    opacity: 1;
    transform: translate(0)
}

.footer-bottom-links {
    opacity: 0;
    transform: translate(30px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 3.4s
}

.footer-bottom-links.animate-in {
    opacity: 1;
    transform: translate(0)
}

.footer-developer {
    opacity: 0;
    transform: translateY(20px) scale(.9);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 3.6s
}

.footer-developer.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.whatsapp-float {
    opacity: 0;
    transform: translateY(100px) scale(.5);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 4s
}

.whatsapp-float.animate-in {
    opacity: 1;
    transform: translateY(0) scale(1)
}

.whatsapp-button {
    opacity: 0;
    transform: scale(.3) rotate(180deg);
    transition: all .8s cubic-bezier(.4, 0, .2, 1) 4.2s
}

.whatsapp-button.animate-in {
    opacity: 1;
    transform: scale(1) rotate(0)
}

.whatsapp-tooltip {
    opacity: 0;
    transform: translate(20px);
    transition: all .6s cubic-bezier(.4, 0, .2, 1) 4.4s
}

.whatsapp-tooltip.animate-in {
    opacity: 0;
    transform: translate(0)
}

@media (max-width: 768px) {
    .footer-container {
        transform: translateY(40px);
        transition-duration: .8s
    }

    .footer-content {
        transform: translateY(30px);
        transition-duration: .6s;
        transition-delay: .1s
    }

    .footer-section {
        transform: translateY(20px);
        transition-duration: .5s
    }

    .footer-main {
        transition-delay: .2s
    }

    .footer-links-combined {
        transition-delay: .3s
    }

    .footer-brand {
        transform: translate(-20px) scale(.95);
        transition-duration: .6s;
        transition-delay: .3s
    }

    .footer-logo {
        transform: scale(.7) rotate(-90deg);
        transition-duration: .6s;
        transition-delay: .4s
    }

    .footer-brand-name {
        transform: translate(15px);
        transition-duration: .5s;
        transition-delay: .5s
    }

    .footer-description {
        transform: translateY(15px);
        transition-duration: .5s;
        transition-delay: .6s
    }

    .footer-contact-compact {
        transform: translateY(20px);
        transition-duration: .6s;
        transition-delay: .7s
    }

    .contact-compact-item:nth-child(1) {
        transition-delay: .8s
    }

    .contact-compact-item:nth-child(2) {
        transition-delay: .9s
    }

    .contact-compact-item:nth-child(3) {
        transition-delay: 1s
    }

    .footer-social {
        transform: translateY(15px) scale(.9);
        transition-duration: .5s;
        transition-delay: 1.1s
    }

    .social-link:nth-child(1) {
        transition-delay: 1.2s
    }

    .social-link:nth-child(2) {
        transition-delay: 1.3s
    }

    .footer-title {
        transform: translateY(-15px);
        transition-duration: .5s;
        transition-delay: .4s
    }

    .footer-links-grid {
        transform: translateY(20px);
        transition-duration: .6s;
        transition-delay: .5s
    }

    .footer-links-column:nth-child(1) {
        transition-delay: .6s
    }

    .footer-links-column:nth-child(2) {
        transition-delay: .7s
    }

    .footer-bottom {
        transform: translateY(30px);
        transition-duration: .6s;
        transition-delay: 1.4s
    }

    .footer-bottom-content {
        transform: translateY(15px);
        transition-duration: .5s;
        transition-delay: 1.5s
    }

    .footer-copyright {
        transform: translate(-20px);
        transition-duration: .5s;
        transition-delay: 1.6s
    }

    .footer-bottom-links {
        transform: translate(20px);
        transition-duration: .5s;
        transition-delay: 1.7s
    }

    .footer-developer {
        transform: translateY(15px) scale(.95);
        transition-duration: .5s;
        transition-delay: 1.8s
    }

    .whatsapp-float {
        transform: translateY(80px) scale(.7);
        transition-duration: .6s;
        transition-delay: 2s
    }

    .whatsapp-button {
        transform: scale(.5) rotate(90deg);
        transition-duration: .6s;
        transition-delay: 2.1s
    }

    .whatsapp-tooltip {
        transform: translate(15px);
        transition-duration: .5s;
        transition-delay: 2.2s
    }
}

@media (max-width: 480px) {
    .footer-container {
        transform: translateY(30px);
        transition-duration: .6s
    }

    .footer-content {
        transform: translateY(20px);
        transition-duration: .5s;
        transition-delay: .05s
    }

    .footer-section {
        transform: translateY(15px);
        transition-duration: .4s
    }

    .footer-main {
        transition-delay: .1s
    }

    .footer-links-combined {
        transition-delay: .15s
    }

    .footer-brand {
        transform: translate(-15px) scale(.9);
        transition-duration: .5s;
        transition-delay: .15s
    }

    .footer-logo {
        transform: scale(.8) rotate(-45deg);
        transition-duration: .5s;
        transition-delay: .2s
    }

    .footer-brand-name {
        transform: translate(10px);
        transition-duration: .4s;
        transition-delay: .25s
    }

    .footer-description {
        transform: translateY(10px);
        transition-duration: .4s;
        transition-delay: .3s
    }

    .footer-contact-compact {
        transform: translateY(15px);
        transition-duration: .5s;
        transition-delay: .35s
    }

    .contact-compact-item:nth-child(1) {
        transition-delay: .4s
    }

    .contact-compact-item:nth-child(2) {
        transition-delay: .45s
    }

    .contact-compact-item:nth-child(3) {
        transition-delay: .5s
    }

    .footer-social {
        transform: translateY(10px) scale(.95);
        transition-duration: .4s;
        transition-delay: .55s
    }

    .social-link:nth-child(1) {
        transition-delay: .6s
    }

    .social-link:nth-child(2) {
        transition-delay: .65s
    }

    .footer-title {
        transform: translateY(-10px);
        transition-duration: .4s;
        transition-delay: .2s
    }

    .footer-links-grid {
        transform: translateY(15px);
        transition-duration: .5s;
        transition-delay: .25s
    }

    .footer-links-column:nth-child(1) {
        transition-delay: .3s
    }

    .footer-links-column:nth-child(2) {
        transition-delay: .35s
    }

    .footer-bottom {
        transform: translateY(20px);
        transition-duration: .5s;
        transition-delay: .7s
    }

    .footer-bottom-content {
        transform: translateY(10px);
        transition-duration: .4s;
        transition-delay: .75s
    }

    .footer-copyright {
        transform: translate(-15px);
        transition-duration: .4s;
        transition-delay: .8s
    }

    .footer-bottom-links {
        transform: translate(15px);
        transition-duration: .4s;
        transition-delay: .85s
    }

    .footer-developer {
        transform: translateY(10px) scale(.9);
        transition-duration: .4s;
        transition-delay: .9s
    }

    .whatsapp-float {
        transform: translateY(60px) scale(.8);
        transition-duration: .5s;
        transition-delay: 1s
    }

    .whatsapp-button {
        transform: scale(.6) rotate(45deg);
        transition-duration: .5s;
        transition-delay: 1.05s
    }

    .whatsapp-tooltip {
        transform: translate(10px);
        transition-duration: .4s;
        transition-delay: 1.1s
    }

    .contact-compact-icon {
        transform: scale(.7) rotate(0);
        transition-duration: .4s
    }
}

/* ============================================
   SERVICES GRID SECTION - Importado de servicos.css
   ============================================ */

.services-grid-section {
    padding: 80px 0;
    background: var(--white);
}

.services-grid-header {
    text-align: center;
    margin-bottom: 60px
}

.services-grid-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 15px
}

.services-grid-subtitle {
    font-size: 1.1rem;
    color: var(--brown-dark-light);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto
}

.service-card-content {
    position: relative;
    z-index: 1;
}

/* Service Card com Imagem */
.service-card-image {
    padding: 0;
    position: relative;
    min-height: 350px;
    overflow: hidden;
}

.service-card-image .service-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    transition: transform 0.5s ease;
}

.service-card-image:hover .service-image {
    transform: scale(1.1);
}

.service-card-image .service-image-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
    padding: 30px;
    z-index: 2;
}

.service-card-image .service-image-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--white);
    margin: 0;
}

/* Estilos dos Cards de Servi�o - Complemento */
.service-card.featured {
    border: 2px solid var(--bronze-light);
    background: linear-gradient(135deg, var(--white), var(--cream-light-hover));
}

.service-card.featured:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--bronze), var(--bronze-light));
}

.service-card-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--bronze), var(--bronze-light));
    border-radius: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.service-card-icon svg {
    width: 30px;
    height: 30px;
    color: var(--white);
}

.service-card-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--brown-dark);
    margin-bottom: 15px;
    line-height: 1.3;
}

.service-card-description {
    color: var(--brown-dark-light);
    line-height: 1.6;
    margin-bottom: 20px;
}

.service-card-features {
    list-style: none;
    padding: 0;
    margin: 0 0 25px;
}

.service-card-features li {
    color: var(--brown-dark-light);
    position: relative;
    padding: 8px 0 8px 20px;
}

.service-card-features li:before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--bronze);
    font-weight: 700
}

.service-card-price {
    padding-top: 20px;
    border-top: 1px solid var(--gray-light);
    text-align: center;
}

/* Responsive para Mobile */
@media (max-width: 768px) {
    .services-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .service-card-image {
        min-height: 300px;
    }
}
