:root {
  --bg: #f1f1f1;
  --surface: #f8f7fb;
  --surface-strong: #ffffff;
  --ink: #000000;
  --muted: #404040;
  --line: rgba(120, 75, 157, 0.14);
  --brand: #784b9d;
  --brand-deep: #5f397d;
  --brand-secondary: #916dad;
  --brand-soft: #d7d0e2;
  --accent: #fab24c;
  --shadow: 0 20px 44px rgba(95, 57, 125, 0.1);
  --radius-lg: 28px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --shell: 1180px;
  --font-body: "Avenir Next", "Segoe UI", "Trebuchet MS", sans-serif;
  --font-display: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background:
    radial-gradient(circle at top left, rgba(215, 208, 226, 0.52), transparent 24%),
    radial-gradient(circle at top right, rgba(145, 109, 173, 0.12), transparent 18%),
    linear-gradient(180deg, #fbfbfd 0%, #f5f4f8 42%, #f0edf5 100%);
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

.lp-shell {
  width: min(calc(100% - 40px), var(--shell));
  margin: 0 auto;
}

.lp-header {
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(18px);
  background: rgba(120, 75, 157, 0.94);
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.lp-header__inner {
  min-height: 88px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.lp-brand picture,
.lp-floating-whatsapp picture {
  display: block;
}

.lp-brand img {
  width: 92px;
  height: auto;
}

.lp-nav {
  display: flex;
  gap: 24px;
  font-size: 0.95rem;
  color: #ffffff;
  font-weight: 700;
}

.lp-nav a {
  text-decoration: none;
}

.lp-btn,
.lp-link,
.guide-category,
.guide-card {
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.lp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-deep) 100%);
  color: #fff;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(120, 75, 157, 0.24);
}

.lp-btn:hover,
.lp-link:hover,
.guide-category:hover,
.guide-card:hover {
  transform: translateY(-2px);
}

.lp-btn--header,
.lp-btn--secondary {
  background: #ffffff;
  color: var(--brand-deep);
  border-color: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 28px rgba(56, 24, 80, 0.18);
}

.lp-btn--light {
  background: #ffffff;
  color: var(--brand-deep);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.14);
}

.lp-link {
  color: var(--brand-deep);
  font-weight: 800;
  text-decoration: none;
}

.lp-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(120, 75, 157, 0.08);
  border: 1px solid rgba(120, 75, 157, 0.12);
  color: var(--brand-deep);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.lp-kicker--light {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.18);
  color: #ffffff;
}

.guide-hero {
  padding: 72px 0 42px;
}

.guide-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, 0.96fr);
  gap: 30px;
  align-items: center;
}

.guide-hero h1,
.guide-section__heading h2,
.guide-article__header h1,
.guide-article h2,
.guide-author h2,
.guide-related h2,
.lp-footer-cta h2 {
  font-family: var(--font-display);
  color: var(--brand-deep);
  letter-spacing: -0.03em;
  line-height: 1.04;
}

.guide-hero h1 {
  max-width: 13ch;
  margin: 16px 0;
  font-size: clamp(2.35rem, 5vw, 4.6rem);
  text-wrap: balance;
}

.guide-hero p,
.guide-section__heading p,
.guide-card p,
.guide-author p,
.guide-article p,
.guide-article li,
.guide-faq p,
.lp-footer-cta p {
  color: var(--muted);
  line-height: 1.68;
}

.guide-hero__lead {
  max-width: 680px;
  margin: 0;
  font-size: 1.08rem;
}

.guide-search {
  margin-top: 28px;
  position: relative;
}

.guide-search input {
  width: 100%;
  min-height: 62px;
  padding: 0 22px 0 54px;
  border: 1px solid rgba(120, 75, 157, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--brand-deep);
  box-shadow: var(--shadow);
  font: inherit;
  font-weight: 700;
  outline: none;
}

.guide-search span {
  position: absolute;
  left: 22px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--brand);
  font-size: 1.1rem;
}

.guide-hero__panel {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(120, 75, 157, 0.08);
  box-shadow: var(--shadow);
}

.guide-hero__panel img {
  width: 100%;
  height: 440px;
  object-fit: cover;
}

.guide-hero__caption {
  padding: 22px 24px;
}

.guide-hero__caption strong {
  display: block;
  margin-bottom: 6px;
  color: var(--brand-deep);
  font-size: 1.15rem;
}

.guide-hero__caption p {
  margin: 0;
}

.guide-section {
  padding: 56px 0;
}

