/* ============================================================
   MINI-GUIA GRAMADO — ESTILOS DA LANDING PAGE
   Construído sobre os tokens da tali-travel-frontend (css/tokens.css).
   ============================================================ */

/* ---- Layout base ---- */
.tt-container { max-width: var(--tt-maxw); margin: 0 auto; padding: 0 var(--tt-space-md); }
.tt-section { padding: var(--tt-space-xl) 0; }
img { max-width: 100%; }

/* ---- Cabeçalho ---- */
.tt-header { padding: var(--tt-space-sm) 0; }
.tt-header__inner { display: flex; justify-content: center; }
.tt-header__logo { height: 42px; width: auto; }

/* ---- Hero ---- */
.tt-hero { padding: var(--tt-space-xl) 0; background: var(--tt-bg); }
.tt-hero h1 { margin: var(--tt-space-sm) 0; }
.tt-lead {
  font-family: var(--tt-font-grotesk);
  font-size: 1.2rem;
  font-weight: var(--tt-w-light);
  max-width: 32rem;
  color: var(--tt-text);
  margin-bottom: var(--tt-space-md);
}
.tt-hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: var(--tt-space-lg);
  align-items: center;
}
.tt-hero__image {
  width: 100%;
  height: auto;
  border-radius: var(--tt-radius);
  box-shadow: var(--tt-shadow);
  display: block;
}
@media (max-width: 860px) {
  .tt-hero__grid { grid-template-columns: 1fr; }
  .tt-hero__media { order: -1; }
}

/* ---- Rótulo de seção / label block ---- */
.tt-label-block { display: grid; grid-template-columns: 1fr 1fr; gap: var(--tt-space-lg); align-items: start; }
.tt-label-block__text {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-light);
  font-size: 1.05rem;
  color: var(--tt-text-soft);
  max-width: 26rem;
}
@media (max-width: 720px) { .tt-label-block { grid-template-columns: 1fr; gap: var(--tt-space-md); } }

/* ---- Botões ---- */
.tt-btn {
  display: inline-block;
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-medium);
  letter-spacing: 0.04em;
  text-decoration: none;
  padding: 0.9rem 2rem;
  border-radius: var(--tt-radius-sm);
  transition: transform .25s ease, background .25s ease;
  border: none;
  cursor: pointer;
  font-size: 1rem;
}
.tt-btn:hover { transform: translateY(-2px); }
.tt-btn--primary { background: var(--tt-primary); color: var(--tt-bg); border: 1px solid var(--tt-gold); }
.tt-btn--primary:hover { background: var(--tt-primary-dark); }
.tt-btn--dark { background: var(--tt-dark); color: var(--tt-bg); }
.tt-btn--dark:hover { background: var(--tt-primary); }
.tt-btn:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

/* ---- Cards / grid ---- */
.tt-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--tt-space-md);
  margin-top: var(--tt-space-md);
}
.tt-card {
  background: var(--tt-card);
  border: 1px solid var(--tt-gold);
  border-radius: var(--tt-radius);
  padding: var(--tt-space-md);
  box-shadow: var(--tt-shadow-soft);
}
.tt-card__num {
  font-family: var(--tt-font-display);
  font-style: italic;
  font-size: 1.6rem;
  color: var(--tt-primary);
}
.tt-card h3, .tt-card h4 { margin: var(--tt-space-xs) 0; color: var(--tt-text); }
.tt-card p { font-family: var(--tt-font-grotesk); font-weight: var(--tt-w-light); color: var(--tt-text); }

/* ---- Faixa navy do formulário ---- */
.tt-band { background: var(--tt-dark); padding: var(--tt-space-xl) 0; }
.tt-band__inner { text-align: center; }
.tt-band blockquote { font-size: clamp(1.6rem, 4vw, 2.6rem); margin: 0 auto; max-width: 38rem; color: var(--tt-bg); }
.tt-band__author {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.8rem;
  color: var(--tt-gold);
  margin-top: var(--tt-space-sm);
}

/* Contraste: título, labels e texto de apoio herdam cores pensadas para
   fundo claro — sobre o navy do .tt-band precisam de override para tons
   claros. Eyebrow e itálico (--tt-gold) já funcionam bem sem mudança. */
