/* ============ PÁGINAS INTERNAS — componentes compartilhados ============ */

/* Page hero */
.page-hero { padding-block: clamp(56px, 8vw, 104px) clamp(40px, 6vw, 72px); }
.page-hero .kicker { margin-bottom: 1.2rem; }
.page-hero h1 { font-size: clamp(2.4rem, 5.2vw, 4.4rem); max-width: 16ch; }
.page-hero .lead { margin-top: 1.4rem; max-width: 56ch; }
.page-hero.band-forest .lead { color: var(--on-forest-soft); }

.split-hero { display: grid; grid-template-columns: 1.25fr 0.9fr; gap: clamp(32px, 5vw, 72px); align-items: end; }
@media (max-width: 900px) { .split-hero { grid-template-columns: 1fr; align-items: start; } }

/* Section heading shared */
.sec-head { max-width: 820px; }
.sec-head .lead { margin-top: 1rem; }

/* Tiers de preço */
.tier-grid { display: grid; gap: 20px; margin-top: 2.8rem; }
.tier-grid.t3 { grid-template-columns: repeat(3, 1fr); }
.tier-grid.t2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 900px) { .tier-grid.t3, .tier-grid.t2 { grid-template-columns: 1fr; } }

.tier {
  background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: clamp(22px, 2.6vw, 30px); display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.tier h3 { font-size: 1.35rem; }
.tier .tier-desc { color: var(--ink-soft); font-size: .98rem; flex: 1; margin: 0; }
.tier .price-row { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; padding-top: 12px; border-top: 1px solid var(--line-soft); }
.tier .price { font-size: clamp(1.5rem, 2.4vw, 2rem); }
.tier-feat-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.tier-feat-list li { padding-left: 22px; position: relative; font-size: .95rem; color: var(--ink-soft); }
.tier-feat-list li::before { content: "→"; position: absolute; left: 0; color: var(--t-accent); font-weight: 700; }

.tier.featured {
  background: var(--forest); color: var(--on-forest); border-color: var(--forest);
  box-shadow: 0 30px 60px -34px rgba(18,46,39,.55);
}
.tier.featured h3, .tier.featured .price { color: var(--on-forest); }
.tier.featured .tier-desc { color: var(--on-forest-soft); }
.tier.featured .price-row { border-top-color: var(--forest-line); }
.tier.featured .tier-feat-list li { color: var(--on-forest-soft); }
.tier.featured .tier-feat-list li::before { color: var(--ochre); }
.tier-flag {
  position: absolute; top: -12px; left: clamp(22px,2.6vw,30px);
  background: var(--ochre); color: #2a2008; font-family: var(--mono); font-size: .68rem;
  font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .4em .8em; border-radius: 4px;
}

/* Eixos / axis grid */
.axis-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; margin-top: 2.6rem; }
@media (max-width: 820px) { .axis-grid { grid-template-columns: 1fr; } }
.axis-card { background: var(--paper); padding: clamp(22px, 2.6vw, 30px); display: flex; flex-direction: column; gap: 10px; transition: background .2s ease; }
.axis-card:hover { background: var(--cream); }
.axis-card .ax-num { font-family: var(--mono); font-size: .76rem; color: var(--ink-faint); letter-spacing: .08em; }
.axis-card h4 { font-family: var(--t-display); font-weight: 500; font-size: 1.3rem; }
.axis-pain { color: var(--ink-soft); font-size: .96rem; margin: 0; }
.axis-sol { font-size: .96rem; margin: 0; padding-top: 10px; border-top: 1px dashed var(--line); }
.axis-sol strong { color: var(--clay-deep); }

/* Processo / steps numerados grandes */
.flow { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px,3vw,36px); margin-top: 2.8rem; }
@media (max-width: 900px) { .flow { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .flow { grid-template-columns: 1fr; } }
.flow-step { display: flex; flex-direction: column; gap: 10px; border-top: 2px solid currentColor; padding-top: 18px; }
.flow-step .fs-n { font-family: var(--mono); font-size: .8rem; color: var(--t-accent); letter-spacing: .06em; }
.flow-step h4 { font-family: var(--t-display); font-weight: 500; font-size: 1.25rem; }
.flow-step p { margin: 0; color: var(--ink-soft); font-size: .95rem; }
.band-forest .flow-step p { color: var(--on-forest-soft); }

/* CTA band genérico */
.cta-band { text-align: center; }
.cta-band h2 { max-width: 20ch; margin-inline: auto; }
.cta-band .lead { max-width: 52ch; margin: 1rem auto 0; }

/* Feature split (texto + lista de bullets em cartão) */
.feature-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,72px); align-items: center; }
@media (max-width: 900px) { .feature-split { grid-template-columns: 1fr; } }
.feature-split.reverse > :first-child { order: 2; }
@media (max-width: 900px) { .feature-split.reverse > :first-child { order: 0; } }