.guide-section--soft {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(232, 227, 239, 0.42));
}

.guide-section__heading {
  max-width: 760px;
  margin: 0 auto 30px;
  text-align: center;
}

.guide-section__heading h2 {
  margin: 14px 0;
  font-size: clamp(2rem, 3.2vw, 3.3rem);
}

.guide-section__heading p {
  margin: 0;
}

.guide-categories {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.guide-category {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(120, 75, 157, 0.1);
  box-shadow: 0 12px 28px rgba(95, 57, 125, 0.08);
  color: var(--brand-deep);
  text-align: center;
  text-decoration: none;
  font-weight: 800;
}

.guide-category:hover {
  background: linear-gradient(135deg, rgba(120, 75, 157, 0.1), rgba(215, 208, 226, 0.44));
  box-shadow: 0 18px 34px rgba(95, 57, 125, 0.12);
}

.guide-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  max-width: 1040px;
  margin: 0 auto;
}

.guide-card {
  overflow: hidden;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(120, 75, 157, 0.08);
  box-shadow: var(--shadow);
}

.guide-card:hover {
  box-shadow: 0 24px 50px rgba(95, 57, 125, 0.14);
}

.guide-cards--related {
  max-width: 760px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guide-card img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  object-position: center top;
}

.guide-card__body {
  padding: 20px;
}

.guide-card__body h3 {
  margin: 10px 0 8px;
  color: var(--brand-deep);
  font-size: 1.22rem;
  line-height: 1.08;
}

.guide-card__body p {
  margin: 0 0 14px;
  font-size: 0.95rem;
}

.guide-card--compact img {
  height: 180px;
}

.guide-card--compact .guide-card__body {
  padding: 18px;
}

.guide-card--compact .guide-card__body h3 {
  font-size: 1.08rem;
}

.guide-card--compact .guide-card__body p {
  font-size: 0.9rem;
  line-height: 1.55;
}

.guide-tag {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(120, 75, 157, 0.08);
  border: 1px solid rgba(120, 75, 157, 0.12);
  color: var(--brand-deep);
  font-size: 0.78rem;
  font-weight: 800;
}

.guide-author {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 22px;
  align-items: center;
  padding: 26px;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(120, 75, 157, 0.08);
  box-shadow: var(--shadow);
}

.guide-author img {
  width: 112px;
  height: 112px;
  object-fit: cover;
  border-radius: 999px;
  background: rgba(120, 75, 157, 0.08);
}

.guide-author h2 {
  margin: 0 0 8px;
  font-size: 1.65rem;
}

.guide-author p {
  margin: 0;
}

.guide-author__crmv {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--brand-deep);
  font-weight: 800;
}

.guide-article-shell {
  width: min(calc(100% - 40px), 920px);
  margin: 0 auto;
}

.guide-article__header {
  padding: 62px 0 34px;
  text-align: center;
}

.guide-breadcrumb {
  margin: 0 auto 18px;
  color: rgba(95, 57, 125, 0.72);
  font-size: 0.86rem;
  font-weight: 800;
}

.guide-breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 7px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.guide-breadcrumb li {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  line-height: 1.35;
}

.guide-breadcrumb li:not(:last-child)::after {
  content: "/";
  color: rgba(95, 57, 125, 0.34);
  font-weight: 700;
}

.guide-breadcrumb a {
  color: rgba(95, 57, 125, 0.78);
  text-decoration: none;
  text-underline-offset: 3px;
  transition: color 0.2s ease;
}

.guide-breadcrumb a:hover {
  color: var(--brand-deep);
  text-decoration: underline;
}

.guide-breadcrumb span {
  color: rgba(95, 57, 125, 0.62);
}

.guide-article__header h1 {
  max-width: 780px;
  margin: 16px auto;
  font-size: clamp(2.25rem, 4.6vw, 4.25rem);
  text-wrap: balance;
}

.guide-article__subtitle {
  max-width: 760px;
  margin: 0 auto;
  font-size: 1.08rem;
}

.guide-article__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
}

.guide-article__meta span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(120, 75, 157, 0.1);
  color: var(--brand-deep);
  font-size: 0.88rem;
  font-weight: 800;
}

.guide-article__image {
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(120, 75, 157, 0.08);
  box-shadow: var(--shadow);
  background: #ffffff;
}

.guide-article__image img {
  width: 100%;
  max-height: 520px;
  object-fit: cover;
}

.guide-article {
  padding: 38px 0 64px;
}

.guide-article h2 {
  margin: 42px 0 12px;
  font-size: clamp(1.75rem, 2.6vw, 2.45rem);
}

