/* ══════════════════════════════════════════════════════════════
   gn-promo.css — Componentes promocionais internos do Guianeo
   Slots: home (hero bottom, between x2), search (top, inline, sidebar), spotlight global
   ══════════════════════════════════════════════════════════════ */

/* ── 1. Newsletter inline (hero bottom) ─────────────────────────────────────── */
.gn-promo-nl {
  background: linear-gradient(135deg, #1e1b4b 0%, #312e81 50%, #1e3a8a 100%);
  color: #fff;
  border-radius: 1.125rem;
  padding: 1.5rem 2rem;
  display: flex;
  align-items: center;
  gap: 2rem;
  margin: 1rem 0 0;
  position: relative;
  overflow: hidden;
}

.gn-promo-nl::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='30'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;
  pointer-events: none;
}

.gn-promo-nl__icon {
  width: 52px;
  height: 52px;
  border-radius: .875rem;
  background: rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.375rem;
  flex-shrink: 0;
}

.gn-promo-nl__text { flex: 1; min-width: 0; }

.gn-promo-nl__title {
  font-size: 1rem;
  font-weight: 800;
  margin: 0 0 .2rem;
  line-height: 1.25;
}

.gn-promo-nl__sub {
  font-size: .8125rem;
  opacity: .75;
  margin: 0;
}

.gn-promo-nl__proof {
  font-size: .75rem;
  opacity: .6;
  margin-top: .375rem;
}

.gn-promo-nl__form {
  display: flex;
  gap: .5rem;
  flex-shrink: 0;
}

.gn-promo-nl__input {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: .625rem;
  color: #fff;
  padding: .625rem 1rem;
  font-size: .875rem;
  width: 220px;
  outline: none;
  transition: border-color .15s, background .15s;
}

.gn-promo-nl__input::placeholder { color: rgba(255,255,255,.45); }
.gn-promo-nl__input:focus {
  border-color: rgba(255,255,255,.5);
  background: rgba(255,255,255,.16);
}

.gn-promo-nl__btn {
  background: #4f46e5;
  color: #fff;
  border: none;
  border-radius: .625rem;
  padding: .625rem 1.125rem;
  font-size: .875rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
  display: flex;
  align-items: center;
  gap: .375rem;
}

.gn-promo-nl__btn:hover { background: #4338ca; }
.gn-promo-nl__btn:disabled { opacity: .6; cursor: not-allowed; }

.gn-promo-nl__ok {
  display: none;
  align-items: center;
  gap: .625rem;
  font-size: .9375rem;
  font-weight: 700;
}

.gn-promo-nl__ok-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #22c55e;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .875rem;
}

@media (max-width: 768px) {
  .gn-promo-nl { flex-direction: column; align-items: stretch; gap: 1rem; padding: 1.25rem; }
  .gn-promo-nl__form { flex-direction: column; }
  .gn-promo-nl__input { width: 100%; }
  .gn-promo-nl__btn { width: 100%; justify-content: center; }
}


/* ── 2. "Como funciona" (home between #1) ───────────────────────────────────── */
.gn-promo-how {
  background: #fff;
  border-top: 1px solid #f1f5f9;
  border-bottom: 1px solid #f1f5f9;
  padding: 3rem 0;
  margin: 2rem 0;
}

.gn-promo-how__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.gn-promo-how__header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.gn-promo-how__eyebrow {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #6366f1;
  margin: 0 0 .5rem;
}

.gn-promo-how__title {
  font-size: 1.625rem;
  font-weight: 800;
  color: #0f172a;
  margin: 0;
  line-height: 1.25;
}

.gn-promo-how__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}

.gn-promo-how__step {
  text-align: center;
  position: relative;
}

.gn-promo-how__step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 2rem;
  right: -1rem;
  width: 2rem;
  height: 2px;
  background: linear-gradient(90deg, #e2e8f0, #c7d2fe);
}

