/* MM FAQ Builder — módulo CSS (requiere mmb-shared.css) */

.mm-faq-container {
    width: 100%;
    max-width: 100%;
    margin: 24px auto;
    padding: 28px 24px;
    background: #fff;
    border-radius: var(--mmb-radius-lg);
    box-shadow: var(--mmb-shadow-md);
}
.mm-faq-h2 {
    font-weight: 700;
    color: var(--mmb-primary);
    margin: 0 0 10px;
    text-align: center;
    font-size: 1.45rem;
    line-height: 1.3;
}
.mm-faq-intro {
    text-align: center;
    color: var(--mmb-text-muted);
    font-size: .95rem;
    line-height: 1.55;
    margin: 0 auto 22px;
    max-width: 65ch;
}
.mm-faq-item { margin-bottom: 8px; border-bottom: 1px solid #e8e8f0; }
.mm-faq-item:last-of-type { border-bottom: none; }

.mm-faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 15px 18px;
    background: var(--mmb-bg-light);
    border-radius: var(--mmb-radius-md);
    cursor: pointer;
    transition: background-color .25s ease;
    font-size: 1rem;
    font-weight: 700;
    color: var(--mmb-primary);
    margin: 0;
    border: 1px solid transparent;
    user-select: none;
    -webkit-user-select: none;
}
.mm-faq-question:hover { background: #eaeaf3; }
.mm-faq-question[aria-expanded="true"] {
    background: #eaeaf3;
    border-color: var(--mmb-primary);
    border-radius: var(--mmb-radius-md) var(--mmb-radius-md) 0 0;
}
.mm-faq-question:focus-visible { outline: 3px solid #a0aec0; outline-offset: 2px; }

/* Toggle +/- (el texto + / − viene del HTML, no del CSS) */
.mm-faq-icon {
    flex-shrink: 0;
    width: 28px; height: 28px;
    border-radius: 50%;
    border: 2px solid var(--mmb-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; font-weight: 400; line-height: 1;
    color: var(--mmb-primary);
    transition: background .2s, color .2s;
    user-select: none;
    font-family: system-ui, sans-serif;
}
.mm-faq-question[aria-expanded="true"] .mm-faq-icon {
    background: var(--mmb-primary);
    color: #fff;
}

.mm-faq-answer {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .3s ease;
    background: var(--mmb-bg-subtle);
    border-radius: 0 0 var(--mmb-radius-md) var(--mmb-radius-md);
    border: 1px solid transparent;
    border-top: none;
}
.mm-faq-answer.mm-open { grid-template-rows: 1fr; border-color: var(--mmb-primary); }
.mm-faq-answer-inner { overflow: hidden; padding: 0 18px; font-size: .95rem; line-height: 1.65; color: #333; }
.mm-faq-answer.mm-open .mm-faq-answer-inner { padding: 14px 18px; }

.mm-faq-meta {
    display: block; margin-top: 12px; padding-top: 10px;
    border-top: 1px solid rgba(0,0,0,.08);
    opacity: .75; font-size: .83rem; font-style: normal;
}
.mm-faq-meta a { color: var(--mmb-primary); text-decoration: underline; }
.mm-faq-meta a:hover { color: var(--mmb-accent); }

.mm-faq-author { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--mmb-border-soft); }
.mm-faq-author__inner {
    display: flex; align-items: center; gap: 16px;
    background: linear-gradient(180deg,#fafafe 0%,#fff 100%);
    border: 1px solid var(--mmb-border-soft);
    border-radius: var(--mmb-radius-lg);
    box-shadow: var(--mmb-shadow-lg);
    padding: 14px 16px;
}
.mm-faq-author__avatar {
    width: 64px; height: 64px; border-radius: 50%;
    object-fit: cover; border: 2px solid #fff;
    box-shadow: 0 3px 10px rgba(0,0,0,.08); flex: 0 0 64px;
}
.mm-faq-author__meta { line-height: 1.25; flex: 1 1 auto; min-width: 0; }
.mm-faq-author__kicker { margin: 0; font-size: .73rem; letter-spacing: .07em; text-transform: uppercase; font-weight: 800; color: #7c7ca1; }
.mm-faq-author__name  { margin: .15rem 0 0; color: var(--mmb-primary); font-weight: 800; font-size: 1.05rem; }
.mm-faq-author__role  { margin: .1rem 0 0; color: var(--mmb-text-muted); font-size: .88rem; }
.mm-faq-author__btn {
    margin-left: auto; flex-shrink: 0; white-space: nowrap;
    background: var(--mmb-primary); color: #fff; text-decoration: none;
    font-weight: 800; font-size: .88rem; padding: .65rem 1rem;
    border-radius: 999px; border: 2px solid transparent;
    transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.mm-faq-author__btn:hover {
    background: var(--mmb-primary-dark); transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(58,57,113,.25); color: #fff; text-decoration: none;
}

@media (max-width: 640px) {
    .mm-faq-container { padding: 20px 14px; border-radius: var(--mmb-radius-md); }
    .mm-faq-h2 { font-size: 1.2rem; }
    .mm-faq-question { font-size: .93rem; padding: 13px 14px; }
    .mm-faq-author__inner { flex-wrap: wrap; text-align: center; justify-content: center; }
    .mm-faq-author__avatar { margin: 0 auto; }
    .mm-faq-author__meta { width: 100%; text-align: center; }
    .mm-faq-author__btn { width: 100%; margin-left: 0; text-align: center; }
}
