/* ================================================
   CONTACTOS — contactos.css
   ================================================ */

/* ── Fade-in ── */
.contact-item, .contact-form-wrap {
    opacity: 0; transform: translateY(20px);
    transition: opacity .5s ease, transform .5s ease;
}
.from-left  { transform: translateX(-28px); }
.from-right { transform: translateX(28px); }
.is-visible { opacity: 1 !important; transform: translate(0,0) !important; }

/* ════════════════════════════════════════════
   CONTACTO
════════════════════════════════════════════ */
.contactos {
    padding: 40px 24px;
    max-width: 1280px;
    margin: 0 auto;
}
.contactos__title {
    font-size: clamp(1.8rem,3vw,2.6rem);
    font-weight: 700; color: var(--color-primary);
    margin: 0 0 8px; font-family: var(--font-primary); text-align: center;
}
.contactos__sub {
    font-size: 1rem; color: #5a7080;
    text-align: center; margin: 0 0 40px; line-height: 1.7;
}
.contactos__layout {
    display: grid; grid-template-columns: 1fr 1.4fr;
    gap: 48px; align-items: start;
}
.contact-item {
    display: flex; align-items: center; gap: 16px; margin-bottom: 24px;
}
.contact-item__icon { width: 68px; height: 68px; object-fit: contain; flex-shrink: 0; }
.contact-item__label { font-size: 1rem; font-weight: 700; color: #2d4d57; margin: 0 0 4px; font-family: var(--font-primary); }
.contact-item__value { font-size: .9rem; color: #5a7080; margin: 0; line-height: 1.7; }
.contact-item__value i            { margin-right: 8px; }
.contact-item__value .fa-whatsapp { color: #25D366; }

.contact-form__title {
    font-size: clamp(1.3rem,2.2vw,1.8rem); font-weight: 700; color: #e39a42;
    margin: 0 0 24px; display: flex; align-items: center; gap: 8px;
    font-family: var(--font-primary);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.form-group { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.form-label { font-size: .875rem; font-weight: 700; color: #2d4a5a; }
.form-input-wrap {
    display: flex; border-radius: 12px; overflow: hidden;
    border: 1.5px solid #e0c99a; transition: border-color .2s, box-shadow .2s;
}
.form-input-wrap:focus-within {
    border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(242,146,36,.15);
}
.form-input-prefix {
    background: #ffefda; padding: 0 12px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; color: var(--color-primary); font-size: 1rem;
    border-right: 1.5px solid #e0c99a;
}
.form-input-prefix--top { align-items: flex-start; padding-top: 12px; }
.form-input, .form-textarea {
    flex: 1; background: #ffefda; border: none; outline: none;
    padding: 12px 16px; font-size: .9rem; color: #2d4a5a;
    font-family: var(--font-primary); width: 100%;
}
.form-textarea { resize: vertical; min-height: 100px; }
.form-error    { font-size: .78rem; color: #d93025; display: none; }
.form-submit {
    display: inline-flex; align-items: center; gap: 8px;
    background: #18574f; color: #fff; border: none; border-radius: 20px;
    padding: 12px 32px; font-size: .9rem; font-weight: 700;
    font-family: var(--font-primary); cursor: pointer;
    transition: filter .2s, transform .15s; float: right;
}
.form-submit:hover  { filter: brightness(1.15); transform: translateY(-2px); }
.form-submit:active { transform: none; }

/* ════════════════════════════════════════════
   FAQ
   Estructura:
   .faq  (fondo oscuro cubre TODO)
     └── .faq__inner  (flex columna)
           ├── fila superior: grid [triggers | foto]
           │     ├── .faq__header-col  (título + 4 triggers)
           │     └── .faq__photo       (imagen, sin overlay extra)
           └── .faq__answers-col  (panel respuesta, ancho completo)
════════════════════════════════════════════ */
.faq__top {
    position: relative;
    background-image: url('/img/icons/preguntas.svg');
    background-size: cover;
    background-position: center;
    overflow: hidden;
    width: 100%;
}


/* Contenedor principal — flex columna */
.faq__inner {
    position: relative; z-index: 1;
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
}

/* ── Fila superior: triggers izquierda + foto derecha ── */
.faq__top {
    display: grid;
    grid-template-columns: 48% 52%;
    align-items: stretch;
}

/* Columna izquierda: título + triggers */
.faq__header-col {
    padding: 48px 36px 36px 48px;
    display: flex;
    flex-direction: column;
}

.faq__title {
    font-size: clamp(1.6rem,2.8vw,2.4rem);
    font-weight: 700; color: #fff;
    margin: 0 0 6px; font-family: var(--font-primary);
}
.faq__subtitle {
    font-size: .88rem; color: rgba(255,255,255,.85);
    margin: 0 0 20px; line-height: 1.5;
}

/* Trigger */
.faq-trigger {
    display: flex; align-items: center; gap: 10px;
    background: #fff; border: 2px solid rgba(255,255,255,.3);
    border-radius: 10px; padding: 10px 14px; width: 100%;
    cursor: pointer; text-align: left; margin-bottom: 10px;
    transition: border-color .2s, background .2s, box-shadow .2s;
    color: #2d4a5a;
    /* los triggers ya tienen is-visible en el HBS — no fade */
    opacity: 1; transform: none;
}
.faq-trigger:hover {
    border-color: var(--color-primary);
    box-shadow: 0 2px 12px rgba(242,146,36,.25);
}
.faq-trigger.active {
    border-color: var(--color-primary);
    background: #fff8f0;
    box-shadow: 0 2px 12px rgba(242,146,36,.25);
}
.faq-trigger__icon  { width: 44px; height: 44px; object-fit: contain; flex-shrink: 0; }
.faq-trigger__label { font-size: .9rem; font-weight: 600; flex: 1; margin: 0; color: #2d4a5a; }
.faq-trigger__arrow {
    color: var(--color-primary); font-size: .85rem;
    transition: transform .2s; flex-shrink: 0;
}
.faq-trigger.active .faq-trigger__arrow { transform: rotate(180deg); }

/* Columna derecha: foto */
.faq__photo {
    overflow: hidden;
    position: relative;
}
.faq__photo img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: center top;
    display: block;
}

/* ── Fila inferior: panel respuesta, ancho completo ── */
.faq__answers-col {
    padding: 0 48px 48px;
}

.faq-panel {
    display: none;
    background: #fff;
    border: 2px solid var(--color-primary);
    border-radius: 10px;
    padding: 22px 28px 26px;
    box-shadow: 0 4px 16px rgba(242,146,36,.12);
    animation: fadePanel .3s ease;
    margin-top: 8px;
}
.faq-panel.active { display: block; }

@keyframes fadePanel {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.faq-panel__question {
    font-size: .97rem; font-weight: 700; color: #354845;
    margin: 0 0 10px; display: flex; align-items: flex-start;
    gap: 10px; line-height: 1.5;
}
.faq-panel__question i { color: var(--color-primary); flex-shrink: 0; margin-top: 2px; }
.faq-panel__answer {
    font-size: .88rem; color: #5a7080;
    line-height: 1.8; margin: 0; padding-left: 26px;
}

/* ════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .contactos__layout  { grid-template-columns: 1fr; gap: 32px; }
    .faq__top           { grid-template-columns: 1fr; }
    .faq__photo         { display: none; }
    .faq__header-col    { padding: 40px 24px 28px; }
    .faq__answers-col   { padding: 0 24px 40px; }
}
@media (max-width: 768px) {
    .contactos          { padding: 32px 16px; }
    .form-row           { grid-template-columns: 1fr; }
    .faq__header-col    { padding: 32px 16px 24px; }
    .faq__answers-col   { padding: 0 16px 32px; }
    .faq-panel          { padding: 16px 18px 20px; }
    .faq-panel__answer  { padding-left: 0; }
    .form-submit        { float: none; width: 100%; justify-content: center; }
}