:root {
            --navy: #071739;
            --steel: #4B6382;
            --mist: #A4B5C4;
            --fog: #CDD5DB;
            --taupe: #A68868;
            --sand: #E3C39D;
            --cream: #F7F3EE;
            --white: #ffffff;
            --transition: all 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
        }

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

        html { scroll-behavior: smooth; }

        body {
            background: var(--white);
            color: var(--navy);
            font-family: 'Nunito', sans-serif;
            overflow-x: hidden;
            -webkit-font-smoothing: antialiased;
        }

        ::selection { background: var(--sand); color: var(--navy); }

        /* ── SCROLLBAR ── */
        ::-webkit-scrollbar { width: 4px; }
        ::-webkit-scrollbar-track { background: var(--cream); }
        ::-webkit-scrollbar-thumb { background: var(--taupe); border-radius: 2px; }

        /* ── NAV ── */
        nav {
            position: fixed;
            top: 0; left: 0; right: 0;
            z-index: 1000;
            padding: 20px 0;
            transition: var(--transition);
        }
        nav.scrolled {
            background: var(--navy) !important;
            padding: 14px 0;
            box-shadow: 0 4px 30px rgba(7,23,57,0.15);
        }
        nav.top { background: transparent; }

        .nav-inner {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 40px;
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        .brand {
            text-decoration: none;
            line-height: 1.1;
        }
        .brand-name {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.5rem;
            font-weight: 500;
            color: var(--white);
            display: block;
            letter-spacing: 1px;
        }
        .brand-sub {
            font-family: 'Nunito', sans-serif;
            font-size: 9px;
            font-weight: 500;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: rgba(255,255,255,0.55);
            display: block;
        }

        .nav-links {
            display: flex;
            align-items: center;
            gap: 10px;
            list-style: none;
        }
        .nav-links a {
            font-family: 'Nunito', sans-serif;
            font-size: 0.78rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 1.5px;
            color: rgba(255,255,255,0.65);
            text-decoration: none;
            padding: 6px 14px;
            transition: var(--transition);
        }
        .nav-links a:hover { color: var(--white); }

        .btn-nav {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.4);
            color: var(--white) !important;
            border-radius: 100px;
            padding: 8px 22px !important;
            transition: var(--transition) !important;
        }
        .btn-nav:hover {
            background: var(--taupe) !important;
            border-color: var(--taupe) !important;
        }

        /* Mobile Menu */
        .hamburger {
            display: none;
            background: none;
            border: none;
            cursor: pointer;
            color: var(--white);
            font-size: 1.6rem;
            padding: 4px;
        }
        .mobile-menu {
            display: none;
            flex-direction: column;
            background: var(--navy);
            padding: 20px 40px 30px;
            gap: 6px;
        }
        .mobile-menu.open { display: flex; }
        .mobile-menu a {
            font-family: 'Nunito', sans-serif;
            font-size: 0.85rem;
            font-weight: 500;
            text-transform: uppercase;
            letter-spacing: 1.5px;
            color: rgba(255,255,255,0.7);
            text-decoration: none;
            padding: 10px 0;
            border-bottom: 1px solid rgba(255,255,255,0.06);
            transition: var(--transition);
        }
        .mobile-menu a:hover { color: var(--white); }
        .mobile-menu .btn-mobile {
            margin-top: 12px;
            background: var(--taupe);
            color: var(--white) !important;
            border-radius: 100px;
            text-align: center;
            padding: 12px !important;
            border: none;
        }

        @media (max-width: 900px) {
            .nav-links { display: none; }
            .hamburger { display: block; }
        }

        /* ── HERO ── */
        #hero {
            min-height: 100vh;
            background: var(--sand);
            display: flex;
            align-items: center;
            position: relative;
            overflow: hidden;
            padding-top: 90px;
        }

        .hero-bg-pattern {
            position: absolute;
            inset: 0;
            opacity: 0.07;
            background-image:
                radial-gradient(circle at 20% 50%, var(--taupe) 0%, transparent 50%),
                radial-gradient(circle at 80% 20%, var(--navy) 0%, transparent 40%);
        }

        .hero-deco-line {
            position: absolute;
            right: 0; top: 0; bottom: 0;
            width: 42%;
            background: linear-gradient(135deg, rgba(166,136,104,0.12) 0%, rgba(7,23,57,0.06) 100%);
            clip-path: polygon(10% 0%, 100% 0%, 100% 100%, 0% 100%);
        }

        .hero-container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 80px 40px;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 60px;
            align-items: center;
            position: relative;
            z-index: 1;
        }

        .hero-eyebrow {
            display: inline-flex;
            align-items: center;
            gap: 14px;
            font-family: 'Nunito', sans-serif;
            font-size: 0.72rem;
            font-weight: 600;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: var(--taupe);
            margin-bottom: 24px;
        }
        .hero-eyebrow::before {
            content: '';
            width: 32px;
            height: 1px;
            background: var(--taupe);
            flex-shrink: 0;
        }

        .hero-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: clamp(2.5rem, 6vw, 5.5rem);
            font-weight: 300;
            line-height: 1.05;
            color: var(--navy);
            margin-bottom: 28px;
        }
        .hero-title em {
            font-style: italic;
            color: var(--taupe);
        }
        .hero-title strong {
            font-weight: 600;
            display: block;
        }

        .hero-desc {
            font-size: 1rem;
            font-weight: 300;
            line-height: 1.85;
            color: var(--steel);
            max-width: 440px;
            margin-bottom: 44px;
        }

        .hero-cta-group {
            display: flex;
            gap: 16px;
            flex-wrap: wrap;
            align-items: center;
        }

        .btn-primary-cta {
            background: var(--navy);
            color: var(--white);
            font-family: 'Nunito', sans-serif;
            font-size: 0.82rem;
            font-weight: 600;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            padding: 15px 32px;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: 10px;
            transition: var(--transition);
        }
        .btn-primary-cta:hover {
            background: var(--taupe);
            color: var(--white);
            transform: translateY(-2px);
        }

        .btn-secondary-cta {
            font-family: 'Nunito', sans-serif;
            font-size: 0.82rem;
            font-weight: 600;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            color: var(--navy);
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding-bottom: 2px;
            border-bottom: 1px solid var(--navy);
            transition: var(--transition);
        }
        .btn-secondary-cta:hover { color: var(--taupe); border-color: var(--taupe); }

        .hero-stats {
            display: flex;
            gap: 36px;
            margin-top: 56px;
            padding-top: 40px;
            border-top: 1px solid rgba(7,23,57,0.1);
        }
        .stat-num {
            font-family: 'Cormorant Garamond', serif;
            font-size: 2.6rem;
            font-weight: 600;
            color: var(--navy);
            line-height: 1;
        }
        .stat-label {
            font-size: 0.72rem;
            font-weight: 500;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            color: var(--steel);
            margin-top: 4px;
        }

        /* Hero Image */
        .hero-image-wrap {
            display: flex;
            justify-content: center;
            align-items: flex-end;
            position: relative;
        }

        .hero-img-frame {
            position: relative;
            width: 100%;
            max-width: 400px;
        }

        .hero-img-frame::before {
            content: '';
            position: absolute;
            top: -20px; right: -20px;
            width: 70%;
            height: 70%;
            border: 1px solid var(--taupe);
            border-radius: 200px 200px 0 0;
            z-index: 0;
        }

        .hero-img-frame img {
            position: relative;
            z-index: 1;
            width: 100%;
            aspect-ratio: 3/4;
            object-fit: cover;
            border-radius: 200px 200px 0 0;
            border: 6px solid var(--white);
            box-shadow: 0 30px 60px rgba(7,23,57,0.12);
        }

        .hero-badge {
            position: absolute;
            bottom: 40px;
            left: -20px;
            background: var(--white);
            padding: 16px 22px;
            box-shadow: 0 10px 30px rgba(7,23,57,0.1);
            display: flex;
            align-items: center;
            gap: 14px;
            z-index: 2;
            border-left: 3px solid var(--taupe);
        }
        .hero-badge-icon {
            width: 40px; height: 40px;
            background: var(--cream);
            border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            color: var(--taupe);
            font-size: 1.1rem;
            flex-shrink: 0;
        }
        .hero-badge-text {
            font-size: 0.72rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--navy);
            line-height: 1.4;
        }
        .hero-badge-text span {
            display: block;
            color: var(--taupe);
            font-weight: 400;
            letter-spacing: 0.5px;
        }

        @media (max-width: 900px) {
            .hero-container {
                grid-template-columns: 1fr;
                text-align: center;
                padding: 60px 24px 40px;
                gap: 48px;
            }
            .hero-eyebrow { justify-content: center; }
            .hero-desc { margin: 0 auto 36px; }
            .hero-cta-group { justify-content: center; }
            .hero-stats { justify-content: center; gap: 28px; }
            .hero-image-wrap { order: -1; }
            .hero-img-frame { max-width: 280px; }
            .hero-badge { left: 0; bottom: 20px; }
            .hero-deco-line { display: none; }
        }

        /* ── SECTION COMMON ── */
        section { padding: 100px 0; }
        .section-inner { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
        @media (max-width: 768px) {
            section { padding: 60px 0; }
            .section-inner { padding: 0 24px; }
        }

        .section-label {
            display: inline-flex;
            align-items: center;
            gap: 14px;
            font-family: 'Nunito', sans-serif;
            font-size: 0.72rem;
            font-weight: 700;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: var(--taupe);
            margin-bottom: 16px;
        }
        .section-label::before {
            content: '';
            width: 28px; height: 1px;
            background: var(--taupe);
        }

        .section-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: clamp(2rem, 4vw, 3.8rem);
            font-weight: 300;
            line-height: 1.1;
            color: var(--navy);
        }
        .section-title em { font-style: italic; color: var(--taupe); }

        /* ── SOBRE ── */
        #sobre { background: var(--cream); }

        .sobre-grid {
            display: grid;
            grid-template-columns: 1fr 1.1fr;
            gap: 80px;
            align-items: center;
        }

        .sobre-image-wrap {
            position: relative;
        }

        .sobre-image-wrap img {
            width: 100%;
            aspect-ratio: 3/4;
            object-fit: cover;
            border-radius: 0 0 200px 200px;
            border: 6px solid var(--white);
            box-shadow: 0 30px 60px rgba(7,23,57,0.1);
            position: relative;
            z-index: 1;
        }

        .sobre-image-wrap::after {
            content: '';
            position: absolute;
            bottom: -20px; left: -20px;
            width: 65%;
            height: 65%;
            border: 1px solid var(--taupe);
            border-radius: 0 0 200px 200px;
            z-index: 0;
        }

        .sobre-text p {
            font-size: 1rem;
            font-weight: 300;
            line-height: 1.9;
            color: var(--steel);
            margin-bottom: 20px;
        }

        .crp-badge {
            display: inline-flex;
            align-items: center;
            gap: 12px;
            border: 1px solid rgba(166,136,104,0.4);
            padding: 12px 20px;
            margin-top: 12px;
        }
        .crp-badge .crp-icon { color: var(--taupe); font-size: 1.2rem; }
        .crp-badge .crp-label {
            font-size: 0.72rem;
            font-weight: 700;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: var(--steel);
        }
        .crp-badge .crp-num {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.1rem;
            color: var(--navy);
        }

        .valores-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2px;
            margin-top: 44px;
        }
        .valor-item {
            background: var(--white);
            padding: 24px 20px;
            text-align: center;
            transition: var(--transition);
        }
        .valor-item:hover { background: var(--navy); }
        .valor-item:hover .valor-icon,
        .valor-item:hover .valor-title,
        .valor-item:hover .valor-desc { color: var(--white); }
        .valor-icon {
            font-size: 1.4rem;
            color: var(--taupe);
            display: block;
            margin-bottom: 10px;
            transition: var(--transition);
        }
        .valor-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.05rem;
            font-weight: 600;
            color: var(--navy);
            display: block;
            margin-bottom: 6px;
            transition: var(--transition);
        }
        .valor-desc {
            font-size: 0.78rem;
            color: var(--steel);
            line-height: 1.6;
            transition: var(--transition);
        }

        @media (max-width: 900px) {
            .sobre-grid { grid-template-columns: 1fr; gap: 48px; }
            .sobre-image-wrap { max-width: 300px; margin: 0 auto; }
            .valores-grid { grid-template-columns: 1fr 1fr; }
        }

        /* ── ESPECIALIDADES ── */
        #especialidades { background: var(--white); }

        .especialidades-intro {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 60px;
            align-items: end;
            margin-bottom: 70px;
        }
        .especialidades-intro p {
            font-size: 1rem;
            font-weight: 300;
            line-height: 1.85;
            color: var(--steel);
        }

        .especialidades-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2px;
        }

        .espec-card {
            background: var(--cream);
            padding: 48px 36px;
            position: relative;
            overflow: hidden;
            transition: var(--transition);
            cursor: default;
        }
        .espec-card::before {
            content: '';
            position: absolute;
            bottom: 0; left: 0;
            width: 0; height: 3px;
            background: var(--taupe);
            transition: var(--transition);
        }
        .espec-card:hover { background: var(--navy); transform: translateY(-4px); }
        .espec-card:hover::before { width: 100%; }
        .espec-card:hover .espec-num,
        .espec-card:hover .espec-title,
        .espec-card:hover .espec-desc { color: var(--white); }
        .espec-card:hover .espec-icon { color: var(--sand); }
        .espec-card:hover .espec-sep { background: rgba(255,255,255,0.3); }

        .espec-num {
            font-family: 'Cormorant Garamond', serif;
            font-size: 0.85rem;
            font-weight: 400;
            color: var(--taupe);
            letter-spacing: 2px;
            display: block;
            margin-bottom: 20px;
            transition: var(--transition);
        }
        .espec-icon {
            font-size: 2rem;
            color: var(--taupe);
            display: block;
            margin-bottom: 20px;
            transition: var(--transition);
        }
        .espec-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.5rem;
            font-weight: 500;
            color: var(--navy);
            margin-bottom: 12px;
            line-height: 1.2;
            transition: var(--transition);
        }
        .espec-sep {
            width: 36px; height: 1px;
            background: var(--taupe);
            margin-bottom: 16px;
            transition: var(--transition);
        }
        .espec-desc {
            font-size: 0.9rem;
            font-weight: 300;
            line-height: 1.8;
            color: var(--steel);
            transition: var(--transition);
        }

        @media (max-width: 900px) {
            .especialidades-intro { grid-template-columns: 1fr; gap: 20px; margin-bottom: 40px; }
            .especialidades-grid { grid-template-columns: 1fr; }
        }

        /* ── DIFERENCIAIS ── */
        #diferenciais {
            background: var(--navy);
            padding: 80px 0;
        }

        .diferenciais-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 1px;
            background: rgba(255,255,255,0.06);
        }

        .diferencial-item {
            background: var(--navy);
            padding: 48px 32px;
            text-align: center;
            transition: var(--transition);
        }
        .diferencial-item:hover { background: rgba(166,136,104,0.1); }

        .dif-icon {
            font-size: 1.6rem;
            color: var(--taupe);
            display: block;
            margin-bottom: 16px;
        }
        .dif-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.2rem;
            font-weight: 500;
            color: var(--white);
            display: block;
            margin-bottom: 10px;
        }
        .dif-desc {
            font-size: 0.83rem;
            font-weight: 300;
            color: rgba(255,255,255,0.55);
            line-height: 1.7;
        }

        @media (max-width: 900px) {
            .diferenciais-grid { grid-template-columns: repeat(2, 1fr); }
        }
        @media (max-width: 480px) {
            .diferenciais-grid { grid-template-columns: 1fr; }
        }

        /* ── TRAJETÓRIA ── */
        #trajetoria { background: var(--cream); }

        .traj-grid {
            display: grid;
            grid-template-columns: 1fr 1px 1fr;
            gap: 0 60px;
            margin-top: 60px;
        }

        .traj-divider {
            background: rgba(7,23,57,0.08);
        }

        .traj-section-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.5rem;
            font-weight: 400;
            font-style: italic;
            color: var(--navy);
            margin-bottom: 36px;
            display: flex;
            align-items: center;
            gap: 14px;
        }
        .traj-section-title i {
            color: var(--taupe);
            font-style: normal;
            font-size: 1.1rem;
        }

        .timeline {
            border-left: 1px solid rgba(166,136,104,0.4);
            padding-left: 28px;
        }

        .tl-item {
            position: relative;
            padding-bottom: 36px;
            transition: var(--transition);
        }
        .tl-item:last-child { padding-bottom: 0; }
        .tl-item::before {
            content: '';
            position: absolute;
            left: -33px; top: 6px;
            width: 9px; height: 9px;
            background: var(--cream);
            border: 1px solid var(--taupe);
            border-radius: 50%;
            transition: var(--transition);
        }
        .tl-item:hover::before {
            background: var(--taupe);
            transform: scale(1.4);
        }

        .tl-date {
            font-size: 0.72rem;
            font-weight: 700;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            color: var(--taupe);
            display: block;
            margin-bottom: 6px;
        }
        .tl-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.15rem;
            font-weight: 500;
            color: var(--navy);
            margin-bottom: 4px;
        }
        .tl-sub {
            font-size: 0.83rem;
            color: var(--steel);
            font-weight: 300;
        }

        @media (max-width: 900px) {
            .traj-grid { grid-template-columns: 1fr; gap: 48px; }
            .traj-divider { height: 1px; width: 100%; }
        }

        /* ── DEPOIMENTOS ── */
        #depoimentos { background: var(--white); }

        .depoimentos-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2px;
            margin-top: 60px;
        }

        .depoimento-card {
            background: var(--cream);
            padding: 44px 36px;
            position: relative;
            transition: var(--transition);
        }
        .depoimento-card:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(7,23,57,0.08); }

        .dep-quote {
            font-family: 'Cormorant Garamond', serif;
            font-size: 4rem;
            line-height: 0.5;
            color: var(--taupe);
            opacity: 0.4;
            display: block;
            margin-bottom: 16px;
        }

        .dep-text {
            font-size: 0.95rem;
            font-weight: 300;
            line-height: 1.85;
            color: var(--steel);
            font-style: italic;
            margin-bottom: 28px;
        }

        .dep-stars {
            color: var(--taupe);
            font-size: 0.8rem;
            margin-bottom: 14px;
            letter-spacing: 3px;
        }

        .dep-author {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1rem;
            font-weight: 600;
            color: var(--navy);
        }
        .dep-role {
            font-size: 0.78rem;
            color: var(--taupe);
            font-weight: 500;
            letter-spacing: 0.5px;
        }

        @media (max-width: 900px) {
            .depoimentos-grid { grid-template-columns: 1fr; max-width: 500px; margin: 40px auto 0; }
        }

        /* ── CTA SECTION ── */
        #cta {
            background: var(--sand);
            padding: 100px 0;
        }

        .cta-inner {
            max-width: 700px;
            margin: 0 auto;
            text-align: center;
            padding: 0 40px;
        }
        .cta-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: clamp(2.2rem, 5vw, 4.2rem);
            font-weight: 300;
            color: var(--navy);
            line-height: 1.1;
            margin-bottom: 20px;
        }
        .cta-title em { font-style: italic; color: var(--taupe); }
        .cta-desc {
            font-size: 1rem;
            font-weight: 300;
            color: var(--steel);
            line-height: 1.8;
            margin-bottom: 44px;
        }
        .cta-buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

        .btn-cta-main {
            background: var(--navy);
            color: var(--white);
            font-family: 'Nunito', sans-serif;
            font-size: 0.82rem;
            font-weight: 600;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            padding: 16px 36px;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: 10px;
            transition: var(--transition);
        }
        .btn-cta-main:hover { background: var(--taupe); color: var(--white); transform: translateY(-2px); }

        .btn-cta-sec {
            background: transparent;
            color: var(--navy);
            font-family: 'Nunito', sans-serif;
            font-size: 0.82rem;
            font-weight: 600;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            padding: 15px 36px;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: 10px;
            border: 1px solid var(--navy);
            transition: var(--transition);
        }
        .btn-cta-sec:hover { background: var(--navy); color: var(--white); }

        /* ── NEW CONTATO SPLIT ── */
        .contato-split {
            display: flex;
            flex-direction: column;
            width: 100%;
            padding: 0 !important; /* Removes the white horizontal bands */
        }
        @media (min-width: 900px) {
            .contato-split { flex-direction: row; }
        }
        .contato-info-side {
            flex: 1;
            background: #F9F8F6; /* very light cream */
            padding: 80px 10%;
            display: flex;
            flex-direction: column;
            justify-content: center;
        }
        @media (max-width: 768px) {
            .contato-info-side { padding: 50px 24px; }
        }
        .contato-split-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: clamp(2.2rem, 4vw, 2.8rem);
            color: var(--navy);
            margin-bottom: 40px;
        }
        .contact-split-links {
            display: flex;
            flex-direction: column;
            gap: 25px;
        }
        .contact-item {
            display: flex;
            align-items: flex-start;
            gap: 15px;
        }
        .contact-item-icon {
            width: 36px; height: 36px;
            background: rgba(75, 99, 130, 0.1);
            color: var(--navy);
            border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 1.1rem;
            flex-shrink: 0;
            margin-top: 4px;
        }
        .contact-item-text {
            display: flex;
            flex-direction: column;
        }
        .contact-item-text strong {
            font-size: 0.95rem;
            color: var(--navy);
            margin-bottom: 3px;
        }
        .contact-item-text span {
            font-size: 0.9rem;
            color: var(--steel);
            line-height: 1.5;
        }

        .contato-map-side {
            flex: 1;
            min-height: 400px;
        }
        .contato-map-side iframe {
            width: 100%;
            height: 100%;
            border: 0;
            display: block;
        }

        /* ── NEW SITE FOOTER ── */
        .site-footer {
            background: #031121; /* Very dark blue matching the image */
            color: #d1d5db;
            padding: 80px 5% 30px;
            font-size: 0.9rem;
            font-family: 'Nunito', sans-serif;
        }
        .footer-top {
            display: grid;
            grid-template-columns: 1fr;
            gap: 50px;
            max-width: 1200px;
            margin: 0 auto 60px;
        }
        @media (min-width: 768px) {
            .footer-top { grid-template-columns: repeat(2, 1fr); }
        }
        @media (min-width: 992px) {
            .footer-top { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; }
        }

        .footer-logo {
            font-family: 'Montserrat', sans-serif;
            font-size: 1.5rem;
            font-weight: 300;
            color: var(--white);
            letter-spacing: 2px;
            margin-bottom: 20px;
        }
        .footer-desc {
            color: rgba(255,255,255,0.7);
            line-height: 1.6;
            margin-bottom: 20px;
            font-size: 0.85rem;
        }
        .footer-contact-mini {
            display: flex;
            flex-direction: column;
            gap: 10px;
            font-size: 0.85rem;
            color: rgba(255,255,255,0.8);
        }
        .footer-contact-mini span {
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .footer-heading {
            color: var(--white);
            font-size: 1.2rem;
            font-weight: 400;
            margin-bottom: 25px;
            font-family: 'Cormorant Garamond', serif;
        }
        .footer-list {
            list-style: none;
            padding: 0;
            margin: 0;
            display: flex;
            flex-direction: column;
            gap: 15px;
        }
        .footer-list a {
            color: rgba(255,255,255,0.7);
            text-decoration: none;
            transition: var(--transition);
            font-size: 0.85rem;
        }
        .footer-list a:hover {
            color: var(--white);
            padding-left: 5px;
        }

        .footer-bottom {
            max-width: 1200px;
            margin: 0 auto;
            padding-top: 30px;
            border-top: 1px solid rgba(255,255,255,0.1);
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 20px;
            text-align: center;
        }
        @media (min-width: 768px) {
            .footer-bottom {
                flex-direction: row;
                justify-content: space-between;
                text-align: left;
            }
        }
        .footer-copy {
            color: rgba(255,255,255,0.5);
            font-size: 0.8rem;
        }
        .footer-socials {
            display: flex;
            gap: 15px;
        }
        .footer-socials a {
            color: rgba(255,255,255,0.7);
            font-size: 1.1rem;
            transition: var(--transition);
        }
        .footer-socials a:hover {
            color: var(--white);
        }

        /* ── WHATSAPP FLOAT ── */
        .whatsapp-float {
            position: fixed;
            bottom: 28px; right: 28px;
            width: 52px; height: 52px;
            background: var(--white);
            border: 1px solid rgba(75,99,130,0.2);
            border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            color: var(--steel);
            font-size: 1.5rem;
            box-shadow: 0 4px 20px rgba(0,0,0,0.07);
            z-index: 9999;
            transition: var(--transition);
            text-decoration: none;
        }
        .whatsapp-float:hover {
            transform: translateY(-4px);
            background: var(--navy);
            border-color: var(--navy);
            color: var(--white);
            box-shadow: 0 10px 28px rgba(7,23,57,0.15);
        }

        /* ── ANIMATIONS ── */
        @keyframes fadeUp {
            from { opacity: 0; transform: translateY(30px); }
            to { opacity: 1; transform: translateY(0); }
        }