:root{
      --primary:#1B3A57;
      --accent:#2AB7CA;
      --neutral:#4A4A4A;
      --bg:#FFFFFF;
      --muted:#F8F9FA;
      --radius:12px;
      --container:1100px;
      --ease:cubic-bezier(.22,.9,.3,1);
    }

    *{box-sizing:border-box}
    html,body{
      height:100%;
      overflow-x:hidden;
      width:100%;
    }
    body{
      margin:0;
      font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
      color:var(--neutral);
      background:var(--bg);
      -webkit-font-smoothing:antialiased;
      -moz-osx-font-smoothing:grayscale;
      line-height:1.5;
      -webkit-text-size-adjust:100%;
    }

    a{color:inherit;text-decoration:none}
    img{max-width:100%;height:auto;display:block}

    .wrap{
      max-width:var(--container);
      margin:0 auto;
      padding:0 16px;
      width:100%;
      overflow-x:hidden;
    }

    /* Header */
    header{
      position:fixed;
      top:0;
      left:0;
      right:0;
      z-index:80;
      backdrop-filter: blur(6px);
      background:rgba(255,255,255,0.7);
      border-bottom:1px solid rgba(27,58,87,0.06);
      transition:box-shadow .25s var(--ease), background .25s var(--ease);
      width:100%;
    }
    header.scrolled{
      box-shadow:0 6px 22px rgba(27,58,87,0.06);
      background:rgba(255,255,255,0.95);
    }
    .nav{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:16px;
      height:72px;
      padding:0 16px;
      max-width:var(--container);
      margin:0 auto;
      width:100%;
    }

    .brand{
      display:flex;
      gap:12px;
      align-items:center;
      min-width:fit-content;
    }
    .brand .logo{
      display:flex;
      flex-direction:column;
      line-height:1;
      flex-shrink:0;
    }
    .brand .brand-name{
      color:var(--primary);
      font-weight:700;
      font-size:1.05rem;
      letter-spacing:0.2px;
      white-space:nowrap;
    }
    .brand .brand-slogan{
      color:var(--neutral);
      font-size:0.78rem;
      margin-top:2px;
      white-space:nowrap;
    }

    nav .nav-links{
      display:flex;
      gap:20px;
      align-items:center;
    }
    nav .nav-links a{
      color:var(--neutral);
      font-weight:600;
      font-size:0.95rem;
      padding:8px;
      border-radius:8px;
      transition:color .18s var(--ease), background .18s var(--ease), transform .18s var(--ease);
      white-space:nowrap;
    }
    nav .nav-links a:hover{color:var(--primary); transform:translateY(-2px)}

    .cta{
      background:var(--accent);
      color:#fff;
      padding:10px 16px;
      border-radius:10px;
      font-weight:700;
      box-shadow: 0 6px 18px rgba(42,183,202,0.12);
      transition:transform .18s var(--ease), box-shadow .18s var(--ease), opacity .18s var(--ease);
      display:inline-flex;
      align-items:center;
      gap:10px;
      border:none;
      cursor:pointer;
      white-space:nowrap;
    }
    .cta:hover{transform:translateY(-3px); box-shadow:0 10px 30px rgba(42,183,202,0.16)}
    .cta--ghost{
      background:transparent;
      color:var(--accent);
      box-shadow:none;
    }
    .cta-form{
      background:var(--primary);
      box-shadow:0 6px 18px rgba(27,58,87,0.15);
    }
    .cta-form:hover{
      box-shadow:0 10px 30px rgba(27,58,87,0.2);
    }

    .hamburger{
      display:none;
      width:44px;
      height:44px;
      border-radius:10px;
      align-items:center;
      justify-content:center;
      cursor:pointer;
      background:transparent;
      border:1px solid rgba(27,58,87,0.06);
      flex-shrink:0;
    }
    .hamburger .bar{width:18px;height:2px;background:var(--primary);display:block;border-radius:2px;position:relative}
    .hamburger .bar::after, .hamburger .bar::before{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--primary);border-radius:2px}
    .hamburger .bar::before{top:-6px}
    .hamburger .bar::after{top:6px}

    .mobile-menu{
      position:fixed;
      right:0;
      top:74px;
      background:#fff;
      border-radius:12px;
      box-shadow:0 14px 40px rgba(27,58,87,0.09);
      padding:12px;
      display:none;
      min-width:200px;
      z-index:90;
      max-width:calc(100vw - 32px);
    }
    .mobile-menu a{display:block;padding:10px;border-radius:8px;transition:background .18s var(--ease);white-space:nowrap}
    .mobile-menu a:hover{background:var(--muted)}

    /* Hero Section */
    .hero{
      min-height:100vh;
      padding-top:140px;
      padding-bottom:80px;
      position:relative;
      display:grid;
      grid-template-columns:1.1fr 1fr;
      gap:64px;
      align-items:center;
      max-width:var(--container);
      margin:0 auto;
      padding-left:24px;
      padding-right:24px;
      z-index:2;
    }

    .hero::after{
      content:"";
      position:absolute;
      top:0;
      left:50%;
      transform:translateX(-50%);
      width:100vw;
      height:100%;
      background:linear-gradient(180deg, rgba(231,238,240,0.4) 0%, rgba(255,255,255,0.8) 50%, rgba(231,238,240,0.3) 100%);
      z-index:-1;
      pointer-events:none;
    }

    .hero::before{
      content:"";
      position:absolute;
      top:60px;
      left:50%;
      transform:translateX(-50%);
      width:100vw;
      height:600px;
      background:
        radial-gradient(circle at 25% 30%, rgba(42,183,202,0.12) 0%, transparent 45%),
        radial-gradient(circle at 75% 60%, rgba(27,58,87,0.08) 0%, transparent 50%),
        linear-gradient(135deg, rgba(42,183,202,0.04) 0%, transparent 60%);
      pointer-events:none;
      z-index:0;
      animation:heroGlow 15s ease-in-out infinite alternate;
    }

    @keyframes heroGlow{
      0%{opacity:0.8;transform:scale(1)}
      100%{opacity:1;transform:scale(1.05)}
    }

    .hero-content{
      position:relative;
      z-index:2;
      display:flex;
      flex-direction:column;
      gap:24px;
    }

    .hero-badge{
      display:none;
      align-items:center;
      gap:8px;
      padding:8px 16px;
      background:linear-gradient(135deg, rgba(42,183,202,0.1), rgba(27,58,87,0.05));
      border:1px solid rgba(42,183,202,0.2);
      border-radius:100px;
      color:var(--accent);
      font-size:0.88rem;
      font-weight:600;
      width:fit-content;
      transition:all .3s var(--ease);
    }

    .hero-badge:hover{
      background:linear-gradient(135deg, rgba(42,183,202,0.15), rgba(27,58,87,0.08));
      border-color:rgba(42,183,202,0.3);
      transform:translateY(-2px);
    }

    .hero-badge svg{
      flex-shrink:0;
    }

    .hero-content h1{
      margin:0;
      color:var(--primary);
      font-size:3rem;
      line-height:1.1;
      font-weight:800;
      letter-spacing:-0.03em;
    }

    .hero-highlight{
      background:linear-gradient(135deg, var(--accent) 0%, rgba(42,183,202,0.8) 100%);
      -webkit-background-clip:text;
      -webkit-text-fill-color:transparent;
      background-clip:text;
      display:inline-block;
      position:relative;
    }

    .hero-description{
      margin:0;
      color:var(--neutral);
      font-size:1.15rem;
      line-height:1.7;
      max-width:52ch;
    }

    .hero-features{
      display:flex;
      flex-wrap:wrap;
      gap:20px;
      margin-top:4px;
    }

    .hero-feature-item{
      display:flex;
      align-items:center;
      gap:8px;
      color:var(--primary);
      font-size:0.95rem;
      font-weight:600;
    }

    .hero-feature-item svg{
      flex-shrink:0;
      color:var(--accent);
    }

    .hero-actions{
      display:flex;
      gap:16px;
      align-items:center;
      flex-wrap:wrap;
      margin-top:8px;
    }

    .cta-hero-primary{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:16px 32px;
      background:linear-gradient(135deg, var(--accent) 0%, rgba(42,183,202,0.9) 100%);
      color:#fff;
      border-radius:12px;
      font-weight:700;
      font-size:1.05rem;
      box-shadow:0 8px 24px rgba(42,183,202,0.25);
      transition:all .3s var(--ease);
      border:none;
    }

    .cta-hero-primary:hover{
      transform:translateY(-3px);
      box-shadow:0 12px 32px rgba(42,183,202,0.35);
    }

    .cta-hero-primary svg{
      transition:transform .3s var(--ease);
    }

    .cta-hero-primary:hover svg{
      transform:translateX(4px);
    }

    .cta-hero-secondary{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:16px 28px;
      background:transparent;
      color:var(--primary);
      border:2px solid rgba(27,58,87,0.15);
      border-radius:12px;
      font-weight:600;
      font-size:1rem;
      transition:all .3s var(--ease);
    }

    .cta-hero-secondary:hover{
      background:rgba(27,58,87,0.04);
      border-color:rgba(27,58,87,0.25);
      transform:translateY(-2px);
    }

    .hero-stats{
      display:flex;
      align-items:center;
      gap:24px;
      margin-top:16px;
      padding-top:24px;
      border-top:1px solid rgba(27,58,87,0.1);
    }

    .hero-stat{
      display:flex;
      flex-direction:column;
      gap:4px;
    }

    .hero-stat-number{
      font-size:1.5rem;
      font-weight:800;
      color:var(--primary);
      line-height:1;
    }

    .hero-stat-label{
      font-size:0.85rem;
      color:var(--neutral);
      font-weight:500;
    }

    .hero-stat-divider{
      width:1px;
      height:32px;
      background:rgba(27,58,87,0.15);
    }

    /* Hero Visual */
    .hero-visual-container{
      position:relative;
      z-index:2;
    }

    .hero-visual-card{
      background:#fff;
      border-radius:20px;
      box-shadow:0 20px 60px rgba(27,58,87,0.12);
      overflow:hidden;
      position:relative;
      transition:transform .4s var(--ease), box-shadow .4s var(--ease);
    }

    .hero-visual-card:hover{
      transform:translateY(-8px) scale(1.02);
      box-shadow:0 30px 80px rgba(27,58,87,0.18);
    }

    .hero-visual-header{
      background:linear-gradient(135deg, rgba(42,183,202,0.08), rgba(27,58,87,0.04));
      padding:16px 20px;
      display:flex;
      align-items:center;
      gap:12px;
      border-bottom:1px solid rgba(27,58,87,0.06);
    }

    .visual-dots{
      display:flex;
      gap:6px;
    }

    .visual-dots span{
      width:12px;
      height:12px;
      border-radius:50%;
      background:rgba(27,58,87,0.2);
    }

    .visual-dots span:nth-child(1){background:#ff5f56}
    .visual-dots span:nth-child(2){background:#ffbd2e}
    .visual-dots span:nth-child(3){background:#27c93f}

    .visual-title{
      font-size:0.9rem;
      color:var(--neutral);
      font-weight:600;
    }

    .hero-visual-content{
      padding:20px;
      background:linear-gradient(180deg, rgba(42,183,202,0.02) 0%, transparent 100%);
    }

    .hero-visual-badge{
      position:absolute;
      bottom:20px;
      right:20px;
      display:flex;
      align-items:center;
      gap:8px;
      padding:10px 16px;
      background:linear-gradient(135deg, var(--accent), rgba(42,183,202,0.9));
      color:#fff;
      border-radius:100px;
      font-size:0.85rem;
      font-weight:700;
      box-shadow:0 6px 20px rgba(42,183,202,0.3);
    }

    .hero-decoration{
      position:absolute;
      border-radius:50%;
      background:linear-gradient(135deg, rgba(42,183,202,0.15), rgba(27,58,87,0.08));
      filter:blur(60px);
      pointer-events:none;
    }

    .hero-decoration-1{
      width:300px;
      height:300px;
      top:-100px;
      right:-100px;
      animation:float 8s ease-in-out infinite;
    }

    .hero-decoration-2{
      width:250px;
      height:250px;
      bottom:-80px;
      left:-80px;
      animation:float 10s ease-in-out infinite reverse;
    }

    @keyframes float{
      0%, 100%{transform:translate(0, 0) rotate(0deg)}
      33%{transform:translate(20px, -20px) rotate(5deg)}
      66%{transform:translate(-20px, 20px) rotate(-5deg)}
    }

    /* SVG Animations */
    .hero-float-1{
      animation:floatElement 4s ease-in-out infinite;
    }

    .hero-float-2{
      animation:floatElement 5s ease-in-out infinite reverse;
    }

    @keyframes floatElement{
      0%, 100%{transform:translateY(0px)}
      50%{transform:translateY(-15px)}
    }

    .section{padding:72px 0;min-height:fit-content}
    .section h2{
      color:var(--primary);
      font-weight:700;
      margin:0 0 22px 0;
      font-size:1.35rem;
      word-break:break-word;
      min-height:1.8rem;
    }

    .pilares{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:20px;
      margin-top:18px;
    }
    .card{
      background:#fff;
      border-radius:12px;
      padding:20px;
      border:1px solid rgba(27,58,87,0.04);
      transition:transform .18s var(--ease), box-shadow .18s var(--ease);
    }
    .card:hover{transform:translateY(-6px); box-shadow:0 14px 40px rgba(27,58,87,0.06)}
    .card .icon{
      width:48px;height:48px;border-radius:10px;display:inline-grid;place-items:center;margin-bottom:12px;background:rgba(42,183,202,0.12);color:var(--accent);flex-shrink:0
    }
    .card h3{margin:0 0 8px 0;color:var(--primary);font-size:1.05rem;word-break:break-word}
    .card p{margin:0;color:var(--neutral);font-size:0.95rem;line-height:1.45;word-break:break-word}

    .servicos-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:24px;
      margin-top:20px;
    }
    .servico-card{
      background:linear-gradient(135deg, rgba(42,183,202,0.04) 0%, rgba(27,58,87,0.02) 100%);
      border:1px solid rgba(42,183,202,0.1);
      border-radius:14px;
      padding:32px 24px;
      transition:transform .18s var(--ease), box-shadow .18s var(--ease), border-color .18s var(--ease);
      display:flex;
      flex-direction:column;
    }
    .servico-card:hover{
      transform:translateY(-8px);
      box-shadow:0 18px 50px rgba(42,183,202,0.12);
      border-color:rgba(42,183,202,0.2);
    }
    .servico-icon{
      width:56px;height:56px;border-radius:12px;display:inline-grid;place-items:center;margin-bottom:16px;background:rgba(42,183,202,0.14);color:var(--accent);flex-shrink:0
    }
    .servico-card h3{margin:0 0 12px 0;color:var(--primary);font-size:1.15rem;font-weight:700;word-break:break-word}
    .servico-card p{margin:0 0 16px 0;color:var(--neutral);font-size:0.95rem;line-height:1.6;flex-grow:1;word-break:break-word}
    .servico-link{
      color:var(--accent);
      font-weight:600;
      font-size:0.9rem;
      transition:color .18s var(--ease), transform .18s var(--ease);
      display:inline-flex;
      align-items:center;
      gap:6px;
      width:fit-content;
    }
    .servico-link:hover{color:var(--primary);transform:translateX(4px)}

    .portfolio-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:20px;
      margin-top:20px;
    }
    .project{
      border-radius:14px;
      overflow:hidden;
      background:#fff;
      border:1px solid rgba(27,58,87,0.06);
      transition:transform .22s var(--ease), box-shadow .22s var(--ease);
    }
    .project:hover{
      transform:translateY(-8px);
      box-shadow:0 20px 50px rgba(27,58,87,0.1);
    }
    .project-image{
      width:100%;
      height:220px;
      background:linear-gradient(135deg, #2AB7CA 0%, #1B3A57 100%);
      display:flex;
      align-items:center;
      justify-content:center;
    }
    .project .meta{
      padding:18px;
    }
    .project .meta h4{
      margin:0 0 4px 0;
      color:var(--primary);
      font-size:1.05rem;
      font-weight:700;
      word-break:break-word;
    }
    .project .meta small{
      color:var(--accent);
      font-size:0.85rem;
      font-weight:600;
      display:block;
      margin-bottom:8px;
    }
    .project-desc{
      margin:0;
      color:var(--neutral);
      font-size:0.9rem;
      line-height:1.5;
      margin-bottom:12px;
      word-break:break-word;
    }
    .project-btn{
      display:inline-flex;
      color:var(--accent);
      font-weight:600;
      font-size:0.88rem;
      align-items:center;
      gap:6px;
      transition:color .18s var(--ease), transform .18s var(--ease);
    }
    .project-btn:hover{
      color:var(--primary);
      transform:translateX(4px);
    }


    /* Footer Styles */
    footer{
      background:linear-gradient(135deg, #0a3a4a 0%, var(--primary) 50%, #0d4a5c 100%);
      color:#fff;
      margin-top:80px;
      width:100%;
      position:relative;
      overflow:hidden;
    }

    footer::before{
      content:'';
      position:absolute;
      top:0;
      left:0;
      right:0;
      height:1px;
      background:linear-gradient(90deg, transparent 0%, rgba(42,183,202,0.4) 50%, transparent 100%);
    }

    .footer-top{
      padding:64px 0 48px 0;
    }

    .footer-grid{
      display:grid;
      grid-template-columns:1.2fr 2fr;
      gap:64px;
      max-width:var(--container);
      margin:0 auto;
      padding:0 24px;
    }

    .footer-brand{
      display:flex;
      flex-direction:column;
      gap:20px;
    }

    .footer-logo{
      display:flex;
      align-items:center;
      gap:12px;
      margin-bottom:4px;
    }

    .footer-logo span{
      font-size:1.35rem;
      font-weight:700;
      color:#fff;
      letter-spacing:-0.02em;
    }

    .footer-tagline{
      color:rgba(255,255,255,0.82);
      line-height:1.6;
      font-size:0.95rem;
      max-width:320px;
    }

    .footer-contact{
      margin-top:8px;
    }

    .footer-email{
      display:inline-flex;
      align-items:center;
      gap:10px;
      color:rgba(255,255,255,0.88);
      font-size:0.92rem;
      padding:10px 16px;
      background:rgba(255,255,255,0.06);
      border-radius:8px;
      transition:all .25s var(--ease);
      border:1px solid rgba(255,255,255,0.08);
    }

    .footer-email:hover{
      background:rgba(255,255,255,0.1);
      border-color:rgba(255,255,255,0.15);
      color:#fff;
      transform:translateY(-2px);
    }

    .footer-email svg{
      flex-shrink:0;
      opacity:0.9;
    }

    .footer-links-group{
      display:grid;
      grid-template-columns:repeat(3, 1fr);
      gap:48px;
    }

    .footer-column{
      display:flex;
      flex-direction:column;
      gap:16px;
    }

    .footer-title{
      font-size:0.95rem;
      font-weight:700;
      color:#fff;
      margin-bottom:4px;
      letter-spacing:-0.01em;
    }

    .footer-links{
      list-style:none;
      padding:0;
      margin:0;
      display:flex;
      flex-direction:column;
      gap:10px;
    }

    .footer-links li a{
      color:rgba(255,255,255,0.78);
      font-size:0.9rem;
      transition:all .2s var(--ease);
      display:inline-block;
      position:relative;
    }

    .footer-links li a::after{
      content:'';
      position:absolute;
      bottom:-2px;
      left:0;
      width:0;
      height:1px;
      background:var(--accent);
      transition:width .25s var(--ease);
    }

    .footer-links li a:hover{
      color:#fff;
      transform:translateX(4px);
    }

    .footer-links li a:hover::after{
      width:100%;
    }

    .footer-social-text{
      color:rgba(255,255,255,0.75);
      font-size:0.88rem;
      margin:0;
      line-height:1.5;
    }

    .footer-socials{
      display:flex;
      gap:10px;
      align-items:center;
      margin-top:4px;
    }

    .footer-socials a{
      display:inline-flex;
      width:44px;
      height:44px;
      border-radius:10px;
      align-items:center;
      justify-content:center;
      background:rgba(255,255,255,0.06);
      border:1px solid rgba(255,255,255,0.08);
      transition:all .25s var(--ease);
      flex-shrink:0;
      color:rgba(255,255,255,0.85);
    }

    .footer-socials a:hover{
      background:rgba(42,183,202,0.15);
      border-color:rgba(42,183,202,0.3);
      transform:translateY(-3px);
      color:#fff;
    }

    .footer-bottom{
      border-top:1px solid rgba(255,255,255,0.08);
      padding:24px 0;
      background:rgba(0,0,0,0.15);
    }

    .footer-bottom-content{
      display:flex;
      justify-content:space-between;
      align-items:center;
      max-width:var(--container);
      margin:0 auto;
      padding:0 24px;
      flex-wrap:wrap;
      gap:16px;
    }

    .footer-bottom-content p{
      color:rgba(255,255,255,0.7);
      font-size:0.88rem;
      margin:0;
    }

    .footer-bottom-links{
      display:flex;
      align-items:center;
      gap:16px;
    }

    .footer-bottom-links a{
      color:rgba(255,255,255,0.7);
      font-size:0.88rem;
      transition:color .2s var(--ease);
    }

    .footer-bottom-links a:hover{
      color:#fff;
    }

    .footer-divider{
      color:rgba(255,255,255,0.3);
      user-select:none;
    }

    .fade-up{opacity:0;transform:translateY(60px);transition:opacity 1.8s var(--ease), transform 1.8s var(--ease);will-change:opacity,transform;visibility:visible;min-height:1px}
    .fade-up.in-view{opacity:1;transform:translateY(0)}
    .muted{color:rgba(74,74,74,0.75)}
    .logo-img{width:42px;height:42px;object-fit:contain;display:block;flex-shrink:0}

    /* ===== RESPONSIVE ===== */
    @media (max-width:1200px){
      .wrap{padding:0 16px}
      .hero{grid-template-columns:1fr 400px;gap:28px;padding-top:110px}
      .hero-content h1{font-size:1.85rem}
      .hero::before{height:450px}
    }

    @media (max-width:1060px){
      .hero{
        grid-template-columns:1fr;
        gap:48px;
        padding-top:120px;
        padding-bottom:64px;
      }
      .hero-visual-container{
        order:2;
        max-width:600px;
        margin:0 auto;
      }
      .hero-content{
        order:1;
        align-items:center;
        text-align:center;
      }
      .hero-content h1{
        font-size:2.5rem;
      }
      .hero-description{
        max-width:58ch;
      }
      .hero-badge,
      .hero-features,
      .hero-actions,
      .hero-stats{
        justify-content:center;
      }
      .portfolio-grid{grid-template-columns:repeat(2,1fr)}
      .servicos-grid{grid-template-columns:repeat(2,1fr)}
      .pilares{grid-template-columns:repeat(2,1fr)}
    }

    @media (max-width:768px){
      .wrap{padding:0 14px}
      .nav{padding:0 14px;gap:12px}
      .nav{height:68px}
      .hamburger{display:flex}
      nav .nav-links{display:none}

      .hero{
        padding-top:100px;
        padding-bottom:48px;
        gap:40px;
        padding-left:16px;
        padding-right:16px;
      }
      .hero-content{
        gap:20px;
      }
      .hero-content h1{
        font-size:2rem;
        line-height:1.15;
      }
      .hero-description{
        font-size:1.05rem;
        max-width:100%;
      }
      .hero-badge{
        display:inline-flex;
        font-size:0.82rem;
        padding:7px 14px;
      }
      .hero-features{
        gap:16px;
      }
      .hero-feature-item{
        font-size:0.88rem;
      }
      .cta-hero-primary{
        padding:14px 28px;
        font-size:1rem;
      }
      .cta-hero-secondary{
        padding:14px 24px;
        font-size:0.95rem;
      }
      .hero-stats{
        gap:20px;
        padding-top:20px;
        margin-top:12px;
      }
      .hero-stat-number{
        font-size:1.35rem;
      }
      .hero-stat-label{
        font-size:0.8rem;
      }
      .hero-visual-container{
        max-width:100%;
      }
      .hero-decoration{
        display:none;
      }
      
      .section{padding:64px 0;scroll-margin-top:80px}
      .section h2{font-size:1.2rem;text-align:center;min-height:2rem;display:block;margin-bottom:32px}
      
      .servicos-grid{grid-template-columns:1fr;gap:16px}
      .servico-card{padding:20px 16px}
      
      .pilares{grid-template-columns:1fr;gap:14px}
      .card{padding:16px}
      
      .portfolio-grid{grid-template-columns:1fr;gap:14px}
      .project-image{height:180px}
      .project .meta{padding:12px}
      
      .mobile-menu{max-width:calc(100vw - 32px);min-width:180px}

      .footer-grid{
        grid-template-columns:1fr;
        gap:40px;
        padding:0 16px;
      }
      .footer-top{padding:48px 0 36px 0}
      .footer-links-group{
        grid-template-columns:1fr;
        gap:32px;
      }
      .footer-tagline{max-width:100%}
    }

    @media (max-width:600px){
      .wrap{padding:0 12px}
      .nav{padding:0 12px;height:64px}

      .brand .brand-name{font-size:0.95rem}
      .brand .brand-slogan{font-size:0.7rem}

      .hero{
        padding-top:90px;
        padding-bottom:40px;
        gap:32px;
        padding-left:12px;
        padding-right:12px;
      }
      .hero-content{
        gap:18px;
      }
      .hero-content h1{
        font-size:1.75rem;
        line-height:1.2;
      }
      .hero-description{
        font-size:1rem;
        line-height:1.65;
      }
      .hero-badge{
        font-size:0.78rem;
        padding:6px 12px;
      }
      .hero-badge svg{
        width:14px;
        height:14px;
      }
      .hero-features{
        flex-wrap:wrap;
        gap:12px;
      }
      .hero-feature-item{
        font-size:0.85rem;
      }
      .hero-feature-item svg{
        width:18px;
        height:18px;
      }
      .hero-actions{
        flex-direction:column;
        width:100%;
        gap:12px;
      }
      .cta-hero-primary,
      .cta-hero-secondary{
        width:100%;
        justify-content:center;
        padding:14px 24px;
        font-size:0.95rem;
      }
      .hero-stats{
        gap:16px;
        padding-top:18px;
        margin-top:8px;
      }
      .hero-stat-number{
        font-size:1.2rem;
      }
      .hero-stat-label{
        font-size:0.75rem;
      }
      .hero-stat-divider{
        height:28px;
      }
      .hero-visual-header{
        padding:12px 16px;
      }
      .visual-dots span{
        width:10px;
        height:10px;
      }
      .visual-title{
        font-size:0.82rem;
      }
      .hero-visual-content{
        padding:16px;
      }
      .hero-visual-badge{
        bottom:16px;
        right:16px;
        padding:8px 14px;
        font-size:0.8rem;
      }
      
      .section{padding:56px 0;scroll-margin-top:70px}
      .section h2{font-size:1.1rem;margin-bottom:28px;min-height:1.8rem}
      
      .servico-card{padding:16px 12px}
      .servico-icon{width:40px;height:40px}
      .servico-card h3{font-size:0.95rem}
      .servico-card p{font-size:0.85rem}
      
      .card h3{font-size:0.9rem}
      .card p{font-size:0.8rem}
      
      .portfolio-grid{gap:12px}
      .project-image{height:160px}
      .project .meta{padding:10px}
      .project-desc{font-size:0.8rem}

      .footer-grid{padding:0 12px}
      .footer-top{padding:40px 0 28px 0}
      .footer-links-group{gap:28px}
      .footer-email{
        font-size:0.85rem;
        padding:9px 14px;
      }
      .footer-bottom-content{
        flex-direction:column;
        text-align:center;
        padding:0 12px;
        gap:12px;
      }
    }

    @media (max-width:420px){
      .wrap{padding:0 10px}
      .nav{padding:0 10px}

      .hero{
        padding-top:80px;
        padding-bottom:32px;
        gap:28px;
        padding-left:10px;
        padding-right:10px;
      }
      .hero-content{
        gap:16px;
      }
      .hero-content h1{
        font-size:1.5rem;
        line-height:1.25;
      }
      .hero-description{
        font-size:0.95rem;
        line-height:1.6;
      }
      .hero-badge{
        font-size:0.75rem;
        padding:6px 12px;
      }
      .hero-badge svg{
        width:13px;
        height:13px;
      }
      .hero-features{
        gap:10px;
        flex-direction:column;
        align-items:center;
      }
      .hero-feature-item{
        font-size:0.82rem;
      }
      .hero-feature-item svg{
        width:16px;
        height:16px;
      }
      .cta-hero-primary,
      .cta-hero-secondary{
        padding:13px 22px;
        font-size:0.9rem;
      }
      .hero-stats{
        flex-wrap:wrap;
        gap:12px;
        padding-top:16px;
      }
      .hero-stat-number{
        font-size:1.1rem;
      }
      .hero-stat-label{
        font-size:0.72rem;
      }
      .hero-stat-divider{
        display:none;
      }
      .hero-visual-header{
        padding:10px 14px;
      }
      .visual-dots span{
        width:9px;
        height:9px;
      }
      .visual-title{
        font-size:0.78rem;
      }
      .hero-visual-content{
        padding:12px;
      }
      .hero-visual-badge{
        bottom:12px;
        right:12px;
        padding:7px 12px;
        font-size:0.75rem;
      }
      .hero-visual-badge svg{
        width:14px;
        height:14px;
      }

      .section{scroll-margin-top:65px;padding:48px 0}
      .section h2{font-size:1rem;min-height:1.6rem;margin-bottom:24px}

      .servico-card{padding:14px 10px}
      .servico-card h3{font-size:0.9rem}
      .servico-card p{font-size:0.8rem}

      .project-image{height:140px}

      nav .nav-links a{font-size:0.8rem;padding:4px}

      .footer-grid{padding:0 10px}
      .footer-top{padding:32px 0 24px 0}
      .footer-logo span{font-size:1.2rem}
      .footer-tagline{font-size:0.88rem}
      .footer-email{
        font-size:0.82rem;
        padding:8px 12px;
      }
      .footer-socials a{
        width:40px;
        height:40px;
      }
      .footer-bottom-content{padding:0 10px}
    }

    /* Adicione no final, antes dos media queries: */

    /* Contato */
    #contato{
      padding-top:80px;
      padding-bottom:80px;
    }

    .contato-header{
      text-align:center;
      margin-bottom:48px;
      background:linear-gradient(135deg, var(--accent) 0%, rgba(42,183,202,0.85) 100%);
      color:#fff;
      border-radius:20px;
      padding:48px 32px;
      box-shadow:0 16px 50px rgba(42,183,202,0.25);
      position:relative;
      overflow:hidden;
    }

    .contato-header::before{
      content:"";
      position:absolute;
      top:-50%;
      right:-10%;
      width:300px;
      height:300px;
      background:radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%);
      border-radius:50%;
      pointer-events:none;
    }

    .contato-header::after{
      content:"";
      position:absolute;
      bottom:-30%;
      left:-5%;
      width:250px;
      height:250px;
      background:radial-gradient(circle, rgba(27,58,87,0.1) 0%, transparent 70%);
      border-radius:50%;
      pointer-events:none;
    }

    .contato-header h2{
      margin:0 0 16px 0;
      font-size:2.2rem;
      font-weight:800;
      color:#fff;
      letter-spacing:-0.5px;
      position:relative;
      z-index:1;
      text-shadow:0 2px 10px rgba(0,0,0,0.1);
    }

    .contato-subtitle{
      margin:0 auto;
      font-size:1.1rem;
      max-width:60ch;
      line-height:1.7;
      color:#fff;
      position:relative;
      z-index:1;
    }

    .contato-container{
      display:flex;
      flex-direction:column;
      gap:32px;
      align-items:center;
      max-width:100%;
    }

    /* Formulário */
    .contato-form{
      background:#fff;
      border:1px solid rgba(27,58,87,0.06);
      border-radius:14px;
      padding:32px;
      width:100%;
      max-width:700px;
    }

    .form-group{
      margin-bottom:20px;
    }

    .form-group.full{
      grid-column:1 / -1;
    }

    .form-group label{
      display:block;
      font-weight:600;
      color:var(--primary);
      margin-bottom:8px;
      font-size:0.95rem;
    }

    .form-group input,
    .form-group select,
    .form-group textarea{
      width:100%;
      padding:12px 14px;
      border:1px solid rgba(27,58,87,0.1);
      border-radius:10px;
      font-family:inherit;
      font-size:0.95rem;
      color:var(--neutral);
      transition:border-color .18s var(--ease), box-shadow .18s var(--ease);
      background:#fff;
    }

    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus{
      outline:none;
      border-color:var(--accent);
      box-shadow:0 0 0 3px rgba(42,183,202,0.1);
    }

    .form-group textarea{
      resize:vertical;
      min-height:120px;
    }

    .form-group input::placeholder,
    .form-group textarea::placeholder{
      color:rgba(74,74,74,0.5);
    }

    /* Info Cards */
    .contato-info{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:20px;
      width:100%;
    }

    .info-card{
      background:linear-gradient(135deg, rgba(42,183,202,0.04) 0%, rgba(27,58,87,0.02) 100%);
      border:1px solid rgba(42,183,202,0.1);
      border-radius:14px;
      padding:24px;
      text-align:center;
      transition:transform .18s var(--ease), border-color .18s var(--ease);
    }

    .info-card:hover{
      transform:translateY(-4px);
      border-color:rgba(42,183,202,0.2);
    }

    .info-icon{
      width:56px;
      height:56px;
      margin:0 auto 16px;
      border-radius:12px;
      display:inline-grid;
      place-items:center;
      background:rgba(42,183,202,0.14);
      color:var(--accent);
    }

    .info-card h3{
      margin:0 0 4px 0;
      color:var(--primary);
      font-size:1.1rem;
      font-weight:700;
    }

    .info-card p{
      margin:0 0 12px 0;
      color:var(--neutral);
      font-size:0.85rem;
    }

    .info-link{
      color:var(--accent);
      font-weight:600;
      font-size:0.9rem;
      transition:color .18s var(--ease), transform .18s var(--ease);
      display:inline-block;
    }

    .info-link:hover{
      color:var(--primary);
      transform:translateX(2px);
    }

    /* Responsive - Contato */
    @media (max-width:1060px){
      .contato-info{
        grid-template-columns:repeat(2,1fr);
      }

      .contato-header{
        padding:40px 28px;
      }

      .contato-header h2{
        font-size:1.9rem;
      }

      .contato-subtitle{
        font-size:1.05rem;
      }
    }

    @media (max-width:768px){
      #contato{
        padding-top:60px;
        padding-bottom:60px;
      }

      .contato-header{
        padding:36px 24px;
        margin-bottom:36px;
      }

      .contato-header h2{
        font-size:1.6rem;
      }

      .contato-subtitle{
        font-size:1rem;
      }

      .contato-form{padding:24px}
      .contato-info{
        grid-template-columns:1fr;
        gap:14px;
      }
      .info-card{padding:20px}
    }

    @media (max-width:600px){
      #contato{
        padding-top:48px;
        padding-bottom:48px;
      }

      .contato-header{
        padding:28px 20px;
        margin-bottom:28px;
        border-radius:16px;
      }

      .contato-header h2{
        font-size:1.4rem;
        margin-bottom:12px;
      }

      .contato-subtitle{
        font-size:0.95rem;
      }

      .contato-container{gap:24px}
      .contato-form{padding:20px}
      .form-group{margin-bottom:16px}
    }

