/* ══════════════════════════════════════════════════════
   SERENITY — ANIMATED TAB FAQ ACCORDION
   File: tab-faq.css
   Base styles. Colors/spacing/typography are overridden
   by Elementor style controls via inline CSS selectors.
══════════════════════════════════════════════════════ */

/* ── Wrapper ── */
.sn-faq-wrap {
    width: 100%;
    max-width: 860px;          /* overridden by Elementor control */
    margin: 0 auto;
    padding: 20px 0 40px;      /* overridden by Elementor control */
    font-family: inherit;
    box-sizing: border-box;
}

/* ══════════════════════════════════════════════════════
   TAB BUTTONS
══════════════════════════════════════════════════════ */

.sn-faq-tabs {
    display: flex;
    gap: 10px;                 /* overridden by Elementor control */
    flex-wrap: wrap;
    margin-bottom: 36px;       /* overridden by Elementor control */
}

.sn-faq-tab-btn {
    padding: 10px 24px;        /* overridden by Elementor control */
    border-radius: 100px;      /* overridden by Elementor control */
    border: 1.5px solid #d0d0d0; /* color + width overridden */
    border-style: solid;
    background: transparent;
    color: #555555;            /* overridden by Elementor control */
    font-size: 0.9rem;         /* overridden by typography control */
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    letter-spacing: 0.01em;
    transition: all 0.3s ease;
    white-space: nowrap;
    line-height: 1;
}

.sn-faq-tab-btn:hover {
    border-color: #7c4dff;     /* overridden by Elementor control */
    color: #7c4dff;            /* overridden by Elementor control */
}

.sn-faq-tab-btn.active {
    background: #7c4dff;       /* overridden by Elementor control */
    border-color: #7c4dff;
    color: #ffffff;            /* overridden by Elementor control */
    box-shadow: 0 4px 16px rgba(124, 77, 255, 0.3); /* overridden */
}

/* ══════════════════════════════════════════════════════
   TAB PANELS
══════════════════════════════════════════════════════ */

.sn-faq-panel {
    display: none;
    animation: snFaqFadeUp 0.35s ease forwards; /* duration overridden */
}

.sn-faq-panel.active {
    display: block;
}

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

/* ══════════════════════════════════════════════════════
   ACCORDION ITEM
══════════════════════════════════════════════════════ */

.sn-acc-item {
    border-bottom: 1px solid #e8e8e8; /* color + width overridden */
    border-bottom-style: solid;
}

.sn-acc-item:first-child {
    border-top: 1px solid #e8e8e8;
    border-top-style: solid;
}

/* ── Header ── */
.sn-acc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 4px;         /* top/bottom overridden by Elementor */
    cursor: pointer;
    user-select: none;
    gap: 16px;
}

.sn-acc-header h4 {
    margin: 0;
    font-size: 1rem;           /* overridden by typography control */
    font-weight: 600;
    color: #1a1a1a;            /* overridden by Elementor control */
    font-family: inherit;
    line-height: 1.4;
    flex: 1;
    transition: color 0.3s ease;
}

.sn-acc-item.open .sn-acc-header h4 {
    color: #7c4dff;            /* overridden by Elementor control */
}

/* ── Plus → X Icon ── */
.sn-acc-icon {
    width: 32px !important;    /* overridden by Elementor control */
    height: 32px !important;   /* overridden by Elementor control */
    min-width: 32px !important;
    min-height: 32px !important;
    border-radius: 50%;
    border: 1.5px solid #d0d0d0; /* overridden by Elementor control */
    border-style: solid;
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.35s ease;
    overflow: hidden;
    box-sizing: border-box;
}

.sn-acc-item.open .sn-acc-icon {
    background: #7c4dff;       /* overridden by Elementor control */
    border-color: #7c4dff;
    transform: rotate(45deg);
}

.sn-acc-icon svg {
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
    min-height: 14px !important;
    max-width: 14px !important;
    max-height: 14px !important;
    stroke: #555555;           /* overridden by Elementor control */
    transition: stroke 0.3s ease;
    display: block !important;
    flex-shrink: 0;
    pointer-events: none;
}

.sn-acc-item.open .sn-acc-icon svg {
    stroke: #ffffff;
}

/* ── Body / Answer ── */
.sn-acc-body {
    max-height: 0;
    overflow: hidden;
    padding: 0 4px;
    /* transition-duration overridden by Elementor control */
    transition: max-height 0.45s cubic-bezier(0.23, 1, 0.32, 1),
                padding    0.3s ease,
                opacity    0.3s ease;
    opacity: 0;
}

.sn-acc-item.open .sn-acc-body {
    max-height: 500px;         /* overridden by Elementor control */
    padding-bottom: 20px;      /* overridden by Elementor control */
    opacity: 1;
}

.sn-acc-body p {
    margin: 0;
    font-size: 0.95rem;        /* overridden by typography control */
    color: #666666;            /* overridden by Elementor control */
    line-height: 1.75;
    font-family: inherit;
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */

@media (max-width: 600px) {

    .sn-faq-tabs {
        gap: 8px;
    }

    .sn-faq-tab-btn {
        padding: 8px 16px;
        font-size: 0.85rem;
    }

    .sn-acc-header {
        padding: 16px 4px;
    }

    .sn-acc-header h4 {
        font-size: 0.95rem;
    }

    .sn-acc-body p {
        font-size: 0.88rem;
    }

    .sn-acc-icon {
        width: 28px;
        height: 28px;
    }
}

@media (max-width: 400px) {
    .sn-faq-tab-btn {
        padding: 7px 14px;
        font-size: 0.8rem;
    }
}

/* ══════════════════════════════════════════════════════
   ELEMENTOR EDITOR SUPPORT
══════════════════════════════════════════════════════ */

/* Show all panels in editor so user can see content */
.elementor-editor-active .sn-faq-panel {
    display: block !important;
    animation: none !important;
}

/* Show all answers open in editor */
.elementor-editor-active .sn-acc-body {
    max-height: none !important;
    opacity: 1 !important;
    padding-bottom: 20px !important;
}

.elementor-editor-active .sn-acc-item.open .sn-acc-icon,
.elementor-editor-active .sn-acc-icon {
    /* Keep icons in default state in editor */
}

/* ══════════════════════════════════════════════════════
   ACCESSIBILITY
══════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
    .sn-faq-panel,
    .sn-acc-body,
    .sn-acc-icon,
    .sn-acc-header h4,
    .sn-faq-tab-btn {
        transition: none !important;
        animation: none !important;
    }
}

.sn-faq-tab-btn:focus-visible {
    outline: 2px solid #7c4dff;
    outline-offset: 2px;
}

.sn-acc-header:focus-visible {
    outline: 2px solid #7c4dff;
    outline-offset: -2px;
}
