/*
Theme Name: Eros - TI Inteligente
Theme URI: https://example.com/
Author: Eros - TI Inteligente
Description: Tema baseado no HTML fornecido (estilo dark, tecnológico e minimalista).
Version: 3.0.11.7
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: eros-ti
Tags: one-column, custom-logo, custom-menu, featured-images, full-width-template, block-styles
*/

:root {
            --primary-dark: #0a0f1a;
            --primary-blue: #0c1929;
            --accent-cyan: #00d4ff;
            --accent-teal: #0ea5e9;
            --accent-purple: #8b5cf6;
            --text-white: #ffffff;
            --text-gray: #94a3b8;
            --text-light: #cbd5e1;
            --card-bg: rgba(15, 25, 45, 0.7);
            --card-border: rgba(0, 212, 255, 0.15);
            --gradient-hero: linear-gradient(135deg, #0a0f1a 0%, #0c1929 50%, #0f172a 100%);
            --gradient-accent: linear-gradient(135deg, #00d4ff 0%, #0ea5e9 50%, #8b5cf6 100%);
            --shadow-glow: 0 0 60px rgba(0, 212, 255, 0.15);
        }

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

        html {
            scroll-behavior: smooth;
        }

        body.eros-ti-site {
            font-family: 'Plus Jakarta Sans', sans-serif;
            background: var(--primary-dark);
            color: var(--text-white);
            line-height: 1.6;
            overflow-x: hidden;
        }

        /* ===== NAVIGATION ===== */
        .navbar {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            z-index: 1000;
            padding: 1rem 2rem;
            background: rgba(10, 15, 26, 0.85);
            backdrop-filter: blur(20px);
            border-bottom: 1px solid var(--card-border);
            transition: all 0.3s ease;
        }

        .navbar.scrolled {
            padding: 0.75rem 2rem;
            background: rgba(10, 15, 26, 0.95);
        }

        .nav-container {
            max-width: 1400px;
            margin: 0 auto;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .logo {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            text-decoration: none;
        }

        .logo-icon {
            width: 45px;
            height: 45px;
            background: var(--gradient-accent);
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: 'Space Grotesk', sans-serif;
            font-weight: 700;
            font-size: 1.5rem;
            color: var(--primary-dark);
        }

        .logo-text {
            font-family: 'Space Grotesk', sans-serif;
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--text-white);
        }

        .logo-text span {
            color: var(--accent-cyan);
        }

        .nav-links {
            display: flex;
            gap: 2.5rem;
            list-style: none;
        }

        .nav-links a {
            color: var(--text-gray);
            text-decoration: none;
            font-weight: 500;
            font-size: 0.95rem;
            transition: color 0.3s ease;
            position: relative;
        }

        .nav-links a::after {
            content: '';
            position: absolute;
            bottom: -5px;
            left: 0;
            width: 0;
            height: 2px;
            background: var(--gradient-accent);
            transition: width 0.3s ease;
        }

        .nav-links a:hover {
            color: var(--text-white);
        }

        .nav-links a:hover::after {
            width: 100%;
        }

        .nav-cta {
            display: flex;
            align-items: center;
            gap: 1rem;
        }

        .phone-link {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            color: var(--text-gray);
            text-decoration: none;
            font-weight: 500;
            transition: color 0.3s ease;
        }

        .phone-link:hover {
            color: var(--accent-cyan);
        }

        .btn-primary {
            background: var(--gradient-accent);
            color: var(--primary-dark);
            padding: 0.75rem 1.5rem;
            border-radius: 10px;
            text-decoration: none;
            font-weight: 600;
            transition: all 0.3s ease;
            border: none;
            cursor: pointer;
        }

        .btn-primary:hover {
            transform: translateY(-2px);
            box-shadow: 0 10px 30px rgba(0, 212, 255, 0.3);
        }

        .btn-secondary {
            background: transparent;
            color: var(--text-white);
            padding: 0.75rem 1.5rem;
            border-radius: 10px;
            text-decoration: none;
            font-weight: 600;
            border: 1px solid var(--card-border);
            transition: all 0.3s ease;
        }

        .btn-secondary:hover {
            border-color: var(--accent-cyan);
            background: rgba(0, 212, 255, 0.1);
        }

        /* ===== HERO SECTION ===== */
        .hero {
            min-height: 100vh;
            background: var(--gradient-hero);
            position: relative;
            display: flex;
            align-items: center;
            padding: 8rem 2rem 4rem;
            overflow: hidden;
        }

        .hero::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: 
                radial-gradient(ellipse at 20% 20%, rgba(0, 212, 255, 0.08) 0%, transparent 50%),
                radial-gradient(ellipse at 80% 80%, rgba(139, 92, 246, 0.08) 0%, transparent 50%);
            pointer-events: none;
        }

        .hero-grid {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background-image: 
                linear-gradient(rgba(0, 212, 255, 0.03) 1px, transparent 1px),
                linear-gradient(90deg, rgba(0, 212, 255, 0.03) 1px, transparent 1px);
            background-size: 60px 60px;
            pointer-events: none;
        }

        .hero-container {
            max-width: 1400px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 4rem;
            align-items: center;
            position: relative;
            z-index: 1;
        }

        .hero-content {
            animation: fadeInUp 1s ease;
        }

        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .hero-badge {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            background: rgba(0, 212, 255, 0.1);
            border: 1px solid var(--card-border);
            padding: 0.5rem 1rem;
            border-radius: 50px;
            font-size: 0.875rem;
            color: var(--accent-cyan);
            margin-bottom: 1.5rem;
        }

        .hero-badge-dot {
            width: 8px;
            height: 8px;
            background: var(--accent-cyan);
            border-radius: 50%;
            animation: pulse 2s infinite;
        }

        @keyframes pulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.5; }
        }

        .hero h1 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: clamp(2.5rem, 5vw, 4rem);
            font-weight: 700;
            line-height: 1.1;
            margin-bottom: 1.5rem;
        }

        .hero h1 .gradient-text {
            background: var(--gradient-accent);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        .hero-description {
            font-size: 1.125rem;
            color: var(--text-gray);
            margin-bottom: 2rem;
            max-width: 540px;
        }

        .hero-buttons {
            display: flex;
            gap: 1rem;
            margin-bottom: 3rem;
        }

        .hero-stats {
            display: flex;
            gap: 3rem;
        }

        .stat-item {
            text-align: left;
        }

        .stat-number {
            font-family: 'Space Grotesk', sans-serif;
            font-size: 2.5rem;
            font-weight: 700;
            color: var(--accent-cyan);
        }

        .stat-label {
            font-size: 0.875rem;
            color: var(--text-gray);
        }

        .hero-visual {
            position: relative;
            animation: fadeInUp 1s ease 0.3s both;
        }

        .hero-card {
            background: var(--card-bg);
            border: 1px solid var(--card-border);
            border-radius: 24px;
            padding: 2rem;
            backdrop-filter: blur(20px);
            box-shadow: var(--shadow-glow);
        }

        .hero-card-header {
            display: flex;
            align-items: center;
            gap: 1rem;
            margin-bottom: 1.5rem;
            padding-bottom: 1.5rem;
            border-bottom: 1px solid var(--card-border);
        }

        .hero-card-icon {
            width: 50px;
            height: 50px;
            background: var(--gradient-accent);
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .hero-card-title {
            font-weight: 600;
        }

        .hero-card-subtitle {
            font-size: 0.875rem;
            color: var(--text-gray);
        }

        .status-list {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .status-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 1rem;
            background: rgba(0, 212, 255, 0.05);
            border-radius: 12px;
            border: 1px solid transparent;
            transition: all 0.3s ease;
        }

        .status-item:hover {
            border-color: var(--card-border);
            background: rgba(0, 212, 255, 0.1);
        }

        .status-info {
            display: flex;
            align-items: center;
            gap: 0.75rem;
        }

        .status-dot {
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: #22c55e;
        }

        .status-dot.warning {
            background: #f59e0b;
        }

        .status-badge {
            padding: 0.25rem 0.75rem;
            border-radius: 50px;
            font-size: 0.75rem;
            font-weight: 600;
        }

        .status-badge.active {
            background: rgba(34, 197, 94, 0.2);
            color: #22c55e;
        }

        .status-badge.progress {
            background: rgba(245, 158, 11, 0.2);
            color: #f59e0b;
        }

        /* ===== SERVICES SECTION ===== */
        .services {
            padding: 8rem 2rem;
            background: var(--primary-blue);
            position: relative;
        }

        .services::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 1px;
            background: linear-gradient(90deg, transparent, var(--card-border), transparent);
        }

        .container {
            max-width: 1400px;
            margin: 0 auto;
        }

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

        .section-tag {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            background: rgba(0, 212, 255, 0.1);
            border: 1px solid var(--card-border);
            padding: 0.5rem 1rem;
            border-radius: 50px;
            font-size: 0.875rem;
            color: var(--accent-cyan);
            margin-bottom: 1rem;
        }

        .section-title {
            font-family: 'Space Grotesk', sans-serif;
            font-size: clamp(2rem, 4vw, 3rem);
            font-weight: 700;
            margin-bottom: 1rem;
        }

        .section-description {
            font-size: 1.125rem;
            color: var(--text-gray);
            max-width: 600px;
            margin: 0 auto;
        }

        .services-grid {
            display: grid;
            /* 6 cards = 2 linhas de 3 (desktop) */
            grid-template-columns: repeat(3, minmax(260px, 360px));
            gap: 1.25rem;
            justify-content: center;
            width: 100%;
            max-width: 1160px;
            margin-inline: auto;
        }

        @media (max-width: 1100px) {
            .services-grid {
                grid-template-columns: repeat(2, minmax(260px, 420px));
                max-width: 920px;
            }
        }

        .service-card {
            display: block;
            text-decoration: none;
            color: inherit;
            background: var(--card-bg);
            border: 1px solid var(--card-border);
            border-radius: 20px;
            padding: 2rem;
            backdrop-filter: blur(20px);
            transition: all 0.4s ease;
            position: relative;
            overflow: hidden;
        }

        .service-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 3px;
            background: var(--gradient-accent);
            transform: scaleX(0);
            transition: transform 0.4s ease;
        }

        .service-card:hover {
            transform: translateY(-8px);
            border-color: rgba(0, 212, 255, 0.3);
            box-shadow: 0 20px 60px rgba(0, 212, 255, 0.15);
        }

        .service-card:hover::before {
            transform: scaleX(1);
        }

        .service-icon {
            width: 60px;
            height: 60px;
            background: linear-gradient(135deg, rgba(0, 212, 255, 0.2), rgba(139, 92, 246, 0.2));
            border-radius: 16px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 1.5rem;
            font-size: 1.5rem;
        }

        .service-icon svg {
            width: 28px;
            height: 28px;
            display: block;
        }

        .service-card h3 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: 1.25rem;
            font-weight: 600;
            margin-bottom: 0.75rem;
        }

        .service-card p {
            color: var(--text-gray);
            font-size: 0.95rem;
            line-height: 1.7;
        }

        /* ===== ABOUT SECTION ===== */
        .about {
            padding: 8rem 2rem;
            background: var(--primary-dark);
        }

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

        .about-image {
            position: relative;
        }

        .about-image img {
            width: 100%;
            border-radius: 24px;
            object-fit: cover;
        }

        .about-image::before {
            content: '';
            position: absolute;
            top: -20px;
            left: -20px;
            right: 20px;
            bottom: 20px;
            border: 2px solid var(--card-border);
            border-radius: 24px;
            z-index: -1;
        }

        .about-content .section-tag {
            margin-bottom: 1rem;
        }

        .about-content h2 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: clamp(2rem, 4vw, 2.5rem);
            font-weight: 700;
            margin-bottom: 1.5rem;
        }

        .about-content p {
            color: var(--text-gray);
            font-size: 1.05rem;
            margin-bottom: 2rem;
        }

        .about-features {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 1.5rem;
        }

        .about-feature {
            display: flex;
            align-items: flex-start;
            gap: 1rem;
        }

        .about-feature-icon {
            width: 40px;
            height: 40px;
            background: rgba(0, 212, 255, 0.1);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            color: var(--accent-cyan);
        }

        .about-feature h4 {
            font-size: 1rem;
            font-weight: 600;
            margin-bottom: 0.25rem;
        }

        .about-feature p {
            font-size: 0.875rem;
            color: var(--text-gray);
            margin-bottom: 0;
        }

        /* ===== WHY US SECTION ===== */
        .why-us {
            padding: 8rem 2rem;
            background: var(--primary-blue);
        }

        .why-us-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 1.5rem;
        }

        .why-card {
            background: var(--card-bg);
            border: 1px solid var(--card-border);
            border-radius: 20px;
            padding: 2rem;
            text-align: center;
            backdrop-filter: blur(20px);
            transition: all 0.4s ease;
        }

        .why-card:hover {
            transform: translateY(-5px);
            border-color: rgba(0, 212, 255, 0.3);
        }

        .why-icon {
            width: 70px;
            height: 70px;
            background: var(--gradient-accent);
            border-radius: 20px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1.5rem;
            font-size: 1.75rem;
        }

        .why-card h3 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: 1.125rem;
            font-weight: 600;
            margin-bottom: 0.75rem;
        }

        .why-card p {
            color: var(--text-gray);
            font-size: 0.9rem;
        }

        /* ===== FAQ SECTION ===== */
        .faq {
            padding: 8rem 2rem;
            background: var(--primary-dark);
        }

        .faq-grid {
            display: grid;
            grid-template-columns: 1fr 1.5fr;
            gap: 4rem;
            align-items: start;
        }

        .faq-content h2 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: clamp(2rem, 4vw, 2.5rem);
            font-weight: 700;
            margin-bottom: 1rem;
        }

        .faq-content p {
            color: var(--text-gray);
            margin-bottom: 2rem;
        }

        .faq-list {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .faq-item {
            background: var(--card-bg);
            border: 1px solid var(--card-border);
            border-radius: 16px;
            overflow: hidden;
            transition: all 0.3s ease;
        }

        .faq-item:hover {
            border-color: rgba(0, 212, 255, 0.3);
        }

        .faq-question {
            width: 100%;
            padding: 1.5rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: transparent;
            border: none;
            color: var(--text-white);
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-size: 1rem;
            font-weight: 600;
            text-align: left;
            cursor: pointer;
            transition: all 0.3s ease;
        }

        .faq-question:hover {
            color: var(--accent-cyan);
        }

        .faq-icon {
            width: 30px;
            height: 30px;
            background: rgba(0, 212, 255, 0.1);
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.3s ease;
            flex-shrink: 0;
        }

        .faq-item.active .faq-icon {
            background: var(--accent-cyan);
            color: var(--primary-dark);
            transform: rotate(45deg);
        }

        .faq-answer {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s ease;
        }

        .faq-item.active .faq-answer {
            max-height: 300px;
        }

        .faq-answer-content {
            padding: 0 1.5rem 1.5rem;
            color: var(--text-gray);
            line-height: 1.7;
        }

        /* ===== CTA SECTION ===== */
        .cta {
            padding: 6rem 2rem;
            background: var(--primary-blue);
            position: relative;
            overflow: hidden;
        }

        .cta::before {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 800px;
            height: 800px;
            background: radial-gradient(circle, rgba(0, 212, 255, 0.1) 0%, transparent 70%);
            pointer-events: none;
        }

        .cta-container {
            max-width: 800px;
            margin: 0 auto;
            text-align: center;
            position: relative;
            z-index: 1;
        }

        .cta h2 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: clamp(2rem, 4vw, 3rem);
            font-weight: 700;
            margin-bottom: 1rem;
        }

        .cta p {
            color: var(--text-gray);
            font-size: 1.125rem;
            margin-bottom: 2rem;
        }

        .cta-buttons {
            display: flex;
            gap: 1rem;
            justify-content: center;
        }

        /* ===== FOOTER ===== */
        .footer {
            padding: 4rem 2rem 2rem;
            background: var(--primary-dark);
            border-top: 1px solid var(--card-border);
        }

        .footer-grid {
            display: grid;
            grid-template-columns: 2fr 1fr 1fr 1fr;
            gap: 3rem;
            margin-bottom: 3rem;
        }

        .footer-brand .logo {
            margin-bottom: 1.5rem;
        }

        .footer-brand p {
            color: var(--text-gray);
            font-size: 0.95rem;
            margin-bottom: 1.5rem;
            max-width: 300px;
        }

        .social-links {
            display: flex;
            gap: 0.75rem;
        }

        .social-link {
            width: 40px;
            height: 40px;
            background: var(--card-bg);
            border: 1px solid var(--card-border);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--text-gray);
            text-decoration: none;
            transition: all 0.3s ease;
        }

        .social-link:hover {
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
        }

        .footer-column h4 {
            font-family: 'Space Grotesk', sans-serif;
            font-size: 1rem;
            font-weight: 600;
            margin-bottom: 1.25rem;
        }

        .footer-links {
            list-style: none;
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }

        .footer-links a {
            color: var(--text-gray);
            text-decoration: none;
            font-size: 0.95rem;
            transition: color 0.3s ease;
        }

        .footer-links a:hover {
            color: var(--accent-cyan);
        }

        /* Lista de serviços no rodapé: mais responsiva */
        .footer-services-links{
            display: grid;
            grid-template-columns: 1fr;
            gap: 0.6rem 1.25rem;
        }
        .footer-services-links a{ display:block; }
        @media (min-width: 520px){
            .footer-services-links{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
        }

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

        .contact-item {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            color: var(--text-gray);
            font-size: 0.95rem;
        }

        .contact-item a {
            color: var(--text-gray);
            text-decoration: none;
            transition: color 0.3s ease;
        }

        .contact-item a:hover {
            color: var(--accent-cyan);
        }

        .footer-bottom {
            padding-top: 2rem;
            border-top: 1px solid var(--card-border);
            display: flex;
            justify-content: space-between;
            align-items: center;
            color: var(--text-gray);
            font-size: 0.875rem;
        }

        /* ===== RESPONSIVE ===== */
        @media (max-width: 1024px) {
            .hero-container {
                grid-template-columns: 1fr;
                text-align: center;
            }

            .hero-content {
                order: 1;
            }

            .hero-visual {
                order: 0;
                max-width: 500px;
                margin: 0 auto;
            }

            .hero-description {
                margin: 0 auto 2rem;
            }

            .hero-buttons {
                justify-content: center;
            }

            .hero-stats {
                justify-content: center;
            }

            .about-grid {
                grid-template-columns: 1fr;
            }

            .why-us-grid {
                grid-template-columns: repeat(2, 1fr);
            }

            .faq-grid {
                grid-template-columns: 1fr;
            }

            .footer-grid {
                grid-template-columns: 1fr 1fr;
            }
        }

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

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

            .why-us-grid {
                grid-template-columns: 1fr;
            }

            .about-features {
                grid-template-columns: 1fr;
            }

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

            .footer-grid {
                grid-template-columns: 1fr;
            }

            .footer-bottom {
                flex-direction: column;
                gap: 1rem;
                text-align: center;
            }
        }

        /* ===== MOBILE MENU ===== */
        .mobile-menu-btn {
            display: none;
            background: none;
            border: none;
            cursor: pointer;
            padding: 0.5rem;
        }

        @media (max-width: 768px) {
            .mobile-menu-btn {
                display: flex;
                flex-direction: column;
                gap: 5px;
            }

            .mobile-menu-btn span {
                display: block;
                width: 25px;
                height: 2px;
                background: var(--text-white);
                transition: all 0.3s ease;
            }
        }