/* ---------- Notification Popup ---------- */
.notification-popup{
  position:fixed;
  top:24px;
  right:24px;
  z-index:9999;
  transform:translateX(400px);
  opacity:0;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
  pointer-events:none;
}

.notification-popup.show{
  transform:translateX(0);
  opacity:1;
  pointer-events:auto;
}

.notification-content{
  background:#fff;
  border-radius:12px;
  padding:20px;
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
  display:flex;
  gap:16px;
  align-items:flex-start;
  min-width:320px;
  max-width:400px;
  border-left:4px solid var(--accent);
}

.notification-content.success{
  border-left-color:var(--accent);
}

.notification-content.error{
  border-left-color:#e74c3c;
}

.notification-icon{
  flex-shrink:0;
  width:48px;
  height:48px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  font-weight:700;
  background:linear-gradient(135deg, rgba(42,183,202,0.15), rgba(27,58,87,0.1));
  color:var(--accent);
}

.notification-content.error .notification-icon{
  background:linear-gradient(135deg, rgba(231,76,60,0.15), rgba(192,57,43,0.1));
  color:#e74c3c;
}

.notification-text{
  flex:1;
}

.notification-title{
  font-weight:700;
  color:var(--primary);
  font-size:1rem;
  margin-bottom:4px;
}

