/* =================================
ARTICLE PAGE
================================= */

.article-page {

  background: var(--cor-clara);

  padding: 40px 0 80px;

}

/* =================================
LAYOUT
================================= */

.article-layout {

  display: grid;

  grid-template-columns:
    minmax(0, 1fr)
    320px;

  gap: 56px;

  align-items: start;

}

.article-content {

  width: 100%;

}

/* =================================
BREADCRUMB
================================= */

.article-breadcrumb {

  display: flex;

  align-items: center;

  gap: 10px;

  flex-wrap: wrap;

  margin-bottom: 32px;

  font-size: 0.9rem;

  color: var(--paragrafos);

}

.article-breadcrumb a {

  color: var(--paragrafos);

}

.article-breadcrumb a:hover {

  color: var(--cor-secundaria);

}

/* =================================
CATEGORY
================================= */

.article-category {

  display: inline-flex;

  margin-bottom: 20px;

  padding: 8px 14px;

  border-radius: 999px;

  background: rgba(67,170,139,0.12);

  color: var(--cor-secundaria);

  font-size: 13px;

  font-weight: 600;

}

/* =================================
HEADER
================================= */

.article-header {

  margin-bottom: 50px;

}

.article-title {

  max-width: 900px;

  margin-bottom: 20px;

}

.article-subtitle {

  max-width: 760px;

  margin-bottom: 30px;

  font-size: 1.25rem;

  line-height: 1.7;

  color: var(--paragrafos);

}

/* =================================
AUTHOR
================================= */

.article-author {

  display: flex;

  align-items: center;

  gap: 14px;

  margin-bottom: 36px;

}

.article-author img {

  width: 56px;

  height: 56px;

  border-radius: 50%;

  object-fit: cover;

}

.article-author__info {

  display: flex;

  flex-direction: column;

  gap: 4px;

}

.article-author__info strong {

  color: var(--cor-primaria);

}

.article-author__info span {

  font-size: 0.9rem;

  color: var(--paragrafos);

}

/* =================================
COVER
================================= */

.article-cover {

  width: 100%;

  max-height: 500px;

  object-fit: cover;

  border-radius: 20px;

  display: block;

}

/* =================================
CONTENT
================================= */

.article-content p {

  margin-bottom: 20px;

  font-size: 1.05rem;

  line-height: 1.8;

  color: var(--paragrafos);

}

.article-content h2 {

  margin-top: 60px;

  margin-bottom: 18px;

  scroll-margin-top: 110px;

}

.article-content ul {

  margin: 24px 0;

  padding-left: 24px;

}

.article-content li {

  margin-bottom: 10px;

}

/* =================================
ARTICLE ACTIONS
================================= */

.article-actions {

  display: flex;

  align-items: center;

  gap: 12px;

  margin-bottom: 36px;

}

.article-action {

  display: inline-flex;

  align-items: center;

  gap: 10px;

  padding: 12px 18px;

  border-radius: 999px;

  border: 1px solid var(--color-border);

  background: var(--cor-clara);

  cursor: pointer;

  transition: .25s ease;

}

.article-action:hover {

  transform: translateY(-2px);

  box-shadow: var(--dropdown-shadow);

}

.article-action img {

  width: 18px;

  height: 18px;

}

.article-action span {

  font-size: 0.95rem;

  font-weight: 500;

}

/* =================================
SIDEBAR
================================= */

.article-sidebar {

  position: sticky;

  top: 120px;

}

.sidebar-card {

  padding: 28px;

  margin-bottom: 24px;

  border-radius: 20px;

  border: 1px solid var(--color-border);

  background: #fff;

}

.sidebar-card h3 {

  margin-bottom: 14px;

  font-size: 1.05rem;

  font-weight: 600;

}

.sidebar-card p {

  margin-bottom: 20px;

  font-size: 0.90rem;

  line-height: 1.7;

}

.article-toc {

  list-style: none;

  padding: 0;

  margin: 0;

}

.article-toc li {

  margin-bottom: 14px;

}

.article-toc a {

  color: var(--paragrafos);

  font-size: 0.95rem;

  font-weight: 400;

  line-height: 1.5;

}

.article-toc a:hover {

  color: var(--cor-secundaria);

}

.article-toc li {

  display: flex;

  align-items: flex-start;

  gap: 12px;

  margin-bottom: 16px;

}