/* WP helpers */
body.eros-ti-site main{padding-top:90px} /* compensate fixed navbar */
.wp-block-columns{gap:1.5rem}
.wp-block-image img{border-radius:24px}
a.btn-primary, a.btn-secondary{display:inline-flex; align-items:center; justify-content:center}
.eros-wrap{max-width:1400px; margin:0 auto}
.notice{margin-bottom:12px}

/* ===== Logo ===== */
.site-logo{height:42px; width:auto; display:block}
.custom-logo{height:42px; width:auto}

/* ===== Mobile menu ===== */
.mobile-menu-btn{display:none}
@media (max-width: 980px){
  .mobile-menu-btn{
    display:inline-flex; flex-direction:column; justify-content:center; gap:6px;
    width:44px; height:44px; border-radius:12px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.04);
    cursor:pointer;
  }
  .mobile-menu-btn span{display:block; height:2px; width:22px; background:rgba(255,255,255,.85); margin:0 auto; border-radius:2px;}

  .mobile-panel{
    position:fixed; top:78px; left:12px; right:12px;
    max-height:calc(100vh - 96px); overflow:auto;
    padding:14px; border-radius:18px;
    border:1px solid var(--card-border);
    background:rgba(16, 24, 40, .92);
    backdrop-filter: blur(14px);
    box-shadow:0 20px 60px rgba(0,0,0,.45);
    display:none;
  }
  .navbar.open .mobile-panel{display:block}

  .nav-links{flex-direction:column; align-items:stretch; gap:6px; margin-top:4px;}
  .nav-links a{padding:12px 12px; border-radius:14px; background:rgba(255,255,255,.03);}
  .nav-cta{width:100%; margin-top:10px; flex-direction:column; gap:10px;}
  .phone-link{justify-content:center}
  .btn-primary{width:100%; justify-content:center}
}