.notification-message{
  color:var(--neutral);
  font-size:0.9rem;
  line-height:1.5;
}

.notification-close{
  background:transparent;
  border:none;
  font-size:1.5rem;
  color:var(--neutral);
  cursor:pointer;
  width:24px;
  height:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:4px;
  transition:background .2s var(--ease), color .2s var(--ease);
  line-height:1;
  flex-shrink:0;
}

.notification-close:hover{
  background:rgba(27,58,87,0.08);
  color:var(--primary);
}

/* Responsive - Notification */
@media (max-width:600px){
  .notification-popup{
    top:16px;
    right:16px;
    left:16px;
  }

  .notification-content{
    min-width:unset;
    max-width:unset;
    padding:16px;
  }
}

/* ---------- Chat Flutuante ---------- */
.chat-float-btn{
  position:fixed;
  bottom:24px;
  right:24px;
  width:60px;
  height:60px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  border:none;
  box-shadow:0 8px 24px rgba(42,183,202,0.3);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:999;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}

.chat-float-btn:hover{
  transform:scale(1.1);
  box-shadow:0 12px 32px rgba(42,183,202,0.4);
}

.chat-modal{
  display:none;
  position:fixed;
  bottom:100px;
  right:24px;
  z-index:1000;
  width:100%;
  max-width:400px;
}

