.hp-stats {
      display: flex;
      flex-direction: column;
      gap: var(--space-xl);
      margin-top: var(--space-3xl);
      padding-top: var(--space-2xl);
      border-top: 1px solid var(--gray-800);
    }

    @media (min-width: 768px) {
      .hp-stats {
        flex-direction: row;
        align-items: center;
        gap: var(--space-2xl);
      }
    }

    .hp-stats__item {
      display: flex;
      flex-direction: column;
      gap: 6px;
      flex: 1;
    }

    .hp-stats__number {
      font-size: clamp(2.5rem, 5vw, 3.5rem);
      font-weight: 700;
      color: var(--rosa);
      line-height: 1;
      letter-spacing: -0.03em;
    }

    .hp-stats__label {
      font-size: var(--text-sm);
      color: var(--gray-400);
      font-weight: 300;
    }

    .hp-stats__aside {
      display: block;
      font-size: var(--text-xs);
      color: var(--gray-600);
      font-weight: 300;
      font-style: italic;
      margin-top: 6px;
      line-height: 1.4;
    }

    .hp-stats__divider {
      display: none;
    }

    @media (min-width: 768px) {
      .hp-stats__divider {
        display: block;
        width: 1px;
        height: 60px;
        background: var(--gray-800);
        flex-shrink: 0;
      }
    }

    .hp-portfolio-header {
      display: flex;
      flex-direction: column;
      gap: var(--space-lg);
      margin-bottom: var(--space-2xl);
    }

    @media (min-width: 768px) {
      .hp-portfolio-header {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
      }
    }

    /* ── Portfolio grid - full-width, matches portfolio.html ── */
    .hp-portfolio-grid {
      display: grid;
      grid-template-columns: 1fr;
      column-gap: 1rem;
      row-gap: 3rem;
      /* Break out of container to full width */
      width: 100vw;
      margin-left: calc(-50vw + 50%);
      padding: 0 var(--container-padding);
      box-sizing: border-box;
    }

    @media (min-width: 768px) {
      .hp-portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    .hp-portfolio-card {
      display: block;
      text-decoration: none;
      color: inherit;
    }

    .hp-portfolio-card__image-wrap {
      overflow: hidden;
      aspect-ratio: 1 / 1;
      cursor: none;
    }

    .hp-portfolio-card__image {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .hp-portfolio-card__info {
      padding: var(--space-sm) 0 0;
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: var(--space-sm);
    }

    @media (min-width: 768px) {
      .hp-portfolio-card__info {
        padding: var(--space-sm) var(--space-md) 0;
      }
    }

    .hp-portfolio-card__left {
      display: flex;
      flex-direction: column;
      gap: 2px;
    }

    .hp-portfolio-card__client {
      font-size: var(--text-base);
      font-weight: 600;
      color: var(--white);
      line-height: 1.3;
      transition: color 0.3s;
    }

    .hp-portfolio-card:hover .hp-portfolio-card__client {
      color: var(--rosa);
    }

    /* ── "Ver projeto" cursor circle ── */
    .hp-cursor {
      position: fixed;
      width: 100px;
      height: 100px;
      border-radius: 50%;
      background: var(--rosa);
      color: var(--white);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.75rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.04em;
      pointer-events: none;
      z-index: 1000;
      opacity: 0;
      transform: translate(-50%, -50%) scale(0.4);
      transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                  transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .hp-cursor.is-active {
      opacity: 1;
      transform: translate(-50%, -50%) scale(1);
    }

    @media (hover: none) {
      .hp-cursor { display: none; }
      .hp-portfolio-card__image-wrap { cursor: pointer; }
    }

    .hp-portfolio-card__name {
      font-size: var(--text-sm);
      font-weight: 300;
      color: var(--gray-400);
      line-height: 1.3;
      margin: 0;
    }

    .hp-portfolio-card__scope {
      font-size: var(--text-sm);
      color: var(--gray-500);
      font-weight: 300;
      text-align: right;
      white-space: nowrap;
    }

    .hp-portfolio-cta {
      display: flex;
      justify-content: center;
      margin-top: var(--space-2xl);
    }

    .hp-highlight {
      position: relative;
      padding: var(--space-3xl) 0;
      overflow: hidden;
    }

    .hp-highlight::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(255, 39, 122, 0.03) 0%, transparent 50%, rgba(255, 39, 122, 0.02) 100%);
      pointer-events: none;
    }

    .hp-highlight__inner {
      position: relative;
      display: flex;
      flex-direction: column;
      gap: var(--space-xl);
    }

    .hp-highlight__rule {
      display: flex;
      align-items: center;
      gap: var(--space-lg);
    }

    .hp-highlight__line {
      flex: 1;
      height: 1px;
      background: var(--gray-800);
    }

    .hp-highlight__tag {
      font-size: var(--text-xs);
      text-transform: uppercase;
      letter-spacing: 0.3em;
      color: var(--rosa);
      font-weight: 500;
      white-space: nowrap;
    }

    .hp-highlight__quote {
      margin: 0;
    }

    .hp-highlight__main {
      display: block;
      font-size: clamp(1.8rem, 4.5vw, 3.8rem);
      font-weight: 300;
      line-height: 1.1;
      color: var(--white);
      letter-spacing: -0.02em;
    }

    .hp-highlight__main .hp-highlight__em {
      color: var(--rosa);
      font-style: normal;
      font-weight: 300;
    }

    .hp-highlight__sub {
      display: block;
      font-size: clamp(1.1rem, 2.5vw, 1.8rem);
      font-weight: 300;
      line-height: 1.3;
      color: var(--gray-400);
      margin-top: var(--space-md);
      max-width: 700px;
    }

    .hp-highlight__accent {
      width: 60px;
      height: 3px;
      background: var(--rosa);
      margin-top: var(--space-sm);
      transform-origin: left;
    }

    @media (min-width: 768px) {
      .hp-highlight {
        padding: var(--space-5xl) 0;
      }

      .hp-highlight__inner {
        gap: var(--space-2xl);
      }
    }

    /* ── Explore Section ── */
    .hp-explore {
      padding: var(--space-xl) 0 var(--space-3xl);
      position: relative;
    }

    .hp-explore__label {
      font-size: var(--text-sm);
      text-transform: uppercase;
      letter-spacing: 0.25em;
      color: var(--gray-500);
      font-weight: 500;
      text-align: center;
      margin-bottom: var(--space-xl);
    }

    .hp-explore__grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--space-sm);
    }

    @media (min-width: 768px) {
      .hp-explore__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-md);
      }
    }

    .hp-explore__card {
      display: flex;
      align-items: center;
      gap: var(--space-md);
      padding: var(--space-lg) var(--space-xl);
      border: 1px solid var(--gray-700);
      border-radius: var(--radius-lg);
      background: var(--gray-800);
      text-decoration: none;
      color: var(--white);
      cursor: pointer;
      transition: border-color 0.3s ease, background 0.3s ease, transform 0.3s var(--ease-out), box-shadow 0.3s ease;
      position: relative;
    }

    .hp-explore__card:hover,
    .hp-explore__card:focus-visible {
      border-color: var(--rosa);
      background: rgba(255, 39, 122, 0.08);
      transform: translateY(-3px);
      box-shadow: 0 8px 30px rgba(255, 39, 122, 0.1);
    }

    .hp-explore__card:focus-visible {
      outline: 2px solid var(--rosa);
      outline-offset: 2px;
    }

    .hp-explore__icon {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 48px;
      height: 48px;
      border-radius: var(--radius-md);
      background: rgba(255, 39, 122, 0.12);
      color: var(--rosa);
      flex-shrink: 0;
      transition: background 0.3s ease, transform 0.3s ease;
    }

    .hp-explore__card:hover .hp-explore__icon {
      background: rgba(255, 39, 122, 0.2);
      transform: scale(1.05);
    }

    .hp-explore__card-text {
      display: flex;
      flex-direction: column;
      gap: 4px;
      flex: 1;
      min-width: 0;
    }

    .hp-explore__card-title {
      font-size: var(--text-lg);
      font-weight: 500;
      line-height: 1.3;
    }

    .hp-explore__card-desc {
      font-size: var(--text-sm);
      color: var(--gray-400);
      font-weight: 300;
      line-height: 1.5;
    }

    .hp-explore__arrow {
      color: var(--rosa);
      flex-shrink: 0;
      transition: transform 0.3s var(--ease-out);
    }

    .hp-explore__card:hover .hp-explore__arrow {
      transform: translate(3px, -3px);
    }

    @media (min-width: 768px) {
      .hp-explore__card {
        flex-direction: column;
        align-items: flex-start;
        padding: var(--space-xl);
        gap: var(--space-lg);
      }

      .hp-explore__arrow {
        align-self: flex-end;
        margin-top: auto;
      }
    }

    /* ── Método - Leeroy-style sticky image + scroll list ── */
    .hp-metodo {
      position: relative;
    }

    /* ── Mobile: vertical layout, no sticky ── */
    .hp-metodo__image {
      display: none;
    }

    .hp-metodo__list {
      padding: 0 var(--container-padding);
      box-sizing: border-box;
    }

    .hp-metodo__item {
      border-top: 1px solid var(--gray-500);
      padding: var(--space-xl) 0;
    }

    .hp-metodo__item:last-child {
      border-bottom: 1px solid var(--gray-500);
    }

    .hp-metodo__item-img {
      width: 100%;
      aspect-ratio: 3 / 4;
      overflow: hidden;
      margin-bottom: var(--space-lg);
    }

    .hp-metodo__item-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    /* Preto e branco nos primeiros dois itens (ouvir + estudar o negócio) — vale em mobile e desktop */
    .hp-metodo__item[data-metodo="0"] .hp-metodo__item-img img,
    .hp-metodo__item[data-metodo="1"] .hp-metodo__item-img img {
      filter: grayscale(100%);
    }

    .hp-metodo__item-grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--space-md);
      width: 100%;
    }

    .hp-metodo__item-title {
      font-size: clamp(1.5rem, 5vw, 2rem);
      font-weight: 300;
      line-height: 1.15;
      letter-spacing: -0.02em;
      color: var(--white);
    }

    .hp-metodo__item-text {
      font-size: var(--text-base);
      color: var(--gray-300);
      line-height: 1.5;
      font-weight: 300;
    }

    /* ── Desktop: sticky image + scroll list ── */
    @media (min-width: 768px) {
      /* Container sticky com a mesma altura da foto e centrado na viewport via top.
         Assim, a foto solta-se exatamente quando a última linha lhe bate na base. */
      .hp-metodo__image {
        display: flex;
        position: sticky;
        top: calc((100svh - 44svh) / 2);
        width: 100%;
        height: 44svh;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        z-index: 1;
      }

      .hp-metodo__image-inner {
        position: relative;
        width: auto;
        height: 44svh;
        aspect-ratio: 3 / 4;
        overflow: hidden;
      }

      .hp-metodo__image-inner img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
        transition: opacity 0.6s ease;
      }

      .hp-metodo__image-inner img.is-hidden {
        opacity: 0;
        position: absolute;
        inset: 0;
      }

      .hp-metodo__image-inner img.is-active {
        opacity: 1;
      }

      /* Preto e branco nos dois primeiros itens (ouvir + estudar o negócio) */
      #metodo-image picture[data-index="0"] img,
      #metodo-image picture[data-index="1"] img {
        filter: grayscale(100%);
      }

      /* Hide per-item images on desktop */
      .hp-metodo__item-img {
        display: none;
      }

      .hp-metodo__list {
        position: relative;
        z-index: 2;
        margin-top: -44svh;
      }

      /* Curso extra para a última linha varrer a última foto (= altura da foto). */
      .hp-metodo__tail {
        height: 44svh;
      }

      .hp-metodo__item {
        min-height: 44svh;
        display: flex;
        align-items: center;
        padding: var(--space-2xl) 0;
        opacity: 0.6;
        transition: opacity 0.5s ease;
      }

      .hp-metodo__item.is-active {
        opacity: 1;
      }

      /* O primeiro e o último item precisam de espaço extra de scroll para que a
         linha divisória consiga ultrapassar a foto e esta apareça por completo. */
      .hp-metodo__item:first-child {
        padding-top: calc(var(--space-3xl) + 14vh);
      }

      .hp-metodo__item:last-child {
        padding-bottom: calc(var(--space-xl) + 6vh);
      }

      /* 3-column grid: title | empty center (image space) | text */
      .hp-metodo__item-grid {
        grid-template-columns: 1fr 30% 1fr;
        gap: 0;
        align-items: start;
      }

      .hp-metodo__item-title {
        grid-column: 1;
        font-size: clamp(2rem, 3.5vw, 3rem);
        padding-right: var(--space-xl);
      }

      .hp-metodo__item-text {
        grid-column: 3;
        padding-left: var(--space-xl);
        font-size: clamp(0.95rem, 1.1vw, 1.55rem);
        line-height: 1.55;
      }
    }

    @media (min-width: 1200px) {
      .hp-metodo__item-grid {
        grid-template-columns: 1fr 28% 1fr;
      }

      .hp-metodo__item-title {
        font-size: clamp(2.5rem, 3vw, 3.2rem);
      }
    }

    /* Clients – Leeroy-inspired bordered grid */
    .hp-clients {
      padding: var(--space-3xl) 0;
    }

    .hp-clients__header {
      display: flex;
      flex-direction: column;
      gap: var(--space-lg);
      margin-bottom: var(--space-3xl);
    }

    .hp-clients__title {
      font-family: var(--font-sans);
      font-size: clamp(2rem, 4.5vw, 3.8rem);
      font-weight: 300;
      line-height: 1.15;
      letter-spacing: -0.02em;
      color: var(--white);
      max-width: 18ch;
    }

    .hp-clients__text {
      font-size: var(--text-base);
      line-height: 1.7;
      color: var(--gray-400);
      max-width: 52ch;
    }

    .hp-clients__text strong {
      color: var(--white);
      font-weight: 500;
    }

    @media (min-width: 768px) {
      .hp-clients__header {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
        gap: var(--space-3xl);
      }

      .hp-clients__title {
        flex: 0 1 55%;
      }

      .hp-clients__text {
        flex: 0 1 40%;
        text-align: left;
      }
    }

    /* Grid with visible borders */
    .hp-clients__grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      border-top: 1px solid var(--gray-800);
      border-left: 1px solid var(--gray-800);
    }

    .hp-clients__cell {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: var(--space-lg) var(--space-md);
      min-height: 100px;
      min-width: 0;
      border-right: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
      overflow: hidden;
      transition: background-color 0.3s ease;
    }

    .hp-clients__cell:hover {
      background-color: rgba(255, 255, 255, 0.03);
    }

    .hp-clients__cell img {
      max-width: 100%;
      max-height: 40px;
      width: auto;
      height: auto;
      object-fit: contain;
      filter: grayscale(100%) brightness(2);
      opacity: 0.5;
      transition: filter 0.3s ease, opacity 0.3s ease;
    }

    .hp-clients__cell--tall img {
      max-height: 64px;
      max-width: 90%;
    }

    .hp-clients__cell:hover img {
      filter: grayscale(0%) brightness(1);
      opacity: 1;
    }

    @media (min-width: 640px) {
      .hp-clients__grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    @media (min-width: 1024px) {
      .hp-clients__grid {
        grid-template-columns: repeat(4, 1fr);
      }

      .hp-clients__cell {
        min-height: 120px;
        padding: var(--space-xl);
      }

      .hp-clients__cell img {
        max-width: 160px;
        max-height: 50px;
      }

      .hp-clients__cell--tall img {
        max-height: 88px;
        max-width: 120px;
      }
    }

    /* ── Team Photo Morph - large → inline ── */
    .hp-photo-morph {
      position: relative;
    }

    /* Sticky frame: stays pinned while content scrolls up */
    .hp-photo-morph__sticky {
      position: sticky;
      top: 0;
      height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      pointer-events: none;
      z-index: 5;
    }

    /* The actual photo wrapper that animates */
    .hp-photo-morph__img {
      width: 100%;
      max-width: var(--container-max);
      padding: 0 var(--container-padding);
      box-sizing: border-box;
      will-change: transform, opacity;
    }

    .hp-photo-morph__img img {
      width: 100%;
      aspect-ratio: 21 / 9;
      object-fit: cover;
      display: block;
      border-radius: var(--radius-xl);
    }

    @media (max-width: 767px) {
      .hp-photo-morph__img img {
        aspect-ratio: 16 / 9;
      }
    }

    /* Spacer pushes statement down, giving scroll room for phase 1 (expand) */
    .hp-photo-morph__spacer {
      height: 50vh;
    }

    /* Statement with inline photo */
    .hp-statement {
      position: relative;
      z-index: 2;
      padding: var(--space-3xl) 0;
    }

    .hp-statement__text {
      font-size: clamp(2rem, 6vw, 5rem);
      font-weight: 900;
      line-height: 0.94;
      letter-spacing: -0.035em;
      color: var(--white);
      text-transform: uppercase;
      max-width: 18ch;
      margin: 0;
    }

    .hp-statement__text .serif {
      font-style: normal;
      color: var(--rosa);
    }

    .hp-statement__inline-img {
      display: inline-block;
      width: clamp(100px, 14vw, 200px);
      height: clamp(40px, 5.5vw, 75px);
      border-radius: 999px;
      overflow: hidden;
      vertical-align: middle;
      margin: 0 0.15em;
      position: relative;
      top: -0.05em;
      opacity: 0;
      transition: opacity 0.3s ease;
    }

    .hp-statement__inline-img.is-visible {
      opacity: 1;
    }

    .hp-statement__inline-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .hp-statement__sub {
      font-size: var(--text-lg);
      font-weight: 300;
      color: var(--gray-400);
      margin-top: var(--space-lg);
      max-width: 700px;
      line-height: 1.5;
    }

    /* ── Full-width break photo ── */
    .hp-break-photo {
      width: 70svw;
      margin-left: auto;
      margin-right: 0;
    }
    @media (max-width: 767px) {
      .hp-break-photo {
        width: 100%;
        margin-left: 0;
      }
    }

    .hp-break-photo img {
      width: 100%;
      height: auto;
      display: block;
    }

    /* Badge circular "SOMOS INSURGENTE" no canto da foto */
    .hp-break-photo {
      position: relative;
    }

    .hp-break-badge {
      position: absolute;
      left: -65px;
      bottom: -65px;
      width: clamp(190px, 19vw, 290px);
      height: clamp(190px, 19vw, 290px);
      z-index: 3;
      pointer-events: none;
      animation: hp-badge-spin 20s linear infinite;
    }

    .hp-break-badge svg {
      width: 100%;
      height: 100%;
      display: block;
    }

    .hp-break-badge text {
      fill: var(--white);
      font-family: 'Inter', sans-serif;
      font-weight: 700;
      font-size: 23px;
      letter-spacing: 0;
      text-transform: uppercase;
    }

    .hp-break-badge .hp-badge-light {
      font-weight: 300;
    }

    @keyframes hp-badge-spin {
      to { transform: rotate(360deg); }
    }

    @media (prefers-reduced-motion: reduce) {
      .hp-break-badge { animation: none; }
    }

    /* ── Manifesto split section (Motto-style) ── */
    .hp-manifesto {
      padding: var(--space-3xl) 0;
    }

    .hp-manifesto__grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--space-xl);
    }

    @media (min-width: 768px) {
      .hp-manifesto__grid {
        grid-template-columns: 1fr 2fr;
        gap: var(--space-2xl);
        align-items: start;
      }
    }

    .hp-manifesto__label {
      font-size: var(--text-sm);
      font-weight: 500;
      color: var(--gray-400);
      line-height: 1.4;
    }

    .hp-manifesto__body {
      max-width: 800px;
    }

    .hp-manifesto__title {
      font-size: clamp(1.75rem, 3.5vw, 3rem);
      font-weight: 300;
      line-height: 1.1;
      letter-spacing: -0.02em;
      color: var(--white);
      margin-bottom: var(--space-lg);
    }

    .hp-manifesto__title .serif {
      font-style: italic;
    }

    .hp-manifesto__text {
      font-size: var(--text-base);
      font-weight: 300;
      color: var(--gray-400);
      line-height: 1.5;
      max-width: 650px;
      margin-bottom: var(--space-xl);
    }

    .hp-manifesto__eyebrow {
      font-size: var(--text-xs);
      font-weight: 700;
      color: var(--gray-500);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-bottom: var(--space-md);
    }

    .hp-manifesto__link {
      font-size: var(--text-base);
      font-weight: 500;
      color: var(--white);
      text-decoration: none;
      border-bottom: 1px solid var(--white);
      padding-bottom: 4px;
      transition: color 0.3s, border-color 0.3s;
      display: inline-flex;
      align-items: center;
      gap: 0.5em;
    }

    .hp-manifesto__link:hover {
      color: var(--rosa);
      border-color: var(--rosa);
    }


    /* ─────────────────────────────────────────────────
       "O que fazemos", Lottie + accordion split
       Mobile-first. Stacked column on small screens.
       Two-column grid from 960px upward.
       ───────────────────────────────────────────────── */

    .hp-svc {
      padding: var(--space-3xl) 0;
      position: relative;
    }

    @media (min-width: 768px) {
      .hp-svc {
        padding: var(--space-4xl) 0;
      }
    }

    /* Same outer padding as .hp-metodo__list, plus internal column padding
       to mirror the breathing room hp-metodo gets from its 3-col grid */
    .hp-svc__grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--space-2xl);
      align-items: start;
      padding: 0 var(--container-padding);
      box-sizing: border-box;
    }

    @media (min-width: 768px) {
      .hp-svc__grid {
        padding: 0 calc(var(--container-padding) + var(--space-md));
      }
    }

    @media (min-width: 960px) {
      .hp-svc__grid {
        grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
        gap: clamp(2.5rem, 5vw, 5rem);
        padding: 0 calc(var(--container-padding) + var(--space-lg));
      }
    }

    @media (min-width: 1280px) {
      .hp-svc__grid {
        padding: 0 calc(var(--container-padding) + var(--space-xl));
      }
    }

    /* ── LEFT column: Lottie centered, text aligned left ── */
    .hp-svc__intro {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      text-align: left;
      gap: var(--space-md);
    }

    @media (min-width: 960px) {
      .hp-svc__intro {
        position: sticky;
        top: 100px;
        gap: var(--space-lg);
      }
    }

    /* .hp-svc__eyebrow removed, replaced by canonical .section-eyebrow */

    .hp-svc__lottie {
      width: 100%;
      max-width: 380px;
      aspect-ratio: 1 / 1;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      margin: var(--space-sm) auto;
    }

    .hp-svc__lottie::before {
      /* soft magenta halo behind the animation */
      content: '';
      position: absolute;
      inset: 8%;
      border-radius: 50%;
      background: radial-gradient(circle at center, rgba(255, 39, 122, 0.18) 0%, rgba(255, 39, 122, 0) 60%);
      filter: blur(20px);
      z-index: 0;
      pointer-events: none;
    }

    .hp-svc__lottie dotlottie-wc {
      position: relative;
      z-index: 1;
      width: 100%;
      height: 100%;
      display: block;
    }

    @media (min-width: 768px) {
      .hp-svc__lottie {
        max-width: 340px;
      }
    }

    @media (min-width: 1280px) {
      .hp-svc__lottie {
        max-width: 360px;
      }
    }

    .hp-svc__title {
      font-size: clamp(2rem, 4.5vw, 3.8rem);
      font-weight: 300;
      line-height: 1.15;
      letter-spacing: -0.02em;
      color: var(--white);
      margin: 0;
    }

    .hp-svc__title .serif {
      font-style: italic;
      color: var(--rosa);
    }

    .hp-svc__text {
      font-size: var(--text-sm);
      font-weight: 300;
      line-height: 1.55;
      color: var(--gray-400);
      max-width: 44ch;
      margin: 0;
    }

    .hp-svc__cta {
      display: inline-flex;
      align-items: center;
      gap: 0.6em;
      font-size: var(--text-sm);
      font-weight: 500;
      letter-spacing: 0.02em;
      color: var(--white);
      padding: 6px 0;
      border-bottom: 1px solid var(--gray-600);
      transition: color 0.3s, border-color 0.3s, gap 0.3s;
      margin-top: var(--space-xs);
    }

    .hp-svc__cta:hover,
    .hp-svc__cta:focus-visible {
      color: var(--rosa);
      border-color: var(--rosa);
      gap: 1em;
    }

    .hp-svc__cta:focus-visible {
      outline: 2px solid var(--rosa);
      outline-offset: 6px;
      border-radius: 2px;
    }

    .hp-svc__cta svg {
      transition: transform 0.3s var(--ease-out);
    }

    .hp-svc__cta:hover svg,
    .hp-svc__cta:focus-visible svg {
      transform: translateX(4px);
    }

    .hp-svc__list {
      display: flex;
      flex-direction: column;
      border-top: 1px solid var(--gray-500);
    }

    .hp-svc-item {
      border-bottom: 1px solid var(--gray-500);
      transition: background 0.4s var(--ease-out);
    }

    .hp-svc-item.is-open {
      background: linear-gradient(90deg, rgba(255, 39, 122, 0.04), transparent 60%);
    }

    .hp-svc-item__heading {
      margin: 0;
      font-weight: inherit;
      font-size: inherit;
    }

    .hp-svc-item__trigger {
      width: 100%;
      display: grid;
      grid-template-columns: 1fr auto;
      align-items: center;
      gap: var(--space-md);
      padding: var(--space-md) var(--space-sm);
      min-height: 72px;
      background: none;
      border: none;
      cursor: pointer;
      text-align: left;
      color: var(--white);
      font-family: inherit;
      transition: color 0.3s ease, background 0.3s ease;
    }

    @media (min-width: 768px) {
      .hp-svc-item__trigger {
        gap: var(--space-lg);
        padding: var(--space-md);
        min-height: 96px;
      }
    }

    .hp-svc-item__trigger:hover {
      color: var(--rosa);
    }

    .hp-svc-item__trigger:focus-visible {
      outline: 2px solid var(--rosa);
      outline-offset: -2px;
    }

    /* Sentence-case, comfortable spacing, perguntas são frases longas
       e merecem ler-se com naturalidade, não como etiquetas. */
    .hp-svc-item__question {
      font-size: var(--text-lg);
      font-weight: 500;
      line-height: 1.35;
      letter-spacing: 0;
      color: inherit;
    }

    @media (min-width: 768px) {
      .hp-svc-item__question {
        font-size: var(--text-xl);
      }
    }

    @media (min-width: 1280px) {
      .hp-svc-item__question {
        font-size: clamp(1.5rem, 1.8vw, 1.875rem);
        font-weight: 400;
        line-height: 1.3;
      }
    }

    /* Plus icon, rotates to X on open */
    .hp-svc-item__icon {
      flex-shrink: 0;
      width: 36px;
      height: 36px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      border: 1px solid var(--gray-700);
      transition: transform 0.4s var(--ease-out),
                  border-color 0.3s,
                  background 0.3s;
      color: currentColor;
    }

    .hp-svc-item__trigger:hover .hp-svc-item__icon {
      border-color: var(--rosa);
    }

    .hp-svc-item.is-open .hp-svc-item__icon {
      transform: rotate(45deg);
      background: var(--rosa);
      border-color: var(--rosa);
      color: var(--white);
    }

    /* Panel, uses grid-template-rows trick for accessible height animation */
    .hp-svc-item__panel {
      display: grid;
      grid-template-rows: 0fr;
      opacity: 0;
      transition: grid-template-rows 0.5s var(--ease-out),
                  opacity 0.4s var(--ease-out);
    }

    .hp-svc-item.is-open .hp-svc-item__panel {
      grid-template-rows: 1fr;
      opacity: 1;
    }

    .hp-svc-item__inner {
      overflow: hidden;
      min-height: 0;
    }

    .hp-svc-item.is-open .hp-svc-item__inner {
      padding: 0 var(--space-sm) var(--space-lg);
    }

    @media (min-width: 768px) {
      .hp-svc-item.is-open .hp-svc-item__inner {
        padding: 0 var(--space-md) var(--space-xl);
      }
    }

    .hp-svc-item__lead {
      font-size: var(--text-base);
      font-weight: 300;
      line-height: 1.55;
      color: var(--gray-300);
      max-width: 56ch;
      margin: 0 0 var(--space-sm);
    }

    /* Tags */
    .hp-svc-item__tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      list-style: none;
      padding: 0;
      margin: 0;
    }

    .hp-svc-item__tags li {
      font-size: var(--text-xs);
      font-weight: 500;
      letter-spacing: 0.02em;
      color: var(--rosa);
      background: rgba(255, 39, 122, 0.08);
      padding: 7px 16px;
      border: 1px solid rgba(255, 39, 122, 0.18);
      border-radius: 100px;
      white-space: nowrap;
      transition: background 0.3s, border-color 0.3s, color 0.3s;
    }

    .hp-svc-item__tags li:hover {
      background: rgba(255, 39, 122, 0.16);
      border-color: rgba(255, 39, 122, 0.35);
    }

    /* Reduced motion */
    @media (prefers-reduced-motion: reduce) {
      .hp-svc-item,
      .hp-svc-item__panel,
      .hp-svc-item__icon,
      .hp-svc-item__trigger,
      .hp-svc__cta,
      .hp-svc__cta svg {
        transition: none !important;
      }

      .hp-svc-item.is-open .hp-svc-item__icon {
        transform: none;
      }
    }

    /* High-contrast / forced-colors mode */
    @media (forced-colors: active) {
      .hp-svc-item {
        border-color: CanvasText;
      }
      .hp-svc-item__icon {
        border-color: CanvasText;
      }
      .hp-svc-item.is-open .hp-svc-item__icon {
        background: Highlight;
        color: HighlightText;
      }
    }


    /* ─────────────────────────────────────────────────
       STATS BLOCK, three big numbers between
       portfolio and clients. Stacks on mobile, row on
       tablet upward, with magenta vertical dividers.
       ───────────────────────────────────────────────── */

    .hp-stats-block {
      padding: var(--space-3xl) 0;
      border-top: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
    }

    @media (min-width: 768px) {
      .hp-stats-block {
        padding: var(--space-4xl) 0;
      }
    }

    .hp-stats-block__grid {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      gap: var(--space-xl);
      list-style: none;
      padding: 0;
      margin: 0;
    }

    @media (min-width: 768px) {
      .hp-stats-block__grid {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        gap: var(--space-lg);
      }
    }

    .hp-stats-block__item {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: var(--space-sm);
      text-align: center;
      padding: 0 var(--space-md);
    }

    @media (min-width: 768px) {
      .hp-stats-block__item {
        gap: var(--space-md);
      }
    }

    .hp-stats-block__number {
      font-size: clamp(3.5rem, 8vw, 6rem);
      font-weight: 700;
      line-height: 0.95;
      letter-spacing: -0.04em;
      color: var(--rosa);
      font-variant-numeric: tabular-nums;
      display: block;
    }

    .hp-stats-block__label {
      font-size: var(--text-sm);
      font-weight: 300;
      line-height: 1.4;
      color: var(--gray-300);
      letter-spacing: 0.01em;
      max-width: 22ch;
      margin: 0 auto;
    }

    @media (min-width: 768px) {
      .hp-stats-block__label {
        font-size: var(--text-base);
      }
    }

    /* Divider, horizontal on mobile, vertical on tablet+ */
    .hp-stats-block__divider {
      align-self: center;
      background: var(--gray-800);
      border: 0;
      flex-shrink: 0;
      width: 60%;
      height: 1px;
    }

    @media (min-width: 768px) {
      .hp-stats-block__divider {
        width: 1px;
        height: 80px;
      }
    }

    @media (min-width: 1024px) {
      .hp-stats-block__divider {
        height: 100px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .hp-stats-block__item {
        transition: none;
      }
    }


    /* =================================================
       Full client list (timeline) - lives INSIDE .hp-clients.
       Multi-column flow with 2024 -> current year header.
       Inherits the dark theme of the parent section.
       ================================================= */

    .hp-timeline {
      margin-top: var(--space-xl);
    }

    @media (min-width: 768px) {
      .hp-timeline {
        margin-top: var(--space-2xl);
      }
    }

    .hp-timeline__years {
      display: flex;
      align-items: center;
      gap: var(--space-md);
      margin-bottom: var(--space-xl);
    }

    .hp-timeline__year {
      font-size: var(--text-xs);
      font-weight: 300;
      color: var(--gray-400);
      font-variant-numeric: tabular-nums;
      letter-spacing: 0.02em;
      flex-shrink: 0;
    }

    @media (min-width: 768px) {
      .hp-timeline__year {
        font-size: var(--text-sm);
      }
    }

    .hp-timeline__rule {
      flex: 1;
      height: 1px;
      background: var(--gray-700);
    }

    .hp-timeline__list {
      list-style: none;
      margin: 0;
      padding: 0;
      column-count: 2;
      column-gap: var(--space-lg);
      font-family: 'IBM Plex Mono', 'Courier New', monospace;
      font-size: 11px;
      letter-spacing: 0.05em;
      text-transform: uppercase;
    }

    @media (min-width: 600px) {
      .hp-timeline__list {
        column-count: 3;
      }
    }

    @media (min-width: 900px) {
      .hp-timeline__list {
        column-count: 5;
        column-gap: var(--space-xl);
      }
    }

    .hp-timeline__list li {
      padding: 0.55rem 0;
      break-inside: avoid;
      border-bottom: 1px dotted var(--gray-700);
      color: var(--white);
      transition: color 0.2s var(--ease-out);
    }

    .hp-timeline__list li::before {
      content: '× ';
      color: var(--rosa);
      font-weight: 700;
    }

    .hp-timeline__list li:hover {
      color: var(--rosa);
    }

    @media (prefers-reduced-motion: reduce) {
      .hp-timeline__list li {
        transition: none;
      }
    }

    /* ── CAPACIDADES (tabela brutalist sobre dark) ── */
    .hp-cap {
      padding: var(--space-4xl) 0 0;
      border-top: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
    }
    .hp-cap__head {
      display: grid;
      grid-template-columns: 1fr;
      gap: 1.5rem;
      padding: 0 var(--container-padding) var(--space-2xl);
    }
    @media (min-width: 768px) {
      .hp-cap__head {
        grid-template-columns: 1fr 2fr;
        align-items: end;
        gap: clamp(2rem, 5vw, 4rem);
      }
    }
    .hp-cap__num {
      font-family: 'IBM Plex Mono', 'Courier New', monospace;
      font-size: 11px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gray-400);
    }
    .hp-cap__num b { color: var(--rosa); font-weight: 700; }
    .hp-cap__title {
      font-size: clamp(2rem, 5vw, 4rem);
      font-weight: 900;
      letter-spacing: -0.025em;
      line-height: 1.02;
      margin: 0;
      text-transform: uppercase;
      max-width: 14ch;
      color: var(--white);
    }
    .hp-cap__title em { font-style: normal; color: var(--rosa); }

    .hp-cap__table { border-top: 1px solid var(--gray-800); }
    .hp-cap__row {
      display: grid;
      grid-template-columns: 50px 1fr;
      align-items: baseline;
      padding: clamp(1.2rem, 3vw, 1.9rem) var(--container-padding);
      border-bottom: 1px solid var(--gray-800);
      text-decoration: none;
      color: var(--white);
      gap: 1rem;
      cursor: pointer;
      position: relative;
      transition: background 0.25s var(--ease-out), color 0.25s ease;
    }
    @media (min-width: 768px) {
      .hp-cap__row {
        grid-template-columns: 60px 1.4fr 1fr 60px;
      }
    }
    .hp-cap__row:hover {
      background: var(--white);
      color: var(--black);
    }
    .hp-cap__row:hover .hp-cap__row-num,
    .hp-cap__row:hover .hp-cap__row-meta { color: var(--rosa); }
    .hp-cap__row:hover .hp-cap__row-arrow::after {
      transform: translateX(8px);
      color: var(--rosa);
    }
    .hp-cap__row-num {
      font-family: 'IBM Plex Mono', monospace;
      font-size: clamp(11px, 0.8vw, 16px);
      letter-spacing: 0.1em;
      color: var(--gray-400);
      text-transform: uppercase;
    }
    .hp-cap__row-name {
      font-size: clamp(1.5rem, 3.6vw, 3.6rem);
      font-weight: 900;
      letter-spacing: -0.02em;
      text-transform: uppercase;
      line-height: 1.05;
    }
    .hp-cap__row-name em { font-style: normal; color: var(--rosa); }
    .hp-cap__row-meta {
      font-family: 'IBM Plex Mono', monospace;
      font-size: clamp(11px, 0.95vw, 18px);
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--gray-400);
      line-height: 1.6;
      display: none;
    }
    @media (min-width: 768px) {
      .hp-cap__row-meta { display: block; }
    }
    .hp-cap__row-arrow {
      font-family: 'IBM Plex Mono', monospace;
      text-align: right;
      display: none;
    }
    @media (min-width: 768px) {
      .hp-cap__row-arrow { display: inline-flex; justify-content: flex-end; }
    }
    .hp-cap__row-arrow::after {
      content: '→';
      display: inline-block;
      transition: transform 0.3s var(--ease-out), color 0.25s ease;
    }

    /* ── PORTFOLIO (mosaico brutalist, dark theme) ── */
    .hp-pf {
      padding: var(--space-4xl) 0 0;
      border-top: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
    }
    .hp-pf__head {
      display: grid;
      grid-template-columns: 1fr;
      gap: 1.5rem;
      padding: 0 var(--container-padding) var(--space-2xl);
    }
    @media (min-width: 768px) {
      .hp-pf__head {
        grid-template-columns: 1fr 2fr;
        align-items: end;
        gap: clamp(2rem, 5vw, 4rem);
      }
    }
    .hp-pf__num {
      font-family: 'IBM Plex Mono', 'Courier New', monospace;
      font-size: 11px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gray-400);
    }
    .hp-pf__num b { color: var(--rosa); font-weight: 700; }
    .hp-pf__title {
      font-size: clamp(2rem, 5vw, 4rem);
      font-weight: 900;
      letter-spacing: -0.025em;
      line-height: 1.02;
      margin: 0;
      text-transform: uppercase;
      max-width: 14ch;
      color: var(--white);
    }
    .hp-pf__title em { font-style: normal; color: var(--rosa); }

    .hp-pf-mosaic {
      display: flex;
      flex-direction: column;
      border-top: 1px solid var(--gray-800);
    }
    .hp-pf-row {
      display: flex;
      flex-direction: column;
      align-items: stretch;
    }
    @media (min-width: 700px) {
      .hp-pf-row {
        flex-direction: row;
        align-items: flex-start;
      }
      .hp-pf-row--5050 > .hp-pf__card { width: 50%; }
      .hp-pf-row--100  > .hp-pf__card { width: 100%; }
    }
    .hp-pf__card {
      position: relative;
      display: block;
      overflow: hidden;
      text-decoration: none;
      color: var(--white);
      background: transparent;
      isolation: isolate;
    }
    .hp-pf__img {
      width: 100%;
      height: auto;
      display: block;
      background: transparent;
    }

    /* Nome no canto superior esquerdo, pequeno */
    .hp-pf__name {
      position: absolute;
      top: 12px;
      left: 14px;
      z-index: 3;
      font-family: 'Inter', sans-serif;
      font-size: clamp(12px, 0.95vw, 15px);
      font-weight: 500;
      line-height: 1;
      letter-spacing: -0.005em;
      color: #fff;
      text-shadow: 0 1px 6px rgba(0,0,0,0.55);
      margin: 0;
      text-transform: none;
    }

    /* Chips de serviços no canto inferior esquerdo */
    .hp-pf__chips {
      position: absolute;
      left: 10px;
      bottom: 10px;
      z-index: 3;
      display: flex;
      gap: 6px;
      flex-wrap: wrap;
      align-items: center;
    }
    .hp-pf__chip {
      font-family: 'IBM Plex Mono', monospace;
      font-size: 10px;
      letter-spacing: 0.05em;
      font-weight: 500;
      padding: 5px 9px;
      background: rgba(250,250,250,0.92);
      color: var(--black);
      border-radius: 3px;
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      line-height: 1.2;
      text-transform: uppercase;
    }

    /* Card de logo (Neblu): fundo gradiente escuro para suportar logo */
    .hp-pf__card--logo {
      background: linear-gradient(160deg, #1f1f1f, #050505);
    }

    /* Card "+ Ver mais" — banda full-width branca no dark */
    .hp-pf__card--more {
      background: var(--white);
      color: var(--black);
      display: grid;
      grid-template-columns: 1fr;
      gap: 0.6rem;
      padding: clamp(1.5rem, 3vw, 2.5rem);
      transition: background 0.3s, color 0.3s;
    }
    @media (min-width: 700px) {
      .hp-pf__card--more {
        grid-template-columns: 1fr 2fr 1fr;
        align-items: center;
        gap: clamp(1.5rem, 4vw, 3rem);
        padding: clamp(1.5rem, 3vw, 2.5rem) clamp(2rem, 5vw, 4rem);
      }
    }
    .hp-pf__card--more:hover .hp-pf-more__name { color: var(--rosa); }
    .hp-pf-more__num {
      font-family: 'IBM Plex Mono', monospace;
      font-size: 11px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gray-500);
    }
    .hp-pf-more__name {
      font-size: clamp(1.6rem, 3.6vw, 3.2rem);
      font-weight: 900;
      letter-spacing: -0.025em;
      text-transform: uppercase;
      line-height: 1.02;
      margin: 0;
      transition: color 0.3s ease;
    }
    .hp-pf-more__name em { font-style: normal; color: var(--rosa); }
    .hp-pf-more__cta {
      font-family: 'IBM Plex Mono', monospace;
      font-size: 11px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gray-500);
      text-align: left;
    }
    @media (min-width: 700px) {
      .hp-pf-more__cta { text-align: right; }
    }

    /* ── Photo strip (contact-sheet sob o hero) ── */
    .hp-strip {
      display: grid;
      grid-template-columns: 1fr;
      gap: 0;
      border-top: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
    }
    @media (min-width: 600px) {
      .hp-strip { grid-template-columns: repeat(3, 1fr); }
    }
    .hp-strip__cell {
      position: relative;
      aspect-ratio: 3 / 2;
      background: #000;
      overflow: hidden;
      border-right: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
    }
    @media (min-width: 600px) {
      .hp-strip__cell { border-bottom: none; }
      .hp-strip__cell:last-child { border-right: none; }
    }
    .hp-strip__cell img {
      width: 100%; height: 100%;
      object-fit: cover; display: block;
      filter: grayscale(75%) contrast(1.05);
      transition: filter 0.5s var(--ease-out), transform 0.7s var(--ease-out);
    }
    .hp-strip__cell:hover img {
      filter: grayscale(0%);
      transform: scale(1.03);
    }
    /* Labels (data-no / data-cap) removidos — fotos limpas */

    /* ── Stats grid (estilo insurgente, UI do teste-pagina-inicial) ── */
    .ti-stats {
      background: var(--black);
      border-top: 1px solid var(--gray-800);
      display: grid;
      grid-template-columns: 1fr;
    }
    @media (min-width: 768px) {
      .ti-stats { grid-template-columns: repeat(3, 1fr); }
    }
    .ti-stat {
      padding: clamp(2.5rem, 6vw, 5rem) var(--container-padding);
      border-right: 1px solid var(--gray-800);
      border-bottom: 1px solid var(--gray-800);
      position: relative;
      overflow: hidden;
    }
    @media (max-width: 767px) {
      .ti-stat { text-align: center; }
      .ti-stat__label { margin-left: auto; margin-right: auto; }
    }
    .ti-stat:last-child { border-right: none; }
    @media (max-width: 767px) {
      .ti-stat { border-right: none; }
    }
    .ti-stat::after {
      content: '';
      position: absolute;
      inset: 0;
      background: var(--rosa);
      transform: translateY(101%);
      transition: transform 0.55s var(--ease-out);
      z-index: 0;
    }
    .ti-stat:hover::after,
    .ti-stat:focus-within::after { transform: translateY(0); }
    .ti-stat > * { position: relative; z-index: 1; transition: color 0.45s var(--ease-out); }
    .ti-stat:hover .ti-stat__num,
    .ti-stat:hover .ti-stat__label,
    .ti-stat:focus-within .ti-stat__num,
    .ti-stat:focus-within .ti-stat__label { color: var(--black); }
    .ti-stat__num {
      font-size: clamp(2.8rem, 7vw, 5rem);
      font-weight: 900;
      line-height: 1;
      letter-spacing: -0.04em;
      color: var(--white);
      font-variant-numeric: tabular-nums;
    }
    .ti-stat__num span { color: var(--rosa); transition: color 0.45s var(--ease-out); }
    .ti-stat:hover .ti-stat__num span,
    .ti-stat:focus-within .ti-stat__num span { color: var(--black); }
    .ti-stat__label {
      margin-top: var(--space-sm);
      font-size: var(--text-sm);
      color: var(--gray-400);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      max-width: 24ch;
    }
    @media (prefers-reduced-motion: reduce) {
      .ti-stat::after { transition: none; }
    }
