/* ===================================================================
   PERSONAL MUAY THAI — estilos específicos da landing de conversão
   (usa os tokens e componentes de styles.css)
   =================================================================== */

/* Selo/urgência no topo do hero */
.pm-flag{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-cond); font-weight:700; text-transform:uppercase; letter-spacing:.14em;
  font-size:.8rem; color:#1a0c02; background:var(--orange);
  padding:.5em 1em; border-radius:999px; margin-bottom:1.4rem;
  box-shadow:0 10px 26px -12px rgba(242,106,27,.7);
}

/* ---------- Banda de dor/promessa ---------- */
.pm-pain{ background:var(--ink); padding:clamp(60px,9vw,110px) 0; }
.pm-pain__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,6vw,4.5rem); align-items:center; }
.pm-pain__text p{ color:#d7d7d2; margin:1.3rem 0; max-width:54ch; }
.pm-strike{ color:var(--ash); }
.pm-strike b{ color:#e3e3df; font-weight:600; }

.pm-checks{ display:grid; gap:.85rem; margin-top:.5rem; }
.pm-check{
  display:flex; gap:.9rem; align-items:flex-start;
  background:var(--graphite); border:1px solid rgba(255,255,255,.07);
  border-radius:12px; padding:1rem 1.15rem;
}
.pm-check svg{ width:22px; height:22px; flex:none; margin-top:2px; fill:var(--orange); }
.pm-check span{ color:#e6e6e2; font-size:1.02rem; }
.pm-check b{ color:#fff; }

/* ---------- Como funciona (passos) ---------- */
.pm-steps{ background:linear-gradient(180deg,var(--ink),var(--ink-2)); padding:clamp(60px,9vw,120px) 0; }
.pm-steps__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:2.6rem; }
.pm-step{
  position:relative; background:var(--graphite); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius); padding:2.2rem 1.7rem 1.9rem; overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s;
}
.pm-step:hover{ transform:translateY(-5px); border-color:rgba(242,106,27,.4); }
.pm-step__n{
  font-family:var(--font-display); font-size:3.4rem; line-height:1; color:transparent;
  -webkit-text-stroke:1.5px rgba(242,106,27,.55); text-stroke:1.5px rgba(242,106,27,.55);
  display:block; margin-bottom:.6rem;
}
.pm-step h3{ font-family:var(--font-display); text-transform:uppercase; font-size:1.4rem; line-height:1.05; margin-bottom:.6rem; }
.pm-step p{ color:var(--ash); font-size:1rem; }

/* ---------- Benefícios ---------- */
.pm-benefits{ background:var(--ink-2); padding:clamp(60px,9vw,120px) 0; }
.pm-benefits__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:2.6rem; }
.pm-benefit{
  background:var(--graphite); border:1px solid rgba(255,255,255,.07); border-radius:var(--radius);
  padding:1.7rem; transition:transform .3s var(--ease), border-color .3s;
}
.pm-benefit:hover{ transform:translateY(-4px); border-color:rgba(242,106,27,.35); }
.pm-benefit__ico{
  width:52px; height:52px; border-radius:12px; display:grid; place-items:center;
  background:rgba(242,106,27,.12); border:1px solid rgba(242,106,27,.3); margin-bottom:1rem;
}
.pm-benefit__ico svg{ width:26px; height:26px; fill:var(--orange); }
.pm-benefit h3{ font-family:var(--font-cond); font-weight:700; text-transform:uppercase; letter-spacing:.03em; font-size:1.2rem; margin-bottom:.4rem; }
.pm-benefit p{ color:var(--ash); font-size:.98rem; }

/* ---------- Prova (professor) ---------- */
.pm-proof{ background:linear-gradient(180deg,var(--ink-2),var(--ink)); padding:clamp(60px,9vw,120px) 0; }
.pm-proof__grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(2rem,6vw,4.5rem); align-items:center; }
.pm-proof__media{ position:relative; }
.pm-proof__frame{ border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5;
  clip-path:polygon(0 0,100% 0,100% 92%,92% 100%,0 100%); box-shadow:0 30px 80px -30px rgba(0,0,0,.9); }
.pm-proof__frame img{ width:100%; height:100%; object-fit:cover; }
.pm-proof__tag{ position:absolute; left:-10px; bottom:24px;
  font-family:var(--font-display); text-transform:uppercase; background:var(--orange); color:#1a0c02;
  padding:.4em .9em; font-size:1.2rem; box-shadow:0 12px 30px -10px rgba(242,106,27,.7); }
