/* Extracted CSS Block */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    :root {
      --navy:#132044; --blue:#1a5daa; --blue-mid:#2472c8;
      --sky:#4fa3e0; --sky-light:#a8d8f5; --accent:#00c8f0;
      --white:#ffffff; --off:#f2f6fc; --border:#dde6f5;
      --text-dark:#0d1b35; --text-mid:#3a5270; --text-light:#6b85a8;
      --font-head:'Montserrat',sans-serif; --font-body:'Inter',sans-serif;
    }
    body { font-family:var(--font-body); color:var(--text-dark); background:var(--white); overflow-x:hidden; }

    /* NAVBAR */
    #navbar {
      position:fixed; top:0; left:0; right:0; z-index:999;
      height:72px; display:flex; align-items:center; justify-content:space-between;
      padding:0 5%; background:rgba(10,18,44,.88); backdrop-filter:blur(18px);
      border-bottom:1px solid rgba(255,255,255,.07); transition:background .3s;
    }
    #navbar.scrolled { background:rgba(10,18,44,.97); }
    .nav-brand { display:flex; align-items:center; gap:14px; text-decoration:none; }
    .nav-brand-mark {
      width:46px; height:46px; flex-shrink:0;
      border-radius:14px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.03));
      border:1px solid rgba(255,255,255,.14);
      box-shadow:0 10px 26px rgba(5,11,27,.22);
      backdrop-filter:blur(10px);
    }
    .nav-brand-mark img { width:32px; height:32px; display:block; }
    .nav-brand-copy { display:flex; flex-direction:column; gap:3px; }
    .nav-brand-name {
      font-family:var(--font-head); font-size:1.55rem; font-weight:900;
      line-height:.88; letter-spacing:-.06em; color:#fff;
    }
    .nav-brand-name em { font-style:normal; color:var(--sky-light); }
    .nav-brand-tag {
      font-size:.48rem; font-weight:700;
      letter-spacing:.2em; text-transform:uppercase;
      color:rgba(255,255,255,.58);
    }
    .nav-links { display:flex; align-items:center; gap:1.6rem; list-style:none; }
    .nav-links a { color:rgba(255,255,255,.78); text-decoration:none; font-size:.875rem; font-weight:500; letter-spacing:.02em; transition:color .2s; }
    .nav-links a:hover, .nav-links a.active { color:var(--sky-light); }
    .nav-links .btn-nav { background:var(--blue-mid); color:#fff!important; padding:.48rem 1.2rem; border-radius:7px; font-weight:700!important; }
    .nav-links .btn-nav:hover { background:var(--sky)!important; }
    .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
    .hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; }

    /* COMMONS */
    section { padding:88px 5%; }
    .section-label { font-size:.7rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue-mid); margin-bottom:.6rem; }
    .section-title { font-family:var(--font-head); font-weight:800; font-size:clamp(1.7rem,3.5vw,2.5rem); line-height:1.15; color:var(--navy); margin-bottom:.9rem; }
    .section-sub { font-size:1rem; line-height:1.8; color:var(--text-mid); max-width:580px; }
    .center { text-align:center; } .center .section-sub { margin:0 auto; }
    .btn-primary { background:var(--blue-mid); color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-family:var(--font-head); font-weight:700; font-size:.92rem; letter-spacing:.03em; transition:background .2s,transform .15s; display:inline-block; }
    .btn-primary:hover { background:var(--sky); transform:translateY(-2px); }
    .btn-ghost { background:transparent; color:var(--navy); padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid var(--border); transition:border-color .2s,background .2s,transform .15s; display:inline-block; }
    .btn-ghost:hover { border-color:var(--blue-mid); background:rgba(36,114,200,.06); transform:translateY(-2px); }
    .btn-ghost-white { background:transparent; color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid rgba(255,255,255,.38); transition:border-color .2s,background .2s,transform .15s; display:inline-block; }
    .btn-ghost-white:hover { border-color:var(--sky-light); background:rgba(255,255,255,.08); transform:translateY(-2px); }

    /* PAGE HERO */
    .page-hero { position:relative; min-height:420px; display:flex; align-items:center; overflow:hidden; }
    .page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center 30%; background-color:#0a1432; animation:subtle-zoom 18s ease-in-out infinite alternate; }
    @keyframes subtle-zoom { from{transform:scale(1.04)} to{transform:scale(1)} }
    .page-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(10,18,50,.92) 0%,rgba(10,18,50,.58) 60%,rgba(10,18,50,.25) 100%); }
    .page-hero-grid { position:absolute; inset:0; z-index:1; pointer-events:none; background-image:linear-gradient(rgba(79,163,224,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.06) 1px,transparent 1px); background-size:55px 55px; animation:grid-move 22s linear infinite; }
    @keyframes grid-move { 0%{background-position:0 0} 100%{background-position:55px 55px} }
    .page-hero-content { position:relative; z-index:2; padding:118px 5% 72px; max-width:760px; }
    .hero-brand-card {
      position:relative;
      display:inline-flex; align-items:center; gap:1rem;
      width:fit-content; max-width:100%;
      padding:.9rem 1.05rem;
      margin-bottom:1.15rem;
      border-radius:22px;
      background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(232,244,255,.92));
      border:1px solid rgba(168,216,245,.5);
      box-shadow:0 20px 52px rgba(8,17,40,.28);
      animation:fadeUp .6s ease both;
    }
    .hero-brand-mark {
      width:62px; height:62px; flex-shrink:0;
      border-radius:18px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(180deg,#ffffff 0%,#eff6ff 100%);
      box-shadow:inset 0 0 0 1px rgba(19,32,68,.06);
    }
    .hero-brand-mark img { width:46px; height:46px; display:block; }
    .hero-brand-copy { display:flex; flex-direction:column; gap:.22rem; min-width:0; }
    .hero-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:clamp(1.55rem,3.5vw,2.2rem);
      line-height:.92; letter-spacing:-.07em; color:var(--navy);
    }
    .hero-brand-name em { font-style:normal; color:var(--blue-mid); }
    .hero-brand-tag {
      font-size:.68rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:var(--blue);
    }
    .eyebrow { display:inline-flex; align-items:center; gap:8px; background:rgba(79,163,224,.15); border:1px solid rgba(79,163,224,.35); border-radius:50px; padding:.32rem .95rem; margin-bottom:1.1rem; animation:fadeUp .6s .05s ease both; }
    .eyebrow span { font-size:.68rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--sky-light); }
    .page-hero-content h1 { font-family:var(--font-head); font-weight:900; font-size:clamp(2rem,5vw,3.1rem); line-height:1.1; color:#fff; margin-bottom:1rem; animation:fadeUp .6s .15s ease both; }
    .page-hero-content h1 em { font-style:normal; color:var(--accent); }
    .page-hero-content p { font-size:1rem; line-height:1.8; color:rgba(255,255,255,.7); max-width:520px; animation:fadeUp .6s .28s ease both; }
    .breadcrumb { position:absolute; bottom:22px; left:5%; z-index:2; display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:rgba(255,255,255,.42); }
    .breadcrumb a { color:rgba(255,255,255,.42); text-decoration:none; transition:color .2s; }
    .breadcrumb a:hover { color:var(--sky-light); }
    .breadcrumb .sep { color:rgba(255,255,255,.2); }
    @keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }

    /* CTA BAND */
    .cta-band { background:linear-gradient(135deg,var(--navy),#0e2659); padding:72px 5%; text-align:center; position:relative; overflow:hidden; }
    .cta-band::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(79,163,224,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.05) 1px,transparent 1px); background-size:52px 52px; }
    .cta-band-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; }
    .cta-band .section-label { color:var(--sky-light); }
    .cta-band h2 { font-family:var(--font-head); font-weight:900; font-size:clamp(1.6rem,3.5vw,2.3rem); color:#fff; margin-bottom:.85rem; line-height:1.2; }
    .cta-band p { color:rgba(255,255,255,.65); font-size:1rem; line-height:1.75; margin-bottom:2rem; }
    .cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

    /* FOOTER */
    footer { background:#070d20; color:rgba(255,255,255,.65); padding:56px 5% 26px; }
    .footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:1.75rem; }
    .footer-brand-lockup { display:flex; align-items:center; gap:1rem; margin-bottom:.9rem; text-decoration:none; }
    .footer-brand-mark {
      width:54px; height:54px; flex-shrink:0;
      border-radius:16px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
      border:1px solid rgba(255,255,255,.08);
    }
    .footer-brand-mark img { width:38px; height:38px; display:block; }
    .footer-brand-copy { display:flex; flex-direction:column; gap:.25rem; }
    .footer-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:1.95rem; line-height:.9;
      letter-spacing:-.06em; color:#fff;
    }
    .footer-brand-name em { font-style:normal; color:var(--sky-light); }
    .footer-brand-tag {
      font-size:.56rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:rgba(255,255,255,.4);
    }
    .footer-brand p { font-size:.85rem; line-height:1.8; color:rgba(255,255,255,.42); }
    .footer-cnpj { font-size:.7rem; color:rgba(255,255,255,.22); margin-top:.65rem; }
    .footer-col h4 { font-family:var(--font-head); font-weight:700; font-size:.75rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin-bottom:1rem; }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.5rem; }
    .footer-col ul a { color:rgba(255,255,255,.42); text-decoration:none; font-size:.85rem; transition:color .2s; }
    .footer-col ul a:hover { color:var(--sky-light); }
    .footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.25); flex-wrap:wrap; gap:.75rem; }
    .socials { display:flex; gap:.5rem; }
    .social-btn { width:32px; height:32px; border-radius:7px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.45); text-decoration:none; font-size:.8rem; font-weight:700; transition:background .2s,color .2s; }
    .social-btn:hover { background:var(--blue-mid); color:#fff; }

    /* REVEAL */
    .reveal { opacity:0; transform:translateY(26px); transition:opacity .6s ease,transform .6s ease; }
    .reveal.on { opacity:1; transform:none; }

    /* RESPONSIVE */
    @media(max-width:1024px){ .footer-grid{grid-template-columns:1fr 1fr;} }
    @media(max-width:768px){
      .nav-links{display:none;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:rgba(7,13,32,.97);padding:1.4rem 5%;gap:1rem;border-bottom:1px solid rgba(255,255,255,.07);}
      .nav-links.open{display:flex;} .hamburger{display:flex;}
      .footer-grid{grid-template-columns:1fr 1fr;} section{padding:64px 5%;}
    }
    @media(max-width:480px){ .footer-grid{grid-template-columns:1fr;} }


    /* ── CONTATO PRINCIPAL ── */
    #contato-main { background:var(--white); }
    .contato-grid {
      display:grid; grid-template-columns:1fr 1.35fr;
      gap:4.5rem; align-items:start;
      max-width:1140px; margin:0 auto;
    }

    /* Info lateral */
    .contato-info h2 { font-family:var(--font-head); font-weight:800; font-size:clamp(1.5rem,3vw,2rem); color:var(--navy); margin-bottom:.75rem; }
    .contato-info > p { color:var(--text-mid); line-height:1.78; margin-bottom:2rem; }

    .info-cards { display:flex; flex-direction:column; gap:.9rem; margin-bottom:2rem; }
    .info-card {
      display:flex; align-items:center; gap:1rem;
      padding:1rem 1.2rem;
      background:var(--off); border:1px solid var(--border);
      border-radius:12px; transition:border-color .2s,box-shadow .2s;
    }
    .info-card:hover { border-color:rgba(36,114,200,.3); box-shadow:0 4px 16px rgba(19,32,68,.08); }
    .info-card-icon {
      width:42px; height:42px; border-radius:10px; flex-shrink:0;
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      display:flex; align-items:center; justify-content:center; font-size:1.1rem;
    }
    .info-card-body strong { display:block; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-light); margin-bottom:2px; }
    .info-card-body span { font-size:.92rem; color:var(--navy); font-weight:500; }
    .info-card-body a { color:var(--blue-mid); text-decoration:none; font-size:.92rem; font-weight:500; }
    .info-card-body a:hover { text-decoration:underline; }

    .horario-box {
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      border-radius:14px; padding:1.4rem 1.6rem;
    }
    .horario-box h4 { font-family:var(--font-head); font-weight:700; font-size:.85rem; color:rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:.1em; margin-bottom:.75rem; }
    .horario-row { display:flex; justify-content:space-between; align-items:center; padding:.35rem 0; border-bottom:1px solid rgba(255,255,255,.08); }
    .horario-row:last-child { border-bottom:none; }
    .horario-row span { font-size:.88rem; color:rgba(255,255,255,.65); }
    .horario-row strong { font-size:.88rem; color:#fff; font-weight:600; }

    /* Formulário */
    .contato-form-wrap {
      background:var(--off); border:1px solid var(--border);
      border-radius:20px; padding:2.4rem;
    }
    .contato-form-wrap h3 {
      font-family:var(--font-head); font-weight:800;
      font-size:1.2rem; color:var(--navy); margin-bottom:.4rem;
    }
    .contato-form-wrap .form-sub { font-size:.88rem; color:var(--text-mid); margin-bottom:1.75rem; }

    .form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
    .form-group { display:flex; flex-direction:column; gap:.38rem; margin-bottom:.9rem; }
    .form-group.full { grid-column:1/-1; }
    .form-group label { font-size:.75rem; font-weight:600; color:var(--text-mid); letter-spacing:.04em; text-transform:uppercase; }
    .form-group input,
    .form-group textarea,
    .form-group select {
      padding:.72rem 1rem; border:1.5px solid var(--border);
      border-radius:8px; font-size:.92rem; font-family:var(--font-body);
      color:var(--navy); background:var(--white); outline:none;
      transition:border-color .2s,box-shadow .2s;
    }
    .form-group input:focus,
    .form-group textarea:focus,
    .form-group select:focus {
      border-color:var(--blue-mid);
      box-shadow:0 0 0 3px rgba(36,114,200,.1);
    }
    .form-group textarea { resize:vertical; min-height:108px; }
    .form-submit {
      width:100%; background:var(--blue-mid); color:#fff;
      padding:.92rem; border:none; border-radius:8px;
      font-family:var(--font-head); font-weight:700; font-size:.95rem;
      cursor:pointer; letter-spacing:.03em;
      transition:background .2s,transform .15s;
      margin-top:.5rem;
    }
    .form-submit:hover { background:var(--navy); transform:translateY(-1px); }

    /* success state */
    .form-success {
      display:none; text-align:center; padding:2rem;
    }
    .form-success .check { font-size:3rem; margin-bottom:.75rem; }
    .form-success h4 { font-family:var(--font-head); font-weight:700; font-size:1.2rem; color:var(--navy); margin-bottom:.5rem; }
    .form-success p { color:var(--text-mid); font-size:.92rem; }

    /* ── MAPA / ÁREA DESTAQUE ── */
    #area { background:var(--off); }
    .area-inner { max-width:1140px; margin:0 auto; }
    .area-inner .center { margin-bottom:3rem; }

    .estados-grid {
      display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
      gap:1rem;
    }
    .estado-card {
      background:var(--white); border:1px solid var(--border); border-radius:14px;
      padding:1.25rem; text-align:center;
      transition:transform .2s,border-color .2s,box-shadow .2s;
    }
    .estado-card:hover { transform:translateY(-4px); border-color:rgba(36,114,200,.3); box-shadow:0 10px 28px rgba(19,32,68,.1); }
    .estado-card .estado-icon { font-size:1.75rem; margin-bottom:.6rem; }
    .estado-card h4 { font-family:var(--font-head); font-weight:700; font-size:.92rem; color:var(--navy); }

    /* ── PROPOSTAS CTA ── */
    #propostas-cta { background:var(--white); padding:72px 5%; }
    .propostas-grid {
      display:grid; grid-template-columns:1fr 1fr;
      gap:1.5rem; max-width:1140px; margin:3rem auto 0;
    }
    .proposta-card {
      border-radius:18px; padding:2.1rem; position:relative; overflow:hidden;
      transition:transform .22s, box-shadow .22s;
    }
    .proposta-card:hover { transform:translateY(-5px); box-shadow:0 20px 48px rgba(19,32,68,.14); }
    .proposta-card.dark { background:linear-gradient(135deg,var(--navy),var(--blue-mid)); }
    .proposta-card.light { background:var(--off); border:1px solid var(--border); }
    .proposta-card h3 { font-family:var(--font-head); font-weight:800; font-size:1.25rem; margin-bottom:.65rem; }
    .proposta-card.dark h3 { color:#fff; }
    .proposta-card.light h3 { color:var(--navy); }
    .proposta-card p { font-size:.9rem; line-height:1.7; margin-bottom:1.5rem; }
    .proposta-card.dark p { color:rgba(255,255,255,.65); }
    .proposta-card.light p { color:var(--text-mid); }

    /* RESPONSIVE CONTATO */
    @media(max-width:900px){
      .contato-grid { grid-template-columns:1fr; gap:2.5rem; }
      .propostas-grid { grid-template-columns:1fr; }
    }
    @media(max-width:768px){
      .nav-brand { gap:10px; }
      .nav-brand-mark { width:40px; height:40px; border-radius:12px; }
      .nav-brand-mark img { width:28px; height:28px; }
      .nav-brand-name { font-size:1.28rem; }
      .nav-brand-tag { display:none; }
      .nav-links { display:none; flex-direction:column; position:absolute; top:72px; left:0; right:0; background:rgba(7,13,32,.97); padding:1.5rem 5%; gap:1.1rem; border-bottom:1px solid rgba(255,255,255,.07); }
      .nav-links.open { display:flex; }
      .hamburger { display:flex; }
      .page-hero-content { padding-top:118px; }
      .hero-brand-card { width:100%; padding:.82rem .95rem; gap:.8rem; }
      .hero-brand-mark { width:52px; height:52px; border-radius:16px; }
      .hero-brand-mark img { width:40px; height:40px; }
      .hero-brand-name { font-size:1.45rem; }
      .hero-brand-tag { font-size:.58rem; letter-spacing:.14em; }
      .footer-grid { grid-template-columns:1fr 1fr; }
      section { padding:70px 5%; }
    }
    @media(max-width:540px){
      .nav-brand-name { font-size:1.05rem; }
      .hero-brand-name { font-size:1.3rem; }
      .form-row { grid-template-columns:1fr; }
      .footer-grid { grid-template-columns:1fr; }
    }

/* Extracted CSS Block */
/* ===========================
       RESET & VARIÁVEIS
    =========================== */
    *, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior: smooth; }
    :root {
      --navy:       #132044;
      --blue:       #1a5daa;
      --blue-mid:   #2472c8;
      --sky:        #4fa3e0;
      --sky-light:  #a8d8f5;
      --accent:     #00c8f0;
      --white:      #ffffff;
      --off:        #f2f6fc;
      --border:     #dde6f5;
      --text-dark:  #0d1b35;
      --text-mid:   #3a5270;
      --text-light: #6b85a8;
      --font-head:  'Montserrat', sans-serif;
      --font-body:  'Inter', sans-serif;
    }
    body {
      font-family: var(--font-body);
      color: var(--text-dark);
      background: var(--white);
      overflow-x: hidden;
    }

    /* ===========================
       NAVBAR
    =========================== */
    #navbar {
      position: fixed; top:0; left:0; right:0; z-index:999;
      height: 72px;
      display: flex; align-items: center; justify-content: space-between;
      padding: 0 5%;
      background: rgba(10,18,44,0.88);
      backdrop-filter: blur(18px);
      border-bottom: 1px solid rgba(255,255,255,0.07);
      transition: background .3s;
    }
    #navbar.scrolled { background: rgba(10,18,44,0.97); }

    .nav-brand {
      display: flex; align-items: center; gap: 14px;
      text-decoration: none;
    }
    .nav-brand-mark {
      width: 46px; height: 46px;
      flex-shrink: 0;
      border-radius: 14px;
      display: flex; align-items: center; justify-content: center;
      background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.03));
      border: 1px solid rgba(255,255,255,.14);
      box-shadow: 0 10px 26px rgba(5,11,27,.22);
      backdrop-filter: blur(10px);
    }
    .nav-brand-mark img {
      width: 32px; height: 32px;
      display: block;
    }
    .nav-brand-copy {
      display: flex;
      flex-direction: column;
      gap: 3px;
    }
    .nav-brand-name {
      font-family: var(--font-head);
      font-size: 1.55rem;
      font-weight: 900;
      line-height: .88;
      letter-spacing: -.06em;
      color: #fff;
    }
    .nav-brand-name em {
      font-style: normal;
      color: var(--sky-light);
    }
    .nav-brand-tag {
      font-size: .48rem;
      font-weight: 700;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: rgba(255,255,255,.58);
    }

    .nav-links {
      display: flex; align-items: center; gap: 1.75rem;
      list-style: none;
    }
    .nav-links a {
      color: rgba(255,255,255,.78);
      text-decoration: none;
      font-size: .875rem;
      font-weight: 500;
      letter-spacing: .025em;
      transition: color .2s;
    }
    .nav-links a:hover { color: var(--sky-light); }
    .nav-links .btn-nav {
      background: var(--blue-mid);
      color: #fff !important;
      padding: .5rem 1.25rem;
      border-radius: 7px;
      font-weight: 700 !important;
      transition: background .2s !important;
    }
    .nav-links .btn-nav:hover { background: var(--sky) !important; }

    .hamburger {
      display: none; flex-direction: column; gap: 5px;
      cursor: pointer; padding: 6px;
    }
    .hamburger span {
      display: block; width: 24px; height: 2px;
      background: #fff; border-radius: 2px; transition: .3s;
    }

    /* ===========================
       HERO  —  banner principal
    =========================== */
    #hero {
  position: relative;
  min-height: 420px;
  display: flex; align-items: center;
  overflow: hidden;
}

    .hero-bg {
      position: absolute; inset: 0;
      background-image: url('../img/imagemestrada.png');
      background-color: #0a1432;
      background-size: cover;
      background-position: center 72%;
      transform: scale(1.04);
      animation: subtle-zoom 18s ease-in-out infinite alternate;
    }
    @keyframes subtle-zoom {
      from { transform: scale(1.04); }
      to   { transform: scale(1.00); }
    }

    /* overlay gradiente duplo */
    .hero-bg::after {
      content: '';
      position: absolute; inset: 0;
      background:
        linear-gradient(90deg, rgba(10,18,50,.88) 0%, rgba(10,18,50,.55) 55%, rgba(10,18,50,.2) 100%),
        linear-gradient(0deg,  rgba(10,18,50,.65) 0%, transparent 60%);
    }

    /* grid decorativo */
    .hero-grid-overlay {
      position: absolute; inset: 0; z-index: 1;
      background-image:
        linear-gradient(rgba(79,163,224,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(79,163,224,.06) 1px, transparent 1px);
      background-size: 55px 55px;
      animation: grid-move 22s linear infinite;
      pointer-events: none;
    }
    @keyframes grid-move {
      0%   { background-position: 0 0; }
      100% { background-position: 55px 55px; }
    }

    .hero-content {
  position: relative; z-index: 2;
  padding: 120px 5% 40px;
  max-width: 760px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
}

    .hero-brand-card {
      position: relative;
      display: inline-flex; align-items: center; gap: 1rem;
      width: fit-content; max-width: 100%;
      padding: 1rem 1.15rem;
      margin-bottom: 1.35rem;
      border-radius: 24px;
      background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(232,244,255,.92));
      border: 1px solid rgba(168,216,245,.5);
      box-shadow: 0 22px 60px rgba(8,17,40,.32);
      animation: fadeUp .7s .06s ease both;
    }
    .hero-brand-card::after {
      content: '';
      position: absolute; left: 22px; right: 22px; bottom: -16px;
      height: 22px;
      background: radial-gradient(circle, rgba(36,114,200,.32) 0%, rgba(36,114,200,0) 72%);
      filter: blur(12px);
      z-index: -1;
    }
    .hero-brand-mark {
      width: 72px; height: 72px;
      flex-shrink: 0;
      border-radius: 20px;
      display: flex; align-items: center; justify-content: center;
      background: linear-gradient(180deg, #ffffff 0%, #eff6ff 100%);
      box-shadow: inset 0 0 0 1px rgba(19,32,68,.06);
    }
    .hero-brand-mark img {
      width: 56px; height: 56px;
      display: block;
    }
    .hero-brand-copy {
      display: flex;
      flex-direction: column;
      gap: .25rem;
      min-width: 0;
    }
    .hero-brand-name {
      font-family: var(--font-head);
      font-weight: 900;
      font-size: clamp(1.8rem, 4vw, 2.5rem);
      line-height: .92;
      letter-spacing: -.07em;
      color: var(--navy);
    }
    .hero-brand-name em {
      font-style: normal;
      color: var(--blue-mid);
    }
    .hero-brand-tag {
      font-size: .76rem;
      font-weight: 700;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--blue);
    }

    .hero-eyebrow {
      display: inline-flex; align-items: center; gap: 8px;
      background: rgba(79,163,224,.15);
      border: 1px solid rgba(79,163,224,.35);
      border-radius: 50px;
      padding: .35rem 1rem;
      margin-bottom: 1.5rem;
      animation: fadeUp .7s .16s ease both;
    }
    .hero-eyebrow .pulse {
      width:7px; height:7px; border-radius:50%;
      background: var(--accent);
      animation: blink 2s ease infinite;
    }
    @keyframes blink {
      0%,100% { opacity:1; transform:scale(1); }
      50%      { opacity:.4; transform:scale(1.5); }
    }
    .hero-eyebrow span {
      font-size:.72rem; font-weight:700;
      letter-spacing:.12em; text-transform:uppercase;
      color: var(--sky-light);
    }

    .hero-content h1 {
      font-family: var(--font-head);
      font-weight: 900;
      font-size: clamp(2.2rem, 5vw, 3.5rem);
      line-height: 1.1;
      color: #fff;
      margin-bottom: 1.25rem;
      max-width: 700px;
      animation: fadeUp .7s .26s ease both;
    }
    .hero-content h1 em {
      font-style: normal;
      color: var(--accent);
    }

    .hero-content p {
      font-size: 1.05rem;
      line-height: 1.8;
      color: rgba(255,255,255,.72);
      max-width: 620px;
      margin-bottom: 1.55rem;
      animation: fadeUp .7s .4s ease both;
    }

    .hero-points {
      display: flex; flex-wrap: wrap; gap: .75rem;
      margin-bottom: 2rem;
      animation: fadeUp .7s .48s ease both;
    }
    .hero-point {
      display: inline-flex; align-items: center;
      padding: .55rem .85rem;
      border-radius: 999px;
      border: 1px solid rgba(168,216,245,.28);
      background: rgba(19,32,68,.32);
      color: rgba(255,255,255,.82);
      font-size: .78rem;
      font-weight: 600;
      letter-spacing: .02em;
      backdrop-filter: blur(10px);
    }

    .hero-btns {
      display: flex; gap: 1rem; flex-wrap: wrap;
      animation: fadeUp .7s .56s ease both;
    }
    .btn-primary {
      background: var(--blue-mid);
      color: #fff;
      padding: .9rem 2.1rem;
      border-radius: 8px;
      text-decoration: none;
      font-family: var(--font-head);
      font-weight: 700; font-size: .95rem;
      letter-spacing: .03em;
      transition: background .2s, transform .15s;
      display: inline-block;
    }
    .btn-primary:hover { background: var(--sky); transform: translateY(-2px); }
    .btn-ghost {
      background: transparent;
      color: #fff;
      padding: .9rem 2.1rem;
      border-radius: 8px;
      text-decoration: none;
      font-weight: 600; font-size: .95rem;
      border: 1.5px solid rgba(255,255,255,.38);
      transition: border-color .2s, background .2s, transform .15s;
      display: inline-block;
    }
    .btn-ghost:hover {
      border-color: var(--sky-light);
      background: rgba(79,163,224,.12);
      transform: translateY(-2px);
    }

    /* stats — ficam no canto inferior direito em desktop,
       desaparecem no mobile para não poluir */
    .hero-stats {
  position: absolute; bottom: 20px; right: 5%; z-index: 2;
  display: flex; gap: 1.25rem;
  animation: fadeUp .7s .65s ease both;
}
    @media(max-width:768px){ .hero-stats { display: none; } }
    .hstat {
      text-align: center;
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.12);
      backdrop-filter: blur(10px);
      border-radius: 14px;
      padding: 1rem 1.4rem;
    }
    .hstat-num {
      font-family: var(--font-head); font-weight:900; font-size:1.9rem;
      color:#fff; line-height:1;
    }
    .hstat-num em { font-style:normal; color:var(--accent); }
    .hstat-label {
      font-size:.7rem; color:rgba(255,255,255,.5);
      text-transform:uppercase; letter-spacing:.08em; margin-top:5px;
    }

    /* scroll indicator */
    .scroll-hint {
      position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
      z-index:2; display:flex; flex-direction:column; align-items:center; gap:6px;
      animation: fadeUp .7s .8s ease both;
    }
    .scroll-hint span {
      font-size:.68rem; letter-spacing:.1em; text-transform:uppercase;
      color:rgba(255,255,255,.4);
    }
    .scroll-arrow {
      width:20px; height:20px; border-right:2px solid rgba(255,255,255,.4);
      border-bottom:2px solid rgba(255,255,255,.4);
      transform: rotate(45deg);
      animation: bounce 1.6s ease infinite;
    }
    @keyframes bounce { 0%,100%{transform:rotate(45deg) translate(0,0)} 50%{transform:rotate(45deg) translate(4px,4px)} }

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

    /* ===========================
       BANNER SECUNDÁRIO (manutenção)
    =========================== */
    .banner-strip {
      position: relative;
      overflow: hidden;
      height: 260px;
    }
    .banner-strip img {
      width:100%; height:100%; object-fit:cover; object-position:center 40%;
      display:block;
    }
    .banner-strip-overlay {
      position:absolute; inset:0;
      background: linear-gradient(90deg, rgba(10,18,50,.82) 0%, rgba(10,18,50,.3) 100%);
      display:flex; align-items:center; padding: 0 5%;
    }
    .banner-strip-text h2 {
      font-family: var(--font-head); font-weight:900;
      font-size: clamp(1.4rem,3vw,2.2rem);
      color:#fff; line-height:1.2; margin-bottom:.5rem;
    }
    .banner-strip-text p {
      color:rgba(255,255,255,.72); font-size:1rem; max-width:480px;
    }
    .banner-strip-badge {
      display:inline-block;
      background: var(--accent);
      color: var(--navy);
      font-family: var(--font-head); font-weight:900;
      font-size:1.1rem; padding:.4rem 1.2rem;
      border-radius:50px; margin-bottom:.75rem;
      letter-spacing:.02em;
    }

    /* ===========================
       SEÇÕES — COMUNS
    =========================== */
    section { padding: 96px 5%; }

    .section-label {
      font-size:.72rem; font-weight:700;
      letter-spacing:.14em; text-transform:uppercase;
      color:var(--blue-mid); margin-bottom:.65rem;
    }
    .section-title {
      font-family: var(--font-head); font-weight:800;
      font-size: clamp(1.75rem,3.5vw,2.6rem);
      line-height:1.15; color:var(--navy); margin-bottom:1rem;
    }
    .section-sub {
      font-size:1.05rem; line-height:1.8;
      color:var(--text-mid); max-width:580px;
    }
    .center { text-align:center; }
    .center .section-sub { margin:0 auto; }

    /* ===========================
       SERVIÇOS — cards
    =========================== */
    #servicos { background: var(--off); }

    .cards-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(290px,1fr));
      gap: 1.4rem;
      max-width: 1200px;
      margin: 3.5rem auto 0;
    }

    .card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 18px;
      padding: 2.1rem;
      position: relative; overflow:hidden;
      transition: transform .25s, box-shadow .25s, border-color .25s;
    }
    .card::after {
      content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
      background: linear-gradient(90deg, var(--navy), var(--sky));
      transform: scaleX(0); transform-origin:left; transition: transform .3s;
    }
    .card:hover { transform:translateY(-7px); box-shadow:0 22px 52px rgba(19,32,68,.13); border-color:rgba(36,114,200,.22); }
    .card:hover::after { transform:scaleX(1); }

    .card-icon {
      width:52px; height:52px; border-radius:13px;
      background: linear-gradient(135deg, var(--navy), var(--blue-mid));
      display:flex; align-items:center; justify-content:center;
      font-size:1.45rem; margin-bottom:1.2rem;
    }
    .card h3 {
      font-family:var(--font-head); font-weight:700;
      font-size:1.05rem; color:var(--navy); margin-bottom:.65rem;
    }
    .card p { font-size:.9rem; line-height:1.72; color:var(--text-mid); }
    .card-link {
      display:inline-flex; align-items:center; gap:5px;
      margin-top:1.1rem; font-size:.82rem; font-weight:600;
      color:var(--blue-mid); text-decoration:none;
      transition: gap .2s, color .2s;
    }
    .card-link:hover { gap:9px; color:var(--navy); }

    /* ===========================
       SOBRE — duas colunas
    =========================== */
    #sobre { background: var(--white); }

    .about-grid {
      display:grid; grid-template-columns:1fr 1fr;
      gap:5rem; align-items:center;
      max-width:1200px; margin:0 auto;
    }
    .about-imgs { position:relative; }
    .about-main-img {
      width:100%; border-radius:20px;
      aspect-ratio:4/3; object-fit:cover;
      box-shadow:0 24px 60px rgba(19,32,68,.18);
      display:block;
    }
    .about-badge {
      position:absolute; bottom:-22px; right:-18px;
      background:var(--white); border:1px solid var(--border);
      border-radius:14px; padding:1.1rem 1.4rem;
      box-shadow:0 12px 36px rgba(19,32,68,.14);
      min-width:160px; text-align:center;
    }
    .about-badge .big-num {
      font-family:var(--font-head); font-weight:900;
      font-size:2rem; color:var(--blue-mid); line-height:1;
    }
    .about-badge .big-num em { font-style:normal; color:var(--accent); }
    .about-badge .small-lbl { font-size:.76rem; color:var(--text-light); margin-top:4px; }

    .about-text .section-sub { max-width:100%; margin-bottom:1.2rem; }
    .about-text p+p { margin-top:.9rem; }
    .about-bullets { display:flex; flex-direction:column; gap:.7rem; margin-top:1.6rem; }
    .bullet-row {
      display:flex; align-items:flex-start; gap:.8rem;
      font-size:.9rem; color:var(--text-mid); line-height:1.65;
    }
    .bullet-check {
      width:20px; height:20px; border-radius:50%; flex-shrink:0; margin-top:1px;
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      display:flex; align-items:center; justify-content:center;
      font-size:.62rem; color:#fff; font-weight:700;
    }
    .about-cta { margin-top:2rem; }

    /* ===========================
       IMAGEM TRIPTYCH — secção visual
    =========================== */
    .visual-strip {
      padding:0;
      overflow:hidden;
      position:relative;
      max-height:460px;
    }
    .visual-strip img {
      width:100%; height:100%; max-height:460px;
      object-fit:cover; object-position:center top;
      display:block;
    }
    .visual-strip-overlay {
      position:absolute; inset:0;
      background:linear-gradient(0deg,rgba(10,18,50,.72) 0%,transparent 55%);
      display:flex; align-items:flex-end; padding:3rem 5%;
    }
    .visual-strip-text {
      font-family:var(--font-head); font-weight:800;
      font-size:clamp(1.3rem,3vw,2rem);
      color:#fff; max-width:620px; line-height:1.3;
    }
    .visual-strip-text em { font-style:normal; color:var(--accent); }

    /* ===========================
       DIFERENCIAIS — números
    =========================== */
    #diferenciais { background:var(--off); }

    .diff-inner {
      max-width:1200px; margin:0 auto;
      display:grid; grid-template-columns: 1fr 1.2fr;
      gap:5rem; align-items:center;
    }
    .diff-numbers {
      display:grid; grid-template-columns:1fr 1fr; gap:1.5rem;
    }
    .diff-box {
      background:var(--white); border:1px solid var(--border);
      border-radius:18px; padding:1.75rem;
      transition:transform .2s, box-shadow .2s;
    }
    .diff-box:hover { transform:translateY(-4px); box-shadow:0 14px 38px rgba(19,32,68,.1); }
    .diff-num {
      font-family:var(--font-head); font-weight:900;
      font-size:2.4rem; line-height:1; color:var(--blue-mid);
    }
    .diff-num em { font-style:normal; color:var(--accent); }
    .diff-desc {
      font-size:.82rem; line-height:1.6;
      color:var(--text-mid); margin-top:.5rem;
    }
    .diff-text .section-sub { max-width:100%; }
    .diff-features { display:flex; flex-direction:column; gap:.8rem; margin-top:1.75rem; }
    .diff-feature {
      display:flex; align-items:flex-start; gap:.85rem;
      padding:1rem 1.1rem;
      background:var(--white); border:1px solid var(--border);
      border-radius:12px;
    }
    .diff-feature-icon {
      font-size:1.3rem; flex-shrink:0; margin-top:1px;
    }
    .diff-feature-body h4 {
      font-family:var(--font-head); font-weight:700;
      font-size:.92rem; color:var(--navy); margin-bottom:.2rem;
    }
    .diff-feature-body p { font-size:.82rem; color:var(--text-mid); line-height:1.6; }

    /* ===========================
       CTA BAND
    =========================== */
    .cta-band {
      background:linear-gradient(135deg,var(--navy) 0%,#0e2659 100%);
      padding:80px 5%; text-align:center; position:relative; overflow:hidden;
    }
    .cta-band::before {
      content:''; position:absolute; inset:0;
      background-image:linear-gradient(rgba(79,163,224,.05) 1px,transparent 1px),
                       linear-gradient(90deg,rgba(79,163,224,.05) 1px,transparent 1px);
      background-size:52px 52px;
    }
    .cta-band-inner { position:relative; z-index:1; max-width:700px; margin:0 auto; }
    .cta-band h2 {
      font-family:var(--font-head); font-weight:900;
      font-size:clamp(1.7rem,3.5vw,2.5rem);
      color:#fff; margin-bottom:.9rem; line-height:1.2;
    }
    .cta-band p {
      color:rgba(255,255,255,.68); font-size:1.05rem;
      line-height:1.75; margin-bottom:2.2rem;
    }
    .cta-band .btn-primary { font-size:1rem; padding:1rem 2.4rem; }

    /* ===========================
       FOOTER
    =========================== */
    footer {
      background:#070d20;
      color:rgba(255,255,255,.65);
      padding:60px 5% 28px;
    }
    .footer-grid {
      display:grid;
      grid-template-columns:1.6fr 1fr 1fr 1fr;
      gap:2.5rem;
      padding-bottom:2.5rem;
      border-bottom:1px solid rgba(255,255,255,.07);
      margin-bottom:2rem;
    }
    .footer-brand-lockup {
      display:flex; align-items:center; gap:1rem;
      margin-bottom:1rem;
      text-decoration:none;
    }
    .footer-brand-mark {
      width:54px; height:54px;
      flex-shrink:0;
      border-radius:16px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
      border:1px solid rgba(255,255,255,.08);
    }
    .footer-brand-mark img {
      width:38px; height:38px;
      display:block;
    }
    .footer-brand-copy {
      display:flex;
      flex-direction:column;
      gap:.25rem;
    }
    .footer-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:1.95rem; line-height:.9;
      letter-spacing:-.06em; color:#fff;
    }
    .footer-brand-name em { font-style:normal; color:var(--sky-light); }
    .footer-brand-tag {
      font-size:.56rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:rgba(255,255,255,.4);
    }
    .footer-brand p { font-size:.875rem; line-height:1.8; color:rgba(255,255,255,.45); }
    .footer-cnpj { font-size:.72rem; color:rgba(255,255,255,.25); margin-top:.75rem; }
    .footer-col h4 {
      font-family:var(--font-head); font-weight:700;
      font-size:.78rem; text-transform:uppercase; letter-spacing:.1em;
      color:#fff; margin-bottom:1.1rem;
    }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.55rem; }
    .footer-col ul a { color:rgba(255,255,255,.45); text-decoration:none; font-size:.875rem; transition:color .2s; }
    .footer-col ul a:hover { color:var(--sky-light); }
    .footer-bottom {
      display:flex; justify-content:space-between; align-items:center;
      font-size:.78rem; color:rgba(255,255,255,.28); flex-wrap:wrap; gap:.75rem;
    }
    .socials { display:flex; gap:.6rem; }
    .social-btn {
      width:34px; height:34px; border-radius:8px;
      background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
      display:flex; align-items:center; justify-content:center;
      color:rgba(255,255,255,.5); text-decoration:none; font-size:.85rem;
      transition:background .2s, color .2s;
    }
    .social-btn:hover { background:var(--blue-mid); color:#fff; }

    /* ===========================
       REVEAL ANIMATION
    =========================== */
    .reveal {
      opacity:0; transform:translateY(28px);
      transition:opacity .6s ease, transform .6s ease;
    }
    .reveal.on { opacity:1; transform:none; }

    /* ===========================
       RESPONSIVE
    =========================== */
    @media(max-width:1024px){
      .footer-grid { grid-template-columns:1fr 1fr; }
      .diff-inner { grid-template-columns:1fr; gap:2.5rem; }
    }
    @media(max-width:768px){
      .nav-brand { gap:10px; }
      .nav-brand-mark { width:40px; height:40px; border-radius:12px; }
      .nav-brand-mark img { width:28px; height:28px; }
      .nav-brand-name { font-size:1.28rem; }
      .nav-brand-tag { display:none; }
      .nav-links {
        display:none; flex-direction:column;
        position:absolute; top:72px; left:0; right:0;
        background:rgba(7,13,32,.97); padding:1.5rem 5%;
        gap:1.1rem; border-bottom:1px solid rgba(255,255,255,.07);
      }
      .nav-links.open { display:flex; }
      .hamburger { display:flex; }
      .hero-content { padding-top: 118px; }
      .hero-brand-card {
        width: 100%;
        padding: .9rem 1rem;
        gap: .85rem;
        border-radius: 20px;
      }
      .hero-brand-mark { width:58px; height:58px; border-radius:16px; }
      .hero-brand-mark img { width:44px; height:44px; }
      .hero-brand-tag { font-size:.63rem; letter-spacing:.16em; }
      .hero-points { gap:.55rem; }
      .hero-point { font-size:.72rem; }
      .about-grid { grid-template-columns:1fr; gap:2.5rem; }
      .about-badge { right:0; bottom:-16px; }
      .diff-numbers { grid-template-columns:1fr 1fr; }
      .footer-grid { grid-template-columns:1fr 1fr; }
      section { padding:70px 5%; }
    }
    @media(max-width:480px){
      .nav-brand-name { font-size:1.05rem; }
      .hero-brand-name { font-size:1.55rem; }
      .diff-numbers { grid-template-columns:1fr; }
      .footer-grid { grid-template-columns:1fr; }
      .hero-btns { flex-direction:column; }
    }

/* Extracted CSS Block */
.wa-float {
  position:fixed; bottom:28px; right:28px; z-index:998;
  width:58px; height:58px; border-radius:50%;
  background:#25d366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,.45);
  transition:transform .2s, box-shadow .2s;
  text-decoration:none;
}
.wa-float:hover { transform:scale(1.1) translateY(-2px); box-shadow:0 10px 32px rgba(37,211,102,.55); }
@keyframes wa-ping {
  0%  { box-shadow:0 0 0 0 rgba(37,211,102,.5); }
  70% { box-shadow:0 0 0 14px rgba(37,211,102,0); }
  100%{ box-shadow:0 0 0 0 rgba(37,211,102,0); }
}
.wa-float { animation: wa-ping 2.5s ease infinite; }
.wa-float:hover { animation:none; }

/* Extracted CSS Block */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    :root {
      --navy:#132044; --blue:#1a5daa; --blue-mid:#2472c8;
      --sky:#4fa3e0; --sky-light:#a8d8f5; --accent:#00c8f0;
      --white:#ffffff; --off:#f2f6fc; --border:#dde6f5;
      --text-dark:#0d1b35; --text-mid:#3a5270; --text-light:#6b85a8;
      --font-head:'Montserrat',sans-serif; --font-body:'Inter',sans-serif;
    }
    body { font-family:var(--font-body); color:var(--text-dark); background:var(--white); overflow-x:hidden; }
    #navbar { position:fixed; top:0; left:0; right:0; z-index:999; height:72px; display:flex; align-items:center; justify-content:space-between; padding:0 5%; background:rgba(10,18,44,.88); backdrop-filter:blur(18px); border-bottom:1px solid rgba(255,255,255,.07); transition:background .3s; }
    #navbar.scrolled { background:rgba(10,18,44,.97); }
    .nav-brand { display:flex; align-items:center; text-decoration:none; }
    .nav-brand img { height:56px; width:auto; }
    .nav-links { display:flex; align-items:center; gap:1.6rem; list-style:none; }
    .nav-links a { color:rgba(255,255,255,.78); text-decoration:none; font-size:.875rem; font-weight:500; letter-spacing:.02em; transition:color .2s; }
    .nav-links a:hover { color:var(--sky-light); }
    .nav-links .btn-nav { background:var(--blue-mid); color:#fff!important; padding:.48rem 1.2rem; border-radius:7px; font-weight:700!important; }
    .nav-links .btn-nav:hover { background:var(--sky)!important; }
    .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
    .hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; }
    section { padding:88px 5%; }
    .section-label { font-size:.7rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue-mid); margin-bottom:.6rem; }
    .section-title { font-family:var(--font-head); font-weight:800; font-size:clamp(1.7rem,3.5vw,2.5rem); line-height:1.15; color:var(--navy); margin-bottom:.9rem; }
    .section-sub { font-size:1rem; line-height:1.8; color:var(--text-mid); max-width:580px; }
    .center { text-align:center; } .center .section-sub { margin:0 auto; }
    .btn-primary { background:var(--blue-mid); color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-family:var(--font-head); font-weight:700; font-size:.92rem; letter-spacing:.03em; transition:background .2s,transform .15s; display:inline-block; }
    .btn-primary:hover { background:var(--sky); transform:translateY(-2px); }
    .btn-ghost { background:transparent; color:var(--navy); padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid var(--border); transition:border-color .2s,background .2s; display:inline-block; }
    .btn-ghost:hover { border-color:var(--blue-mid); background:rgba(36,114,200,.06); }
    .btn-ghost-white { background:transparent; color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid rgba(255,255,255,.38); transition:border-color .2s,background .2s; display:inline-block; }
    .btn-ghost-white:hover { border-color:var(--sky-light); background:rgba(255,255,255,.08); }
    .page-hero { position:relative; min-height:420px; display:flex; align-items:center; overflow:hidden; }
    .page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center 30%; background-color:#0a1432; animation:subtle-zoom 18s ease-in-out infinite alternate; }
    @keyframes subtle-zoom { from{transform:scale(1.04)} to{transform:scale(1)} }
    .page-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(10,18,50,.92) 0%,rgba(10,18,50,.58) 60%,rgba(10,18,50,.25) 100%); }
    .page-hero-grid { position:absolute; inset:0; z-index:1; pointer-events:none; background-image:linear-gradient(rgba(79,163,224,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.06) 1px,transparent 1px); background-size:55px 55px; animation:grid-move 22s linear infinite; }
    @keyframes grid-move { 0%{background-position:0 0} 100%{background-position:55px 55px} }
    .page-hero-content { position:relative; z-index:2; padding:118px 5% 72px; max-width:660px; }
    .hero-logo { display:block; width:180px; margin-bottom:1.25rem; animation:fadeUp .6s ease both; }
    .eyebrow { display:inline-flex; align-items:center; gap:8px; background:rgba(79,163,224,.15); border:1px solid rgba(79,163,224,.35); border-radius:50px; padding:.32rem .95rem; margin-bottom:1.1rem; animation:fadeUp .6s .05s ease both; }
    .eyebrow span { font-size:.68rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--sky-light); }
    .page-hero-content h1 { font-family:var(--font-head); font-weight:900; font-size:clamp(2rem,5vw,3.1rem); line-height:1.1; color:#fff; margin-bottom:1rem; animation:fadeUp .6s .15s ease both; }
    .page-hero-content h1 em { font-style:normal; color:var(--accent); }
    .page-hero-content p { font-size:1rem; line-height:1.8; color:rgba(255,255,255,.7); max-width:520px; animation:fadeUp .6s .28s ease both; }
    .breadcrumb { position:absolute; bottom:22px; left:5%; z-index:2; display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:rgba(255,255,255,.42); }
    .breadcrumb a { color:rgba(255,255,255,.42); text-decoration:none; }
    .breadcrumb a:hover { color:var(--sky-light); }
    .breadcrumb .sep { color:rgba(255,255,255,.2); }
    @keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }
    footer { background:#070d20; color:rgba(255,255,255,.65); padding:56px 5% 26px; }
    .footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:1.75rem; }
    .footer-brand-logo { height:52px; width:auto; margin-bottom:.9rem; display:block; }
    .footer-brand p { font-size:.85rem; line-height:1.8; color:rgba(255,255,255,.42); }
    .footer-cnpj { font-size:.7rem; color:rgba(255,255,255,.22); margin-top:.65rem; }
    .footer-col h4 { font-family:var(--font-head); font-weight:700; font-size:.75rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin-bottom:1rem; }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.5rem; }
    .footer-col ul a { color:rgba(255,255,255,.42); text-decoration:none; font-size:.85rem; transition:color .2s; }
    .footer-col ul a:hover { color:var(--sky-light); }
    .footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.25); flex-wrap:wrap; gap:.75rem; }
    .socials { display:flex; gap:.5rem; }
    .social-btn { width:32px; height:32px; border-radius:7px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.45); text-decoration:none; font-size:.8rem; font-weight:700; transition:background .2s,color .2s; }
    .social-btn:hover { background:var(--blue-mid); color:#fff; }
    .reveal { opacity:0; transform:translateY(26px); transition:opacity .6s ease,transform .6s ease; }
    .reveal.on { opacity:1; transform:none; }
    @media(max-width:1024px){ .footer-grid{grid-template-columns:1fr 1fr;} }
    @media(max-width:768px){
      .nav-links{display:none;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:rgba(7,13,32,.97);padding:1.4rem 5%;gap:1rem;border-bottom:1px solid rgba(255,255,255,.07);}
      .nav-links.open{display:flex;} .hamburger{display:flex;}
      .footer-grid{grid-template-columns:1fr 1fr;} section{padding:64px 5%;}
    }
    @media(max-width:480px){ .footer-grid{grid-template-columns:1fr;} }


    /* ── NAVEGAÇÃO INTERNA ── */
    .integ-nav {
      position:sticky; top:72px; z-index:90;
      background:var(--white); border-bottom:1px solid var(--border);
      padding:0 5%; display:flex; gap:0; overflow-x:auto;
    }
    .integ-nav a {
      display:inline-block; padding:.85rem 1.25rem;
      font-size:.82rem; font-weight:600; color:var(--text-mid);
      text-decoration:none; border-bottom:2px solid transparent;
      white-space:nowrap; transition:color .2s,border-color .2s;
    }
    .integ-nav a:hover,
    .integ-nav a.active { color:var(--blue-mid); border-bottom-color:var(--blue-mid); }

    /* ── LAYOUT PRINCIPAL ── */
    .integ-main { background:var(--white); }
    .integ-layout {
      display:grid; grid-template-columns:260px 1fr;
      gap:4rem; align-items:start;
      max-width:1140px; margin:0 auto;
    }

    /* Sidebar */
    .integ-sidebar { position:sticky; top:130px; }
    .integ-sidebar-title { font-family:var(--font-head); font-weight:800; font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-light); margin-bottom:1rem; padding-bottom:.6rem; border-bottom:1px solid var(--border); }
    .integ-sidebar ul { list-style:none; display:flex; flex-direction:column; gap:.25rem; }
    .integ-sidebar ul a {
      display:flex; align-items:center; gap:.6rem;
      padding:.55rem .75rem; border-radius:8px;
      font-size:.88rem; font-weight:500; color:var(--text-mid);
      text-decoration:none; transition:background .2s,color .2s;
    }
    .integ-sidebar ul a:hover { background:var(--off); color:var(--blue-mid); }
    .integ-sidebar ul a.active { background:rgba(36,114,200,.08); color:var(--blue-mid); font-weight:700; }

    /* Conteúdo */
    .integ-content { min-width:0; }
    .integ-section { margin-bottom:4rem; padding-bottom:4rem; border-bottom:1px solid var(--border); }
    .integ-section:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }
    .integ-section h2 { font-family:var(--font-head); font-weight:800; font-size:1.6rem; color:var(--navy); margin-bottom:1rem; }
    .integ-section h3 { font-family:var(--font-head); font-weight:700; font-size:1.05rem; color:var(--navy); margin:1.5rem 0 .6rem; }
    .integ-section p { font-size:.95rem; line-height:1.85; color:var(--text-mid); margin-bottom:.9rem; }
    .integ-section ul { padding-left:1.4rem; display:flex; flex-direction:column; gap:.5rem; margin-bottom:.9rem; }
    .integ-section ul li { font-size:.95rem; line-height:1.75; color:var(--text-mid); }
    .last-update { font-size:.78rem; color:var(--text-light); margin-bottom:1.5rem; padding:.4rem .75rem; background:var(--off); border-radius:6px; display:inline-block; }

    /* Cards de destaque */
    .integ-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1rem; margin:1.5rem 0; }
    .integ-card {
      padding:1.25rem; border-radius:14px;
      border:1px solid var(--border); background:var(--off);
      transition:border-color .2s,transform .2s;
    }
    .integ-card:hover { border-color:rgba(36,114,200,.3); transform:translateY(-3px); }
    .integ-card-icon { font-size:1.5rem; margin-bottom:.6rem; }
    .integ-card h4 { font-family:var(--font-head); font-weight:700; font-size:.9rem; color:var(--navy); margin-bottom:.4rem; }
    .integ-card p { font-size:.82rem; line-height:1.6; color:var(--text-mid); }

    /* Canal de denúncias — destaque */
    .denuncia-box {
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      border-radius:18px; padding:2.2rem; margin:1.5rem 0;
    }
    .denuncia-box h3 { font-family:var(--font-head); font-weight:800; font-size:1.2rem; color:#fff; margin-bottom:.65rem; }
    .denuncia-box p { color:rgba(255,255,255,.7); font-size:.9rem; line-height:1.75; margin-bottom:1.25rem; }
    .denuncia-btn { display:inline-flex; align-items:center; gap:.5rem; background:var(--accent); color:var(--navy); padding:.7rem 1.5rem; border-radius:8px; text-decoration:none; font-family:var(--font-head); font-weight:800; font-size:.88rem; transition:opacity .2s,transform .15s; }
    .denuncia-btn:hover { opacity:.9; transform:translateY(-1px); }
    .denuncia-garantias { display:flex; flex-wrap:wrap; gap:.75rem; margin-top:1.25rem; }
    .denuncia-tag { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:50px; padding:.3rem .85rem; font-size:.75rem; color:rgba(255,255,255,.8); font-weight:600; }

    /* RESPONSIVE INTEG */
    @media(max-width:900px){
      .integ-layout{ grid-template-columns:1fr; gap:2rem; }
      .integ-sidebar{ position:static; }
    }

/* Extracted CSS Block */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    :root {
      --navy:#132044; --blue:#1a5daa; --blue-mid:#2472c8;
      --sky:#4fa3e0; --sky-light:#a8d8f5; --accent:#00c8f0;
      --white:#ffffff; --off:#f2f6fc; --border:#dde6f5;
      --text-dark:#0d1b35; --text-mid:#3a5270; --text-light:#6b85a8;
      --font-head:'Montserrat',sans-serif; --font-body:'Inter',sans-serif;
    }
    body { font-family:var(--font-body); color:var(--text-dark); background:var(--white); overflow-x:hidden; }
    #navbar { position:fixed; top:0; left:0; right:0; z-index:999; height:72px; display:flex; align-items:center; justify-content:space-between; padding:0 5%; background:rgba(10,18,44,.88); backdrop-filter:blur(18px); border-bottom:1px solid rgba(255,255,255,.07); transition:background .3s; }
    #navbar.scrolled { background:rgba(10,18,44,.97); }
    .nav-brand { display:flex; align-items:center; gap:14px; text-decoration:none; }
    .nav-brand-mark {
      width:46px; height:46px; flex-shrink:0;
      border-radius:14px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.03));
      border:1px solid rgba(255,255,255,.14);
      box-shadow:0 10px 26px rgba(5,11,27,.22);
      backdrop-filter:blur(10px);
    }
    .nav-brand-mark img { width:32px; height:32px; display:block; }
    .nav-brand-copy { display:flex; flex-direction:column; gap:3px; }
    .nav-brand-name {
      font-family:var(--font-head); font-size:1.55rem; font-weight:900;
      line-height:.88; letter-spacing:-.06em; color:#fff;
    }
    .nav-brand-name em { font-style:normal; color:var(--sky-light); }
    .nav-brand-tag {
      font-size:.48rem; font-weight:700;
      letter-spacing:.2em; text-transform:uppercase;
      color:rgba(255,255,255,.58);
    }
    .nav-links { display:flex; align-items:center; gap:1.6rem; list-style:none; }
    .nav-links a { color:rgba(255,255,255,.78); text-decoration:none; font-size:.875rem; font-weight:500; letter-spacing:.02em; transition:color .2s; }
    .nav-links a:hover { color:var(--sky-light); }
    .nav-links .btn-nav { background:var(--blue-mid); color:#fff!important; padding:.48rem 1.2rem; border-radius:7px; font-weight:700!important; }
    .nav-links .btn-nav:hover { background:var(--sky)!important; }
    .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
    .hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; }
    section { padding:88px 5%; }
    .section-label { font-size:.7rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue-mid); margin-bottom:.6rem; }
    .section-title { font-family:var(--font-head); font-weight:800; font-size:clamp(1.7rem,3.5vw,2.5rem); line-height:1.15; color:var(--navy); margin-bottom:.9rem; }
    .section-sub { font-size:1rem; line-height:1.8; color:var(--text-mid); max-width:580px; }
    .center { text-align:center; } .center .section-sub { margin:0 auto; }
    .btn-primary { background:var(--blue-mid); color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-family:var(--font-head); font-weight:700; font-size:.92rem; letter-spacing:.03em; transition:background .2s,transform .15s; display:inline-block; }
    .btn-primary:hover { background:var(--sky); transform:translateY(-2px); }
    .btn-ghost { background:transparent; color:var(--navy); padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid var(--border); transition:border-color .2s,background .2s; display:inline-block; }
    .btn-ghost:hover { border-color:var(--blue-mid); background:rgba(36,114,200,.06); }
    .btn-ghost-white { background:transparent; color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid rgba(255,255,255,.38); transition:border-color .2s,background .2s; display:inline-block; }
    .btn-ghost-white:hover { border-color:var(--sky-light); background:rgba(255,255,255,.08); }
    .page-hero { position:relative; min-height:420px; display:flex; align-items:center; overflow:hidden; }
    .page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center 30%; background-color:#0a1432; animation:subtle-zoom 18s ease-in-out infinite alternate; }
    @keyframes subtle-zoom { from{transform:scale(1.04)} to{transform:scale(1)} }
    .page-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(10,18,50,.92) 0%,rgba(10,18,50,.58) 60%,rgba(10,18,50,.25) 100%); }
    .page-hero-grid { position:absolute; inset:0; z-index:1; pointer-events:none; background-image:linear-gradient(rgba(79,163,224,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.06) 1px,transparent 1px); background-size:55px 55px; animation:grid-move 22s linear infinite; }
    @keyframes grid-move { 0%{background-position:0 0} 100%{background-position:55px 55px} }
    .page-hero-content { position:relative; z-index:2; padding:118px 5% 72px; max-width:760px; }
    .hero-brand-card {
      position:relative;
      display:inline-flex; align-items:center; gap:1rem;
      width:fit-content; max-width:100%;
      padding:.9rem 1.05rem;
      margin-bottom:1.15rem;
      border-radius:22px;
      background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(232,244,255,.92));
      border:1px solid rgba(168,216,245,.5);
      box-shadow:0 20px 52px rgba(8,17,40,.28);
      animation:fadeUp .6s ease both;
    }
    .hero-brand-mark {
      width:62px; height:62px; flex-shrink:0;
      border-radius:18px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(180deg,#ffffff 0%,#eff6ff 100%);
      box-shadow:inset 0 0 0 1px rgba(19,32,68,.06);
    }
    .hero-brand-mark img { width:46px; height:46px; display:block; }
    .hero-brand-copy { display:flex; flex-direction:column; gap:.22rem; min-width:0; }
    .hero-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:clamp(1.55rem,3.5vw,2.2rem);
      line-height:.92; letter-spacing:-.07em; color:var(--navy);
    }
    .hero-brand-name em { font-style:normal; color:var(--blue-mid); }
    .hero-brand-tag {
      font-size:.68rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:var(--blue);
    }
    .eyebrow { display:inline-flex; align-items:center; gap:8px; background:rgba(79,163,224,.15); border:1px solid rgba(79,163,224,.35); border-radius:50px; padding:.32rem .95rem; margin-bottom:1.1rem; animation:fadeUp .6s .05s ease both; }
    .eyebrow span { font-size:.68rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--sky-light); }
    .page-hero-content h1 { font-family:var(--font-head); font-weight:900; font-size:clamp(2rem,5vw,3.1rem); line-height:1.1; color:#fff; margin-bottom:1rem; animation:fadeUp .6s .15s ease both; }
    .page-hero-content h1 em { font-style:normal; color:var(--accent); }
    .page-hero-content p { font-size:1rem; line-height:1.8; color:rgba(255,255,255,.7); max-width:520px; animation:fadeUp .6s .28s ease both; }
    .breadcrumb { position:absolute; bottom:22px; left:5%; z-index:2; display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:rgba(255,255,255,.42); }
    .breadcrumb a { color:rgba(255,255,255,.42); text-decoration:none; }
    .breadcrumb a:hover { color:var(--sky-light); }
    .breadcrumb .sep { color:rgba(255,255,255,.2); }
    @keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }
    footer { background:#070d20; color:rgba(255,255,255,.65); padding:56px 5% 26px; }
    .footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:1.75rem; }
    .footer-brand-lockup { display:flex; align-items:center; gap:1rem; margin-bottom:.9rem; text-decoration:none; }
    .footer-brand-mark {
      width:54px; height:54px; flex-shrink:0;
      border-radius:16px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
      border:1px solid rgba(255,255,255,.08);
    }
    .footer-brand-mark img { width:38px; height:38px; display:block; }
    .footer-brand-copy { display:flex; flex-direction:column; gap:.25rem; }
    .footer-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:1.95rem; line-height:.9;
      letter-spacing:-.06em; color:#fff;
    }
    .footer-brand-name em { font-style:normal; color:var(--sky-light); }
    .footer-brand-tag {
      font-size:.56rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:rgba(255,255,255,.4);
    }
    .footer-brand p { font-size:.85rem; line-height:1.8; color:rgba(255,255,255,.42); }
    .footer-cnpj { font-size:.7rem; color:rgba(255,255,255,.22); margin-top:.65rem; }
    .footer-col h4 { font-family:var(--font-head); font-weight:700; font-size:.75rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin-bottom:1rem; }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.5rem; }
    .footer-col ul a { color:rgba(255,255,255,.42); text-decoration:none; font-size:.85rem; transition:color .2s; }
    .footer-col ul a:hover { color:var(--sky-light); }
    .footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.25); flex-wrap:wrap; gap:.75rem; }
    .socials { display:flex; gap:.5rem; }
    .social-btn { width:32px; height:32px; border-radius:7px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.45); text-decoration:none; font-size:.8rem; font-weight:700; transition:background .2s,color .2s; }
    .social-btn:hover { background:var(--blue-mid); color:#fff; }
    .reveal { opacity:0; transform:translateY(26px); transition:opacity .6s ease,transform .6s ease; }
    .reveal.on { opacity:1; transform:none; }
    @media(max-width:1024px){ .footer-grid{grid-template-columns:1fr 1fr;} }
    @media(max-width:768px){
      .nav-links{display:none;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:rgba(7,13,32,.97);padding:1.4rem 5%;gap:1rem;border-bottom:1px solid rgba(255,255,255,.07);}
      .nav-links.open{display:flex;} .hamburger{display:flex;}
      .footer-grid{grid-template-columns:1fr 1fr;} section{padding:64px 5%;}
    }
    @media(max-width:480px){ .footer-grid{grid-template-columns:1fr;} }


    /* ── PROPOSTA PRINCIPAL ── */
    #proposta-main { background:var(--white); }
    .proposta-layout {
      display:grid; grid-template-columns:1fr 1.4fr;
      gap:5rem; align-items:start;
      max-width:1140px; margin:0 auto;
    }

    /* Coluna esquerda — benefícios */
    .prop-beneficios .section-sub { max-width:100%; margin-bottom:2rem; }

    .beneficio-list { display:flex; flex-direction:column; gap:1.1rem; margin-bottom:2.5rem; }
    .beneficio-item {
      display:flex; gap:1rem; align-items:flex-start;
      padding:1.1rem 1.2rem;
      background:var(--off); border:1px solid var(--border);
      border-radius:14px; transition:border-color .2s,transform .2s;
    }
    .beneficio-item:hover { border-color:rgba(36,114,200,.3); transform:translateX(4px); }
    .beneficio-icon {
      width:44px; height:44px; border-radius:11px; flex-shrink:0;
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      display:flex; align-items:center; justify-content:center; font-size:1.2rem;
    }
    .beneficio-body h4 { font-family:var(--font-head); font-weight:700; font-size:.95rem; color:var(--navy); margin-bottom:.25rem; }
    .beneficio-body p { font-size:.85rem; line-height:1.65; color:var(--text-mid); }

    .prop-destaques {
      display:grid; grid-template-columns:1fr 1fr; gap:1rem;
    }
    .prop-destaque {
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      border-radius:14px; padding:1.25rem; text-align:center;
    }
    .prop-destaque .d-num { font-family:var(--font-head); font-weight:900; font-size:2rem; color:#fff; line-height:1; }
    .prop-destaque .d-num em { font-style:normal; color:var(--accent); }
    .prop-destaque .d-lbl { font-size:.72rem; color:rgba(255,255,255,.6); margin-top:.3rem; text-transform:uppercase; letter-spacing:.07em; }

    /* Coluna direita — formulário */
    .prop-form-card {
      background:var(--off); border:1px solid var(--border);
      border-radius:22px; padding:2.5rem;
      position:sticky; top:90px;
    }
    .prop-form-card h3 { font-family:var(--font-head); font-weight:800; font-size:1.25rem; color:var(--navy); margin-bottom:.35rem; }
    .prop-form-card .form-sub { font-size:.88rem; color:var(--text-mid); margin-bottom:1.75rem; padding-bottom:1.5rem; border-bottom:1px solid var(--border); }

    .form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
    .form-group { display:flex; flex-direction:column; gap:.38rem; margin-bottom:.9rem; }
    .form-group.full { grid-column:1/-1; }
    .form-group label { font-size:.72rem; font-weight:700; color:var(--text-mid); letter-spacing:.05em; text-transform:uppercase; }
    .form-group input,
    .form-group textarea,
    .form-group select {
      padding:.72rem 1rem; border:1.5px solid var(--border);
      border-radius:8px; font-size:.92rem; font-family:var(--font-body);
      color:var(--navy); background:var(--white); outline:none;
      transition:border-color .2s,box-shadow .2s;
    }
    .form-group input:focus,
    .form-group textarea:focus,
    .form-group select:focus { border-color:var(--blue-mid); box-shadow:0 0 0 3px rgba(36,114,200,.1); }
    .form-group textarea { resize:vertical; min-height:100px; }

    /* checkboxes de serviços */
    .check-grid { display:grid; grid-template-columns:1fr 1fr; gap:.6rem; }
    .check-item {
      display:flex; align-items:center; gap:.6rem;
      padding:.6rem .8rem; border:1.5px solid var(--border);
      border-radius:8px; cursor:pointer;
      transition:border-color .2s,background .2s;
      font-size:.85rem; color:var(--text-mid); font-weight:500;
    }
    .check-item:hover { border-color:var(--blue-mid); background:rgba(36,114,200,.04); }
    .check-item input[type=checkbox] { accent-color:var(--blue-mid); width:15px; height:15px; }
    .check-item.checked { border-color:var(--blue-mid); background:rgba(36,114,200,.06); color:var(--navy); }

    .form-submit {
      width:100%; background:var(--blue-mid); color:#fff;
      padding:.95rem; border:none; border-radius:8px;
      font-family:var(--font-head); font-weight:700; font-size:.95rem;
      cursor:pointer; letter-spacing:.03em;
      transition:background .2s,transform .15s; margin-top:.75rem;
    }
    .form-submit:hover { background:var(--navy); transform:translateY(-1px); }
    .form-note { font-size:.75rem; color:var(--text-light); text-align:center; margin-top:.75rem; }

    .form-success { display:none; text-align:center; padding:2.5rem 1rem; }
    .form-success .big-check { font-size:3.5rem; margin-bottom:1rem; }
    .form-success h4 { font-family:var(--font-head); font-weight:800; font-size:1.3rem; color:var(--navy); margin-bottom:.6rem; }
    .form-success p { color:var(--text-mid); line-height:1.7; margin-bottom:1.5rem; }

    /* ── PLANOS / MODALIDADES ── */
    #planos { background:var(--off); }
    .planos-inner { max-width:1140px; margin:0 auto; }
    .planos-grid {
      display:grid; grid-template-columns:repeat(3,1fr);
      gap:1.4rem; margin-top:3rem;
    }
    .plano-card {
      border-radius:20px; padding:2.1rem; position:relative;
      transition:transform .22s,box-shadow .22s;
    }
    .plano-card:hover { transform:translateY(-6px); box-shadow:0 24px 52px rgba(19,32,68,.14); }
    .plano-card.base { background:var(--white); border:1px solid var(--border); }
    .plano-card.pro  {
      background:linear-gradient(145deg,var(--navy),#1a4a8a);
      border:1px solid rgba(79,163,224,.2);
    }
    .plano-card.pro::before {
      content:'MAIS POPULAR'; position:absolute; top:-12px; left:50%; transform:translateX(-50%);
      background:var(--accent); color:var(--navy); font-family:var(--font-head);
      font-weight:800; font-size:.65rem; letter-spacing:.12em; padding:.3rem .9rem;
      border-radius:20px;
    }
    .plano-card.enterprise { background:var(--white); border:1px solid var(--border); }
    .plano-tag { font-family:var(--font-head); font-weight:700; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:.75rem; }
    .plano-card.base .plano-tag,
    .plano-card.enterprise .plano-tag { color:var(--blue-mid); }
    .plano-card.pro .plano-tag { color:var(--accent); }
    .plano-card h3 { font-family:var(--font-head); font-weight:800; font-size:1.3rem; margin-bottom:.5rem; }
    .plano-card.base h3,
    .plano-card.enterprise h3 { color:var(--navy); }
    .plano-card.pro h3 { color:#fff; }
    .plano-desc { font-size:.88rem; line-height:1.65; margin-bottom:1.5rem; padding-bottom:1.5rem; border-bottom:1px solid; }
    .plano-card.base .plano-desc,
    .plano-card.enterprise .plano-desc { color:var(--text-mid); border-color:var(--border); }
    .plano-card.pro .plano-desc { color:rgba(255,255,255,.65); border-color:rgba(255,255,255,.12); }
    .plano-features { list-style:none; display:flex; flex-direction:column; gap:.6rem; margin-bottom:1.75rem; }
    .plano-features li { display:flex; align-items:center; gap:.6rem; font-size:.88rem; }
    .plano-card.base .plano-features li,
    .plano-card.enterprise .plano-features li { color:var(--text-mid); }
    .plano-card.pro .plano-features li { color:rgba(255,255,255,.75); }
    .plano-features li::before { content:'✓'; font-weight:700; color:var(--accent); flex-shrink:0; }

    /* ── FAQ ── */
    #faq { background:var(--white); }
    .faq-inner { max-width:800px; margin:0 auto; }
    .faq-list { margin-top:2.5rem; display:flex; flex-direction:column; gap:.75rem; }
    .faq-item {
      border:1px solid var(--border); border-radius:14px; overflow:hidden;
      transition:border-color .2s;
    }
    .faq-item.open { border-color:rgba(36,114,200,.35); }
    .faq-question {
      display:flex; justify-content:space-between; align-items:center;
      padding:1.1rem 1.4rem; cursor:pointer;
      font-family:var(--font-head); font-weight:700; font-size:.95rem; color:var(--navy);
      transition:background .2s;
    }
    .faq-question:hover { background:var(--off); }
    .faq-item.open .faq-question { background:var(--off); color:var(--blue-mid); }
    .faq-chevron { font-size:.75rem; transition:transform .25s; flex-shrink:0; margin-left:1rem; }
    .faq-item.open .faq-chevron { transform:rotate(180deg); }
    .faq-answer {
      max-height:0; overflow:hidden;
      transition:max-height .3s ease, padding .3s ease;
      padding:0 1.4rem;
      font-size:.9rem; line-height:1.75; color:var(--text-mid);
    }
    .faq-item.open .faq-answer { max-height:300px; padding:.2rem 1.4rem 1.2rem; }

    /* RESPONSIVE PROPOSTAS */
    @media(max-width:1024px){ .planos-grid{grid-template-columns:1fr 1fr;} }
    @media(max-width:900px){
      .proposta-layout{grid-template-columns:1fr; gap:2.5rem;}
      .prop-form-card{position:static;}
    }
    @media(max-width:768px){
      .nav-brand { gap:10px; }
      .nav-brand-mark { width:40px; height:40px; border-radius:12px; }
      .nav-brand-mark img { width:28px; height:28px; }
      .nav-brand-name { font-size:1.28rem; }
      .nav-brand-tag { display:none; }
      .nav-links { display:none; flex-direction:column; position:absolute; top:72px; left:0; right:0; background:rgba(7,13,32,.97); padding:1.5rem 5%; gap:1.1rem; border-bottom:1px solid rgba(255,255,255,.07); }
      .nav-links.open { display:flex; }
      .hamburger { display:flex; }
      .page-hero-content { padding-top:118px; }
      .hero-brand-card { width:100%; padding:.82rem .95rem; gap:.8rem; }
      .hero-brand-mark { width:52px; height:52px; border-radius:16px; }
      .hero-brand-mark img { width:40px; height:40px; }
      .hero-brand-name { font-size:1.45rem; }
      .hero-brand-tag { font-size:.58rem; letter-spacing:.14em; }
      .footer-grid { grid-template-columns:1fr 1fr; }
      section { padding:70px 5%; }
    }
    @media(max-width:640px){
      .nav-brand-name { font-size:1.05rem; }
      .hero-brand-name { font-size:1.3rem; }
      .planos-grid{grid-template-columns:1fr;}
      .form-row{grid-template-columns:1fr;}
      .check-grid{grid-template-columns:1fr;}
      .prop-destaques{grid-template-columns:1fr 1fr;}
      .footer-grid { grid-template-columns:1fr; }
    }

/* Extracted CSS Block */
.wa-float {
  position:fixed; bottom:28px; right:28px; z-index:998;
  width:58px; height:58px; border-radius:50%;
  background:#25d366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,.45);
  transition:transform .2s, box-shadow .2s;
  text-decoration:none;
}
.wa-float:hover { transform:scale(1.1) translateY(-2px); box-shadow:0 10px 32px rgba(37,211,102,.55); }
@keyframes wa-ping {
  0%  { box-shadow:0 0 0 0 rgba(37,211,102,.5); }
  70% { box-shadow:0 0 0 14px rgba(37,211,102,0); }
  100%{ box-shadow:0 0 0 0 rgba(37,211,102,0); }
}
.wa-float { animation: wa-ping 2.5s ease infinite; }
.wa-float:hover { animation:none; }

/* Extracted CSS Block */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    :root {
      --navy:#132044; --blue:#1a5daa; --blue-mid:#2472c8;
      --sky:#4fa3e0; --sky-light:#a8d8f5; --accent:#00c8f0;
      --white:#ffffff; --off:#f2f6fc; --border:#dde6f5;
      --text-dark:#0d1b35; --text-mid:#3a5270; --text-light:#6b85a8;
      --font-head:'Montserrat',sans-serif; --font-body:'Inter',sans-serif;
    }
    body { font-family:var(--font-body); color:var(--text-dark); background:var(--white); overflow-x:hidden; }

    /* NAVBAR */
    #navbar {
      position:fixed; top:0; left:0; right:0; z-index:999;
      height:72px; display:flex; align-items:center; justify-content:space-between;
      padding:0 5%; background:rgba(10,18,44,.88); backdrop-filter:blur(18px);
      border-bottom:1px solid rgba(255,255,255,.07); transition:background .3s;
    }
    #navbar.scrolled { background:rgba(10,18,44,.97); }
    .nav-brand { display:flex; align-items:center; gap:14px; text-decoration:none; }
    .nav-brand-mark {
      width:46px; height:46px; flex-shrink:0;
      border-radius:14px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.03));
      border:1px solid rgba(255,255,255,.14);
      box-shadow:0 10px 26px rgba(5,11,27,.22);
      backdrop-filter:blur(10px);
    }
    .nav-brand-mark img { width:32px; height:32px; display:block; }
    .nav-brand-copy { display:flex; flex-direction:column; gap:3px; }
    .nav-brand-name {
      font-family:var(--font-head); font-size:1.55rem; font-weight:900;
      line-height:.88; letter-spacing:-.06em; color:#fff;
    }
    .nav-brand-name em { font-style:normal; color:var(--sky-light); }
    .nav-brand-tag {
      font-size:.48rem; font-weight:700;
      letter-spacing:.2em; text-transform:uppercase;
      color:rgba(255,255,255,.58);
    }
    .nav-links { display:flex; align-items:center; gap:1.6rem; list-style:none; }
    .nav-links a { color:rgba(255,255,255,.78); text-decoration:none; font-size:.875rem; font-weight:500; letter-spacing:.02em; transition:color .2s; }
    .nav-links a:hover, .nav-links a.active { color:var(--sky-light); }
    .nav-links .btn-nav { background:var(--blue-mid); color:#fff!important; padding:.48rem 1.2rem; border-radius:7px; font-weight:700!important; }
    .nav-links .btn-nav:hover { background:var(--sky)!important; }
    .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
    .hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; }

    /* COMMONS */
    section { padding:88px 5%; }
    .section-label { font-size:.7rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue-mid); margin-bottom:.6rem; }
    .section-title { font-family:var(--font-head); font-weight:800; font-size:clamp(1.7rem,3.5vw,2.5rem); line-height:1.15; color:var(--navy); margin-bottom:.9rem; }
    .section-sub { font-size:1rem; line-height:1.8; color:var(--text-mid); max-width:580px; }
    .center { text-align:center; } .center .section-sub { margin:0 auto; }
    .btn-primary { background:var(--blue-mid); color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-family:var(--font-head); font-weight:700; font-size:.92rem; letter-spacing:.03em; transition:background .2s,transform .15s; display:inline-block; }
    .btn-primary:hover { background:var(--sky); transform:translateY(-2px); }
    .btn-ghost { background:transparent; color:var(--navy); padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid var(--border); transition:border-color .2s,background .2s,transform .15s; display:inline-block; }
    .btn-ghost:hover { border-color:var(--blue-mid); background:rgba(36,114,200,.06); transform:translateY(-2px); }
    .btn-ghost-white { background:transparent; color:#fff; padding:.85rem 2rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.92rem; border:1.5px solid rgba(255,255,255,.38); transition:border-color .2s,background .2s,transform .15s; display:inline-block; }
    .btn-ghost-white:hover { border-color:var(--sky-light); background:rgba(255,255,255,.08); transform:translateY(-2px); }

    /* PAGE HERO */
    .page-hero { position:relative; min-height:420px; display:flex; align-items:center; overflow:hidden; }
    .page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center 30%; background-color:#0a1432; animation:subtle-zoom 18s ease-in-out infinite alternate; }
    @keyframes subtle-zoom { from{transform:scale(1.04)} to{transform:scale(1)} }
    .page-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(10,18,50,.92) 0%,rgba(10,18,50,.58) 60%,rgba(10,18,50,.25) 100%); }
    .page-hero-grid { position:absolute; inset:0; z-index:1; pointer-events:none; background-image:linear-gradient(rgba(79,163,224,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.06) 1px,transparent 1px); background-size:55px 55px; animation:grid-move 22s linear infinite; }
    @keyframes grid-move { 0%{background-position:0 0} 100%{background-position:55px 55px} }
    .page-hero-content { position:relative; z-index:2; padding:118px 5% 72px; max-width:760px; }
    .hero-brand-card {
      position:relative;
      display:inline-flex; align-items:center; gap:1rem;
      width:fit-content; max-width:100%;
      padding:.9rem 1.05rem;
      margin-bottom:1.15rem;
      border-radius:22px;
      background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(232,244,255,.92));
      border:1px solid rgba(168,216,245,.5);
      box-shadow:0 20px 52px rgba(8,17,40,.28);
      animation:fadeUp .6s ease both;
    }
    .hero-brand-mark {
      width:62px; height:62px; flex-shrink:0;
      border-radius:18px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(180deg,#ffffff 0%,#eff6ff 100%);
      box-shadow:inset 0 0 0 1px rgba(19,32,68,.06);
    }
    .hero-brand-mark img { width:46px; height:46px; display:block; }
    .hero-brand-copy { display:flex; flex-direction:column; gap:.22rem; min-width:0; }
    .hero-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:clamp(1.55rem,3.5vw,2.2rem);
      line-height:.92; letter-spacing:-.07em; color:var(--navy);
    }
    .hero-brand-name em { font-style:normal; color:var(--blue-mid); }
    .hero-brand-tag {
      font-size:.68rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:var(--blue);
    }
    .eyebrow { display:inline-flex; align-items:center; gap:8px; background:rgba(79,163,224,.15); border:1px solid rgba(79,163,224,.35); border-radius:50px; padding:.32rem .95rem; margin-bottom:1.1rem; animation:fadeUp .6s .05s ease both; }
    .eyebrow span { font-size:.68rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--sky-light); }
    .page-hero-content h1 { font-family:var(--font-head); font-weight:900; font-size:clamp(2rem,5vw,3.1rem); line-height:1.1; color:#fff; margin-bottom:1rem; animation:fadeUp .6s .15s ease both; }
    .page-hero-content h1 em { font-style:normal; color:var(--accent); }
    .page-hero-content p { font-size:1rem; line-height:1.8; color:rgba(255,255,255,.7); max-width:520px; animation:fadeUp .6s .28s ease both; }
    .breadcrumb { position:absolute; bottom:22px; left:5%; z-index:2; display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:rgba(255,255,255,.42); }
    .breadcrumb a { color:rgba(255,255,255,.42); text-decoration:none; transition:color .2s; }
    .breadcrumb a:hover { color:var(--sky-light); }
    .breadcrumb .sep { color:rgba(255,255,255,.2); }
    @keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }

    /* CTA BAND */
    .cta-band { background:linear-gradient(135deg,var(--navy),#0e2659); padding:72px 5%; text-align:center; position:relative; overflow:hidden; }
    .cta-band::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(79,163,224,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.05) 1px,transparent 1px); background-size:52px 52px; }
    .cta-band-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; }
    .cta-band .section-label { color:var(--sky-light); }
    .cta-band h2 { font-family:var(--font-head); font-weight:900; font-size:clamp(1.6rem,3.5vw,2.3rem); color:#fff; margin-bottom:.85rem; line-height:1.2; }
    .cta-band p { color:rgba(255,255,255,.65); font-size:1rem; line-height:1.75; margin-bottom:2rem; }
    .cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

    /* FOOTER */
    footer { background:#070d20; color:rgba(255,255,255,.65); padding:56px 5% 26px; }
    .footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:1.75rem; }
    .footer-brand-lockup { display:flex; align-items:center; gap:1rem; margin-bottom:.9rem; text-decoration:none; }
    .footer-brand-mark {
      width:54px; height:54px; flex-shrink:0;
      border-radius:16px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
      border:1px solid rgba(255,255,255,.08);
    }
    .footer-brand-mark img { width:38px; height:38px; display:block; }
    .footer-brand-copy { display:flex; flex-direction:column; gap:.25rem; }
    .footer-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:1.95rem; line-height:.9;
      letter-spacing:-.06em; color:#fff;
    }
    .footer-brand-name em { font-style:normal; color:var(--sky-light); }
    .footer-brand-tag {
      font-size:.56rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:rgba(255,255,255,.4);
    }
    .footer-brand p { font-size:.85rem; line-height:1.8; color:rgba(255,255,255,.42); }
    .footer-cnpj { font-size:.7rem; color:rgba(255,255,255,.22); margin-top:.65rem; }
    .footer-col h4 { font-family:var(--font-head); font-weight:700; font-size:.75rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin-bottom:1rem; }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.5rem; }
    .footer-col ul a { color:rgba(255,255,255,.42); text-decoration:none; font-size:.85rem; transition:color .2s; }
    .footer-col ul a:hover { color:var(--sky-light); }
    .footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.25); flex-wrap:wrap; gap:.75rem; }
    .socials { display:flex; gap:.5rem; }
    .social-btn { width:32px; height:32px; border-radius:7px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.45); text-decoration:none; font-size:.8rem; font-weight:700; transition:background .2s,color .2s; }
    .social-btn:hover { background:var(--blue-mid); color:#fff; }

    /* REVEAL */
    .reveal { opacity:0; transform:translateY(26px); transition:opacity .6s ease,transform .6s ease; }
    .reveal.on { opacity:1; transform:none; }

    /* RESPONSIVE */
    @media(max-width:1024px){ .footer-grid{grid-template-columns:1fr 1fr;} }
    @media(max-width:768px){
      .nav-links{display:none;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:rgba(7,13,32,.97);padding:1.4rem 5%;gap:1rem;border-bottom:1px solid rgba(255,255,255,.07);}
      .nav-links.open{display:flex;} .hamburger{display:flex;}
      .footer-grid{grid-template-columns:1fr 1fr;} section{padding:64px 5%;}
    }
    @media(max-width:480px){ .footer-grid{grid-template-columns:1fr;} }


    /* ── CARDS PRINCIPAIS ── */
    .service-block { background:var(--white); }
    .service-block:nth-child(even) { background:var(--off); }

    .svc-row {
      display:grid; grid-template-columns:1fr 1fr;
      gap:5rem; align-items:center;
      max-width:1140px; margin:0 auto;
    }
    .svc-row.reverse { direction:rtl; }
    .svc-row.reverse > * { direction:ltr; }

    .svc-img-wrap { position:relative; }
    .svc-img {
      width:100%; border-radius:18px; aspect-ratio:4/3;
      object-fit:cover; display:block;
      box-shadow:0 20px 52px rgba(19,32,68,.15);
    }
    .svc-badge {
      position:absolute; top:-16px; right:-16px;
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      border-radius:14px; padding:.9rem 1.2rem; text-align:center;
      box-shadow:0 8px 24px rgba(19,32,68,.28);
    }
    .svc-badge-icon { font-size:1.6rem; line-height:1; }
    .svc-badge-lbl { font-size:.65rem; color:rgba(255,255,255,.7); margin-top:4px; text-transform:uppercase; letter-spacing:.08em; }

    .svc-text .section-sub { max-width:100%; margin-bottom:1.1rem; }
    .svc-text p+p { margin-top:.85rem; }

    .svc-bullets { display:flex; flex-direction:column; gap:.6rem; margin:1.4rem 0 1.8rem; }
    .svc-bullet {
      display:flex; align-items:flex-start; gap:.75rem;
      font-size:.9rem; color:var(--text-mid); line-height:1.6;
    }
    .svc-bullet-dot {
      width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:6px;
      background:linear-gradient(135deg,var(--blue-mid),var(--sky));
    }

    /* ── GRID DE RECURSOS ── */
    #recursos { background:linear-gradient(135deg,var(--navy),#0e2659); position:relative; overflow:hidden; }
    #recursos::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(79,163,224,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.04) 1px,transparent 1px); background-size:50px 50px; pointer-events:none; }
    .recursos-inner { position:relative; z-index:1; max-width:1140px; margin:0 auto; }
    .recursos-inner .center .section-label { color:var(--sky-light); }
    .recursos-inner .center .section-title { color:#fff; }
    .recursos-inner .center .section-sub { color:rgba(255,255,255,.6); margin:0 auto 3rem; }

    .recursos-grid {
      display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem;
    }
    .recurso-card {
      background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
      border-radius:16px; padding:1.75rem;
      transition:background .25s,border-color .25s,transform .22s;
    }
    .recurso-card:hover { background:rgba(255,255,255,.1); border-color:rgba(79,163,224,.3); transform:translateY(-4px); }
    .recurso-icon { font-size:1.75rem; margin-bottom:.9rem; }
    .recurso-card h3 { font-family:var(--font-head); font-weight:700; font-size:1rem; color:#fff; margin-bottom:.55rem; }
    .recurso-card p { font-size:.85rem; line-height:1.7; color:rgba(255,255,255,.58); }

    /* ── PROCESSO ── */
    #processo { background:var(--off); }
    .processo-inner { max-width:1140px; margin:0 auto; }
    .steps { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; margin-top:3rem; position:relative; }
    .steps::before {
      content:''; position:absolute; top:32px; left:10%; right:10%; height:2px;
      background:linear-gradient(90deg,var(--blue-mid),var(--sky),var(--blue-mid));
      z-index:0;
    }
    .step { position:relative; z-index:1; text-align:center; padding:0 .5rem; }
    .step-num {
      width:64px; height:64px; border-radius:50%; margin:0 auto 1.1rem;
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      display:flex; align-items:center; justify-content:center;
      font-family:var(--font-head); font-weight:900; font-size:1.2rem; color:#fff;
      box-shadow:0 6px 20px rgba(36,114,200,.35);
    }
    .step h3 { font-family:var(--font-head); font-weight:700; font-size:.95rem; color:var(--navy); margin-bottom:.5rem; }
    .step p { font-size:.83rem; line-height:1.65; color:var(--text-mid); }

    /* RESPONSIVE SERVICOS */
    @media(max-width:900px){
      .svc-row,.svc-row.reverse { grid-template-columns:1fr; gap:2.5rem; direction:ltr; }
      .svc-badge { top:-12px; right:0; }
      .recursos-grid { grid-template-columns:1fr 1fr; }
      .steps { grid-template-columns:1fr 1fr; }
      .steps::before { display:none; }
    }
    @media(max-width:768px){
      .nav-brand { gap:10px; }
      .nav-brand-mark { width:40px; height:40px; border-radius:12px; }
      .nav-brand-mark img { width:28px; height:28px; }
      .nav-brand-name { font-size:1.28rem; }
      .nav-brand-tag { display:none; }
      .nav-links { display:none; flex-direction:column; position:absolute; top:72px; left:0; right:0; background:rgba(7,13,32,.97); padding:1.5rem 5%; gap:1.1rem; border-bottom:1px solid rgba(255,255,255,.07); }
      .nav-links.open { display:flex; }
      .hamburger { display:flex; }
      .page-hero-content { padding-top:118px; }
      .hero-brand-card { width:100%; padding:.82rem .95rem; gap:.8rem; }
      .hero-brand-mark { width:52px; height:52px; border-radius:16px; }
      .hero-brand-mark img { width:40px; height:40px; }
      .hero-brand-name { font-size:1.45rem; }
      .hero-brand-tag { font-size:.58rem; letter-spacing:.14em; }
      .footer-grid { grid-template-columns:1fr 1fr; }
      section { padding:70px 5%; }
    }
    @media(max-width:540px){
      .nav-brand-name { font-size:1.05rem; }
      .hero-brand-name { font-size:1.3rem; }
      .recursos-grid { grid-template-columns:1fr; }
      .steps { grid-template-columns:1fr; }
      .footer-grid { grid-template-columns:1fr; }
    }

/* Extracted CSS Block */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    :root {
      --navy:#132044; --blue:#1a5daa; --blue-mid:#2472c8;
      --sky:#4fa3e0; --sky-light:#a8d8f5; --accent:#00c8f0;
      --white:#ffffff; --off:#f2f6fc; --border:#dde6f5;
      --text-dark:#0d1b35; --text-mid:#3a5270; --text-light:#6b85a8;
      --font-head:'Montserrat',sans-serif; --font-body:'Inter',sans-serif;
    }
    body { font-family:var(--font-body); color:var(--text-dark); background:var(--white); overflow-x:hidden; }

    /* ── NAVBAR ── */
    #navbar {
      position:fixed; top:0; left:0; right:0; z-index:999;
      height:72px; display:flex; align-items:center; justify-content:space-between;
      padding:0 5%; background:rgba(10,18,44,.88); backdrop-filter:blur(18px);
      border-bottom:1px solid rgba(255,255,255,.07); transition:background .3s;
    }
    #navbar.scrolled { background:rgba(10,18,44,.97); }
    .nav-brand { display:flex; align-items:center; gap:14px; text-decoration:none; }
    .nav-brand-mark {
      width:46px; height:46px; flex-shrink:0;
      border-radius:14px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.03));
      border:1px solid rgba(255,255,255,.14);
      box-shadow:0 10px 26px rgba(5,11,27,.22);
      backdrop-filter:blur(10px);
    }
    .nav-brand-mark img { width:32px; height:32px; display:block; }
    .nav-brand-copy { display:flex; flex-direction:column; gap:3px; }
    .nav-brand-name {
      font-family:var(--font-head); font-size:1.55rem; font-weight:900;
      line-height:.88; letter-spacing:-.06em; color:#fff;
    }
    .nav-brand-name em { font-style:normal; color:var(--sky-light); }
    .nav-brand-tag {
      font-size:.48rem; font-weight:700;
      letter-spacing:.2em; text-transform:uppercase;
      color:rgba(255,255,255,.58);
    }
    .nav-links { display:flex; align-items:center; gap:1.75rem; list-style:none; }
    .nav-links a { color:rgba(255,255,255,.78); text-decoration:none; font-size:.875rem; font-weight:500; letter-spacing:.025em; transition:color .2s; }
    .nav-links a:hover { color:var(--sky-light); }
    .nav-links .btn-nav { background:var(--blue-mid); color:#fff!important; padding:.5rem 1.25rem; border-radius:7px; font-weight:700!important; transition:background .2s!important; }
    .nav-links .btn-nav:hover { background:var(--sky)!important; }
    .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
    .hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; transition:.3s; }

    /* ── PAGE HERO ── */
    .page-hero { position:relative; min-height:480px; display:flex; align-items:center; overflow:hidden; }
    .page-hero-bg {
      position:absolute; inset:0;
      background-image:url('../img/c-5.png');
      background-color:#0a1432;
      background-size:cover; background-position:center 25%;
      animation:subtle-zoom 18s ease-in-out infinite alternate;
    }
    @keyframes subtle-zoom { from{transform:scale(1.04)} to{transform:scale(1)} }
    .page-hero-bg::after {
      content:''; position:absolute; inset:0;
      background:linear-gradient(90deg,rgba(10,18,50,.92) 0%,rgba(10,18,50,.58) 60%,rgba(10,18,50,.28) 100%);
    }
    .page-hero-grid {
      position:absolute; inset:0; z-index:1; pointer-events:none;
      background-image:linear-gradient(rgba(79,163,224,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.06) 1px,transparent 1px);
      background-size:55px 55px; animation:grid-move 22s linear infinite;
    }
    @keyframes grid-move { 0%{background-position:0 0} 100%{background-position:55px 55px} }
    .page-hero-content { position:relative; z-index:2; padding:130px 5% 90px; max-width:760px; }
    .hero-brand-card {
      position:relative;
      display:inline-flex; align-items:center; gap:1rem;
      width:fit-content; max-width:100%;
      padding:.9rem 1.05rem;
      margin-bottom:1.2rem;
      border-radius:22px;
      background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(232,244,255,.92));
      border:1px solid rgba(168,216,245,.5);
      box-shadow:0 20px 52px rgba(8,17,40,.28);
      animation:fadeUp .7s ease both;
    }
    .hero-brand-mark {
      width:62px; height:62px; flex-shrink:0;
      border-radius:18px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(180deg,#ffffff 0%,#eff6ff 100%);
      box-shadow:inset 0 0 0 1px rgba(19,32,68,.06);
    }
    .hero-brand-mark img { width:46px; height:46px; display:block; }
    .hero-brand-copy { display:flex; flex-direction:column; gap:.22rem; min-width:0; }
    .hero-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:clamp(1.55rem,3.5vw,2.2rem);
      line-height:.92; letter-spacing:-.07em; color:var(--navy);
    }
    .hero-brand-name em { font-style:normal; color:var(--blue-mid); }
    .hero-brand-tag {
      font-size:.68rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:var(--blue);
    }
    .eyebrow {
      display:inline-flex; align-items:center; gap:8px;
      background:rgba(79,163,224,.15); border:1px solid rgba(79,163,224,.35);
      border-radius:50px; padding:.35rem 1rem; margin-bottom:1.25rem;
      animation:fadeUp .7s .05s ease both;
    }
    .eyebrow span { font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--sky-light); }
    .page-hero-content h1 {
      font-family:var(--font-head); font-weight:900;
      font-size:clamp(2.1rem,5vw,3.3rem); line-height:1.1;
      color:#fff; margin-bottom:1.1rem; animation:fadeUp .7s .15s ease both;
    }
    .page-hero-content h1 em { font-style:normal; color:var(--accent); }
    .page-hero-content p { font-size:1.05rem; line-height:1.8; color:rgba(255,255,255,.72); max-width:540px; animation:fadeUp .7s .28s ease both; }
    .breadcrumb {
      position:absolute; bottom:26px; left:5%; z-index:2;
      display:flex; align-items:center; gap:.5rem; font-size:.78rem; color:rgba(255,255,255,.45);
    }
    .breadcrumb a { color:rgba(255,255,255,.45); text-decoration:none; transition:color .2s; }
    .breadcrumb a:hover { color:var(--sky-light); }
    .breadcrumb .sep { color:rgba(255,255,255,.22); }
    @keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }

    /* ── COMMONS ── */
    section { padding:96px 5%; }
    .section-label { font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue-mid); margin-bottom:.65rem; }
    .section-title { font-family:var(--font-head); font-weight:800; font-size:clamp(1.75rem,3.5vw,2.6rem); line-height:1.15; color:var(--navy); margin-bottom:1rem; }
    .section-sub { font-size:1.05rem; line-height:1.8; color:var(--text-mid); max-width:580px; }
    .center { text-align:center; } .center .section-sub { margin:0 auto; }
    .btn-primary { background:var(--blue-mid); color:#fff; padding:.9rem 2.1rem; border-radius:8px; text-decoration:none; font-family:var(--font-head); font-weight:700; font-size:.95rem; letter-spacing:.03em; transition:background .2s,transform .15s; display:inline-block; }
    .btn-primary:hover { background:var(--sky); transform:translateY(-2px); }
    .btn-ghost { background:transparent; color:var(--navy); padding:.9rem 2.1rem; border-radius:8px; text-decoration:none; font-weight:600; font-size:.95rem; border:1.5px solid var(--border); transition:border-color .2s,background .2s,transform .15s; display:inline-block; }
    .btn-ghost:hover { border-color:var(--blue-mid); background:rgba(36,114,200,.06); transform:translateY(-2px); }

    /* ── HISTÓRIA ── */
    #historia { background:var(--white); }
    .historia-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; max-width:1200px; margin:0 auto; }
    .historia-img-wrap { position:relative; }
    .historia-img { width:100%; border-radius:20px; aspect-ratio:4/3; object-fit:cover; object-position:center; box-shadow:0 24px 60px rgba(19,32,68,.18); display:block; }
    .historia-float {
      position:absolute; bottom:-22px; left:-18px;
      background:linear-gradient(135deg,var(--navy),var(--blue-mid));
      border-radius:16px; padding:1.3rem 1.6rem;
      box-shadow:0 16px 40px rgba(19,32,68,.28); min-width:170px;
    }
    .historia-float .year { font-family:var(--font-head); font-weight:900; font-size:2.4rem; color:#fff; line-height:1; }
    .historia-float .year-lbl { font-size:.72rem; color:rgba(255,255,255,.65); margin-top:4px; letter-spacing:.06em; text-transform:uppercase; }
    .historia-text .section-sub { max-width:100%; margin-bottom:1.1rem; }
    .historia-text p+p { margin-top:.9rem; }
    .historia-text blockquote { margin:1.5rem 0; padding:1.1rem 1.4rem; border-left:4px solid var(--blue-mid); background:var(--off); border-radius:0 12px 12px 0; font-style:italic; color:var(--text-mid); font-size:.95rem; line-height:1.7; }

    /* ── MVV ── */
    #mvv { background:linear-gradient(135deg,var(--navy) 0%,#0e2659 100%); position:relative; overflow:hidden; }
    #mvv::before { content:''; position:absolute; inset:0; pointer-events:none; background-image:linear-gradient(rgba(79,163,224,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.04) 1px,transparent 1px); background-size:50px 50px; }
    .mvv-inner { position:relative; z-index:1; max-width:1200px; margin:0 auto; }
    .mvv-inner .center .section-label { color:var(--sky-light); }
    .mvv-inner .center .section-title { color:#fff; }
    .mvv-inner .center .section-sub { color:rgba(255,255,255,.62); margin:0 auto 3.5rem; }
    .mvv-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-bottom:3rem; }
    .mvv-card { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:2.1rem; transition:background .25s,border-color .25s,transform .25s; }
    .mvv-card:hover { background:rgba(255,255,255,.1); border-color:rgba(79,163,224,.3); transform:translateY(-5px); }
    .mvv-tag { font-family:var(--font-head); font-weight:800; font-size:.7rem; letter-spacing:.15em; text-transform:uppercase; color:var(--accent); margin-bottom:.75rem; }
    .mvv-card h3 { font-family:var(--font-head); font-weight:700; font-size:1.15rem; color:#fff; margin-bottom:.75rem; }
    .mvv-card p { font-size:.9rem; line-height:1.72; color:rgba(255,255,255,.62); }
    .valores-titulo { font-family:var(--font-head); font-weight:700; font-size:1rem; color:var(--sky-light); text-transform:uppercase; letter-spacing:.1em; margin-bottom:1.5rem; text-align:center; }
    .valores-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:1.2rem; }
    .valor-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:1.5rem; transition:background .2s,border-color .2s,transform .2s; }
    .valor-card:hover { background:rgba(255,255,255,.09); border-color:rgba(79,163,224,.25); transform:translateY(-3px); }
    .valor-card h4 { font-family:var(--font-head); font-weight:700; font-size:.95rem; color:var(--sky-light); margin-bottom:.5rem; }
    .valor-card p { font-size:.83rem; line-height:1.65; color:rgba(255,255,255,.52); }

    /* ── COMPROMISSO ── */
    #compromisso { background:var(--off); }
    .comp-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:5rem; align-items:center; max-width:1200px; margin:0 auto; }
    .comp-text .section-sub { max-width:100%; margin-bottom:1.1rem; }
    .comp-text p+p { margin-top:.9rem; }
    .comp-quote { margin:1.75rem 0; padding:1.25rem 1.5rem; border-left:4px solid var(--accent); background:var(--white); border-radius:0 12px 12px 0; font-family:var(--font-head); font-weight:700; font-size:1rem; color:var(--navy); line-height:1.55; }
    .comp-btns { display:flex; gap:1rem; flex-wrap:wrap; margin-top:2rem; }
    .comp-img-wrap { position:relative; }
    .comp-img { width:100%; border-radius:20px; aspect-ratio:1; object-fit:cover; object-position:center 35%; box-shadow:0 24px 60px rgba(19,32,68,.16); display:block; }
    .comp-badge { position:absolute; top:-18px; right:-18px; background:var(--blue-mid); border-radius:14px; padding:1rem 1.3rem; text-align:center; box-shadow:0 10px 28px rgba(36,114,200,.4); }
    .comp-badge .b-num { font-family:var(--font-head); font-weight:900; font-size:1.8rem; color:#fff; line-height:1; }
    .comp-badge .b-num em { font-style:normal; color:var(--accent); }
    .comp-badge .b-lbl { font-size:.7rem; color:rgba(255,255,255,.75); margin-top:3px; text-transform:uppercase; letter-spacing:.06em; }

    /* ── CTA BAND ── */
    .cta-band { background:linear-gradient(135deg,var(--navy),#0e2659); padding:80px 5%; text-align:center; position:relative; overflow:hidden; }
    .cta-band::before { content:''; position:absolute; inset:0; pointer-events:none; background-image:linear-gradient(rgba(79,163,224,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(79,163,224,.05) 1px,transparent 1px); background-size:52px 52px; }
    .cta-band-inner { position:relative; z-index:1; max-width:700px; margin:0 auto; }
    .cta-band .section-label { color:var(--sky-light); }
    .cta-band h2 { font-family:var(--font-head); font-weight:900; font-size:clamp(1.7rem,3.5vw,2.4rem); color:#fff; margin-bottom:.9rem; line-height:1.2; }
    .cta-band p { color:rgba(255,255,255,.68); font-size:1.05rem; line-height:1.75; margin-bottom:2.2rem; }

    /* ── FOOTER ── */
    footer { background:#070d20; color:rgba(255,255,255,.65); padding:60px 5% 28px; }
    .footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:2rem; }
    .footer-brand-lockup { display:flex; align-items:center; gap:1rem; margin-bottom:1rem; text-decoration:none; }
    .footer-brand-mark {
      width:54px; height:54px; flex-shrink:0;
      border-radius:16px;
      display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
      border:1px solid rgba(255,255,255,.08);
    }
    .footer-brand-mark img { width:38px; height:38px; display:block; }
    .footer-brand-copy { display:flex; flex-direction:column; gap:.25rem; }
    .footer-brand-name {
      font-family:var(--font-head); font-weight:900;
      font-size:1.95rem; line-height:.9;
      letter-spacing:-.06em; color:#fff;
    }
    .footer-brand-name em { font-style:normal; color:var(--sky-light); }
    .footer-brand-tag {
      font-size:.56rem; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:rgba(255,255,255,.4);
    }
    .footer-brand p { font-size:.875rem; line-height:1.8; color:rgba(255,255,255,.45); }
    .footer-cnpj { font-size:.72rem; color:rgba(255,255,255,.25); margin-top:.75rem; }
    .footer-col h4 { font-family:var(--font-head); font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin-bottom:1.1rem; }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.55rem; }
    .footer-col ul a { color:rgba(255,255,255,.45); text-decoration:none; font-size:.875rem; transition:color .2s; }
    .footer-col ul a:hover { color:var(--sky-light); }
    .footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.78rem; color:rgba(255,255,255,.28); flex-wrap:wrap; gap:.75rem; }
    .socials { display:flex; gap:.6rem; }
    .social-btn { width:34px; height:34px; border-radius:8px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); text-decoration:none; font-size:.85rem; transition:background .2s,color .2s; }
    .social-btn:hover { background:var(--blue-mid); color:#fff; }

    /* ── REVEAL ── */
    .reveal { opacity:0; transform:translateY(28px); transition:opacity .6s ease,transform .6s ease; }
    .reveal.on { opacity:1; transform:none; }

    /* ── RESPONSIVE ── */
    @media(max-width:1024px) { .footer-grid { grid-template-columns:1fr 1fr; } }
    @media(max-width:900px) {
      .historia-grid,.comp-grid { grid-template-columns:1fr; gap:2.5rem; }
      .mvv-cards { grid-template-columns:1fr 1fr; }
      .historia-float { left:0; bottom:-16px; }
      .comp-badge { top:-14px; right:0; }
    }
    @media(max-width:768px) {
      .nav-brand { gap:10px; }
      .nav-brand-mark { width:40px; height:40px; border-radius:12px; }
      .nav-brand-mark img { width:28px; height:28px; }
      .nav-brand-name { font-size:1.28rem; }
      .nav-brand-tag { display:none; }
      .nav-links { display:none; flex-direction:column; position:absolute; top:72px; left:0; right:0; background:rgba(7,13,32,.97); padding:1.5rem 5%; gap:1.1rem; border-bottom:1px solid rgba(255,255,255,.07); }
      .nav-links.open { display:flex; }
      .hamburger { display:flex; }
      .page-hero-content { padding-top:118px; }
      .hero-brand-card { width:100%; padding:.82rem .95rem; gap:.8rem; }
      .hero-brand-mark { width:52px; height:52px; border-radius:16px; }
      .hero-brand-mark img { width:40px; height:40px; }
      .hero-brand-name { font-size:1.45rem; }
      .hero-brand-tag { font-size:.58rem; letter-spacing:.14em; }
      .footer-grid { grid-template-columns:1fr 1fr; }
      section { padding:70px 5%; }
    }
    @media(max-width:480px) {
      .nav-brand-name { font-size:1.05rem; }
      .hero-brand-name { font-size:1.3rem; }
      .mvv-cards { grid-template-columns:1fr; }
      .footer-grid { grid-template-columns:1fr; }
      .comp-btns { flex-direction:column; }
    }