.chat-modal.active{
  display:block;
  animation:slideUpRight .3s var(--ease);
}

@keyframes slideUpRight{
  from{transform:translateY(20px);opacity:0}
  to{transform:translateY(0);opacity:1}
}

.chat-modal-content{
  background:#fff;
  border-radius:16px;
  width:100%;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
}

.chat-modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 24px;
  border-bottom:1px solid rgba(27,58,87,0.08);
}

.chat-modal-header h3{
  margin:0;
  color:var(--primary);
  font-size:1.25rem;
  font-weight:700;
}

.chat-close{
  background:transparent;
  border:none;
  font-size:2rem;
  color:var(--neutral);
  cursor:pointer;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:6px;
  transition:background .2s var(--ease), color .2s var(--ease);
  line-height:1;
}

.chat-close:hover{
  background:rgba(27,58,87,0.08);
  color:var(--primary);
}

.chat-modal-body{
  padding:24px;
}

.chat-desc{
  margin:0 0 20px 0;
  color:var(--neutral);
  font-size:0.95rem;
  text-align:center;
}

.chat-form-group{
  margin-bottom:16px;
}

.chat-form-group label{
  display:block;
  font-weight:600;
  color:var(--primary);
  margin-bottom:6px;
  font-size:0.9rem;
}

