/* Reset básico e configurações gerais */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background-color: #EADFEB;
    font-family: 'Roboto', sans-serif;
    padding: 20px;
}

/* O cartão principal */
.card {
    background-color: #FDF4E3;
    padding: 35px 30px; /* Um pouco mais de padding */
    border-radius: 15px; /* Mais arredondado */
    max-width: 550px; /* Um pouco maior para acomodar os 6 contadores */
    width: 100%;
    text-align: center;
    border: 1px solid #E0D8C8;
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.1); /* Sombra mais pronunciada */
}

/* Título: Gabriel e Julia */
.title {
    font-family: 'Fredoka One', cursive;
    color: #8C3B3B;
    font-size: 3em;
    margin-bottom: 25px;
    font-weight: 400;
    line-height: 1.2;
    /* Adiciona um cursor de link aqui também se desejar */
    /* cursor: pointer; */
}

/* ---- NOVA REGRA CSS ---- */
/* Estilo para o link DENTRO do título */
.title a {
    color: inherit; /* Herda a cor (#8C3B3B) do h1 pai */
    text-decoration: none; /* Remove o sublinhado */
    font-family: inherit; /* Garante herança da fonte */
    font-weight: inherit; /* Garante herança do peso da fonte */
    /* Remove qualquer estilo extra que o navegador possa adicionar */
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    display: inline; /* Garante que se comporte como texto */
}

/* Opcional: Adicionar um efeito sutil no hover/focus se desejar */
/*
.title a:hover,
.title a:focus {
    opacity: 0.85;
    outline: none; /* Remove outline de foco padrão se não gostar
}
*/


/* Placeholder da Imagem / Container Clicável */
.image-placeholder {
 /* ... (restante do seu CSS existente permanece igual) ... */
    width: 100%;
    aspect-ratio: 1 / 1;
    border: 1px solid #D5CDBF;
    margin: 0 auto 30px auto;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    perspective: 1000px;
    background-color: #EFE8D9;
    border-radius: 10px;
}

/* Placeholder da Imagem / Container Clicável */
.image-placeholder {
    width: 100%;
    aspect-ratio: 1 / 1;
    border: 1px solid #D5CDBF;
    margin: 0 auto 30px auto; /* Mais margem inferior */
    position: relative;
    overflow: hidden;
    cursor: pointer;
    perspective: 1000px;
    background-color: #EFE8D9;
    border-radius: 10px; /* Bordas arredondadas no container também */
}

/* Estilo base para TODAS as imagens do casal dentro do placeholder */
.image-placeholder .couple-image {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transform: rotateY(-90deg);
    transition: opacity 0.6s ease-in-out, transform 0.6s ease-in-out;
    backface-visibility: hidden;
    pointer-events: none;
    z-index: 1;
    border-radius: 10px; /* Garante que a imagem siga o arredondamento do container */
}

/* Estilo para a imagem ATIVA (visível e na frente) */
.image-placeholder .couple-image.active {
    opacity: 1;
    transform: rotateY(0deg);
    pointer-events: auto;
    z-index: 2;
}

/* Classe TEMPORÁRIA para a imagem que está SAINDO com animação */
.image-placeholder .couple-image.flipping-out {
    z-index: 3;
    animation: flipOut 0.6s ease-in-out forwards;
}

/* Classe TEMPORÁRIA para a imagem que está ENTRANDO com animação */
.image-placeholder .couple-image.flipping-in {
    z-index: 4;
    animation: flipIn 0.6s ease-in-out forwards;
}

/* Animações Keyframes para o efeito Flip/Page-Turn */
@keyframes flipOut {
    from { transform: rotateY(0deg); opacity: 1; }
    to { transform: rotateY(90deg); opacity: 0; }
}
@keyframes flipIn {
    from { transform: rotateY(-90deg); opacity: 0; }
    to { transform: rotateY(0deg); opacity: 1; }
}

/* Rótulo do contador */
.counter-label {
    color: #5C5346;
    font-size: 1.2em; /* Um pouco maior */
    margin-bottom: 20px; /* Mais espaço */
}

/* Container das caixas do contador */
.counter-boxes {
    display: flex;
    justify-content: center;
    gap: 12px; /* Mais espaçamento entre as caixas */
    flex-wrap:nowrap;
    margin-bottom: 30px; /* Mais espaço */
}

/* Estilo individual de cada caixa do contador (MAIS ARREDONDADO) */
.box {
    background: linear-gradient(145deg, #fdece8, #f8e0da); /* Gradiente suave */
    border: 1px solid #EACDC7;
    border-radius: 15px; /* BEM MAIS ARREDONDADO */
    padding: 15px 10px; /* Mais padding vertical */
    min-width: 70px; /* Ajuste mínimo */
    flex-basis: 75px; /* Base flex para tentar manter tamanho */
    flex-grow: 1; /* Permite crescer se houver espaço */
    max-width: 90px; /* Limita largura máxima */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 3px 3px 6px #d5c8c4, /* Sombra externa suave */
               -3px -3px 6px #ffffff; /* Brilho interno suave (efeito Neumorphism leve) */
    transition: transform 0.2s ease-out; /* Efeito sutil ao passar o mouse */
}

.box:hover {
    transform: translateY(-2px); /* Leve subida no hover */
}


/* Números dentro das caixas */
.number {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 2.2em; /* Um pouco maior */
    color: #8C3B3B;
    line-height: 1.1;
    margin-bottom: 3px; /* Pequeno espaço antes da unidade */
}

/* Unidades (ANOS, MESES, etc.) */
.unit {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 0.65em; /* Levemente menor para contraste */
    color: #a15858; /* Cor um pouco mais suave */
    text-transform: uppercase;
    letter-spacing: 0.5px; /* Espaçamento leve entre letras */
}

/* Mensagem final */
.final-message {
    color: #5C5346;
    font-size: 1.3em; /* Um pouco maior */
    margin-top: 20px;
}

/* Ajustes para telas menores */
@media (max-width: 540px) {
     .card {
        padding: 25px 20px;
    }
    .title {
        font-size: 2.5em;
    }
    .counter-boxes {
        gap: 8px;
    }
    .box {
        min-width: 60px;
        flex-basis: 65px;
        padding: 12px 5px;
        border-radius: 12px; /* Um pouco menos redondo em telas pequenas */
    }
    .number {
        font-size: 1.8em;
    }
    .unit {
        font-size: 0.6em;
    }
}

@media (max-width: 420px) {
    .title {
        font-size: 2.1em;
    }
     /* Força 3 caixas por linha em telas muito pequenas */
    .box {
       flex-basis: calc(33.33% - 10px); /* Calcula largura para 3 colunas com gap */
       min-width: unset; /* Remove min-width */
    }
     .number {
        font-size: 1.6em;
    }
}