.gn-promo-how__step-icon {
  width: 64px;
  height: 64px;
  border-radius: 1.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto 1.125rem;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.gn-promo-how__step-icon--blue   { background: linear-gradient(135deg, #3b82f6, #6366f1); color: #fff; }
.gn-promo-how__step-icon--green  { background: linear-gradient(135deg, #22c55e, #10b981); color: #fff; }
.gn-promo-how__step-icon--orange { background: linear-gradient(135deg, #f97316, #f59e0b); color: #fff; }

.gn-promo-how__step-num {
  font-size: .6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #94a3b8;
  margin: 0 0 .375rem;
}

.gn-promo-how__step-title {
  font-size: 1.0625rem;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 .5rem;
}

.gn-promo-how__step-desc {
  font-size: .875rem;
  color: #64748b;
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 640px) {
  .gn-promo-how__grid { grid-template-columns: 1fr; gap: 2rem; }
  .gn-promo-how__step::after { display: none; }
}


/* ── 3. CTA anunciantes (home between #2) ───────────────────────────────────── */
.gn-promo-biz {
  background: linear-gradient(135deg, #0f172a 0%, #1e3a8a 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}

.gn-promo-biz::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: rgba(99,102,241,.15);
  pointer-events: none;
}

.gn-promo-biz__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  position: relative;
}

.gn-promo-biz__left { flex: 1; max-width: 600px; }

.gn-promo-biz__eyebrow {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #818cf8;
  margin: 0 0 .625rem;
  display: flex;
  align-items: center;
  gap: .375rem;
}

.gn-promo-biz__title {
  font-size: 1.75rem;
  font-weight: 900;
  line-height: 1.2;
  margin: 0 0 .75rem;
  color: #fff;
}

.gn-promo-biz__title em { color: #818cf8; font-style: normal; }

.gn-promo-biz__sub {
  font-size: .9375rem;
  color: rgba(255,255,255,.7);
  margin: 0 0 1.5rem;
  line-height: 1.6;
}

.gn-promo-biz__trust {
  font-size: .8125rem;
  color: rgba(255,255,255,.45);
  margin: .75rem 0 0;
  display: flex;
  align-items: center;
  gap: .375rem;
}

.gn-promo-biz__cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: #6366f1;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  padding: .875rem 1.75rem;
  border-radius: .875rem;
  text-decoration: none;
  transition: background .15s, transform .15s;
}
.gn-promo-biz__cta:hover { background: #4f46e5; transform: translateY(-1px); }

.gn-promo-biz__pills {
  display: flex;
  gap: .625rem;
  flex-wrap: wrap;
  margin-top: 1.25rem;
}

.gn-promo-biz__pill {
  font-size: .8125rem;
  font-weight: 600;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.8);
  padding: .375rem .875rem;
  border-radius: 999px;
}

.gn-promo-biz__stats {
  flex-shrink: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.gn-promo-biz__stat {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: .875rem;
  padding: 1rem 1.25rem;
  text-align: center;
}

.gn-promo-biz__stat-n {
  font-size: 1.625rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: .25rem;
}

.gn-promo-biz__stat-label {
  font-size: .75rem;
  color: rgba(255,255,255,.5);
}

@media (max-width: 768px) {
  .gn-promo-biz__inner { flex-direction: column; }
  .gn-promo-biz__stats { width: 100%; }
  .gn-promo-biz__title { font-size: 1.375rem; }
}


/* ── 4. Prova social (search top) ───────────────────────────────────────────── */
.gn-promo-proof {
  background: linear-gradient(90deg, #f0f9ff, #eff6ff);
  border: 1px solid #bae6fd;
  border-radius: .875rem;
  padding: .875rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.gn-promo-proof__left {
  display: flex;
  align-items: center;
  gap: .875rem;
}

.gn-promo-proof__icon {
  width: 40px;
  height: 40px;
  border-radius: .625rem;
  background: #3b82f6;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.gn-promo-proof__text strong {
  display: block;
  font-size: .9375rem;
  font-weight: 700;
  color: #1e3a8a;
  margin-bottom: .1rem;
}

.gn-promo-proof__text span {
  font-size: .8125rem;
  color: #64748b;
}

.gn-promo-proof__chips {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  flex-shrink: 0;
}

.gn-promo-proof__chip {
  font-size: .75rem;
  font-weight: 600;
  background: #dbeafe;
  color: #1d4ed8;
  padding: .25rem .75rem;
  border-radius: 999px;
  white-space: nowrap;
}

@media (max-width: 600px) {
  .gn-promo-proof { flex-direction: column; align-items: flex-start; }
  .gn-promo-proof__chips { display: none; }
}


/* ── 5. "Sugira um lugar" (search inline card) ──────────────────────────────── */
.gn-promo-suggest {
  background: linear-gradient(135deg, #fef3c7, #fff7ed);
  border: 1px solid #fde68a;
  border-radius: 1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .15s, box-shadow .15s;
}

.gn-promo-suggest:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.08);
}

.gn-promo-suggest a {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.25rem;
  gap: .875rem;
  text-decoration: none;
}

.gn-promo-suggest__icon {
  width: 48px;
  height: 48px;
  border-radius: .875rem;
  background: linear-gradient(135deg, #f59e0b, #f97316);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: #fff;
}

.gn-promo-suggest__title {
  font-size: 1rem;
  font-weight: 800;
  color: #92400e;
  margin: 0;
}

.gn-promo-suggest__desc {
  font-size: .8125rem;
  color: #78350f;
  line-height: 1.55;
  margin: 0;
  opacity: .85;
}

.gn-promo-suggest__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  font-size: .875rem;
  font-weight: 700;
  color: #d97706;
}


/* ── 6. Newsletter sidebar (search sidebar) ──────────────────────────────────── */
.gn-promo-nl-side {
  background: linear-gradient(160deg, #1e1b4b, #312e81);
  color: #fff;
  border-radius: .875rem;
  overflow: hidden;
  padding: 1.375rem;
}

.gn-promo-nl-side__icon {
  font-size: 1.5rem;
  margin-bottom: .625rem;
}

.gn-promo-nl-side__title {
  font-size: .9375rem;
  font-weight: 800;
  margin: 0 0 .375rem;
  line-height: 1.25;
}

.gn-promo-nl-side__sub {
  font-size: .8rem;
  opacity: .7;
  margin: 0 0 1rem;
  line-height: 1.5;
}

.gn-promo-nl-side__input {
  width: 100%;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: .5rem;
  color: #fff;
  padding: .5625rem .875rem;
  font-size: .8125rem;
  outline: none;
  margin-bottom: .5rem;
  box-sizing: border-box;
  transition: border-color .15s;
}

.gn-promo-nl-side__input::placeholder { color: rgba(255,255,255,.4); }
.gn-promo-nl-side__input:focus { border-color: rgba(255,255,255,.45); }

.gn-promo-nl-side__btn {
  width: 100%;
  background: #6366f1;
  color: #fff;
  border: none;
  border-radius: .5rem;
  padding: .5625rem;
  font-size: .875rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s;
}

.gn-promo-nl-side__btn:hover { background: #4f46e5; }

.gn-promo-nl-side__proof {
  font-size: .6875rem;
  opacity: .5;
  text-align: center;
  margin-top: .5rem;
}

.gn-promo-nl-side__ok {
  display: none;
  text-align: center;
  padding: .5rem 0;
  font-size: .875rem;
  font-weight: 700;
  color: #86efac;
}


/* ── 7. Spotlight global (acima do footer) ───────────────────────────────────── */
.gn-promo-spotlight {
  background: linear-gradient(90deg, #4338ca, #6d28d9);
  color: #fff;
  position: relative;
  overflow: hidden;
}

.gn-promo-spotlight::after {
  content: '';
  position: absolute;
  top: -40px; right: 10%;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
  pointer-events: none;
}

.gn-promo-spotlight a, .gn-promo-spotlight__wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  text-decoration: none;
  color: inherit;
  position: relative;
}

.gn-promo-spotlight__left {
  display: flex;
  align-items: center;
  gap: .875rem;
}

.gn-promo-spotlight__icon { font-size: 1.25rem; color: #c4b5fd; }

.gn-promo-spotlight__text strong {
  display: block;
  font-size: .9375rem;
  font-weight: 700;
}

.gn-promo-spotlight__text span {
  font-size: .8125rem;
  opacity: .7;
}

.gn-promo-spotlight__cta {
  flex-shrink: 0;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  font-size: .8125rem;
  font-weight: 700;
  padding: .5rem 1.125rem;
  border-radius: .625rem;
  white-space: nowrap;
  transition: background .15s;
}

.gn-promo-spotlight a:hover .gn-promo-spotlight__cta { background: rgba(255,255,255,.22); }

@media (max-width: 600px) {
  .gn-promo-spotlight a, .gn-promo-spotlight__wrap { flex-direction: column; align-items: flex-start; padding: .875rem 1.25rem; gap: .75rem; }
  .gn-promo-spotlight__cta { width: 100%; text-align: center; }
  .gn-promo-spotlight__text span { display: none; }
}

/* ── Ajuste ícone FA nos slots (tamanho consistente com emoji original) ── */
.gn-promo-nl__icon i       { font-size: 1.25rem; }
.gn-promo-nl__ok-icon i    { font-size: .875rem; }
.gn-promo-nl__proof i      { font-size: .6875rem; opacity: .8; }
.gn-promo-nl-side__icon i  { font-size: 1.375rem; }
.gn-promo-proof__chip i    { font-size: .6875rem; margin-right: .2rem; }
.gn-promo-suggest__icon i  { font-size: 1.125rem; color: #fff; }
.gn-promo-spotlight__icon i { font-size: 1.125rem; }


/* ── 8. Depoimentos (slot home_between #2) ───────────────────────────────────── */
.gn-promo-dep {
  background: #f8fafc;
  border-top: 1px solid #f1f5f9;
  border-bottom: 1px solid #f1f5f9;
  padding: 3.5rem 0;
}

.gn-promo-dep__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.gn-promo-dep__header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.gn-promo-dep__eyebrow {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #6366f1;
  margin: 0 0 .5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .375rem;
}

.gn-promo-dep__title {
  font-size: 1.625rem;
  font-weight: 800;
  color: #0f172a;
  margin: 0;
  line-height: 1.25;
}

.gn-promo-dep__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.gn-promo-dep__card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .875rem;
  transition: box-shadow .2s, transform .2s;
}

.gn-promo-dep__card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.07);
  transform: translateY(-2px);
}

.gn-promo-dep__stars {
  display: flex;
  gap: .175rem;
  color: #f59e0b;
  font-size: .875rem;
}

.gn-promo-dep__text {
  font-size: .9375rem;
  color: #334155;
  line-height: 1.65;
  margin: 0;
  flex: 1;
  font-style: italic;
}

.gn-promo-dep__author {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-top: auto;
  padding-top: .875rem;
  border-top: 1px solid #f1f5f9;
}

.gn-promo-dep__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.gn-promo-dep__name {
  font-size: .9375rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 .125rem;
}

.gn-promo-dep__role {
  font-size: .75rem;
  color: #94a3b8;
  margin: 0;
}

@media (max-width: 768px) {
  .gn-promo-dep__grid { grid-template-columns: 1fr; }
  .gn-promo-dep__title { font-size: 1.375rem; }
}
