/* Variáveis de cores do app */
:root {
    --app-bar-color: #4A41C5;
    --sliding-top: #9ACAF7;
    --background-color: #ACBCFF;
    --button-amber: #FFC107;
    --text-dark: #1F1F1F;
    --text-light: #ffffff;
    --card-bg: #ffffff;
    --card-border: #ddd;
}

/* Reset e base */
body {
    margin: 0;
    padding: 0;
    font-family: "Segoe UI", sans-serif;
    background-color: var(--background-color);
    color: var(--text-dark);
}

/* Barra de navegação ou topo */
.navbar,
.app-bar {
    background-color: var(--app-bar-color) !important;
    color: var(--text-light);
}

.navbar a,
.app-bar a {
    color: var(--text-light);
    font-weight: 600;
}

/* Botões */
.btn-primary,
.btn-warning {
    background-color: var(--button-amber) !important;
    border: none;
    color: #000;
    font-weight: bold;
}

.btn-primary:hover,
.btn-warning:hover {
    background-color: #e6b300 !important;
    color: #000;
}

/* Cards de plano */
.card-plan {
    background-color: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: 16px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    padding: 24px;
    text-align: center;
    transition: transform 0.3s ease;
}

.card-plan:hover {
    transform: translateY(-4px);
}

.card-title {
    font-size: 1.6rem;
    color: var(--app-bar-color);
    font-weight: 700;
}

.card-price {
    font-size: 2.4rem;
    color: var(--app-bar-color);
    margin: 12px 0;
}

.card-popular {
    position: relative;
    border: 2px solid var(--button-amber);
}

.card-popular::before {
    content: "Mais Popular";
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--button-amber);
    color: #000;
    padding: 4px 12px;
    font-size: 0.85rem;
    border-radius: 16px;
    font-weight: bold;
}

/* Tabela de comparação */
.plan-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 40px;
    background-color: var(--card-bg);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.06);
}

.plan-table th,
.plan-table td {
    padding: 16px;
    text-align: center;
    border-bottom: 1px solid #eee;
}

.plan-table th {
    background-color: var(--sliding-top);
    color: #000;
    font-weight: 600;
}

.plan-table td {
    background-color: #fff;
}

.plan-table tr:hover {
    background-color: #f7f7f7;
}

/* Rodapé */
.footer {
    background-color: var(--app-bar-color);
    color: var(--text-light);
    padding: 20px;
    text-align: center;
    margin-top: 60px;
}

/* Responsividade */
@media (max-width: 768px) {
    .card-plan {
        margin-bottom: 20px;
    }

    .plan-table th,
    .plan-table td {
        font-size: 0.9rem;
        padding: 12px;
    }
}

.table-pricing {
    border-radius: 12px;
    overflow: hidden;
    border: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.table-pricing > thead > tr > th {
    background-color: var(--app-bar-color) !important;
    color: var(--text-light) !important;
    font-weight: 600;
    font-size: 1.1rem;
    border: none;
    padding: 1rem;
}


.table-pricing th,
.table-pricing td {
    vertical-align: middle;
    padding: 1rem;
    border: none;
    font-size: 1rem;
}

.table-pricing tbody tr:nth-child(even) {
    background-color: #f8f9fc;
}

.table-pricing tbody tr:nth-child(odd) {
    background-color: #fff;
}

.table-pricing .check {
    color: #28a745;
    /* Verde */
    font-size: 1.25rem;
}

.table-pricing .cross {
    color: #dc3545;
    /* Vermelho */
    font-size: 1.25rem;
}

@media (max-width: 768px) {

    .table-pricing th,
    .table-pricing td {
        padding: 0.75rem;
        font-size: 0.9rem;
    }
}

/* Wrapper ocupa toda a altura da coluna e controla overflow */
.feature-ec__imgwrap {
  display: flex;
  height: 100%;
  width: 100%;
  align-items: center;   /* centraliza verticalmente a imagem se sobrar espaço */
  justify-content: center; /* centraliza horizontalmente */
  overflow: hidden;      /* evita qualquer estouro visual */
}

/* Garante altura boa em desktop; as colunas esticam na mesma altura */
.feature-ec__row { 
  min-height: 480px; 
}

.feature-ec__photo {
  flex: 1;
  width: 100%;
  height: 100%;               /* ocupa a altura total da coluna */
  display: flex;              /* para alinhar o <img> dentro */
}

.feature-ec__image {
  width: 100%;
  height: 100%;
  object-fit: cover;          /* cobre todo o espaço sem distorcer */
  border-radius: 1rem;
  box-shadow: 0 10px 30px rgba(0,0,0,.15);
}

/* Mobile: altura fixa agradável */
@media (max-width: 991.98px) {
  .feature-ec__row { min-height: unset; }
  .feature-ec__photo {
    height: 320px;            /* ou aspect-ratio: 4/3 */
  }
  .feature-ec__image {
    object-fit: contain;      /* no mobile mostra inteira */
  }
}

/* Em telas menores, deixar a imagem mais solta */
@media (max-width: 991.98px) {
  .feature-ec__image {
    max-height: none;    /* deixa crescer naturalmente no mobile */
    width: 100%;
  }
}

.feature-ec__list { line-height: 1.4; }
.feature-ec__icon {
  font-size: 1.4rem;
  line-height: 1;
  flex: 0 0 auto;
  margin-top: 2px;
}
@media (max-width: 991.98px) {
  .feature-ec { text-align: left; }
}