.checklist { list-style: none; margin: 1.4rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.checklist li { display: flex; gap: 14px; align-items: flex-start; }
.checklist .ck { flex: none; width: 24px; height: 24px; border-radius: 50%; background: var(--t-accent); color: #fff; display: grid; place-items: center; font-size: .8rem; font-weight: 700; margin-top: 2px; }
.band-forest .checklist .ck { background: var(--ochre); color: #2a2008; }
.checklist strong { display: block; }
.checklist span.sub { color: var(--ink-soft); font-size: .95rem; }
.band-forest .checklist span.sub { color: var(--on-forest-soft); }

/* Big stat row */
.stat-row { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(20px,3vw,40px); margin-top: 2.6rem; }
@media (max-width: 720px) { .stat-row { grid-template-columns: 1fr; gap: 28px; } }
.stat-block { border-left: 2px solid var(--t-accent); padding-left: 20px; }
.stat-block .bignum { display: block; }
.stat-block p { margin: .4rem 0 0; color: var(--ink-soft); font-size: .98rem; }
.band-forest .stat-block p { color: var(--on-forest-soft); }

/* Pull quote / manifesto line */
.pull {
  font-family: var(--t-display); font-weight: 500; font-style: italic;
  font-size: clamp(1.6rem, 3.4vw, 2.6rem); line-height: 1.22; text-wrap: balance;
  max-width: 22ch;
}
.pull.center { margin-inline: auto; text-align: center; }

/* Audience cards */
.aud-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; margin-top: 2.6rem; }
@media (max-width: 760px) { .aud-grid { grid-template-columns: 1fr; } }
.aud-card { display: flex; gap: 18px; align-items: flex-start; padding: clamp(20px,2.4vw,28px); border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--cream); }
.aud-card .aud-ic { flex: none; font-family: var(--t-display); font-size: 1.6rem; color: var(--t-accent); line-height: 1; width: 44px; height: 44px; border: 1px solid var(--line); border-radius: 50%; display: grid; place-items: center; }
.aud-card h4 { font-size: 1.15rem; }
.aud-card p { margin: .3rem 0 0; color: var(--ink-soft); font-size: .95rem; }

/* Form (Raio-X) */
.form-card { background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(26px,3.5vw,44px); }
.band-forest .form-card { background: var(--forest-2); border-color: var(--forest-line); }
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 18px; }
.field label { font-family: var(--mono); font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); }
.band-forest .field label { color: var(--on-forest-soft); }
.field input, .field select, .field textarea {
  font-family: var(--sans); font-size: 1rem; color: var(--ink); background: var(--paper);
  border: 1px solid var(--line); border-radius: var(--radius); padding: .8em 1em; width: 100%;
}
.band-forest .field input, .band-forest .field select, .band-forest .field textarea { background: var(--forest); color: var(--on-forest); border-color: var(--forest-line); }
.field input:focus, .field select:focus, .field textarea:focus { outline: 2px solid var(--t-accent); outline-offset: 1px; border-color: transparent; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 560px) { .form-row { grid-template-columns: 1fr; } }
.form-success { display: none; text-align: center; padding: 1rem 0; }
.form-success.show { display: block; }
.form-success .sx { font-size: 2.4rem; color: var(--ochre); }

/* Bot de contratacao */
.hirebot { position: relative; }
.bot-step { margin-bottom: 18px; }
.bot-q, .bot-step-title {
  margin: 0 0 10px;
  font-family: var(--mono);
  font-size: .76rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.tick-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.tick-grid.tick-grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .tick-grid.tick-grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .tick-grid, .tick-grid.tick-grid-4 { grid-template-columns: 1fr; } }

.tick-card {
  position: relative;
  min-height: 84px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 12px 14px 12px 42px;
  display: flex;
  align-items: center;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease, background .15s ease;
  cursor: pointer;
}
.tick-card:hover { transform: translateY(-1px); }
.tick-card input {
  position: absolute;
  left: 0;
  top: 0;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.tick-mark {
  position: absolute;
  left: 13px;
  top: 14px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--t-accent);
  color: #fff;
  font-size: .76rem;
  font-weight: 700;
  display: grid;
  place-items: center;
  opacity: 0;
  transform: scale(.75);
  transition: opacity .12s ease, transform .15s ease;
}

