    :root{
      --red:#d61f2a;
      --red-dark:#b01821;
      --black:#111;
      --text:#1d1d1d;
      --muted:#6b6b6b;
      --bg:#f6f6f6;
      --card:#ffffff;
      --line:#e6e6e6;
      --green:#21b35b;
      --container: 1120px;
      --radius: 14px;
    }

    *{ box-sizing:border-box; }
    body{
      margin:0;
      font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color:var(--text);
      background:#fff;
    }
    a{ color:inherit; text-decoration:none; }
    img{ max-width:100%; display:block; }
    .container{
      width:min(var(--container), calc(100% - 32px));
      margin:0 auto;
    }

    /* Top bar */
    .topbar{
      background:var(--black);
      color:#fff;
      font-size:12px;
    }
    .topbar .wrap{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      padding:10px 0;
    }
    .topbar .links{
      display:flex;
      gap:14px;
      flex-wrap:wrap;
      opacity:.92;
    }
    .topbar .actions{
      display:flex;
      align-items:center;
      gap:10px;
      flex-wrap:wrap;
      justify-content:flex-end;
    }
    .pill{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:7px 10px;
      border-radius:999px;
      font-weight:600;
      border:1px solid rgba(255,255,255,.18);
      background:rgba(255,255,255,.06);
    }
    .pill.red{ background:rgba(214,31,42,.2); border-color:rgba(214,31,42,.35); }
    .pill.green{ background:rgba(33,179,91,.18); border-color:rgba(33,179,91,.35); }
    .pill.gray{ background:rgba(255,255,255,.06); }

    /* Header */
    header{
      background:#fff;
      border-bottom:1px solid var(--line);
      position:sticky;
      top:0;
      z-index:50;
    }
    .header-wrap{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:16px;
      padding:14px 0;
    }
    .brand{
      display:flex;
      align-items:center;
      gap:12px;
      min-width:220px;
    }
    .brand img{
      width:150px;
      height:auto;
    }
    nav{
      display:flex;
      gap:14px;
      flex-wrap:wrap;
      justify-content:flex-end;
      font-size:13px;
      font-weight:600;
      color:#2b2b2b;
    }
    nav a{ padding:6px 6px; border-radius:8px; }
    nav a:hover{ background:#f3f3f3; }

    /* Hero */
    .hero{
      background:#fff;
      padding:22px 0 10px;
    }
    .hero-banner{
      background:linear-gradient(180deg,#f3f3f3,#ffffff);
      border:1px solid var(--line);
      border-radius:var(--radius);
      overflow:hidden;
      position:relative;
    }
    .hero-grid{
      display:grid;
      grid-template-columns: 1.1fr 1fr 1.1fr;
      gap:0;
      align-items:stretch;
      min-height:260px;
    }
    .hero-left{
      padding:28px 26px;
      display:flex;
      flex-direction:column;
      justify-content:center;
      gap:10px;
    }
    .kicker{
      font-weight:800;
      letter-spacing:.02em;
      color:var(--red);
      font-size:34px;
      line-height:1.05;
      text-transform:uppercase;
    }
    .hero-sub{
      font-weight:700;
      color:#333;
      font-size:12px;
      line-height:1.45;
      text-transform:uppercase;
      max-width:320px;
    }
    .hero-mid{
      display:flex;
      align-items:center;
      justify-content:center;
      padding:18px;
    }
    .hero-mid img{
      width:min(360px, 90%);
      height:auto;
      filter: drop-shadow(0 10px 18px rgba(0,0,0,.08));
    }
    .hero-right{
      position:relative;
      display:flex;
      align-items:center;
      justify-content:flex-end;
      padding:12px 0 0 0;
      background:
        linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255, 255, 255, 0) 18%, rgba(255, 255, 255, 0) 40%),
        radial-gradient(circle at 70% 30%, rgba(214, 31, 43, 0), transparent 55%);
    }
    .hero-right::after{
      content:"";
      position:absolute;
      right:0; top:0; bottom:0;
      width:80px;
      background:var(--red);
      opacity:.95;
    }
    .hero-right img{
      position:relative;
      z-index:2;
      width:min(420px, 86%);
      margin-right:40px;
      filter: drop-shadow(0 14px 18px rgba(0, 0, 0, 0));
    }

    /* Intro */
    .intro{
      padding:14px 0 8px;
    }
    .intro p{
      margin:0;
      font-size:13px;
      color:#2b2b2b;
      line-height:1.6;
      text-transform:uppercase;
      letter-spacing:.01em;
    }

    /* Small strip */
    .strip{
      padding:10px 0 4px;
    }
    .strip-box{
      display:flex;
      align-items:stretch;
      border:1px solid var(--line);
      border-radius:12px;
      overflow:hidden;
      background:#fff;
    }
    .strip-content{
      padding:14px 16px;
      flex:1;
    }
    .strip-title{
      font-weight:800;
      color:#0a2a6b;
      font-size:14px;
      margin:0 0 4px;
      text-transform:uppercase;
    }
    .strip-title span{ color:var(--red); }
    .strip-desc{
      margin:0;
      font-size:11px;
      color:#444;
      line-height:1.5;
      text-transform:uppercase;
    }
    .strip-accent{
      width:80px;
      background:var(--red);
    }

    /* Main content */
    main{
      padding:18px 0 34px;
    }
    h2{
      margin:18px 0 10px;
      color:var(--red);
      font-size:26px;
      line-height:1.15;
      text-transform:uppercase;
      letter-spacing:.01em;
    }
    .lead{
      margin:0 0 14px;
      color:#2b2b2b;
      font-size:13px;
      line-height:1.7;
      text-transform:uppercase;
    }
    h3{
      margin:14px 0 10px;
      color:var(--red);
      font-size:18px;
      text-transform:uppercase;
    }

    .checklist{
      display:grid;
      gap:12px;
      margin:10px 0 18px;
    }
    .check{
      display:grid;
      grid-template-columns: 20px 1fr;
      gap:10px;
      align-items:flex-start;
    }
    .check .icon{
      width:18px;height:18px;
      border-radius:4px;
      background:rgba(33,179,91,.15);
      border:1px solid rgba(33,179,91,.35);
      display:flex;
      align-items:center;
      justify-content:center;
      margin-top:2px;
    }
    .check .icon svg{ width:13px;height:13px; fill:var(--green); }
    .check b{
      display:block;
      font-size:12px;
      text-transform:uppercase;
      margin-bottom:4px;
    }
    .check p{
      margin:0;
      font-size:12px;
      color:#333;
      line-height:1.6;
      text-transform:uppercase;
    }

    .parts-title{
      margin-top:18px;
      color:var(--red);
      font-weight:800;
      letter-spacing:.01em;
      font-size:18px;
      text-transform:uppercase;
    }
    .parts-lead{
      margin:8px 0 14px;
      font-size:12px;
      color:#333;
      line-height:1.65;
      text-transform:uppercase;
    }

    /* Blocos / "tabela" de categorias (site) */
    .parts-grid{
      display:grid;
      grid-template-columns: repeat(2, 1fr);
      gap:12px;
      margin:10px 0 16px;
    }
    .parts-card{
      border:1px solid var(--line);
      border-radius:12px;
      background:#fff;
      padding:12px 14px;
    }
    .parts-card h4{
      margin:0 0 6px;
      font-size:13px;
      font-weight:800;
      text-transform:uppercase;
      color:#222;
    }
    .parts-card ul{
      margin:0;
      padding-left:16px;
      font-size:12px;
      line-height:1.6;
      color:#333;
      text-transform:uppercase;
    }

    /* CTA Catálogo */
    .cta-row{
      margin:18px 0 22px;
      display:flex;
      align-items:stretch;
      gap:10px;
    }
    .cta-box{
      flex:1;
      border-radius:12px;
      overflow:hidden;
      border:1px solid var(--line);
      background:#fff;
      display:flex;
      align-items:center;
      justify-content:space-between;
    }
    .cta-box .btn{
      margin:16px;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      background:var(--red);
      color:#fff;
      font-weight:900;
      letter-spacing:.02em;
      padding:14px 18px;
      border-radius:12px;
      text-transform:uppercase;
      box-shadow: 0 10px 18px rgba(214,31,42,.18);
    }
    .cta-box .btn:hover{ background:var(--red-dark); }
    .cta-accent{
      width:90px;
      background:var(--red);
    }

    /* Diferenciais */
    .diff{
      margin-top:14px;
    }
    .diff h3{
      margin:0 0 10px;
      color:var(--red);
      font-weight:900;
      text-transform:uppercase;
    }
    .diff ul{
      margin:0;
      padding-left:16px;
      font-size:12px;
      line-height:1.75;
      color:#333;
      text-transform:uppercase;
    }

    /* Flutuantes (assistência / QR) */
    .float-area{
      position:fixed;
      right:18px;
      bottom:18px;
      z-index:60;
      display:flex;
      flex-direction:column;
      gap:10px;
      align-items:flex-end;
    }
    .float-btn{
      background:var(--red);
      color:#fff;
      font-weight:800;
      border-radius:10px;
      padding:10px 12px;
      font-size:12px;
      box-shadow:0 14px 24px rgba(0,0,0,.15);
    }
    .float-card{
      background:#fff;
      border:1px solid var(--line);
      border-radius:12px;
      padding:10px;
      width:130px;
      box-shadow:0 14px 24px rgba(0,0,0,.10);
      text-align:center;
    }
    .float-card small{
      display:block;
      font-size:10px;
      font-weight:800;
      color:#333;
      text-transform:uppercase;
      margin-bottom:8px;
    }
    .float-card img{
      width:100%;
      height:auto;
    }

    /* Footer CTA */
    .footer-cta{
      margin-top:26px;
      background:
        linear-gradient(0deg, rgba(214,31,42,.90), rgba(214,31,42,.90)),
        url("assets/bg-footer.jpg") center/cover no-repeat;
      color:#fff;
      padding:28px 0;
    }
    .footer-cta .wrap{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:14px;
      flex-wrap:wrap;
    }
    .footer-cta h4{
      margin:0;
      font-size:18px;
      font-weight:900;
      text-transform:uppercase;
    }
    .footer-cta p{
      margin:6px 0 0;
      font-size:12px;
      opacity:.95;
      text-transform:uppercase;
      line-height:1.5;
      max-width:520px;
    }
    .footer-cta .cta{
      display:inline-flex;
      align-items:center;
      gap:10px;
      background:#0b0b0b;
      color:#fff;
      padding:12px 14px;
      border-radius:12px;
      font-weight:800;
      text-transform:uppercase;
    }
    .footer-cta .cta:hover{ background:#000; }

    /* Responsivo */
    @media (max-width: 980px){
      .hero-grid{ grid-template-columns: 1fr; }
      .hero-right::after{ display:none; }
      .hero-right{ justify-content:center; padding:18px; }
      .hero-right img{ margin:0; width:min(520px, 92%); }
      .hero-mid{ order:2; }
      .hero-right{ order:3; }
      .parts-grid{ grid-template-columns: 1fr; }
      nav{ display:none; } /* simples: some no mobile */
    }


    .hero-catalogo{ padding:22px 0 8px; }
    .hero-box{
      border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
      background:linear-gradient(180deg,#f3f3f3,#fff);
      display:grid; grid-template-columns: 1.2fr .8fr; align-items:center; min-height:190px; position:relative;
    }
    .hero-left{ padding:26px; }
    .hero-title{ margin:0; font-size:30px; line-height:1.1; font-weight:900; text-transform:uppercase; color:var(--red); }
    .hero-sub{ margin:10px 0 0; font-size:13px; line-height:1.6; text-transform:uppercase; color:#333; max-width:680px; }
    .hero-right-logo{position:relative;display:flex; align-items:center; justify-content:center; padding:18px; background: radial-gradient(circle at 65% 35%, rgba(255, 255, 255, 0), transparent 55%); }
    .hero-box::after{ content:""; position:absolute; right:0; top:0; bottom:0; width:60px; background:var(--red); }
    .hero-right-logo img{ width:min(300px, 90%); filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.1)); }

    main{ padding:18px 0 28px; }
    .panel{ border:1px solid var(--line); background:#fff; border-radius:12px; padding:14px; }
    .tools{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between; margin-bottom:10px; }
    .tools .left{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
    .input{ border:1px solid var(--line); border-radius:10px; padding:10px 12px; font-weight:600; font-size:13px; min-width:260px; outline:none; }
    .select{ border:1px solid var(--line); border-radius:10px; padding:10px 12px; font-weight:700; font-size:13px; outline:none; background:#fff; }
    .count{ font-size:12px; color:#333; font-weight:800; text-transform:uppercase; }
    .hint{ margin:10px 0 0; color:var(--muted); font-size:12px; line-height:1.5; }

    details{ border:1px solid var(--line); border-radius:12px; margin:12px 0; overflow:hidden; background:#fff; }
    summary{
      cursor:pointer; list-style:none; padding:12px 14px; font-weight:900; text-transform:uppercase; color:#222;
      display:flex; align-items:center; justify-content:space-between; gap:10px; background:#fcfcfc;
    }
    summary::-webkit-details-marker{ display:none; }
    .badge{ font-size:11px; font-weight:900; color:#fff; background:var(--red); padding:6px 10px; border-radius:999px; white-space:nowrap; }

    .table-wrap{ padding:12px 14px 14px; overflow:auto; }
    table{ width:100%; border-collapse:collapse; font-size:13px; min-width:740px; }
    th, td{ padding:10px 8px; border-bottom:1px solid var(--line); text-align:left; }
    th{ font-size:11px; text-transform:uppercase; letter-spacing:.02em; color:#333; }
    td.code{ font-weight:900; color:#111; width:160px; }
    td.desc{ font-weight:700; color:#333; text-transform:uppercase; }

    .footer-cta{ margin-top:18px; background: linear-gradient(0deg, rgba(214,31,42,.92), rgba(214,31,42,.92)); color:#fff; padding:28px 0; }
    .footer-cta .wrap{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
    .footer-cta h4{ margin:0; font-size:18px; font-weight:900; text-transform:uppercase; }
    .footer-cta p{ margin:6px 0 0; font-size:12px; opacity:.95; text-transform:uppercase; line-height:1.5; max-width:560px; }
    .footer-cta .cta{ display:inline-flex; align-items:center; gap:10px; background:#0b0b0b; color:#fff; padding:12px 14px; border-radius:12px; font-weight:800; text-transform:uppercase; }
    .footer-cta .cta:hover{ background:#000; }

    @media (max-width: 980px){
      nav{ display:none; }
      .hero-box{ grid-template-columns:1fr; }
      .hero-box::after{ display:none; }
      .input{ min-width:100%; }
      table{ min-width:640px; }
    }