@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
    --lime: #A1CC3E;
    --plum: #914B8A;
    --green: #2CA44F;
    --charcoal: #111827;
    --black: #000000;
    --violet: #4C1D95;
    --lavender: #F4F4FE;
    --purple: #6D28D9;
}

body {
    font-family: 'Poppins', sans-serif;
}

/* Tipografia base */
.text-headline-large {
    font-size: 32px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
}

.text-headline-medium {
    font-size: 28px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
}

.text-headline-small {
    font-size: 24px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
}

.text-title-large {
    font-size: 22px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
}

.text-title-medium {
    font-size: 16px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
}

.text-title-small {
    font-size: 14px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
}

.text-body-large {
    font-size: 16px;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
}

.text-body-medium {
    font-size: 14px;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
}

.text-body-small {
    font-size: 12px;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
}

.text-label-large {
    font-size: 14px;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
}

.text-label-medium {
    font-size: 12px;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
}

.text-label-small {
    font-size: 11px;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
}

.text-button-large {
    font-size: 14px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
    text-transform: uppercase;
}

.text-button-medium {
    font-size: 12px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
    text-transform: uppercase;
}

.text-button-small {
    font-size: 11px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0;
    text-transform: uppercase;
}

/* Modelos */
.nav-link-custom {
    font-size: 16px;
    font-weight: 400;
    line-height: 16px;
    letter-spacing: 0;
    color: #4b5563 !important;
}

.btn-green {
    color: #fff;
    background-color: #059669;
    border-color: #059669;
    line-height: 2;
}

.btn-green:hover {
    color: #fff;
    background-color: #047857;
    border-color: #046c6c;
}

.btn-green:focus,
.btn-green.focus {
    color: #fff;
    background-color: #047857;
    border-color: #046c6c;
    -webkit-box-shadow: 0 0 0 0.2rem rgba(5, 150, 105, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(5, 150, 105, 0.5);
}

.btn-green.disabled,
.btn-green:disabled {
    color: #fff;
    background-color: #059669;
    border-color: #059669;
}

.btn-green:not(:disabled):not(.disabled):active,
.btn-green:not(:disabled):not(.disabled).active,
.show>.btn-green.dropdown-toggle {
    color: #fff;
    background-color: #046c6c;
    border-color: #035f5a;
}

.btn-green:not(:disabled):not(.disabled):active:focus,
.btn-green:not(:disabled):not(.disabled).active:focus,
.show>.btn-green.dropdown-toggle:focus {
    -webkit-box-shadow: 0 0 0 0.2rem rgba(5, 150, 105, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(5, 150, 105, 0.5);
}

.btn-purple {
    color: #fff;
    background-color: #7C3AED;
    border-color: #7C3AED;
    line-height: 2;
}

.btn-purple:hover {
    color: #fff;
    background-color: #6B21A8;
    border-color: #5B179E;
}

.btn-purple:focus,
.btn-purple.focus {
    color: #fff;
    background-color: #6B21A8;
    border-color: #5B179E;
    -webkit-box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.5);
}

.btn-purple.disabled,
.btn-purple:disabled {
    color: #fff;
    background-color: #7C3AED;
    border-color: #7C3AED;
}

.btn-purple:not(:disabled):not(.disabled):active,
.btn-purple:not(:disabled):not(.disabled).active,
.show>.btn-purple.dropdown-toggle {
    color: #fff;
    background-color: #5B179E;
    border-color: #4C0E94;
}

.btn-purple:not(:disabled):not(.disabled):active:focus,
.btn-purple:not(:disabled):not(.disabled).active:focus,
.show>.btn-purple.dropdown-toggle:focus {
    -webkit-box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.5);
}

.btn-lime {
    color: #fff;
    background-color: #10B981;
    border-color: #10B981;
    line-height: 2;
}

.btn-lime:hover {
    color: #fff;
    background-color: #0e9e6e;
    /* tom mais escuro para hover */
    border-color: #0d8c63;
}

.btn-lime:focus,
.btn-lime.focus {
    color: #fff;
    background-color: #0e9e6e;
    border-color: #0d8c63;
    -webkit-box-shadow: 0 0 0 0.2rem rgba(16, 185, 129, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(16, 185, 129, 0.5);
}

.btn-lime.disabled,
.btn-lime:disabled {
    color: #fff;
    background-color: #10B981;
    border-color: #10B981;
}

.btn-lime:not(:disabled):not(.disabled):active,
.btn-lime:not(:disabled):not(.disabled).active,
.show>.btn-lime.dropdown-toggle {
    color: #fff;
    background-color: #0b7458;
    border-color: #0a654e;
}

.btn-lime:not(:disabled):not(.disabled):active:focus,
.btn-lime:not(:disabled):not(.disabled).active:focus,
.show>.btn-lime.dropdown-toggle:focus {
    -webkit-box-shadow: 0 0 0 0.2rem rgba(16, 185, 129, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(16, 185, 129, 0.5);
}

.ellipsis {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.footer-link {
    color: #9CA3AF;
    text-decoration: none;
}

.footer-link:hover,
.footer-link:focus,
.footer-link:active {
    color: white;
    text-decoration: none;
}

.card-rounded {
    border-radius: 0.85rem !important;
    box-shadow: 10px 10px 5px rgba(0, 0, 0, 0.15);
}

.text-purple {
    color: #7C3AED;
}

.custom-link {
    color: #7C3AED;
    text-decoration: none;
    transition: color 0.3s ease;
}

.custom-link:hover {
    color: #5B179E;
    text-decoration: none;
}

.dropdown-item.active,
.dropdown-item:active {
  color: #fff;
  text-decoration: none;
  background-color: #059669;
}

.page-item.active .page-link {
  z-index: 3;
  color: #fff;
  background-color: #059669;
  border-color: #059669;
}

.page-link {
  position: relative;
  display: block;
  padding: 0.5rem 0.75rem;
  margin-left: -1px;
  line-height: 1.25;
  color: #059669;
  background-color: #fff;
  border: 1px solid #dee2e6;
}

.page-link:hover {
  z-index: 2;
  color: #046c6c;
  text-decoration: none;
  background-color: #e9ecef;
  border-color: #dee2e6;
}

.page-link:focus {
  z-index: 3;
  outline: 0;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(5, 150, 105, 0.5);
          box-shadow: 0 0 0 0.2rem rgba(5, 150, 105, 0.5);
}

.page-item.active .page-link {
  z-index: 3;
  color: #fff;
  background-color: #059669;
  border-color: #059669;
}