/* ===== Services dropdown (desktop) ===== */
.nav-links li{position:relative}
.nav-links .menu-item-has-children > a::after{content:"▾"; font-size:12px; margin-left:8px; opacity:.85;}
.nav-links .sub-menu{
  display:none; position:absolute; top:calc(100% + 10px); left:0; width:280px;
  padding:10px; border-radius:18px; border:1px solid var(--card-border);
  background:rgba(16, 24, 40, .96); box-shadow:0 24px 70px rgba(0,0,0,.45);
}
.nav-links li:hover > .sub-menu{display:block}
.nav-links .sub-menu a{display:block; padding:10px 12px; border-radius:14px}
.nav-links .sub-menu a:hover{background:rgba(255,255,255,.06)}
@media (max-width: 980px){
  .nav-links .sub-menu{position:static; width:auto; padding:6px; margin-top:6px; display:block; background:rgba(255,255,255,.03);}
}

/* ===== Service detail page blocks ===== */
.service-hero{padding:6rem 0 3rem;}
.service-hero .service-hero-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:2.2rem; align-items:center;}
.service-box{background:var(--card-bg); border:1px solid var(--card-border); border-radius:24px; padding:1.8rem;}
.service-list{margin:0; padding-left:1.2rem; color:var(--text-gray)}
.service-list li{margin:.35rem 0}
.service-media{
  border-radius:24px; overflow:hidden; border:1px solid var(--card-border);
  background:rgba(255,255,255,.03); min-height:320px;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.6); font-weight:700;
}

