/* ============================================================
   Páginas de funil da MARCA Grupo Karppa: /bio/ (linktree do
   Instagram @grupokarppa) e /agendar/ (captura da Sessão
   Estratégica para tráfego pago).

   Carregado DEPOIS de styles.css: reaproveita os tokens, os
   botões (.btn), os campos (.field) e o sucesso (.form-success)
   do design system institucional, e adiciona só os componentes
   específicos do funil (prefixo .k-), espelhando a estrutura
   das páginas do perfil do Nícolas (nicolas.css), mas com a
   identidade da marca: azul profundo + laranja como destaque,
   tipografia Archopada Rounded, mobile-first.
   ============================================================ */

/* ---------- Base da página (sobre o azul profundo) ---------- */
.k-page {
  /* aura laranja sutil no topo (espelha a aura dourada do perfil) */
  background-image: radial-gradient(120% 60% at 50% -10%, rgba(230, 57, 5, 0.12), rgba(230, 57, 5, 0) 60%);
  background-repeat: no-repeat;
  min-height: 100vh;
  line-height: 1.7;
}
.k-page strong, .k-page b { color: #FFFFFF; font-weight: 800; }
.k-page img { max-width: 100%; height: auto; display: block; }
/* mobile: esconde a barra de rolagem (o scroll continua funcionando) */
@media (max-width: 768px) {
  .k-page { scrollbar-width: none; -ms-overflow-style: none; }
  .k-page::-webkit-scrollbar { width: 0; height: 0; display: none; }
}

/* ---------- Layout ---------- */
.k-wrap { width: 100%; max-width: 640px; margin: 0 auto; padding: 0 20px; }
.k-wrap--narrow { max-width: 460px; }
@media (min-width: 480px) { .k-wrap { padding: 0 28px; } }
/* faixa de seção full-bleed: cria quebra visual entre seções vizinhas */
.k-band {
  background: rgba(255, 255, 255, 0.045);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  padding: 52px 0;
}

/* ---------- Tipografia ---------- */
/* kicker próprio do funil: NÃO usa .eyebrow (que some no mobile na home) */
.k-eyebrow {
  display: inline-block;
  color: var(--orange-300);
  font-size: 0.74rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 800;
}
.k-h1, .k-h2 { color: #FFFFFF; letter-spacing: var(--track-tight); }
/* teto em 2.25rem: no desktop (coluna de 640px) o H1 da captura fica em
   até 4 linhas (pedido do dono); no mobile quem manda é o termo em vw */
.k-h1 { font-size: clamp(1.7rem, 7.1vw, 2.25rem); font-weight: 900; line-height: 1.08; margin: 0; }
.k-h2 { font-size: clamp(1.5rem, 6vw, 2.1rem); font-weight: 800; line-height: 1.12; margin: 0; }
.k-lead-sub { color: rgba(255, 255, 255, 0.72); font-size: 1.06rem; line-height: 1.5; margin: 0; }
.k-lead-sub strong { color: #FFFFFF; }

/* número-promessa em destaque na headline */
.k-hl-num { color: var(--orange-300); font-style: italic; white-space: nowrap; }

/* linha fina laranja (separador pontual) */
.k-rule { width: 64px; height: 3px; border-radius: 2px; background: var(--karppa-orange); border: 0; margin: 0; }
.k-rule--full { width: 100%; height: 1px; background: rgba(255, 255, 255, 0.12); border: 0; margin: 0; }

/* ---------- Selo de escassez ---------- */
.k-badge {
  display: inline-flex; align-items: center; gap: 9px;
  border: 1px solid var(--orange-300); color: var(--orange-300);
  border-radius: 999px; padding: 9px 16px;
  font-size: 0.72rem; line-height: 1; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 800;
}
.k-badge::before {
  content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--orange-300);
  animation: k-pulse 2s infinite;
}
@keyframes k-pulse {
  0% { box-shadow: 0 0 0 0 rgba(254, 121, 89, 0.5); }
  70% { box-shadow: 0 0 0 8px rgba(254, 121, 89, 0); }
  100% { box-shadow: 0 0 0 0 rgba(254, 121, 89, 0); }
}
@media (prefers-reduced-motion: reduce) { .k-badge::before { animation: none; } }

/* ---------- CTA primário com brilho pulsante (conversão) ---------- */
.k-glow { box-shadow: 0 0 18px rgba(230, 57, 5, 0.38); animation: k-ctaglow 2.6s ease-in-out infinite; }
@keyframes k-ctaglow {
  0%, 100% { box-shadow: 0 0 16px rgba(230, 57, 5, 0.34); }
  50% { box-shadow: 0 0 34px 3px rgba(230, 57, 5, 0.65); }
}
@media (prefers-reduced-motion: reduce) { .k-glow { animation: none; } }
/* na coluna estreita do funil, o CTA ocupa a largura toda */
.k-wrap .btn { width: 100%; }

/* ---------- Símbolo da carpa no hero (com brilho laranja atrás) ---------- */
.k-figure { position: relative; width: min(320px, 78%); margin: 0 auto; }
.k-figure::before {
  content: ''; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 132%; height: 96%; z-index: 0; pointer-events: none;
  background: radial-gradient(closest-side, rgba(230, 57, 5, 0.30), rgba(230, 57, 5, 0) 72%);
}
.k-figure svg, .k-figure img { position: relative; z-index: 1; width: 100%; height: auto; display: block; filter: drop-shadow(0 26px 46px rgba(0, 0, 0, 0.6)); }

/* ---------- Lista numerada (o que você sai sabendo) ---------- */
.k-points { list-style: none; display: grid; gap: 0; margin: 0; padding: 0; }
.k-point {
  display: grid; grid-template-columns: 54px 1fr; gap: 18px; align-items: start;
  padding: 22px 0; border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.k-point:last-child { border-bottom: 1px solid rgba(255, 255, 255, 0.12); }
.k-point__num { color: var(--orange-300); font-style: italic; font-weight: 800; font-size: 1.6rem; line-height: 1; }
.k-point__t { color: #FFFFFF; font-weight: 800; font-size: 1.1rem; margin-bottom: 4px; }
.k-point__d { color: rgba(255, 255, 255, 0.68); font-size: 0.96rem; line-height: 1.55; margin: 0; }
/* quebra de linha só no desktop (pedido do dono: na lista da Sessão,
   depois da vírgula o resto do texto desce pra linha de baixo) */
.k-br-desk { display: none; }
@media (min-width: 600px) { .k-br-desk { display: inline; } }

/* ---------- É / não é pra você ---------- */
.k-fortwo { display: grid; gap: 16px; margin-top: 20px; }
@media (min-width: 560px) { .k-fortwo { grid-template-columns: 1fr 1fr; } }
.k-forcard { border-top: 2px solid rgba(255, 255, 255, 0.14); padding: 18px 2px 0; }
.k-forcard h3 { font-size: 1.06rem; color: #FFFFFF; margin: 0 0 14px; }
.k-forcard.is-yes { border-top-color: var(--karppa-orange); }
.k-forcard.is-yes h3 { color: var(--orange-300); }
.k-forcard ul { list-style: none; display: grid; gap: 11px; margin: 0; padding: 0; }
.k-forcard li { position: relative; padding-left: 28px; color: rgba(255, 255, 255, 0.7); font-size: 0.96rem; line-height: 1.45; }
.k-forcard.is-yes li::before { content: '✓'; position: absolute; left: 0; top: 0; color: var(--orange-300); font-weight: 800; }
.k-forcard.is-no li::before { content: '✕'; position: absolute; left: 0; top: 0; color: #E5484D; font-weight: 800; }

/* ---------- Painel destacado do formulário ---------- */
.k-formpanel {
  background: rgba(230, 57, 5, 0.05);
  border: 1px solid rgba(254, 121, 89, 0.6);
  border-radius: 20px;
  padding: 28px 18px;
  box-shadow: 0 0 46px rgba(230, 57, 5, 0.14);
}
@media (min-width: 480px) { .k-formpanel { padding: 32px 26px; } }
.k-form { display: grid; gap: 18px; }
.k-form-foot { display: flex; flex-direction: column; gap: 14px; margin-top: 4px; }
/* o disclaimer e o erro de envio reusam .form-disclaimer / .form-submit-error do styles.css */
.k-formpanel .form-disclaimer a { color: var(--orange-200); border-bottom: 1px solid rgba(254, 121, 89, 0.4); }

/* ============================================================
   BIO (/bio/): perfil + bento de links, espelho do /links/
   ============================================================ */
.k-profile { text-align: center; }
/* símbolo da carpa como "avatar" da marca, com brilho laranja atrás */
.k-avatar { position: relative; width: min(240px, 68vw); margin: 0 auto 18px; }
.k-avatar::before {
  content: ''; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 170%; height: 150%; z-index: 0; pointer-events: none;
  background: radial-gradient(closest-side, rgba(230, 57, 5, 0.32), rgba(230, 57, 5, 0) 72%);
}
.k-avatar svg { position: relative; z-index: 1; width: 100%; height: auto; display: block; filter: drop-shadow(0 16px 30px rgba(0, 0, 0, 0.55)); }
/* koi 3D (koi3d.js) no lugar do SVG: SEM filter no canvas e com uma MÁSCARA
   radial suave. Motivo: no iOS (Safari e navegador do Instagram) o WebKit às
   vezes pinta os pixels transparentes do canvas WebGL num tom mais claro e
   aparece um QUADRADO em volta da logo (visto em produção, jun/2026; filter
   agrava, e o antialias do WebGL é desligado no iOS pelo koi3d.js). A máscara
   zera o alfa nas bordas do canvas: mesmo se o tom vazar, não há aresta dura
   visível. O koi ocupa ~78% do raio do canvas, a parte sólida (80%) não o
   corta. O brilho fica por conta do ::before, atrás do canvas. */
.k-avatar .koi-3d, .k-figure .koi-3d {
  filter: none;
  -webkit-mask-image: radial-gradient(circle closest-side at 50% 50%, #000 80%, transparent 98%);
  mask-image: radial-gradient(circle closest-side at 50% 50%, #000 80%, transparent 98%);
}
.k-avatar .koi-3d { animation: none; } /* sem o balanço vertical da home no avatar */
.k-profile__logo { margin: 0 auto; width: min(220px, 64%); }
.k-profile__name { color: #FFFFFF; font-weight: 900; font-size: clamp(1.7rem, 7vw, 2.1rem); letter-spacing: var(--track-tight); margin: 0; }
.k-profile__handle {
  display: inline-block; margin-top: 8px; color: var(--orange-300);
  font-size: 0.8rem; letter-spacing: 0.18em; text-transform: lowercase; font-weight: 800;
}
.k-profile__bio { color: rgba(255, 255, 255, 0.72); font-size: 1.02rem; line-height: 1.55; margin: 14px 0 0; }

/* bento de links (cards ricos com foto integrada à direita) */
.k-bento { display: grid; grid-template-columns: 1fr; gap: 12px; }
.k-bcard {
  position: relative; overflow: hidden; border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.14); background: var(--gray-950);
  min-height: 178px; padding: 18px; text-align: left;
  display: flex; flex-direction: column; justify-content: center;
  transition: border-color 200ms, transform 200ms var(--ease-out), box-shadow 200ms;
}
.k-bcard, .k-bcard:hover { border-bottom-color: rgba(255, 255, 255, 0.14); } /* anula o sublinhado global de <a> */
.k-bcard:hover { border-color: var(--orange-300); transform: translateY(-3px); box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45); }
.k-bcard:active { transform: translateY(-1px); }
.k-bcard:focus-visible { outline: 2px solid var(--orange-200); outline-offset: 3px; box-shadow: none; }
.k-bcard__t { position: relative; z-index: 2; color: #FFFFFF; font-weight: 800; font-size: 1.04rem; line-height: 1.16; letter-spacing: -0.01em; max-width: 58%; margin: 0; }
.k-bcard__t em { display: block; white-space: nowrap; color: var(--orange-300); font-style: normal; }
.k-bcard__s { position: relative; z-index: 2; max-width: 56%; margin: 7px 0 0; color: rgba(255, 255, 255, 0.66); font-size: 0.82rem; line-height: 1.4; }
.k-bcard__cta {
  position: relative; z-index: 2; margin-top: 12px; align-self: flex-start;
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--karppa-orange); color: #FFFFFF; font-weight: 800;
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em;
  padding: 9px 16px; border-radius: 999px; line-height: 1;
}
.k-bcard__cta svg { width: 13px; height: 13px; }
/* foto integrada à direita (todos os cards) */
.k-bcard__photo { position: absolute; top: 0; right: 0; bottom: 0; width: 40%; z-index: 0; background-size: cover; background-position: 50% 8%; }
.k-bcard__photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to right, var(--gray-950) 0%, rgba(10, 10, 18, 0.28) 44%, transparent 82%); }
/* Sessão: card primário (borda laranja, um pouco maior) */
.k-bcard--feat { border-color: var(--orange-300); min-height: 200px; box-shadow: 0 0 30px rgba(230, 57, 5, 0.16); }
.k-bcard--feat .k-bcard__t { font-size: 1.18rem; line-height: 1.12; }

/* ---------- Rodapé ---------- */
.k-foot { text-align: center; color: rgba(255, 255, 255, 0.45); font-size: 0.8rem; line-height: 1.7; }
.k-foot p { color: inherit; font-size: inherit; margin: 0; }
.k-foot .k-rule--full { margin: 0 auto 12px; }
/* ícones das redes no rodapé da bio */
.k-social { display: flex; justify-content: center; gap: 22px; margin-bottom: 12px; }
.k-social a { color: var(--orange-300); display: inline-flex; border: 0; transition: color 180ms, transform 180ms var(--ease-out); }
.k-social a:hover { color: var(--orange-200); border: 0; transform: translateY(-2px); }
.k-social a:focus-visible { outline: 2px solid var(--orange-200); outline-offset: 4px; border-radius: 6px; box-shadow: none; }
.k-social svg { width: 22px; height: 22px; }

/* ---------- Captura: layout centralizado (mobile-first) ---------- */
.kp-center { text-align: center; }
.kp-center .k-rule { margin-left: auto; margin-right: auto; }
.kp-center .k-point { grid-template-columns: 1fr; justify-items: center; text-align: center; gap: 6px; }
.kp-center .k-forcard ul { text-align: left; }
.kp-center .k-form { text-align: left; }   /* campos do formulário à esquerda (usabilidade) */

/* ---------- util ---------- */
[hidden] { display: none !important; }
.k-visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.k-spacer-sm { height: 28px; }
.k-spacer { height: 44px; }
.k-spacer-lg { height: 64px; }