.tick-copy { display: flex; flex-direction: column; gap: 3px; }
.tick-copy strong { font-size: .98rem; }
.tick-copy small { font-size: .84rem; color: var(--ink-soft); line-height: 1.35; }

.tick-frame {
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  border: 1px solid transparent;
  pointer-events: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.tick-card input:checked ~ .tick-mark { opacity: 1; transform: scale(1); }
.tick-card input:checked ~ .tick-frame { border-color: var(--ink); box-shadow: 0 0 0 1px var(--ink); }
.tick-card input:checked ~ .tick-copy strong { color: var(--ink); }
.tick-card input:focus-visible ~ .tick-frame {
  border-color: var(--t-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--t-accent) 36%, transparent);
}

.bot-group-error { display: none; margin: 8px 0 0; color: #9E3F1F; font-size: .88rem; }
.bot-group-error.show { display: block; }
.bot-conditional { margin-top: 12px; }
.bot-conditional[hidden], .field[hidden] { display: none !important; }
.bot-note {
  margin: 2px 0 0;
  color: var(--ink-soft);
  font-size: .9rem;
  line-height: 1.45;
}


/* ============================================================
   CHAT BOT DE CONTRATAÇÃO
   ============================================================ */
.chatbot-shell{
  max-width: 760px; margin: 0 auto;
  background: var(--cream); border:1px solid var(--line); border-radius: var(--radius-lg);
  box-shadow: 0 30px 80px -50px rgba(22,17,13,.35);
  display:flex; flex-direction:column; min-height: 560px;
  overflow:hidden;
}
.chatbot-head{
  display:flex; align-items:center; gap:14px;
  padding:18px 22px; border-bottom:1px solid var(--line-soft);
  background: var(--paper);
}
.chatbot-avatar{
  width:44px; height:44px; border-radius:12px; background: var(--ink-2);
  display:flex; align-items:center; justify-content:center; flex:none;
  box-shadow: 0 6px 18px -8px rgba(22,17,13,.4);
}
.chatbot-avatar svg{ width:64%; height:64%; }
.chatbot-id{ display:flex; flex-direction:column; line-height:1.15; }
.chatbot-id strong{ font-family: var(--font-display); font-weight:700; font-size:1rem; color: var(--ink); letter-spacing:-0.01em; }
.chatbot-sub{ font-family: var(--font-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color: var(--ink-faint); margin-top:3px; }
.chatbot-progress{
  margin-left:auto; font-family: var(--font-mono); font-size:.72rem; letter-spacing:.16em;
  color: var(--ink-faint); text-transform:uppercase;
}

.chatbot-stream{
  flex:1; padding: 24px 22px; display:flex; flex-direction:column; gap:14px;
  overflow-y:auto; max-height: 520px;
  background: linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%);
}

.chat-row{ display:flex; gap:10px; align-items:flex-end; animation: chatIn .25s ease both; }
.chat-row.chat-bot{ justify-content:flex-start; }
.chat-row.chat-user{ justify-content:flex-end; }
@keyframes chatIn{ from{opacity:0; transform: translateY(6px);} to{opacity:1; transform:none;} }

.bubble-avatar{
  width:28px; height:28px; border-radius:8px; background: var(--ink-2); flex:none;
  display:flex; align-items:center; justify-content:center;
}
.bubble-avatar svg{ width:70%; height:70%; }

.chat-bubble{
  max-width: 78%; padding: 12px 16px; border-radius: 16px;
  font-size: 0.97rem; line-height: 1.45; color: var(--ink);
  font-family: var(--font-body);
}
.chat-bot .chat-bubble{
  background: #fff; border:1px solid var(--line-soft); border-bottom-left-radius: 6px;
}
.chat-user .chat-bubble{
  background: var(--accent); color:#fff; border-bottom-right-radius: 6px;
  font-weight: 500;
}

.typing{ display:inline-flex; gap:4px; align-items:center; padding: 2px 0; }
.typing i{ width:6px; height:6px; border-radius:50%; background: var(--ink-faint); display:inline-block; animation: blink 1.2s infinite ease-in-out; }
.typing i:nth-child(2){ animation-delay:.15s; }
.typing i:nth-child(3){ animation-delay:.3s; }
@keyframes blink{ 0%,80%,100%{ opacity:.25; transform: scale(.85);} 40%{ opacity:1; transform: scale(1);} }

.chatbot-input{
  padding: 16px 22px 20px; border-top:1px solid var(--line-soft);
  background: var(--paper);
}

.chat-options{
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px;
}
@media (max-width: 600px){ .chat-options{ grid-template-columns: 1fr; } }
.chat-chip{
  display:flex; align-items:center; gap:12px; text-align:left;
  background:#fff; border:1.5px solid var(--line); border-radius:12px;
  padding: 12px 14px; cursor:pointer; transition: all .15s ease;
  font-family: var(--font-body); color: var(--ink);
}
.chat-chip:hover{ border-color: var(--ink-faint); transform: translateY(-1px); }
.chat-chip.on{ border-color: var(--accent); background: #FFF6F0; box-shadow: 0 0 0 3px rgba(255,90,44,.12); }
.chat-chip .chip-check{
  width:22px; height:22px; border-radius:50%; flex:none;
  border:1.5px solid var(--line); display:flex; align-items:center; justify-content:center;
  font-size:.75rem; color:transparent; background:#fff; transition: all .15s ease;
}
.chat-chip.on .chip-check{ background: var(--accent); border-color: var(--accent); color:#fff; }
.chat-chip .chip-body{ display:flex; flex-direction:column; min-width:0; }
.chat-chip .chip-body strong{ font-family: var(--font-display); font-weight:600; font-size:.95rem; letter-spacing:-0.01em; }
.chat-chip .chip-body small{ color: var(--ink-soft); font-size:.78rem; margin-top:2px; }

.chat-actions{ display:flex; justify-content:flex-end; margin-top:12px; }
.chat-actions .btn[disabled]{ opacity:.4; cursor:not-allowed; }

.chat-text{ display:flex; gap:8px; align-items:flex-end; }
.chat-text-input{
  flex:1; font-family: var(--font-body); font-size: 1rem;
  padding: 12px 14px; border:1.5px solid var(--line); border-radius:12px; background:#fff; color: var(--ink);
  outline:none; transition: border-color .15s ease, box-shadow .15s ease; resize: vertical;
}
.chat-text-input:focus{ border-color: var(--accent); box-shadow: 0 0 0 3px rgba(255,90,44,.15); }
.chat-text-input.shake{ animation: shake .35s ease; border-color: var(--accent-deep); }
@keyframes shake{ 0%,100%{ transform:translateX(0);} 25%{transform:translateX(-4px);} 75%{transform:translateX(4px);} }
.chat-send{
  width:44px; height:44px; border-radius:12px; border:none;
  background: var(--accent); color:#fff; font-size:1.1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition: background .15s ease;
}
.chat-send:hover{ background: var(--accent-2); }
.chat-skip{
  margin-top:10px; background:none; border:none; color: var(--ink-faint);
  font-family: var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  cursor:pointer;
}
.chat-skip:hover{ color: var(--ink); }

/* Recomendação dentro do chat */
.reco-card{
  background: linear-gradient(135deg, #FFF6F0 0%, #FFEFE7 100%);
  border:1.5px solid var(--accent-soft); border-radius:14px;
  padding: 16px 18px; margin-bottom: 12px; position:relative;
}
.reco-flag{
  display:inline-block; font-family: var(--font-mono); font-size:.66rem; letter-spacing:.18em;
  text-transform:uppercase; color: var(--accent-deep); background:#fff;
  border:1px solid var(--accent-soft); border-radius: 100px; padding: 4px 10px; margin-bottom:8px;
}
.reco-card h4{
  font-family: var(--font-display); font-weight:700; font-size:1.15rem; margin:0 0 6px;
  letter-spacing:-0.02em; color: var(--ink);
}
.reco-card p{ margin:0 0 8px; font-size:.92rem; color: var(--ink-soft); line-height:1.45; }
.reco-price{ font-family: var(--font-mono); font-size:.78rem; color: var(--accent-deep); font-weight:500; }

/* WhatsApp em 3 campos */
.chat-whats{ flex-wrap: wrap; gap:6px; }
.chat-whats .chat-w-pais{ flex: 1 1 180px; min-width: 0; padding-right:8px; }
.chat-whats .chat-w-ddd{ flex: 0 0 70px; text-align:center; }
.chat-whats .chat-w-num{ flex: 1 1 140px; min-width: 0; }
.chat-whats select.chat-text-input{ appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--ink-faint) 50%), linear-gradient(135deg, var(--ink-faint) 50%, transparent 50%); background-position: calc(100% - 16px) 50%, calc(100% - 11px) 50%; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: 28px; cursor:pointer; }

/* CTA bot dentro dos cartões de produto (.tier) */
.tier .btn.bot-cta{ margin-top:14px; }