/* Imagem/ilustração do topo das páginas de serviço */
.service-hero-image,
.service-hero-illustration{width:100%; height:100%}
.service-hero-image img{
  width:100%; height:100%; display:block;
  object-fit:cover;
}
.service-hero-illustration svg{
  width:100%; height:100%; display:block;
}
@media (max-width: 980px){
  .service-hero .service-hero-grid{grid-template-columns:1fr}
  .service-hero{padding:5rem 0 2.2rem}
}

/* ===== Services mega items ===== */
.nav-links .sub-menu li{margin:4px 0}
.nav-links .sub-menu a strong{display:block; font-weight:700}
.nav-links .sub-menu a{line-height:1.2}

/* ===============================
   NAVBAR / MEGA MENU FIX (v2.8)
   Prevent mobile panel from showing on desktop and keep mega menu positioned.
   =============================== */
.mobile-panel{display:none;}
.desktop-nav-wrap{display:flex; align-items:center; gap:22px;}
.desktop-nav{display:flex; align-items:center; gap:26px; margin:0; padding:0; list-style:none;}
.desktop-nav > li{position:relative;}
.desktop-nav a{white-space:nowrap;}

/* Mega menu positioning (desktop) */
#menuServicos{position:relative;}
#menuServicos .mega-menu{
  display:none;
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  top:calc(100% + 14px);
  width:min(980px, calc(100vw - 40px));
  z-index:9999;
}
#menuServicos.is-open > .mega-menu{display:block;}