.guide-article p {
  margin: 0 0 18px;
  font-size: 1.04rem;
}

.guide-article ul {
  margin: 0 0 24px;
  padding-left: 22px;
}

.guide-article li {
  margin-bottom: 10px;
}

.guide-note {
  margin: 34px 0;
  padding: 24px 26px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(120, 75, 157, 0.1), rgba(215, 208, 226, 0.42));
  border: 1px solid rgba(120, 75, 157, 0.08);
}

.guide-note p {
  margin: 0;
  color: var(--brand-deep);
  font-weight: 800;
}

.guide-faq {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.guide-faq details {
  border-radius: var(--radius-sm);
  padding: 20px 22px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(120, 75, 157, 0.08);
  box-shadow: var(--shadow);
}

.guide-faq summary {
  cursor: pointer;
  color: var(--brand-deep);
  font-weight: 800;
  list-style: none;
}

.guide-faq summary::-webkit-details-marker {
  display: none;
}

.guide-faq p {
  margin: 12px 0 0;
}

.guide-related {
  padding: 56px 0 72px;
}

.guide-related h2 {
  margin: 0 0 24px;
  text-align: center;
  font-size: clamp(2rem, 3vw, 3rem);
}

.lp-section--footer-cta {
  padding: 64px 0;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.08), transparent 28%),
    linear-gradient(135deg, #784b9d 0%, #916dad 52%, #5f397d 100%);
  color: #ffffff;
}

.lp-footer-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.lp-footer-cta h2,
.lp-footer-cta p {
  color: #ffffff;
}

.lp-footer-cta h2 {
  max-width: 760px;
  margin: 14px 0;
  font-size: clamp(2rem, 3.2vw, 3.3rem);
}

.lp-footer-cta__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.lp-footer-cta__note {
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.98rem;
  font-weight: 700;
}

.lp-footer {
  padding: 26px 0 34px;
  background: var(--brand-deep);
  color: rgba(255, 255, 255, 0.82);
  text-align: center;
}

.lp-footer p {
  margin: 6px 0;
}

.lp-floating-whatsapp {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 50;
}

.lp-floating-whatsapp img {
  width: 58px;
  height: 58px;
  border-radius: 999px;
  box-shadow: 0 14px 26px rgba(0, 0, 0, 0.18);
}

@media (max-width: 1080px) {
  .guide-hero__grid,
  .guide-cards {
    grid-template-columns: 1fr;
  }

  .guide-categories {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guide-card {
    display: grid;
    grid-template-columns: 36% minmax(0, 1fr);
  }

  .guide-cards--related {
    max-width: 100%;
  }

  .guide-card img {
    height: 100%;
    min-height: 260px;
  }

  .guide-card--compact img {
    min-height: 190px;
  }
}

@media (max-width: 860px) {
  .lp-header__inner {
    min-height: auto;
    padding: 12px 0;
    flex-wrap: wrap;
    gap: 12px;
  }

  .lp-brand {
    width: 100%;
    display: flex;
    justify-content: flex-start;
  }

  .lp-nav {
    order: 3;
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    gap: 12px 22px;
  }

  .lp-btn,
  .lp-btn--header {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .lp-shell,
  .guide-article-shell {
    width: min(calc(100% - 52px), var(--shell));
  }

  .guide-hero {
    padding-top: 44px;
  }

  .guide-hero h1,
  .guide-article__header h1 {
    font-size: clamp(2.1rem, 10vw, 3rem);
    max-width: none;
  }

  .guide-hero__panel img {
    height: 270px;
  }

  .guide-section {
    padding: 46px 0;
  }

  .guide-categories,
  .guide-card,
  .guide-author {
    grid-template-columns: 1fr;
  }

  .guide-card img {
    height: 300px;
    min-height: 0;
  }

  .guide-card--compact img {
    height: 220px;
    min-height: 0;
  }

  .guide-breadcrumb {
    font-size: 0.78rem;
    margin-bottom: 14px;
  }

  .guide-breadcrumb ol {
    justify-content: flex-start;
  }

  .guide-author {
    text-align: center;
  }

  .guide-author img {
    margin: 0 auto;
  }

  .guide-article__header {
    padding-top: 44px;
  }

  .guide-article__image img {
    max-height: 340px;
  }

  .lp-floating-whatsapp {
    right: 14px;
    bottom: 14px;
  }

  .lp-floating-whatsapp img {
    width: 54px;
    height: 54px;
  }
}
