/**
 * Contact Buttons Styles
 * Loaded for the Contact section
 */

/* Force transparent background to show the fixed global background (red carpet) */
.tm-section--contacto {
    background-color: transparent !important;
    position: relative;
    z-index: 10;
    display: flex;
    flex-direction: column;
}
/* Posición vertical del bloque de contacto (título + subtítulo + iconos) */
.tm-section--contacto-block-top {
    justify-content: flex-start;
    padding-top: clamp(2rem, 8vh, 6rem);
}
.tm-section--contacto-block-center {
    justify-content: center;
}
.tm-section--contacto-block-bottom {
    justify-content: flex-end;
    padding-bottom: clamp(2rem, 8vh, 6rem);
}
.tm-section--contacto .wp-block-group {
    flex-shrink: 0;
}

/* Typography */
.tm-contact-title {
    font-family: "Cinzel", serif;
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--tm-gold, #F1D58A);
    margin-bottom: 1rem;
    text-shadow: 0 2px 8px rgba(0,0,0,0.55);
}

.tm-contact-subtitle {
    font-size: clamp(1rem, 2vw, 1.25rem);
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: 3rem !important;
    font-weight: 300;
    letter-spacing: 0.06em;
}

.tm-contact-title--small { font-size: clamp(1.35rem, 3.5vw, 2.25rem) !important; }
.tm-contact-title--large { font-size: clamp(2.5rem, 6vw, 4rem) !important; }
.tm-contact-subtitle--small { font-size: clamp(0.875rem, 1.5vw, 1rem) !important; }
.tm-contact-subtitle--large { font-size: clamp(1.15rem, 2.5vw, 1.5rem) !important; }

/* Grid Container */
.tm-contact-grid {
    display: flex;
    justify-content: center;
    gap: clamp(2rem, 5vw, 4rem);
    flex-wrap: wrap;
}

/* Contact Cards (Icon Buttons) */
.tm-contact-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    group: transition;
}

.tm-contact-card__icon-box {
    width: clamp(80px, 15vw, 120px);
    height: clamp(80px, 15vw, 120px);
    background: rgba(0, 0, 0, 0.28);
    border: 1px solid rgba(241, 213, 138, 0.2);
    border-radius: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.25s ease;
    backdrop-filter: blur(8px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.35);
}

.tm-contact-card__icon-box svg,
.tm-contact-card__icon-box img {
    width: 50%;
    height: 50%;
    object-fit: contain;
    color: rgba(241, 213, 138, 0.8);
    transition: color 0.2s ease;
}

.tm-contact-card__label {
    margin-top: 0.85rem;
    color: rgba(241, 213, 138, 0.75);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-weight: 600;
    transition: color 0.2s ease;
}

/* Hover Effects */
.tm-contact-card:hover .tm-contact-card__icon-box {
    transform: translateY(-6px) scale(1.02);
    border-color: rgba(241, 213, 138, 0.45);
}

.tm-contact-card:hover .tm-contact-card__label {
    color: #fff;
}

/* WhatsApp Specifics */
.tm-contact-card--whatsapp:hover .tm-contact-card__icon-box {
    border-color: rgba(37, 211, 102, 0.7);
    box-shadow: 0 8px 20px rgba(0,0,0,0.35), 0 0 12px rgba(37, 211, 102, 0.25);
}
.tm-contact-card--whatsapp:hover .tm-contact-card__icon-box svg {
    color: #25D366;
}

/* Email Specifics */
.tm-contact-card--email:hover .tm-contact-card__icon-box {
    border-color: rgba(234, 67, 53, 0.7);
    box-shadow: 0 8px 20px rgba(0,0,0,0.35), 0 0 12px rgba(234, 67, 53, 0.25);
}
.tm-contact-card--email:hover .tm-contact-card__icon-box svg {
    color: #EA4335;
}

/* Instagram Specifics */
.tm-contact-card--instagram:hover .tm-contact-card__icon-box {
    border-color: rgba(193, 53, 132, 0.7);
    box-shadow: 0 8px 20px rgba(0,0,0,0.35), 0 0 12px rgba(193, 53, 132, 0.25);
}
.tm-contact-card--instagram:hover .tm-contact-card__icon-box svg {
    color: #C13584;
}

/* Extra Golden Button (bloque del correo): fondo oscuro por defecto para buen contraste */
.tm-contact-extra {
    display: flex;
    justify-content: center;
    width: 100%;
}

.tm-contact-golden-btn {
    display: inline-block;
    padding: 0.85rem 2.4rem;
    font-family: "Cinzel", serif;
    font-size: 0.95rem;
    font-weight: 700;
    text-decoration: none;
    text-transform: uppercase;
    color: var(--tm-gold, #F1D58A);
    background: rgba(20, 12, 8, 0.88);
    border: 1px solid rgba(241, 213, 138, 0.45);
    border-radius: 999px;
    box-shadow: 0 6px 16px rgba(0,0,0,0.4);
    transition: all 0.2s ease;
    letter-spacing: 0.12em;
}

.tm-contact-golden-btn:hover {
    background: rgba(35, 22, 14, 0.95);
    border-color: rgba(241, 213, 138, 0.6);
    transform: translateY(-1px);
    color: #fff;
}

/* Página de contacto: sin scroll horizontal */
.tm-main--contacto {
    overflow-x: hidden;
    max-width: 100vw;
}

/* En móvil: espacio arriba para que el contenido no quede detrás del menú fijo */
@media (max-width: 768px) {
    .tm-main--contacto #contacto,
    .tm-main--contacto .tm-section--contacto {
        padding-top: 5.5rem;
    }
}
.tm-contact-content {
    max-width: min(800px, 100%);
}

/* ==============================
   CONTACTO: responsive móvil
   ============================== */
@media (max-width: 767px) {
    .tm-section--contacto {
        overflow-x: hidden;
        padding-left: 0;
        padding-right: 0;
    }
    .tm-section--contacto .wp-block-group {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    .tm-contact-extra {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
        width: 100%;
        box-sizing: border-box;
    }
    .tm-contact-golden-btn {
        display: block;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        padding: 0.7rem 1rem;
        font-size: 0.75rem;
        letter-spacing: 0.08em;
        white-space: normal;
        word-break: break-all;
        overflow-wrap: break-word;
        text-align: center;
    }
    .tm-contact-grid {
        gap: 1.25rem;
    }
    .tm-contact-card__icon-box {
        width: clamp(70px, 22vw, 90px);
        height: clamp(70px, 22vw, 90px);
    }
    .tm-contact-card__label {
        font-size: 0.75rem;
        letter-spacing: 0.12em;
    }
}