/* Make mega menu items wrap nicely */
#menuServicos .mega-grid{display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:14px;}
@media (max-width: 1100px){
  #menuServicos .mega-grid{grid-template-columns:repeat(2, minmax(0, 1fr));}
}
@media (max-width: 980px){
  .desktop-nav-wrap{display:none;}
  .mobile-panel{display:none;}
  .navbar.open .mobile-panel{display:block;}
}

/* Garantir serviços totalmente clicáveis */
.nav-links .sub-menu a{
  display:block;
  width:100%;
  cursor:pointer;
}

/* Logo layout */
.logo{display:flex; align-items:center; gap:12px; text-decoration:none}
.logo img.site-logo{height:44px; width:auto; display:block}

/* Make submenu clickable */
.navbar{z-index:9999}
.nav-links .sub-menu{pointer-events:auto}
@media (max-width: 980px){
  .nav-links .menu-item-has-children .sub-menu{display:none}
  .nav-links .menu-item-has-children.sub-open .sub-menu{display:block}
}

/* v1.6 navbar fixes */
.logo-text{font-weight:700; color:#fff}
.site-logo{height:42px; width:auto; display:block}

.menu-row{display:flex; align-items:center; gap:10px}
.submenu-toggle{
  display:none;
  width:36px; height:36px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.9);
  cursor:pointer;
}

.nav-links .sub-menu{
  padding:12px;
}
.nav-links .sub-menu li{margin:6px 0}
a.service-item{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px;
  border-radius:16px;
  text-decoration:none;
  background:rgba(255,255,255,.03);
}
a.service-item:hover{background:rgba(255,255,255,.06)}
.service-thumb{
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(16px 16px at 30% 30%, rgba(80,220,255,.55), transparent 70%),
    radial-gradient(18px 18px at 70% 70%, rgba(132,110,255,.55), transparent 70%),
    rgba(255,255,255,.03);
  flex:0 0 auto;
}
.service-meta strong{display:block; font-weight:700; color:#fff; margin-bottom:4px}
.service-meta span{display:block; color:var(--text-gray); font-size:.92rem; line-height:1.35}

/* Desktop dropdown */
@media (min-width: 981px){
  .menu-item-has-children .sub-menu{
    display:none;
    position:absolute;
    top:calc(100% + 12px);
    left:0;
    width:360px;
    z-index:2000;
  }
  .menu-item-has-children:hover > .sub-menu{display:block}
}

/* Mobile behavior */
@media (max-width: 980px){
  .submenu-toggle{display:inline-flex; align-items:center; justify-content:center}
  .menu-item-has-children .sub-menu{position:static; width:auto; display:none; margin-top:10px; background:transparent; box-shadow:none; border:none; padding:0}
  .menu-item-has-children.sub-open .sub-menu{display:block}
}



/* Services submenu */
.submenu-toggle{display:none; border:0; background:transparent; color:rgba(255,255,255,.85); cursor:pointer; padding:8px 10px; border-radius:12px;}
.menu-item-has-children > .sub-menu{
  display:none;
  position:absolute;
  top:calc(100% + 12px);
  left:0;
  width:360px;
  padding:10px;
  border-radius:18px;
  border:1px solid var(--card-border);
  background:rgba(16,24,40,.96);
  box-shadow:0 24px 70px rgba(0,0,0,.45);
}
.menu-item-has-children:hover > .sub-menu{display:block;}
.sub-menu li{margin:4px 0;}
.sub-menu a{display:block; padding:12px 12px; border-radius:14px; line-height:1.15;}
.sub-menu a:hover{background:rgba(255,255,255,.06);}
.sub-menu a strong{display:block; font-weight:800; margin-bottom:4px;}
.sub-menu a span{display:block; font-size:.9em; opacity:.78; font-weight:500;}

/* Mobile navbar */
@media (max-width: 980px){
  .nav-links{flex-direction:column; align-items:stretch; gap:8px;}
  .nav-links > li{flex-direction:column; align-items:stretch; gap:6px;}
  .submenu-toggle{display:inline-flex; align-self:flex-end;}
  .menu-item-has-children > a{display:flex; justify-content:space-between; width:100%;}
  .menu-item-has-children > .sub-menu{
    position:static;
    width:auto;
    display:none;
    padding:8px;
    margin-top:4px;
    background:rgba(255,255,255,.03);
    box-shadow:none;
  }
  .menu-item-has-children.sub-open > .sub-menu{display:block;}
}


/* ===== Navbar layout fixes (v1.8) ===== */
.navbar{position:fixed; top:0; left:0; right:0; z-index:9999;}
.nav-container{display:flex; align-items:center; justify-content:space-between; gap:22px;}
.logo{display:flex; align-items:center; gap:14px; text-decoration:none; white-space:nowrap;}
.logo .site-logo{height:48px; width:auto; display:block;}
.logo .logo-name{font-weight:800; letter-spacing:-.3px; color:var(--text-white);}

/* reset lists */
.nav-links, .nav-links li, .sub-menu, .sub-menu li{list-style:none; margin:0; padding:0;}
.nav-links{display:flex; align-items:center; gap:22px; flex-wrap:nowrap;}
.nav-links > li{position:relative; display:inline-flex; align-items:center; gap:8px;}
.nav-links a{white-space:nowrap; text-decoration:none;}

/* Services submenu desktop */
.submenu-toggle{display:none; border:0; background:transparent; color:rgba(255,255,255,.85); cursor:pointer; padding:8px 10px; border-radius:12px;}
.menu-item-has-children > .sub-menu{
  display:none;
  position:absolute !important;
  top:calc(100% + 12px);
  left:0;
  width:360px;
  padding:10px;
  border-radius:18px;
  border:1px solid var(--card-border);
  background:rgba(16,24,40,.96);
  box-shadow:0 24px 70px rgba(0,0,0,.45);
}
.menu-item-has-children:hover > .sub-menu{display:block;}
.sub-menu li{margin:4px 0;}
.sub-menu a{display:block; padding:12px 12px; border-radius:14px; line-height:1.15;}
.sub-menu a:hover{background:rgba(255,255,255,.06);}
.sub-menu a strong{display:block; font-weight:800; margin-bottom:4px;}
.sub-menu a span{display:block; font-size:.9em; opacity:.78; font-weight:500;}

/* Force desktop layout even if other styles exist */
@media (min-width: 981px){
  .nav-links{flex-direction:row !important;}
  .nav-links > li{flex-direction:row !important;}
  .menu-item-has-children > .sub-menu{display:none;}
  .menu-item-has-children:hover > .sub-menu{display:block;}
}

/* Mobile layout */
@media (max-width: 980px){
  .nav-links{flex-direction:column; align-items:stretch; gap:8px;}
  .nav-links > li{display:flex; flex-direction:column; align-items:stretch; gap:6px;}
  .submenu-toggle{display:inline-flex; align-self:flex-end;}
  .menu-item-has-children > a{display:flex; justify-content:space-between; width:100%;}
  .menu-item-has-children > .sub-menu{
    position:static !important;
    width:auto;
    display:none;
    padding:8px;
    margin-top:4px;
    background:rgba(255,255,255,.03);
    box-shadow:none;
  }
  .menu-item-has-children.sub-open > .sub-menu{display:block;}
}




/* ===== Mega menu (Serviços) v2.3 ===== */
.has-mega{position:relative;}
.has-mega .submenu-toggle{display:none;}
.has-mega .mega-menu{
  display:none !important;
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%);
  width:min(980px, calc(100vw - 40px));
  padding:14px;
  border-radius:22px;
  border:1px solid var(--card-border);
  background:rgba(16,24,40,.96);
  box-shadow:0 28px 90px rgba(0,0,0,.55);
}
.has-mega.is-open .mega-menu{display:block !important;}

