/* =====================================================================
   Cabinet Dentaire Gloria — assets/css/faq-page.css
   Page /faq : search live + categories + accordeons + Schema.org
   ===================================================================== */

/* ========== Search ========== */
.faq-search-section {
    background: var(--color-cream);
    padding: var(--sp-7) 0 var(--sp-5);
    position: sticky;
    top: 80px;
    z-index: 50;
    box-shadow: 0 2px 12px rgba(30, 58, 95, 0.04);
}

.faq-search {
    position: relative;
    max-width: 640px;
    margin: 0 auto;
}

.faq-search__icon {
    position: absolute;
    left: var(--sp-4);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gold);
    pointer-events: none;
}

.faq-search__input {
    width: 100%;
    padding: 16px 20px 16px 52px;
    background: var(--color-white);
    border: 1px solid var(--color-beige);
    border-radius: 999px;
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--color-text-strong);
    transition: border-color var(--tx-fast), box-shadow var(--tx-fast);
}
.faq-search__input::placeholder { color: rgba(30, 58, 95, 0.4); }
.faq-search__input:focus {
    outline: none;
    border-color: var(--color-gold);
    box-shadow: 0 0 0 4px rgba(201, 169, 110, 0.18);
}

/* ========== Categories ========== */
.faq-categories-section {
    background: var(--color-white);
    padding: var(--sp-9) 0 var(--sp-10);
}

.faq-categories-section__inner {
    max-width: 800px;
    margin: 0 auto;
}

.faq-category {
    margin-bottom: var(--sp-9);
}
.faq-category:last-child { margin-bottom: 0; }

.faq-category__title {
    font-family: var(--font-display);
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 600;
    color: var(--color-navy);
    margin: 0 0 var(--sp-5);
    padding-bottom: var(--sp-3);
    border-bottom: 2px solid var(--color-gold);
    display: flex;
    align-items: baseline;
    gap: var(--sp-2);
}

.faq-category__count {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: rgba(30, 58, 95, 0.5);
    letter-spacing: 0.5px;
}

/* ========== Accordion ========== */
.faq-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.faq-item {
    list-style: none;
    border-bottom: 1px solid var(--color-beige);
}
.faq-item:first-child { border-top: 1px solid var(--color-beige); }

.faq-item__trigger {
    width: 100%;
    text-align: left;
    background: transparent;
    border: 0;
    font-family: var(--font-body);
    font-size: 17px;
    font-weight: 600;
    color: var(--color-navy);
    padding: var(--sp-5) 40px var(--sp-5) 0;
    position: relative;
    cursor: pointer;
    line-height: 1.4;
    transition: color var(--tx-fast);
}
.faq-item__trigger:hover { color: rgba(30, 58, 95, 0.75); }

.faq-item__trigger::after {
    content: '+';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
    color: var(--color-gold);
    font-size: 26px;
    font-weight: 300;
    transition: transform var(--tx-fast);
    line-height: 1;
}
.faq-item__trigger[aria-expanded="true"]::after {
    transform: translateY(-50%) rotate(45deg);
}

.faq-item__panel {
    padding: 0 0 var(--sp-5);
    font-size: 16px;
    line-height: 1.75;
    color: rgba(30, 58, 95, 0.85);
    max-width: 720px;
}
.faq-item__panel[hidden] { display: none; }
.faq-item__panel p { margin: 0 0 var(--sp-3); }
.faq-item__panel p:last-child { margin-bottom: 0; }

.faq-no-results {
    text-align: center;
    font-size: 17px;
    color: rgba(30, 58, 95, 0.6);
    padding: var(--sp-7);
    margin: 0;
}

/* ========== Help CTA ========== */
.faq-help {
    background: var(--color-cream);
    padding: var(--sp-9) 0;
    text-align: center;
}

.faq-help__inner {
    max-width: 600px;
    margin: 0 auto;
}

.faq-help__title {
    font-family: var(--font-display);
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 600;
    color: var(--color-navy);
    margin: 0 0 var(--sp-3);
}

.faq-help__text {
    font-size: 17px;
    line-height: 1.6;
    color: rgba(30, 58, 95, 0.78);
    margin: 0 0 var(--sp-5);
}

.faq-help .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
}