.chat-form-group input,
.chat-form-group textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid rgba(27,58,87,0.1);
  border-radius:8px;
  font-family:inherit;
  font-size:0.95rem;
  color:var(--neutral);
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}

.chat-form-group input:focus,
.chat-form-group textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(42,183,202,0.1);
}

.chat-form-group textarea{
  resize:vertical;
  min-height:80px;
}

.chat-form-group input::placeholder,
.chat-form-group textarea::placeholder{
  color:rgba(74,74,74,0.5);
}

/* Responsive - Chat */
@media (max-width:600px){
  .chat-float-btn{
    width:56px;
    height:56px;
    bottom:20px;
    right:20px;
  }

  .chat-modal{
    bottom:90px;
    right:16px;
    left:16px;
    max-width:unset;
  }

  .chat-modal-header{
    padding:16px 20px;
  }

  .chat-modal-body{
    padding:20px;
  }
}

/* ---------- Sobre (Nova Versão) ---------- */
#sobre{
  background:linear-gradient(180deg, rgba(42,183,202,0.02) 0%, rgba(255,255,255,0) 100%);
  padding:72px 0;
  scroll-margin-top:80px;
}

.sobre-content{
  overflow:hidden;
}

/* Header */
.sobre-header{
  text-align:center;
  margin-bottom:48px;
}