/* Make sure global nav link styles do not affect mega menu cards */
.has-mega .mega-menu a{
  white-space:normal !important;
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
}

.mega-inner{padding:10px;}
.mega-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; padding:6px 6px 14px;}
.mega-title{font-size:1.05rem; font-weight:800; color:var(--text-white);}
.mega-subtitle{font-size:.95rem; opacity:.78; color:var(--text-gray);}

.mega-grid{display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:12px;}
.mega-item{
  display:flex !important;
  gap:14px;
  padding:14px !important;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03) !important;
  text-decoration:none !important;
}
.mega-item:hover{background:rgba(255,255,255,.06) !important;}
.mega-icon{
  width:44px; height:44px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
  flex:0 0 44px;
}
.mega-item-title{font-weight:800; color:var(--text-white); margin-bottom:4px;}
.mega-item-desc{font-size:.92rem; color:var(--text-gray); opacity:.88; line-height:1.25;}
.mega-text{min-width:0;}

@media (max-width: 980px){
  .has-mega .submenu-toggle{display:inline-flex;}
  .has-mega .mega-menu{
    position:static;
    transform:none;
    width:auto;
    padding:10px;
    margin-top:6px;
    box-shadow:none;
  }
  .mega-grid{grid-template-columns:1fr;}
  .mega-head{flex-direction:column; align-items:flex-start;}
}

/* ===== Navbar hard reset v2.6 ===== */
.navbar ul, .navbar ol, .navbar li{list-style:none !important; margin:0 !important; padding:0 !important;}
.navbar a{color:rgba(255,255,255,.85); text-decoration:none;}
.navbar a:visited{color:rgba(255,255,255,.85);}
.navbar a:hover{color:#fff;}
/* Hide any WP-generated submenu completely (we use mega menu only) */
.navbar .sub-menu{display:none !important;}

/* Ensure menu layout */
.nav-container{display:flex; align-items:center; justify-content:space-between; gap:18px;}
.main-nav{flex:1;}
.nav-links{display:flex; align-items:center; justify-content:flex-end; gap:22px; flex-wrap:nowrap;}
.nav-links > li{position:relative; display:inline-flex; align-items:center; gap:8px;}
.nav-links > li > a{padding:10px 10px; border-radius:12px; white-space:nowrap;}
.nav-links > li > a:hover{background:rgba(255,255,255,.06);}

/* Mega menu */
.has-mega{position:relative;}
.has-mega .submenu-toggle{display:none; border:0; background:transparent; color:rgba(255,255,255,.85); cursor:pointer; padding:8px 10px; border-radius:12px;}
.has-mega .mega-menu{
  display:none;
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%);
  width:min(980px, calc(100vw - 40px));
  padding:14px;
  border-radius:22px;
  border:1px solid var(--card-border);
  background:rgba(16,24,40,.96);
  box-shadow:0 28px 90px rgba(0,0,0,.55);
  z-index:99999;
}
.has-mega.is-open .mega-menu{display:block;}
.mega-inner{padding:10px;}
.mega-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; padding:6px 6px 14px;}
.mega-title{font-size:1.05rem; font-weight:800; color:var(--text-white);}
.mega-subtitle{font-size:.95rem; opacity:.78; color:var(--text-gray);}