.article-toc__number {

  display: flex;

  align-items: center;

  justify-content: center;

  width: 26px;

  height: 26px;

  flex-shrink: 0;

  border-radius: 50%;

  background: rgba(67,170,139,0.12);

  color: var(--cor-secundaria);

  font-size: 13px;

  font-weight: 700;

}

.article-toc a {

  flex: 1;

  line-height: 1.45;

}

.article-toc a.active {

  color: var(--cor-secundaria);

  font-weight: 600;
}

.article-toc li.active .article-toc__number {

  background: var(--cor-secundaria);

  color: #fff;
}

.article-toc a,
.article-toc__number {

  transition: .25s ease;
}

.article-section-title {
  position: relative;

  margin-top: 72px;
  margin-bottom: 28px;

  font-size: 2rem;
  line-height: 1.2;

  color: var(--cor-primaria);
}

.article-section-title::after {
  content: "";

  display: block;

  width: 56px;
  height: 3px;

  margin-top: 16px;

  border-radius: 999px;

  background: var(--cor-secundaria);
}

.article-tip {

  display: flex;
  gap: 18px;

  margin: 32px 0;

  padding: 24px;

  border-radius: 18px;

  background: #f5fbf8;

  border: 1px solid rgba(67,170,139,0.15);
}

.article-tip__icon {

  width: 48px;
  height: 48px;

  flex-shrink: 0;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;

  background: rgba(67,170,139,0.12);

  font-size: 22px;
}

.article-tip strong {

  display: block;

  margin-bottom: 4px;

  font-size: 1rem;

  font-weight: 600;

  color: var(--cor-secundaria);
}

.article-tip p {
  margin: 0;

  font-size: 0.95rem;

  line-height: 1.7;

  color: var(--paragrafos);
}

.article-checklist {

  display: flex;
  flex-direction: column;

  gap: 12px;

  margin: 28px 0;
}

.article-checklist__item {

  display: flex;
  align-items: center;

  padding: 14px 18px;

  font-size: 1rem;

  font-weight: 400;

  border-radius: 14px;

  color: var(--paragrafos);

  background: #ffffff;

  border: 1px solid var(--color-border);
}

.article-checklist__item::before {

  content: "✓";

  width: 20px;
  height: 20px;

  margin-right: 12px;

  border-radius: 50%;

  display: flex;
  align-items: center;
  justify-content: center;

  background: rgba(67,170,139,0.12);

  color: var(--cor-secundaria);

  font-size: 10px;
  font-weight: 700;
}

.article-related {

  margin: 32px 0;

  padding: 24px;

  border-radius: 18px;

  background: var(--cor-fundo);

  border: 1px solid var(--color-border);
}

.article-related__label {

  display: block;

  margin-bottom: 10px;

  font-size: .9rem;
  font-weight: 600;

  color: var(--cor-secundaria);
}

.article-related__link {

  font-size: 1.1rem;
  font-weight: 600;

  color: var(--cor-primaria);
}

/* =================================
RESPONSIVO
================================= */

@media (max-width: 768px) {

  .article-title {

    font-size: 2.2rem;

  }

  .article-subtitle {

    font-size: 1.1rem;

  }

}

.article-inline-simple {
  color: var(--cor-secundaria);
  font-weight: 500;
}

.article-inline-simple:hover {
  text-decoration: underline;
}

/* =================================
CIDADES
================================= */

.article-city-links {

  margin: 40px 0;

  padding: 40px;

  border-radius: 20px;

  background: var(--cor-fundo);

  text-align: center;
}

.article-city-links p {

  margin-bottom: 24px;

  color: var(--paragrafos);

  font-size: 1.05rem;
}

.article-city-links a {

  display: block;

  width: fit-content;

  margin: 0 auto 16px;

  color: var(--cor-secundaria);

  font-weight: 500;

  text-decoration: none;

  transition:
    color .2s ease,
    transform .2s ease;
}

.article-city-links a::before {

  content: "✓";

  display: inline-flex;

  align-items: center;
  justify-content: center;

  width: 18px;
  height: 18px;

  margin-right: 10px;

  border-radius: 50%;

  background: rgba(67,170,139,0.12);

  color: var(--cor-secundaria);

  font-size: 11px;
  font-weight: 700;
}

.article-city-links a:hover {

  color: var(--cor-primaria);

  transform: translateX(3px);
}

