/*
 * Gericia Property Card – Estilos do card flutuante
 * @package GericiaPropertyCard
 */

/* ================================================
   Variáveis CSS (sobrescritas via PHP inline)
   ================================================ */
:root {
    --gpc-bg:         #ffffff;
    --gpc-text:       #4A4A4A;
    --gpc-btn:        #2A5C6D;
    --gpc-btn-hover:  #1E4350;
    --gpc-total:      #000000;
    --gpc-radius:     12px;
    --gpc-font-size:  14px;
    --gpc-width:      320px;
    --gpc-sticky-top: 80px;
    --gpc-border:     #e8e8e8;
    --gpc-shadow:     0 4px 24px rgba(0, 0, 0, 0.10);
    --gpc-label-color:#888888;
}

/* ================================================
   Wrapper
   O sticky é gerenciado via JS (card.js).
   position:sticky não funciona quando o container
   pai tem altura igual à do card (caso Elementor Widget HTML).
   ================================================ */
.gpc-card-wrapper {
    width: var(--gpc-width);
    max-width: 100%;
    align-self: flex-start;
}

/* ================================================
   Card
   ================================================ */
.gpc-card {
    background: var(--gpc-bg);
    border-radius: var(--gpc-radius);
    box-shadow: var(--gpc-shadow);
    font-size: var(--gpc-font-size);
    color: var(--gpc-text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    padding: 0;
    overflow: hidden;
    border: 1px solid var(--gpc-border);
}

/* Código do imóvel */
.gpc-code {
    background: #f7f7f7;
    padding: 8px 20px;
    font-size: calc(var(--gpc-font-size) - 2px);
    color: var(--gpc-label-color);
    border-bottom: 1px solid var(--gpc-border);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* ================================================
   Preços
   ================================================ */
.gpc-prices {
    padding: 16px 20px 4px;
}

.gpc-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 8px 0;
    border-bottom: 1px solid #f0f0f0;
    gap: 8px;
}

.gpc-row:last-child {
    border-bottom: none;
}

.gpc-label {
    color: var(--gpc-label-color);
    font-size: calc(var(--gpc-font-size) - 1px);
    flex: 1;
    line-height: 1.4;
}

.gpc-value {
    font-weight: 600;
    color: var(--gpc-text);
    white-space: nowrap;
}

/* Venda — destaque visual */
.gpc-row--sale .gpc-value {
    font-size: calc(var(--gpc-font-size) + 2px);
}

/* ================================================
   Total
   ================================================ */
.gpc-total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin: 4px 20px 0;
    padding: 12px 0 14px;
    border-top: 2px solid var(--gpc-border);
}

.gpc-total__label {
    font-size: calc(var(--gpc-font-size) - 1px);
    color: var(--gpc-label-color);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.gpc-total__value {
    font-size: calc(var(--gpc-font-size) + 6px);
    font-weight: 700;
    color: var(--gpc-total);
}

/* ================================================
   Botão CTA
   ================================================ */
.gpc-cta-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: calc(100% - 40px);
    margin: 0 20px 20px;
    padding: 14px 20px;
    background: var(--gpc-btn);
    color: #ffffff;
    border: none;
    border-radius: calc(var(--gpc-radius) - 4px);
    font-size: var(--gpc-font-size);
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.1s ease;
    letter-spacing: 0.02em;
    font-family: inherit;
    text-decoration: none;
}

.gpc-cta-button:hover,
.gpc-cta-button:focus {
    background: var(--gpc-btn-hover);
    outline: none;
}

.gpc-cta-button:active {
    transform: scale(0.98);
}

.gpc-whatsapp-icon {
    width: 20px;
    height: 20px;
    fill: #ffffff;
    flex-shrink: 0;
}

/* ================================================
   Responsivo – Tablet
   ================================================ */
@media (max-width: 1024px) {
    .gpc-card-wrapper {
        position: relative;
        top: auto;
        width: 100%;
        max-width: 480px;
        margin: 24px auto;
    }
}

/* ================================================
   Responsivo – Mobile
   ================================================ */
@media (max-width: 600px) {
    .gpc-card-wrapper {
        position: relative;
        top: auto;
        width: 100%;
        max-width: 100%;
        margin: 16px 0;
    }

    .gpc-total__value {
        font-size: calc(var(--gpc-font-size) + 4px);
    }
}