.pm-proof__text p{ color:#d7d7d2; margin:1.3rem 0; max-width:56ch; }

/* ---------- Planos (sem preço, direciona ao WhatsApp) ---------- */
.pm-plans{ background:var(--ink); padding:clamp(60px,9vw,120px) 0; }
.pm-plans__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:2.6rem; }
.pm-plan{
  position:relative; background:var(--graphite); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius); padding:2rem 1.7rem; display:flex; flex-direction:column;
  transition:transform .3s var(--ease), border-color .3s;
}
.pm-plan:hover{ transform:translateY(-5px); }
.pm-plan--featured{ border-color:var(--orange); box-shadow:0 26px 60px -30px rgba(242,106,27,.5); }
.pm-plan__badge{
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  font-family:var(--font-cond); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:.75rem;
  background:var(--orange); color:#1a0c02; padding:.35em .9em; border-radius:999px;
}
.pm-plan h3{ font-family:var(--font-display); text-transform:uppercase; font-size:1.55rem; line-height:1; margin-bottom:.3rem; }
.pm-plan__desc{ color:var(--ash); font-size:.96rem; margin-bottom:1.2rem; }
.pm-plan ul{ display:grid; gap:.65rem; margin-bottom:1.6rem; }
.pm-plan li{ position:relative; padding-left:1.6rem; color:#e3e3df; font-size:.98rem; }
.pm-plan li::before{ content:""; position:absolute; left:0; top:.5em; width:9px; height:9px; background:var(--orange); transform:rotate(45deg); }
.pm-plan .btn{ margin-top:auto; justify-content:center; }
.pm-plans__note{ text-align:center; margin-top:1.8rem; color:var(--ash); font-size:.95rem; }

/* ---------- FAQ (details/summary — sem JS) ---------- */
.pm-faq{ background:linear-gradient(180deg,var(--ink),var(--ink-2)); padding:clamp(60px,9vw,120px) 0; }
.pm-faq__list{ max-width:820px; margin:2.4rem auto 0; display:grid; gap:12px; }
.pm-faq__item{
  background:var(--graphite); border:1px solid rgba(255,255,255,.07); border-radius:12px; overflow:hidden;
}
.pm-faq__item summary{
  list-style:none; cursor:pointer; padding:1.2rem 1.4rem; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  font-family:var(--font-cond); font-weight:600; font-size:1.12rem; color:#f2f2ee;
}
.pm-faq__item summary::-webkit-details-marker{ display:none; }
.pm-faq__item summary::after{
  content:"+"; font-family:var(--font-display); color:var(--orange); font-size:1.5rem; line-height:1; flex:none; transition:transform .3s var(--ease);
}
.pm-faq__item[open] summary::after{ transform:rotate(45deg); }
.pm-faq__item p{ padding:0 1.4rem 1.3rem; color:var(--ash); }

/* ---------- CTA final da página ---------- */
.pm-final{ position:relative; text-align:center; padding:clamp(70px,11vw,140px) 0;
  background:linear-gradient(120deg,var(--orange-deep),var(--orange) 55%,var(--orange-bright)); overflow:hidden; }
.pm-final .cta__grain{ position:absolute; inset:0; opacity:.18; mix-blend-mode:multiply; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.pm-final__inner{ position:relative; z-index:2; }
.pm-final__title{ font-family:var(--font-display); text-transform:uppercase; color:#1a0c02; line-height:1.05; font-size:clamp(2.4rem,7vw,4.8rem); }
.pm-final__sub{ color:#2a1402; font-weight:500; max-width:48ch; margin:1.2rem auto 2.2rem; font-size:1.1rem; }

/* Voltar ao site */
.pm-back{ font-family:var(--font-cond); font-weight:600; text-transform:uppercase; letter-spacing:.06em; font-size:.95rem; color:var(--ash); }
.pm-back:hover{ color:var(--orange); }

/* ---------- Responsivo ---------- */
@media (max-width:980px){
  .pm-pain__grid, .pm-proof__grid{ grid-template-columns:1fr; }
  .pm-proof__media{ max-width:420px; }
  .pm-steps__grid, .pm-benefits__grid, .pm-plans__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  .pm-steps__grid, .pm-benefits__grid, .pm-plans__grid{ grid-template-columns:1fr; }
}
