    /* ── Hero ──────────────────────────────────── */
    .pg-hero{background:var(--yellow-bg);padding:52px 0 44px;border-bottom:1px solid var(--yellow);position:relative;overflow:hidden}
    .pg-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(247,197,0,.18),transparent);pointer-events:none}

    /* Search */
    .search-wrap{
      max-width:480px;margin:22px auto 0;
      display:flex;align-items:center;gap:10px;
      background:var(--white);border:1.5px solid var(--gray-200);
      border-radius:var(--radius-pill);padding:11px 20px;
      transition:border-color .2s, box-shadow .2s;
    }
    .search-wrap:focus-within{border-color:var(--yellow);box-shadow:0 0 0 4px rgba(247,197,0,.15)}
    .search-input{border:none;background:transparent;font-family:'Nunito Sans',sans-serif;font-size:14px;color:var(--black);outline:none;flex:1}

    /* ── Filter bar ─────────────────────────────── */
    .filters-bar{padding:18px 0;border-bottom:1px solid var(--gray-100);background:var(--white);position:sticky;top:64px;z-index:10}
    .filters-inner{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
    .filter-chip{
      padding:7px 18px;border-radius:var(--radius-pill);font-size:13px;font-weight:700;
      cursor:pointer;border:2px solid var(--gray-200);color:var(--gray-500);
      font-family:'Nunito',sans-serif;background:var(--white);
      transition:all .2s;display:flex;align-items:center;gap:6px;
      user-select:none;
    }
    .filter-chip:hover{border-color:var(--yellow-d);color:var(--black)}
    .filter-chip.on{background:var(--yellow);border-color:var(--yellow);color:var(--black);box-shadow:0 2px 10px rgba(247,197,0,.3)}
    .filter-chip svg{flex-shrink:0}
    .results-count{margin-left:auto;font-size:13px;color:var(--gray-400);font-weight:600}

    /* ── Partner grid & FLIP container ─────────── */
    .partners-section{padding:36px 0 64px}

    /* ═══════════════════════════════════════════
       INOVAÇÃO 4 — Fluid Filter (Isotope-style FLIP)
       .p-grid uses CSS Grid; JS records positions,
       mutates DOM, then plays FLIP transitions
    ═══════════════════════════════════════════ */
    .p-grid{
      display:grid;
      grid-template-columns:repeat(5,1fr);
      gap:16px;
      position:relative;
    }

    .p-card{
      background:var(--white);border:1.5px solid var(--gray-100);
      border-radius:18px;padding:20px 14px;text-align:center;
      cursor:pointer;position:relative;
      transition:border-color .25s, box-shadow .25s, transform .25s, opacity .25s;
      will-change:transform;
      --mx:50%;--my:50%;
    }
    /* Card spotlight on hover */
    .p-card::before{
      content:'';position:absolute;inset:-1px;border-radius:inherit;
      background:radial-gradient(200px circle at var(--mx) var(--my), rgba(247,197,0,.45), transparent 70%);
      opacity:0;transition:opacity .3s;pointer-events:none;z-index:0;
    }
    .p-card:hover::before{opacity:1}
    .p-card:hover{border-color:rgba(247,197,0,.55);box-shadow:0 6px 24px rgba(247,197,0,.18);transform:translateY(-3px)}
    .p-card > *{position:relative;z-index:1}

    /* FLIP transition classes */
    .p-card.flip-transit{
      transition:transform .38s cubic-bezier(.4,0,.2,1), opacity .3s ease !important;
    }
    .p-card.hiding{
      opacity:0;transform:scale(.85) !important;
      pointer-events:none;
    }
    .p-card.entering{
      animation:card-enter .38s cubic-bezier(.34,1.3,.64,1) forwards;
    }
    @keyframes card-enter{
      from{opacity:0;transform:scale(.82) translateY(12px)}
      to{opacity:1;transform:scale(1) translateY(0)}
    }

    .p-logo{width:52px;height:52px;border-radius:14px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--black);font-family:'Nunito',sans-serif}
    .p-name{font-size:13px;font-weight:800;color:var(--black);margin-bottom:3px;font-family:'Nunito',sans-serif}
    .p-cat{font-size:11px;color:var(--gray-400);margin-bottom:10px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:4px}
    .p-cashback{display:inline-flex;align-items:center;gap:4px;background:var(--yellow-bg);border:1.5px solid var(--yellow);color:var(--black);font-family:'Nunito',sans-serif;font-size:12px;font-weight:900;border-radius:var(--radius-pill);padding:4px 10px}
    .p-pro{position:absolute;top:10px;right:10px;background:var(--black);color:var(--yellow);font-size:9px;font-weight:900;border-radius:6px;padding:2px 7px;font-family:'Nunito',sans-serif;letter-spacing:.5px}
    .p-card[data-plano="premium"] .p-cashback{background:#1A1A1A;color:var(--yellow);border-color:#1A1A1A}

    /* Empty state */
    .empty{text-align:center;padding:56px 0;color:var(--gray-400);display:none}
    .empty.show{display:block}
    .empty h3{font-family:'Nunito',sans-serif;font-size:18px;font-weight:800;margin-bottom:8px;color:var(--black)}

    /* ── Modal ─────────────────────────────────── */
    .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(4px)}
    .modal-overlay.open{opacity:1;pointer-events:all}
    .modal{background:var(--white);border-radius:22px;padding:34px;width:490px;max-width:92vw;max-height:90vh;overflow-y:auto;transform:translateY(14px) scale(.97);transition:transform .3s cubic-bezier(.34,1.4,.64,1)}
    .modal-overlay.open .modal{transform:translateY(0) scale(1)}
    .modal-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}
    .modal-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;font-family:'Nunito',sans-serif;font-weight:900}
    .modal-title{font-family:'Nunito',sans-serif;font-size:20px;font-weight:900;color:var(--black)}
    .modal-sub{font-size:13px;color:var(--gray-400)}
    .modal-close{margin-left:auto;background:var(--gray-100);border:none;width:34px;height:34px;border-radius:50%;font-size:15px;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}
    .modal-close:hover{background:var(--gray-200)}
    .modal-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--gray-100);font-size:14px}
    .modal-row:last-child{border-bottom:none}
    .modal-row-label{color:var(--gray-500)}
    .modal-row-value{font-weight:700;color:var(--black)}

    /* ── Responsividade Parceiros ── */
    @media (max-width: 980px) {
      .p-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
      .pg-hero { padding: 36px 0 32px; }
      .filters-inner {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 4px;
      }
      .filters-inner::-webkit-scrollbar { display: none; }
      .filter-chip { flex-shrink: 0; white-space: nowrap; }
      .results-count { display: none; }
    }

    @media (max-width: 640px) {
      .p-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
      .pg-hero h1 { font-size: 1.5rem; }
      .search-wrap { margin: 16px 12px 0; }
    }

    @media (max-width: 380px) {
      .p-grid { grid-template-columns: 1fr; gap: 10px; }
      .p-card { padding: 16px 12px; }
      .partners-section { padding: 24px 0 48px; }
    }

    /* Modal mobile — bottom sheet */
    @media (max-width: 640px) {
      .modal-overlay { align-items: flex-end; }
      .modal {
        width: 100%;
        max-width: 100%;
        border-radius: 22px 22px 0 0;
        padding: 28px 20px 36px;
        max-height: 88vh;
        transform: translateY(100%) scale(1);
      }
      .modal-overlay.open .modal { transform: translateY(0) scale(1); }
      .modal::before {
        content: '';
        display: block;
        width: 40px; height: 4px;
        background: var(--gray-200);
        border-radius: 50px;
        margin: 0 auto 18px;
      }
    }

