/* =============================================
   CONTACT.CSS — Section kontak / formulir
   Mengatur tampilan info kontak, formulir, social links.
   ============================================= */

/* --- Contact Section Container --- */
.contact {
    padding: var(--section-padding) 0;
    position: relative;
    background: linear-gradient(180deg, var(--sky-100) 0%, var(--sky-50) 50%, var(--cloud-white) 100%);
}

.contact-cloud-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 60px;
    align-items: start;
}

/* --- Info Cards (kartu alamat / WA / email) --- */
.contact-info-cloud {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.info-cloud-card {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 24px;
    background: var(--cloud-white);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-cloud);
    transition: var(--transition-normal);
}

.info-cloud-card:hover {
    transform: translateX(10px);
    box-shadow: var(--shadow-cloud-hover);
}

.info-icon-cloud {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gradient-button);
    border-radius: 50%;
    flex-shrink: 0;
    transition: var(--transition-bounce);
}

.info-cloud-card:hover .info-icon-cloud {
    transform: rotate(15deg) scale(1.1);
}

.info-icon-cloud svg {
    color: var(--cloud-white);
}

.info-content {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.info-label {
    font-size: 12px;
    color: var(--sky-600);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.info-value {
    font-size: 16px;
    color: var(--deep-blue);
    font-weight: 600;
}

/* --- Social Cloud Links --- */
.social-cloud-links {
    display: flex;
    gap: 12px;
    margin-top: 20px;
}

.social-cloud-btn {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--cloud-white);
    border-radius: 50%;
    color: var(--sky-600);
    box-shadow: var(--shadow-soft);
    transition: var(--transition-bounce);
}

.social-cloud-btn:hover {
    background: var(--gradient-button);
    color: var(--cloud-white);
    transform: translateY(-8px) scale(1.1);
    box-shadow: var(--shadow-cloud);
}

/* --- Contact Form --- */
.contact-form-cloud {
    background: var(--cloud-white);
    padding: 50px;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-cloud);
}

.cloud-form {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

/* --- Input Group (field input / textarea) --- */
.cloud-input-group {
    position: relative;
}

.cloud-input-group input,
.cloud-input-group textarea {
    width: 100%;
    padding: 20px;
    font-size: 16px;
    font-family: inherit;
    color: var(--deep-blue);
    background: var(--sky-50);
    border: 2px solid transparent;
    border-radius: var(--radius-md);
    transition: var(--transition-normal);
    outline: none;
}

.cloud-input-group textarea {
    resize: vertical;
    min-height: 140px;
}

/* Label floating (animasi naik saat fokus) */
.cloud-input-group label {
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
    color: var(--sky-600);
    pointer-events: none;
    transition: var(--transition-normal);
    background: transparent;
}

.cloud-input-group textarea~label {
    top: 30px;
}

/* Input bubble dekoratif */
.input-bubble {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    width: 12px;
    height: 12px;
    background: var(--sky-300);
    border-radius: 50%;
    opacity: 0;
    transition: var(--transition-bounce);
}

/* Fokus state */
.cloud-input-group input:focus,
.cloud-input-group textarea:focus {
    background: var(--cloud-white);
    border-color: var(--sky-400);
    box-shadow: 0 0 0 4px rgba(56, 189, 248, 0.1);
}

.cloud-input-group input:focus~.input-bubble,
.cloud-input-group textarea:focus~.input-bubble {
    opacity: 1;
    animation: bubblePop 0.5s var(--ease-cloud);
}

@keyframes bubblePop {
    0% {
        transform: translateY(-50%) scale(0);
    }

    50% {
        transform: translateY(-50%) scale(1.3);
    }

    100% {
        transform: translateY(-50%) scale(1);
    }
}

/* Label saat fokus / terisi */
.cloud-input-group input:focus~label,
.cloud-input-group input:valid~label,
.cloud-input-group textarea:focus~label,
.cloud-input-group textarea:valid~label {
    top: 0;
    font-size: 12px;
    color: var(--sky-500);
    background: var(--cloud-white);
    padding: 0 8px;
}