.sobre-header h2{
  margin:0 0 12px 0;
  color:var(--primary);
  font-size:2rem;
  font-weight:800;
  letter-spacing:-0.5px;
}

.sobre-subtitle{
  margin:0;
  color:var(--neutral);
  font-size:1.15rem;
  max-width:50ch;
  margin:0 auto;
  line-height:1.6;
}

/* Hero Card */
.sobre-hero-card{
  display:grid;
  grid-template-columns:400px 1fr;
  gap:40px;
  align-items:center;
  background:#fff;
  border:1px solid rgba(27,58,87,0.06);
  border-radius:16px;
  padding:40px;
  margin-bottom:40px;
  box-shadow:0 10px 40px rgba(27,58,87,0.04);
}

.sobre-hero-visual{
  width:100%;
  height:280px;
  border-radius:12px;
  overflow:hidden;
}

.sobre-hero-visual svg{
  display:block;
  width:100%;
  height:100%;
}

.sobre-hero-text h3{
  margin:0 0 16px 0;
  color:var(--primary);
  font-size:1.5rem;
  font-weight:700;
}

.sobre-hero-text p{
  margin:0 0 16px 0;
  color:var(--neutral);
  line-height:1.7;
  font-size:1rem;
}

.sobre-hero-text p:last-child{
  margin-bottom:0;
}