.article-city-links a:last-child {
  margin-bottom: 0;
}

.article-example {

  margin: 32px 0;

  padding: 28px;

  border: 1px solid var(--color-border);

  border-radius: 20px;

  background: #fff;
}

.article-example__label {

  display: inline-block;

  margin-bottom: 12px;

  color: var(--cor-secundaria);

  font-size: 0.9rem;

  font-weight: 600;
}

.article-example h4 {

  margin-bottom: 10px;

  font-size: 1.2rem;
}

.article-example p {

  margin-bottom: 18px;
}

.article-example__button {

  display: inline-flex;

  font-weight: 600;

  color: var(--cor-secundaria);
}

/* =================================
CTA INLINE
================================= */

.article-cta-inline {

  margin: 40px 0;

  padding: 32px;

  border-radius: 20px;

  background:
    radial-gradient(
      circle at 20% 30%,
      rgba(67,170,139,0.08),
      transparent 40%
    ),
    #f8fbfb;

  border: 1px solid var(--color-border);
}

.article-cta-inline h3 {

  margin-bottom: 10px;

  font-size: 1.3rem;
}

.article-cta-inline p {

  margin-bottom: 22px;

  color: var(--paragrafos);
}

/* =================================
CTA FINAL
================================= */

.article-final-cta {

  margin-top: 80px;

  padding: 60px;

  border-radius: 28px;

  text-align: center;

  background:
    radial-gradient(
      circle at 20% 30%,
      rgba(67,170,139,0.12),
      transparent 40%
    ),
    radial-gradient(
      circle at 80% 20%,
      rgba(23,81,108,0.08),
      transparent 40%
    ),
    #ffffff;

  border: 1px solid var(--color-border);
}

.article-final-cta__eyebrow {

  display: inline-flex;

  margin-bottom: 18px;

  padding: 8px 14px;

  border-radius: 999px;

  background: rgba(67,170,139,0.12);

  color: var(--cor-secundaria);

  font-size: 14px;
  font-weight: 600;
}

.article-final-cta h2 {

  margin-bottom: 16px;

  font-size: 2.2rem;
}

.article-final-cta p {

  max-width: 650px;

  margin: 0 auto 32px;

  color: var(--paragrafos);
}

.article-final-cta .btn {

  min-width: 260px;
}

/* =================================
CONTINUE APRENDENDO
================================= */

.article-more {

  margin-top: 100px;

  padding-top: 80px;

  border-top: 1px solid var(--color-border);
}

.article-more h2 {

  text-align: center;

  margin-bottom: 12px;
}

.article-more__subtitle {

  text-align: center;

  max-width: 600px;

  margin: 0 auto 40px;

  margin-bottom: 50px;

  color: var(--paragrafos);
}

.article-more__grid {

  display: grid;

  grid-template-columns: repeat(2, 1fr);

  gap: 24px;
}

.article-more-card {

  display: block;

  overflow: hidden;

  border-radius: 20px;

  border: 1px solid var(--color-border);

  background: #fff;

  text-decoration: none;

  transition:
    transform .25s ease,
    box-shadow .25s ease;
}

.article-more-card:hover {

  transform: translateY(-4px);

  box-shadow: var(--dropdown-shadow);
}

.article-more-card__image {

  width: 100%;

  height: 200px;

  object-fit: cover;

  display: block;
}

.article-more-card__content {

  padding: 22px;
}

.article-more-card__tag {

  display: inline-flex;

  margin-bottom: 12px;

  padding: 5px 10px;

  border-radius: 999px;

  background: rgba(67,170,139,0.12);

  color: var(--cor-secundaria);

  font-size: 12px;

  font-weight: 600;
}

.article-more-card h3 {

  margin-bottom: 10px;

  font-size: 1.35rem;

  line-height: 1.35;

  color: var(--cor-primaria);
}

.article-more-card p {

  margin-bottom: 18px;

  font-size: .95rem;

  color: var(--paragrafos);

  line-height: 1.6;
}

.article-more-card__meta {

  font-size: .85rem;

  color: var(--paragrafos);
}

@media (max-width: 1100px) {

  .article-layout {

    grid-template-columns: 1fr;

  }

  .article-sidebar {

    position: static;

  }

}

@media (max-width: 768px) {

  .article-more__grid {

    grid-template-columns: 1fr;
  }

}