.mega-grid{display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:12px;}
.mega-item{
  display:flex;
  gap:14px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.mega-item:hover{background:rgba(255,255,255,.06);}
.mega-icon{
  width:44px; height:44px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
  flex:0 0 44px;
}
.mega-item-title{font-weight:800; color:var(--text-white); margin-bottom:4px;}
.mega-item-desc{font-size:.92rem; color:var(--text-gray); opacity:.88; line-height:1.25;}
.mega-text{min-width:0;}
/* override global nav link styles inside mega menu */
.has-mega .mega-menu a{padding:0 !important; background:transparent !important; white-space:normal !important;}

@media (max-width: 980px){
  .nav-links{flex-direction:column; align-items:stretch; justify-content:flex-start; gap:8px;}
  .nav-links > li{display:flex; flex-direction:column; align-items:stretch;}
  .has-mega .submenu-toggle{display:inline-flex; align-self:flex-end;}
  .has-mega .mega-menu{
    position:static;
    transform:none;
    width:auto;
    margin-top:6px;
    box-shadow:none;
  }
  .mega-grid{grid-template-columns:1fr;}
  .mega-head{flex-direction:column; align-items:flex-start;}
}

/* ===== Mega menu force-hide / layout lock v2.7 ===== */
#menuServicos .mega-menu{display:none !important; position:absolute !important; left:50% !important; transform:translateX(-50%) !important; top:calc(100% + 14px) !important;}
#menuServicos.is-open > .mega-menu{display:block !important;}
#menuServicos .mega-menu, #menuServicos .mega-menu *{box-sizing:border-box;}
/* ensure mega menu never becomes inline text inside navbar */
#menuServicos .mega-menu{white-space:normal !important;}
#menuServicos .mega-item{white-space:normal !important;}
/* if any theme/mobile styles set it static, keep desktop absolute */
@media (min-width: 981px){
  #menuServicos .mega-menu{position:absolute !important;}
}

/* ===== Dropdown de Serviços (estilo TIMT) ===== */
/* (Substitui o mega menu) */
#menuServicos .mega-menu{display:none !important;}

#menuServicos{position:relative;}
#menuServicos .dropdown-menu{
  position:absolute;
  /* sem “buraco” entre o item e o dropdown (evita fechar ao mover o mouse) */
  top:100%;
  left:50%;
  transform:translateX(-50%);
  min-width: 220px;
  max-width: 280px;
  background: rgba(255,255,255,0.98);
  color: #0b1220;
  border-radius: 12px;
  padding: 6px;
  box-shadow: 0 14px 34px rgba(0,0,0,0.22);
  border: 1px solid rgba(0,0,0,0.08);
  list-style: none;
  display: none;
  z-index: 1200;
}

/* “ponte” invisível para manter hover ativo ao mover o mouse do item para o dropdown */
#menuServicos .dropdown-menu::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:-10px;
  height:10px;
}

#menuServicos.is-open .dropdown-menu{display:block;}

/* Desktop: abre no hover/focus */
@media (min-width: 981px){
  #menuServicos:hover .dropdown-menu,
  #menuServicos:focus-within .dropdown-menu{display:block;}
}

#menuServicos .dropdown-menu li{margin:0; padding:0;}

/* (mantido por segurança caso algum conteúdo antigo volte) */
#menuServicos .dropdown-label{display:none;}

#menuServicos .dropdown-menu a{
  display:block;
  padding: 9px 10px;
  border-radius: 10px;
  color: #0b1220 !important;
  text-decoration:none;
  font-weight: 600;
  font-size: 0.92rem;
}

#menuServicos .dropdown-menu a:hover,
#menuServicos .dropdown-menu a:focus{
  background: rgba(13, 20, 35, 0.05);
}

/* Evita que o estilo global do menu (cor cinza) afete o dropdown */
#menuServicos .dropdown-menu a{white-space:nowrap;}

/* Mobile: dropdown vira bloco dentro do painel (sem overlay absoluto) */
@media (max-width: 980px){
  #menuServicos .dropdown-menu{
    position: static;
    transform:none;
    background: transparent;
    color: var(--text-white);
    box-shadow:none;
    border:0;
    padding: 6px 0 0;
    min-width:0;
    max-width:none;
  }
  #menuServicos .dropdown-label{
    background: rgba(255,255,255,0.06);
    color: var(--text-white);
  }
  #menuServicos .dropdown-menu a{
    color: var(--text-light) !important;
    white-space: normal;
  }
}

/* v2.8 - ensure desktop header uses desktop nav and hide mobile panel */
.desktop-nav-wrap{display:flex; align-items:center; gap:22px;}
.mobile-panel{display:none;}

@media (max-width: 980px){
  .desktop-nav-wrap{display:none;}
  .navbar.open .mobile-panel{display:flex; flex-direction:column;}
  .mobile-panel{padding:14px 16px; gap:14px;}
  .mobile-panel .nav-links{display:flex; flex-direction:column; gap:10px;}
  .mobile-panel .nav-links a{display:block; padding:10px 12px; border-radius:12px;}
}


/* ===== Menu ultra minimalista (v3.0.2) ===== */

/* Menor no desktop (menu principal) */
.header-nav > ul { gap: 12px; }
.header-nav > ul > li > a {
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.15px;
  padding: 8px 10px;
  line-height: 1.1;
  color: #d7dde6;
  transition: color 0.2s ease, background 0.2s ease;
}
.header-nav > ul > li > a:hover {
  color: #ffffff;
  background: rgba(255,255,255,0.04);
}

/* Dropdown Serviços (mais compacto) */
.header-nav .submenu {
  min-width: 200px;
  padding: 4px 0;
  background: rgba(18, 25, 40, 0.96);
  border-radius: 8px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(6px);
}
/* remove qualquer título extra */
.header-nav .submenu .submenu-title { display: none !important; }

.header-nav .submenu a {
  font-size: 11.5px;
  font-weight: 400;
  letter-spacing: 0.12px;
  padding: 6px 12px;
  line-height: 1.15;
  color: #cfd6e3;
  display: block;
  transition: background 0.18s ease, color 0.18s ease;
}
.header-nav .submenu a:hover {
  background: rgba(255, 255, 255, 0.035);
  color: #ffffff;
}
.header-nav .submenu li { margin: 0; }

/* Mobile: mantém leve */
@media (max-width: 980px){
  .header-nav > ul > li > a { font-size: 12.5px; padding: 10px 12px; }
  .header-nav .submenu a { font-size: 12px; padding: 8px 12px; }
}


/* ===== Ajuste de alinhamento do header (sem remover menus) ===== */
.site-header,
.header-nav {
  display: flex;
  align-items: center;
}