/* Features Grid */
.sobre-features{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:40px;
}

.sobre-feature-card{
  background:#fff;
  border:1px solid rgba(27,58,87,0.06);
  border-radius:14px;
  padding:28px;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
}

.sobre-feature-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 48px rgba(27,58,87,0.08);
  border-color:rgba(42,183,202,0.2);
}

.feature-icon{
  width:56px;
  height:56px;
  border-radius:12px;
  background:linear-gradient(135deg, rgba(42,183,202,0.12), rgba(27,58,87,0.08));
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--accent);
  margin-bottom:16px;
}

.sobre-feature-card h4{
  margin:0 0 10px 0;
  color:var(--primary);
  font-size:1.1rem;
  font-weight:700;
}

.sobre-feature-card p{
  margin:0;
  color:var(--neutral);
  font-size:0.95rem;
  line-height:1.6;
}

/* Stats Banner */
.sobre-stats{
  background:linear-gradient(90deg, var(--primary) 0%, rgba(27,58,87,0.95) 100%);
  border-radius:16px;
  padding:40px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  box-shadow:0 12px 40px rgba(27,58,87,0.15);
}

.stat-item{
  text-align:center;
}

.stat-number{
  font-size:2.5rem;
  font-weight:800;
  color:#fff;
  line-height:1;
  margin-bottom:8px;
}

