/**
 * Trevenque FAQs - Front Styles
 *
 * Accordion accesible, autocontenido. Clases propias (sin .card / .btn / .collapse)
 * para evitar herencia de reglas del tema y choques con otros accordions Bootstrap.
 *
 * @author    Trevenque
 * @copyright Trevenque
 * @license   AFL-3.0
 */

.trevenque-faqs-widget {
    margin: 2rem 0;
    max-width: 100%;
}

.trevenque-faqs-title {
    margin-bottom: 1rem;
    font-size: 1.25rem;
    font-weight: 700;
    color: #232323;
}

/* Wrapper accordion */
.trevenque-faqs-accordion {
    border: 1px solid #dee2e6;
    border-radius: 4px;
    overflow: hidden;
}

/* Item */
.trevenque-faqs-accordion .trevenque-faq-item {
    border-bottom: 1px solid #dee2e6;
    background: #fff;
}

.trevenque-faqs-accordion .trevenque-faq-item:last-child {
    border-bottom: 0;
}

/* Header (sin estilos del tema) */
.trevenque-faqs-accordion .trevenque-faq-header {
    margin: 0;
    padding: 0;
    background: #f8f9fa;
}

/* Botón pregunta */
.trevenque-faqs-accordion .trevenque-faq-question {
    display: flex;
    align-items: center;
    width: 100%;
    margin: 0;
    padding: 0.875rem 1.25rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: #333;
    text-align: left;
    text-decoration: none;
    background: transparent;
    border: 0;
    cursor: pointer;
    line-height: 1.4;
    transition: background-color 0.15s ease-in-out;
}

.trevenque-faqs-accordion .trevenque-faq-question:hover {
    background-color: #e9ecef;
    text-decoration: none;
    color: #333;
}

.trevenque-faqs-accordion .trevenque-faq-question:focus {
    outline: 2px solid #007bff;
    outline-offset: -2px;
    z-index: 1;
    text-decoration: none;
    color: #333;
}

.trevenque-faqs-accordion .trevenque-faq-question.is-open {
    background-color: #f1f3f5;
}

/* Texto pregunta — anula márgenes/headings inline que el usuario haya metido */
.trevenque-faqs-accordion .trevenque-faq-question-text {
    flex: 1;
    min-width: 0;
}

.trevenque-faqs-accordion .trevenque-faq-question-text > h1,
.trevenque-faqs-accordion .trevenque-faq-question-text > h2,
.trevenque-faqs-accordion .trevenque-faq-question-text > h3,
.trevenque-faqs-accordion .trevenque-faq-question-text > h4,
.trevenque-faqs-accordion .trevenque-faq-question-text > h5,
.trevenque-faqs-accordion .trevenque-faq-question-text > h6,
.trevenque-faqs-accordion .trevenque-faq-question-text > p {
    margin: 0;
    display: inline;
    font: inherit;
    color: inherit;
}

/* Icono +/- */
.trevenque-faqs-accordion .trevenque-faq-icon {
    display: inline-block;
    flex-shrink: 0;
    width: 1rem;
    height: 1rem;
    margin-right: 0.75rem;
    position: relative;
}

.trevenque-faqs-accordion .trevenque-faq-icon::before,
.trevenque-faqs-accordion .trevenque-faq-icon::after {
    content: '';
    position: absolute;
    background-color: #495057;
    transition: transform 0.2s ease;
}

.trevenque-faqs-accordion .trevenque-faq-icon::before {
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    transform: translateY(-50%);
}

.trevenque-faqs-accordion .trevenque-faq-icon::after {
    top: 0;
    left: 50%;
    width: 2px;
    height: 100%;
    transform: translateX(-50%);
}

.trevenque-faqs-accordion .trevenque-faq-question[aria-expanded="true"] .trevenque-faq-icon::after {
    transform: translateX(-50%) rotate(90deg);
}

/* Panel (cerrado por defecto, [hidden] nativo) */
.trevenque-faqs-accordion .trevenque-faq-panel {
    background: #fff;
}

.trevenque-faqs-accordion .trevenque-faq-panel[hidden] {
    display: none !important;
}

.trevenque-faqs-accordion .trevenque-faq-answer {
    padding: 1rem 1.25rem 1.25rem;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: #555;
}

.trevenque-faqs-accordion .trevenque-faq-answer p:last-child {
    margin-bottom: 0;
}

.trevenque-faqs-accordion .trevenque-faq-answer a {
    color: #007bff;
    text-decoration: underline;
}

.trevenque-faqs-accordion .trevenque-faq-answer a:focus {
    outline: 2px solid #007bff;
    outline-offset: 2px;
}

/* Responsive */
@media (max-width: 767px) {
    .trevenque-faqs-accordion .trevenque-faq-question {
        padding: 0.75rem 1rem;
        font-size: 0.875rem;
    }

    .trevenque-faqs-accordion .trevenque-faq-answer {
        padding: 0.75rem 1rem 1rem;
        font-size: 0.875rem;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .trevenque-faqs-accordion .trevenque-faq-icon::before,
    .trevenque-faqs-accordion .trevenque-faq-icon::after,
    .trevenque-faqs-accordion .trevenque-faq-question {
        transition: none;
    }
}