.header-nav {
  gap: 14px;
}

.header-nav .menu {
  display: flex;
  align-items: center;
  gap: 14px;
}

.header-nav .header-contact {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
}

.header-nav .header-contact a,
.header-nav .header-contact span {
  font-size: 12px;
  white-space: nowrap;
}

/* Botão Fale Conosco compacto */
.header-nav .btn-contact {
  padding: 7px 12px;
  font-size: 12px;
  border-radius: 8px;
}


/* ===== Fix: telefone + botão alinhados, sem quebrar menus ===== */
.header-nav { display:flex; align-items:center; }
.header-nav .menu { display:flex; align-items:center; gap:14px; flex:1; }
.header-nav .header-contact{
  display:flex; align-items:center; gap:12px;
  margin-left:auto; white-space:nowrap;
}
.header-nav .header-contact *{ white-space:nowrap; }
.header-nav .header-phone{ display:inline-flex; align-items:center; gap:8px; font-size:12px; line-height:1; }
.header-nav .btn-contact{ display:inline-flex; align-items:center; justify-content:center; line-height:1; padding:7px 12px; font-size:12px; border-radius:8px; }
@media (min-width: 981px){ .header-nav .menu { margin-right: 18px; } }




/* Service detail pages */
.service-hero{
  padding: 64px 0 28px;
}
.service-hero h1{
  margin: 0 0 10px;
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.02em;
}
.service-hero p{
  margin: 0;
  max-width: 820px;
  opacity: .9;
  font-size: 16px;
  line-height: 1.65;
}

.service-section{
  padding: 28px 0 58px;
}
.service-section h2{
  margin: 0 0 14px;
  font-size: 22px;
}
.service-list{
  margin: 0;
  padding-left: 18px;
  max-width: 900px;
}
.service-list li{
  margin: 8px 0;
  line-height: 1.6;
  opacity: .95;
}

.service-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
  max-width: 980px;
}
@media (max-width: 900px){
  .service-grid{ grid-template-columns: 1fr; }
}

.service-card{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius: 16px;
  padding: 16px 18px;
  backdrop-filter: blur(10px);
}
.service-card h3{
  margin: 0 0 8px;
  font-size: 16px;
}
.service-card p{
  margin: 0;
  opacity: .9;
  line-height: 1.6;
}

.service-cta{
  padding: 34px 0 74px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.service-cta h2{
  margin: 0 0 10px;
  font-size: 24px;
}
.service-cta p{
  margin: 0 0 18px;
  opacity: .9;
  max-width: 860px;
  line-height: 1.6;
}


/* === Service details (modern minimal) === */
.service-card--media{
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 220px;
}
.svc-thumb{
  width:100%;
  height:auto;
  border-radius: 14px;
}
.svc-illus{
  width: 100%;
  height: auto;
  max-width: 340px;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.35));
}
.service-features{
  margin-top: 14px;
}
.service-features li{
  margin: 8px 0;
  opacity: .92;
}
.svc-section{
  margin-top: 28px;
}
.svc-section__head{
  margin: 0 0 14px;
}
.svc-section__head h2{
  margin: 0 0 6px;
  font-size: 20px;
}
.svc-section__head p{
  margin: 0;
  opacity: .88;
  line-height: 1.6;
  max-width: 860px;
}
.svc-cards{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}
@media (max-width: 980px){
  .svc-cards{ grid-template-columns: 1fr; }
}
.svc-card{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
  border-radius: 18px;
  padding: 14px 14px;
}
.svc-card h3{
  margin: 0;
  font-size: 14px;
}
.svc-card p{
  margin: 0 0 10px;
  opacity: .88;
  line-height: 1.6;
}

/* top row inside service cards (icon + title) */
.svc-card__top{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-bottom: 10px;
}
.svc-card__top .svc-ico{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}
.svc-card__top .svc-ico svg{
  width: 22px;
  height: 22px;
}

/* checklist style (like your reference cards) */
.svc-mini{
  list-style:none;
  padding: 0;
  margin: 10px 0 0;
}
.svc-mini li{
  position: relative;
  padding: 7px 0 7px 20px;
  border-top: 1px solid rgba(255,255,255,.06);
  line-height: 1.55;
  opacity: .92;
}
.svc-mini li:first-child{ border-top: 0; padding-top: 0; }
.svc-mini li::before{
  content: "✓";
  position:absolute;
  left: 0;
  top: 10px;
  color: rgba(48, 214, 255, .95);
  font-weight: 700;
}
.svc-mini li:first-child::before{ top: 0; }
.svc-card__icon{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
}
.svc-ico{
  width: 18px;
  height: 18px;
  color: rgba(120, 220, 255, .95);
}
.svc-mini{
  margin: 0;
  padding-left: 16px;
  opacity: .92;
}
.svc-mini li{
  margin: 6px 0;
}
.svc-section--alt{
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 22px;
}
.svc-steps{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}
@media (max-width: 980px){
  .svc-steps{ grid-template-columns: 1fr; }
}
.svc-step{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  border-radius: 16px;
  padding: 14px;
  display:flex;
  gap: 12px;
}
.svc-step__num{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(0,212,255,.10);
  border: 1px solid rgba(0,212,255,.18);
  font-weight: 700;
  letter-spacing: .5px;
  color: rgba(180, 245, 255, .95);
}
.svc-step h4{
  margin: 0 0 6px;
  font-size: 14px;
}
.svc-step p{
  margin: 0;
  opacity: .88;
  line-height: 1.6;
}
.svc-final{
  margin-top: 26px;
}
.svc-final__box{
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(135deg, rgba(0,212,255,.08), rgba(94,99,255,.06));
  border-radius: 18px;
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
}
@media (max-width: 900px){
  .svc-final__box{ flex-direction: column; align-items: flex-start; }
}
.svc-final__box h2{
  margin: 0 0 8px;
  font-size: 18px;
}
.svc-final__box p{
  margin: 0;
  opacity: .9;
  line-height: 1.6;
  max-width: 820px;
}
