/* single.css - Final V4 (3-Block Contact) */

:root {
    --porto-blue: #0a4d53;
    --porto-green: #62B74E;
    --zap-green: #25D366;
}

/* NAVBAR */
.navbar {
    transition: background-color 0.3s ease, transform 0.3s ease;
    background-color: transparent;
    /* Stick to Transparent initially */
}

.navbar-hidden {
    transform: translateY(-100%);
}

.navbar-visible {
    transform: translateY(0);
}

/* Back Button Custom Style */
.btn-back-custom {
    color: var(--color-primary) !important;
    border: 1px solid var(--color-primary) !important;
    background: transparent !important;
    transition: all 0.3s ease;
}

.btn-back-custom:hover {
    background: var(--color-primary) !important;
    color: var(--color-text-dark) !important;
}

/* === HERO SECTION === */
.event-banner-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 500px;
    background-image: url('/theme/img/events/poster-vertical.png');
    background-size: cover;
    background-position: center center;
    filter: blur(6px) brightness(0.4);
    transform: scale(1.1);
    z-index: -1;
    overflow: hidden;
}

.event-header-content {
    margin-top: 150px;
    color: white;
}

/* Poster */
/* Poster overrides for Single Event (Dark Background) */
.poster-thumb-container {
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6) !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
    margin-bottom: -50px;
    /* Overlap effect */
}

.poster-thumb-container:hover {
    border-color: rgba(255, 255, 255, 0.8) !important;
}

.text-shadow {
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
}

/* === OFFSET TEXTO === */
@media (min-width: 992px) {
    .info-offset-fix {
        padding-left: 170px !important;
        transition: padding 0.3s ease;
    }
}

/* === SIDEBAR === */
@media (min-width: 992px) {
    .sidebar-spacer {
        margin-top: 8rem !important;
    }
}

.sticky-sidebar {
    position: sticky;
    top: 120px;
    z-index: 10;
}

/* === UI ELEMENTS === */
.bento-card {
    border-radius: 24px !important;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.bg-porto-blue {
    background-color: var(--porto-blue) !important;
}

/* WhatsApp Theme */
.bg-whatsapp {
    background-color: var(--zap-green) !important;
    color: white;
}

.btn-white {
    background-color: white;
    color: var(--zap-green);
    border: none;
    transition: all 0.3s ease;
}

.btn-white:hover {
    background-color: #f0f0f0;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.text-whatsapp-green {
    color: var(--zap-green) !important;
}

/* === FORMULÁRIO === */
.form-control-dark {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    color: white !important;
    font-size: 0.95rem;
    height: 50px;
    padding: 0 15px;
}

.form-control-dark::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.form-control-dark:focus {
    background-color: rgba(255, 255, 255, 0.2) !important;
    box-shadow: none;
    border-color: var(--porto-green) !important;
    color: white;
}

.input-group-text.form-control-dark {
    border-right: none;
    display: flex;
    align-items: center;
}

/* When sibling input is focused/filled, make icon dark too?
   Hard to do with CSS predecessors, leave as is or make solid white if needed.
   For now, let's keep icon simplified. */

/* === BOTÃO DE ENVIAR (BLOCO DIREITA) === */
.btn-block-send {
    background-color: transparent;
    color: white;
    border: none;
    transition: all 0.3s ease;
    cursor: pointer;
}

.btn-block-send:hover {
    background-color: var(--porto-green);
    color: white;
}

.btn-block-send i {
    transition: transform 0.3s ease;
}

.btn-block-send:hover i {
    transform: scale(1.2) rotate(-10deg);
}

/* Utils */
.btn-porto-cta {
    background-color: var(--porto-green);
    color: white;
    border: none;
    padding: 15px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.btn-porto-cta:hover {
    background-color: white;
    color: var(--porto-blue);
    transform: translateY(-3px);
}

.hover-lift:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15) !important;
}

.countdown-box {
    background: rgba(255, 255, 255, 0.1);
    padding: 5px 12px;
    border-radius: 8px;
    text-align: center;
    min-width: 65px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Mobile Adjustments */
@media (max-width: 991.98px) {
    .event-banner-bg {
        height: 600px;
    }

    /* Poster styles moved to events.css */

    .event-header-content {
        margin-top: 100px;
        text-align: center;
    }

    .event-header-content .col-lg-8 {
        flex-direction: column;
        align-items: center !important;
    }

    .text-lg-end {
        text-align: center !important;
    }

    .border-end {
        border-right: none !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        padding-bottom: 20px;
    }

    .info-offset-fix {
        padding-left: 0 !important;
    }

    /* Botão Enviar no Mobile */
    .btn-block-send {
        height: 80px !important;
        /* Altura fixa no mobile */
        background-color: var(--porto-green);
        /* Já fica verde no mobile para destaque */
    }
}

/* Utilities */
.hover-white:hover {
    color: white !important;
}

.opacity-10 {
    opacity: 0.1 !important;
}

.ls-1 {
    letter-spacing: 1px;
}

.bg-light-theme {
    background-color: var(--color-bg-light, #ffffff) !important;
}