.tt-band h2 { color: var(--tt-bg); }
.tt-band .tt-form-wrap__lead,
.tt-band .tt-form__privacy {
  color: var(--tt-text-on-dark);
}
.tt-band .tt-form__row label {
  color: var(--tt-bg);
}
/* Contraste: botão navy-sobre-navy ficaria invisível aqui — preenchimento
   dourado no lugar do navy padrão de .tt-btn--primary. */
.tt-band .tt-btn--primary {
  background: var(--tt-gold);
  color: var(--tt-primary);
  border-color: var(--tt-gold);
}
.tt-band .tt-btn--primary:hover {
  background: var(--tt-gold-soft);
}
/* Contraste: --tt-primary-dark (navy quase-preto) fica ilegível sobre navy. */
.tt-band .form-status--success {
  color: var(--tt-gold);
}

/* ---- CTA escuro ---- */
.tt-cta-dark {
  background: var(--tt-dark);
  color: var(--tt-bg);
  padding: var(--tt-space-xl) 0;
  text-align: center;
}
.tt-cta-dark h2 { color: var(--tt-bg); }
.tt-cta-dark h2 em { color: var(--tt-gold); }
.tt-cta-dark__lead {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-light);
  max-width: 32rem;
  margin: var(--tt-space-sm) auto var(--tt-space-md);
  color: var(--tt-bg);
}
/* Contraste: botão navy-sobre-navy ficaria invisível aqui — mesmo ajuste
   de preenchimento dourado usado em .tt-band. */
.tt-cta-dark .tt-btn--primary {
  background: var(--tt-gold);
  color: var(--tt-primary);
  border-color: var(--tt-gold);
}
.tt-cta-dark .tt-btn--primary:hover {
  background: var(--tt-gold-soft);
}

/* ---- Quem está por trás disso ---- */
.tt-about__grid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: var(--tt-space-lg); align-items: center; }
.tt-about__image { width: 100%; height: auto; border-radius: var(--tt-radius); box-shadow: var(--tt-shadow); display: block; }
@media (max-width: 860px) { .tt-about__grid { grid-template-columns: 1fr; } }

/* ---- Formulário de liberação do guia ---- */
.tt-form-wrap { max-width: 40rem; margin: 0 auto; text-align: center; }
.tt-form-wrap__lead { margin: var(--tt-space-xs) auto var(--tt-space-md); }
.tt-form { text-align: left; display: grid; gap: var(--tt-space-sm); }
.tt-form__row { display: grid; gap: 0.35rem; }
.tt-form__row label {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-medium);
  font-size: 0.9rem;
  color: var(--tt-text);
}
.tt-form__row input,
.tt-form__row select {
  font-family: var(--tt-font-grotesk);
  font-size: 1rem;
  padding: 0.75rem 1rem;
  border-radius: var(--tt-radius-sm);
  border: 1px solid var(--tt-border);
  background: var(--tt-bg);
  color: var(--tt-text);
}
.tt-form__row input:focus,
.tt-form__row select:focus {
  outline: 2px solid var(--tt-primary);
  outline-offset: 1px;
}
.tt-form .tt-btn { justify-self: start; margin-top: var(--tt-space-xs); }
.tt-form__privacy {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-light);
  font-size: 0.82rem;
  color: var(--tt-text-soft);
  margin: 0.5rem 0 0;
}
.form-status { font-family: var(--tt-font-grotesk); font-weight: var(--tt-w-medium); margin-top: 0.5rem; min-height: 1.2em; }
.form-status--success { color: var(--tt-primary-dark); }
.form-status--error { color: var(--tt-error); }

/* ---- Bloco de download do guia (após o formulário) ---- */
.tt-download { max-width: 40rem; margin: 0 auto; text-align: center; }
.tt-download__lead {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-light);
  margin: var(--tt-space-xs) auto var(--tt-space-md);
}
.tt-download__btn { font-size: 1.05rem; }

/* ---- Rodapé (dentro do CTA escuro) ---- */
.tt-footer { margin-top: var(--tt-space-lg); display: flex; flex-direction: column; align-items: center; gap: var(--tt-space-xs); }
.tt-footer__logo { height: 32px; width: auto; }
.tt-footer__text {
  font-family: var(--tt-font-grotesk);
  font-weight: var(--tt-w-light);
  font-size: 0.85rem;
  color: var(--tt-bg);
  margin: 0;
}
