/* =============================================================
   PFP ADVERTISE WITH US
   Matches ResponsibleTrading.com design system exactly.
   ============================================================= */

.pfpadv-wrap {
  font-family: var(--font-body, 'DM Sans', system-ui, sans-serif);
  color: var(--tx-1, #F0F4FF);
}

/* HERO */
.pfpadv-hero {
  position: relative;
  padding: 3.5rem 1.5rem 3rem;
  text-align: center;
  overflow: hidden;
}
.pfpadv-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 50% at 50% 0%, rgba(0,212,160,.07) 0%, transparent 70%),
    radial-gradient(ellipse 30% 35% at 85% 80%, rgba(59,130,246,.04) 0%, transparent 60%);
  pointer-events: none;
}
.pfpadv-hero-inner {
  position: relative; z-index: 1;
  max-width: 620px; margin: 0 auto;
}
.pfpadv-eyebrow {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--pfp-green, #00D4A0);
  background: var(--pfp-green-bg, rgba(0,212,160,.08));
  border: 1px solid var(--pfp-green-border, rgba(0,212,160,.22));
  border-radius: 100px; padding: .28rem .75rem; margin-bottom: 1.25rem;
}
.pfpadv-hero-title {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 800; line-height: 1.15; letter-spacing: -.02em;
  color: var(--tx-1, #F0F4FF); margin: 0 0 1rem;
}
.pfpadv-hero-sub {
  font-size: .875rem; color: var(--tx-2, #8B9BBD);
  line-height: 1.7; max-width: 520px; margin: 0 auto 1.75rem;
}
.pfpadv-hero-actions { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }

/* STATS BAR */
.pfpadv-stats-bar {
  display: grid; grid-template-columns: repeat(4,1fr);
  background: var(--bg-surface, #0D1120);
  border-top: 1px solid var(--border, rgba(255,255,255,.06));
  border-bottom: 1px solid var(--border, rgba(255,255,255,.06));
}
@media (max-width:600px) { .pfpadv-stats-bar { grid-template-columns: 1fr 1fr; } }
.pfpadv-stat {
  padding: 1.25rem 1rem; text-align: center;
  border-right: 1px solid var(--border, rgba(255,255,255,.06));
}
.pfpadv-stat:last-child { border-right: none; }
.pfpadv-stat-num {
  display: block;
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: 1.5rem; font-weight: 800;
  color: var(--pfp-green, #00D4A0); line-height: 1; margin-bottom: .2rem;
}
.pfpadv-stat-label { font-size: .72rem; color: var(--tx-3, #4E5E7A); font-weight: 500; }

/* SECTIONS */
.pfpadv-section { padding: 3.5rem 1.5rem; max-width: 1140px; margin: 0 auto; }
.pfpadv-section-dark {
  background: var(--bg-surface, #0D1120); max-width: 100%;
  border-top: 1px solid var(--border, rgba(255,255,255,.06));
  border-bottom: 1px solid var(--border, rgba(255,255,255,.06));
  padding: 3.5rem 0;
}
.pfpadv-section-dark .pfpadv-section-head { padding: 0 1.5rem; }
.pfpadv-section-dark .pfpadv-pkg-grid,
.pfpadv-section-dark .pfpadv-aud-grid {
  max-width: 1140px; margin: 0 auto; padding: 0 1.5rem; box-sizing: border-box;
}
.pfpadv-section-head { text-align: center; margin-bottom: 2rem; }
.pfpadv-section-head h2 {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: clamp(1.2rem, 2.2vw, 1.6rem);
  font-weight: 800; color: var(--tx-1, #F0F4FF);
  margin: 0 0 .5rem; letter-spacing: -.015em;
}
.pfpadv-section-head p {
  font-size: .85rem; color: var(--tx-2, #8B9BBD);
  max-width: 480px; margin: 0 auto; line-height: 1.65;
}

/* WHY GRID */
.pfpadv-why-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
@media (max-width:860px) { .pfpadv-why-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width:520px) { .pfpadv-why-grid { grid-template-columns: 1fr; } }
.pfpadv-why-card {
  background: var(--bg-card, #141D2E);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: var(--r-xl, 22px); padding: 1.35rem;
  transition: border-color .2s, transform .2s;
}
.pfpadv-why-card:hover { border-color: var(--pfp-green-border, rgba(0,212,160,.22)); transform: translateY(-2px); }
.pfpadv-why-icon {
  width: 38px; height: 38px; border-radius: var(--r-md, 10px);
  background: var(--pfp-green-bg, rgba(0,212,160,.08));
  border: 1px solid var(--pfp-green-border, rgba(0,212,160,.22));
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; color: var(--pfp-green, #00D4A0); margin-bottom: .75rem;
}
.pfpadv-why-card h3 {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: .875rem; font-weight: 700; color: var(--tx-1, #F0F4FF); margin: 0 0 .35rem;
}
.pfpadv-why-card p { font-size: .8rem; color: var(--tx-2, #8B9BBD); line-height: 1.6; margin: 0; }

/* PACKAGES */
.pfpadv-pkg-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
@media (max-width:860px) { .pfpadv-pkg-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; } }
.pfpadv-pkg {
  background: var(--bg-card, #141D2E);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: var(--r-xl, 22px); padding: 1.5rem;
  display: flex; flex-direction: column; position: relative;
  transition: transform .2s, box-shadow .2s;
}
.pfpadv-pkg:hover { transform: translateY(-3px); box-shadow: var(--shadow-md, 0 4px 24px rgba(0,0,0,.5)); }
.pfpadv-pkg-featured {
  border-color: var(--pfp-green-border, rgba(0,212,160,.22));
  background: linear-gradient(160deg, var(--bg-card, #141D2E), rgba(0,212,160,.03));
}
.pfpadv-pkg-featured::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--pfp-green, #00D4A0), #00A8FF);
  border-radius: 22px 22px 0 0;
}
.pfpadv-pkg-badge {
  display: inline-block; align-self: flex-start;
  background: var(--pfp-green, #00D4A0); color: #000;
  font-size: .6rem; font-weight: 800; text-transform: uppercase; letter-spacing: .07em;
  padding: .18rem .55rem; border-radius: 100px; margin-bottom: .75rem;
}
.pfpadv-pkg-name {
  font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  color: var(--tx-3, #4E5E7A); margin-bottom: .3rem;
}
.pfpadv-pkg-price { display: flex; align-items: baseline; gap: .15rem; margin-bottom: .4rem; }
.pfpadv-pkg-price strong {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: 1.85rem; font-weight: 800; color: var(--tx-1, #F0F4FF);
  line-height: 1; letter-spacing: -.02em;
}
.pfpadv-pkg-price span { font-size: .78rem; color: var(--tx-3, #4E5E7A); }
.pfpadv-pkg-desc { font-size: .8rem; color: var(--tx-2, #8B9BBD); line-height: 1.5; margin: 0 0 1.1rem; }
.pfpadv-pkg-features {
  list-style: none; padding: 0; margin: 0 0 1.25rem; flex: 1;
  display: flex; flex-direction: column; gap: .45rem;
  border-top: 1px solid var(--border, rgba(255,255,255,.06)); padding-top: 1.1rem;
}
.pfpadv-pkg-features li {
  display: flex; align-items: flex-start; gap: .4rem;
  font-size: .8rem; color: var(--tx-2, #8B9BBD); line-height: 1.45;
}
.pfpadv-pkg-features li i { color: var(--pfp-green, #00D4A0); font-size: .9rem; flex-shrink: 0; margin-top: .1rem; }
.pfpadv-pkg-cta { margin-top: auto; }

/* WHAT YOU GET */
.pfpadv-get-wrap { display: grid; grid-template-columns: 1fr 1.4fr; gap: 3rem; align-items: center; }
@media (max-width:720px) { .pfpadv-get-wrap { grid-template-columns: 1fr; gap: 1.5rem; } }
.pfpadv-get-left h2 {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  font-weight: 800; color: var(--tx-1, #F0F4FF); margin: 0 0 .625rem; letter-spacing: -.015em;
}
.pfpadv-get-left p { font-size: .85rem; color: var(--tx-2, #8B9BBD); line-height: 1.65; margin: 0; }
.pfpadv-get-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .45rem; }
.pfpadv-get-list li {
  display: flex; align-items: center; gap: .625rem;
  padding: .625rem .875rem;
  background: var(--bg-card, #141D2E);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: var(--r-md, 10px);
  font-size: .82rem; color: var(--tx-2, #8B9BBD);
  transition: border-color .15s, color .15s;
}
.pfpadv-get-list li:hover { border-color: var(--pfp-green-border, rgba(0,212,160,.22)); color: var(--tx-1, #F0F4FF); }
.pfpadv-get-list li i { color: var(--pfp-green, #00D4A0); font-size: .95rem; flex-shrink: 0; }

/* AUDIENCE */
.pfpadv-aud-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; }
@media (max-width:860px) { .pfpadv-aud-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width:480px) { .pfpadv-aud-grid { grid-template-columns: 1fr; } }
.pfpadv-aud-card {
  background: var(--bg-card, #141D2E);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: var(--r-xl, 22px); padding: 1.25rem 1rem; text-align: center;
}
.pfpadv-aud-pct {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: 2rem; font-weight: 800; color: var(--pfp-green, #00D4A0);
  line-height: 1; margin-bottom: .4rem; letter-spacing: -.02em;
}
.pfpadv-aud-card p { font-size: .78rem; color: var(--tx-2, #8B9BBD); line-height: 1.5; margin: 0; }

/* CONTACT */
.pfpadv-contact-wrap { display: grid; grid-template-columns: 1fr 1.6fr; gap: 3rem; align-items: start; }
@media (max-width:860px) { .pfpadv-contact-wrap { grid-template-columns: 1fr; gap: 1.75rem; } }
.pfpadv-contact-left h2 {
  font-family: var(--font-heading, 'Syne', system-ui, sans-serif);
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  font-weight: 800; color: var(--tx-1, #F0F4FF); margin: 0 0 .625rem; letter-spacing: -.015em;
}
.pfpadv-contact-left > p { font-size: .85rem; color: var(--tx-2, #8B9BBD); line-height: 1.65; margin: 0 0 .875rem; }
.pfpadv-direct-email { font-size: .8rem; color: var(--tx-3, #4E5E7A) !important; margin: 0 0 1.25rem !important; }
.pfpadv-direct-email a { color: var(--pfp-green, #00D4A0); font-weight: 600; }
.pfpadv-contact-badges { display: flex; flex-wrap: wrap; gap: .4rem; }
.pfpadv-contact-badges span {
  display: inline-flex; align-items: center; gap: .3rem;
  font-size: .72rem; color: var(--tx-2, #8B9BBD);
  background: var(--bg-raised, #121826);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: 100px; padding: .28rem .7rem;
}
.pfpadv-contact-badges i { color: var(--pfp-green, #00D4A0); font-size: .8rem; }

/* FORM */
.pfpadv-form-card {
  background: var(--bg-card, #141D2E);
  border: 1px solid var(--border-md, rgba(255,255,255,.10));
  border-radius: var(--r-xl, 22px); padding: 1.5rem;
}
.pfpadv-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-bottom: .75rem; }
@media (max-width:540px) { .pfpadv-form-row { grid-template-columns: 1fr; } }
.pfpadv-form-group { display: flex; flex-direction: column; gap: .3rem; margin-bottom: .75rem; }
.pfpadv-form-row .pfpadv-form-group { margin-bottom: 0; }
.pfpadv-form-group label {
  font-size: .7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--tx-2, #8B9BBD);
}
.pfpadv-form-group input,
.pfpadv-form-group select,
.pfpadv-form-group textarea {
  background: var(--bg-input, #0F1520);
  border: 1.5px solid var(--border-md, rgba(255,255,255,.10));
  color: var(--tx-1, #F0F4FF);
  border-radius: var(--r-md, 10px);
  padding: .6rem .875rem; font-size: .875rem; font-family: inherit;
  transition: border-color .2s, box-shadow .2s;
  width: 100%; box-sizing: border-box;
}
.pfpadv-form-group input:focus,
.pfpadv-form-group select:focus,
.pfpadv-form-group textarea:focus {
  outline: none;
  border-color: var(--pfp-green, #00D4A0);
  box-shadow: 0 0 0 3px var(--pfp-green-bg, rgba(0,212,160,.08));
}
.pfpadv-form-group input::placeholder,
.pfpadv-form-group textarea::placeholder { color: var(--tx-4, #2E3A50); }
.pfpadv-form-group select option { background: #141D2E; }
.pfpadv-form-group textarea { resize: vertical; min-height: 95px; }
#pfpadv-msg {
  margin-top: .875rem; padding: .65rem .875rem;
  border-radius: var(--r-md, 10px); font-size: .8rem; text-align: center;
}
#pfpadv-msg.success {
  background: var(--pfp-green-bg, rgba(0,212,160,.08));
  color: var(--pfp-green, #00D4A0);
  border: 1px solid var(--pfp-green-border, rgba(0,212,160,.22));
}
#pfpadv-msg.error {
  background: var(--pfp-red-bg, rgba(239,68,68,.08));
  color: var(--pfp-red, #EF4444);
  border: 1px solid rgba(239,68,68,.22);
}