.stat-text{
  color:rgba(255,255,255,0.9);
  font-size:0.95rem;
  font-weight:600;
}

/* Responsive */
@media (max-width:1060px){
  .sobre-hero-card{
    grid-template-columns:1fr;
    gap:28px;
    padding:32px;
  }

  .sobre-hero-visual{
    height:240px;
  }

  .sobre-features{
    grid-template-columns:repeat(2,1fr);
    gap:20px;
  }

  .sobre-stats{
    grid-template-columns:repeat(2,1fr);
    gap:24px;
    padding:32px;
  }
}

@media (max-width:768px){
  .sobre-header h2{
    font-size:1.6rem;
  }

  .sobre-subtitle{
    font-size:1rem;
  }

  .sobre-hero-card{
    padding:24px;
  }

  .sobre-features{
    grid-template-columns:1fr;
    gap:16px;
  }

  .sobre-feature-card{
    padding:20px;
  }

  .sobre-stats{
    padding:24px;
  }

  .stat-number{
    font-size:2rem;
  }
}

@media (max-width:600px){
  #sobre{
    padding:48px 0;
  }

  .sobre-header{
    margin-bottom:32px;
  }

  .sobre-header h2{
    font-size:1.4rem;
  }

  .sobre-hero-card{
    padding:20px;
    margin-bottom:24px;
  }

  .sobre-hero-visual{
    height:200px;
  }

  .sobre-hero-text h3{
    font-size:1.2rem;
  }

  .sobre-hero-text p{
    font-size:0.95rem;
  }

  .sobre-stats{
    grid-template-columns:1fr;
    gap:20px;
    padding:20px;
  }

  .stat-number{
    font-size:1.8rem;
  }

  .stat-text{
    font-size:0.9rem;
  }
}
