/**
 * SR Modern Theme - SEO/AEO Components Styles
 *
 * @package SR_Modern_Theme
 * @since 1.0
 */

/* ==========================================================================
   Table of Contents
   ========================================================================== */

.sr-toc {
    margin: var(--sr-space-8) 0;
    padding: var(--sr-space-6);
    background-color: var(--sr-surface);
    border-radius: var(--sr-radius-xl);
    border: 1px solid var(--sr-border);
}

.sr-toc__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sr-space-4);
    padding-bottom: var(--sr-space-4);
    border-bottom: 1px solid var(--sr-border);
}

.sr-toc__title {
    display: flex;
    align-items: center;
    gap: var(--sr-space-2);
    font-size: var(--sr-text-lg);
    font-weight: var(--sr-font-semibold);
    margin: 0;
    color: var(--sr-text-primary);
}

.sr-toc__title svg {
    color: var(--sr-primary);
}

.sr-toc__toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background-color: var(--sr-surface-hover);
    border: none;
    border-radius: var(--sr-radius-md);
    cursor: pointer;
    transition: all var(--sr-transition-fast);
}

.sr-toc__toggle:hover {
    background-color: var(--sr-primary);
    color: var(--sr-white);
}

.sr-toc__toggle[aria-expanded="false"] svg {
    transform: rotate(-90deg);
}

.sr-toc__list {
    list-style: none;
    margin: 0;
    padding: 0;
    counter-reset: toc-counter;
}

.sr-toc__item {
    counter-increment: toc-counter;
    margin-bottom: var(--sr-space-2);
}

.sr-toc__item--level-3 {
    margin-left: var(--sr-space-6);
}

.sr-toc__item--level-4 {
    margin-left: var(--sr-space-10);
}

.sr-toc__link {
    display: flex;
    align-items: flex-start;
    gap: var(--sr-space-2);
    padding: var(--sr-space-2) var(--sr-space-3);
    color: var(--sr-text-secondary);
    font-size: var(--sr-text-sm);
    border-radius: var(--sr-radius-md);
    transition: all var(--sr-transition-fast);
}

.sr-toc__link::before {
    content: counter(toc-counter) ".";
    font-weight: var(--sr-font-semibold);
    color: var(--sr-primary);
    min-width: 24px;
}

.sr-toc__link:hover {
    background-color: var(--sr-surface-hover);
    color: var(--sr-primary);
}

.sr-toc__sublist {
    list-style: none;
    margin: var(--sr-space-2) 0 0 var(--sr-space-6);
    padding: 0;
}

/* ==========================================================================
   Key Takeaways
   ========================================================================== */

.sr-key-takeaways {
    margin: var(--sr-space-8) 0;
    padding: var(--sr-space-6);
    background: linear-gradient(135deg, var(--sr-primary) 0%, var(--sr-secondary) 100%);
    border-radius: var(--sr-radius-xl);
    color: var(--sr-white);
}

.sr-key-takeaways__header {
    display: flex;
    align-items: center;
    gap: var(--sr-space-3);
    margin-bottom: var(--sr-space-5);
}

.sr-key-takeaways__header svg {
    opacity: 0.9;
}

.sr-key-takeaways__title {
    font-size: var(--sr-text-lg);
    font-weight: var(--sr-font-semibold);
    margin: 0;
}

.sr-key-takeaways__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sr-key-takeaways__item {
    display: flex;
    align-items: flex-start;
    gap: var(--sr-space-3);
    padding: var(--sr-space-3) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
    font-size: var(--sr-text-base);
    line-height: var(--sr-leading-relaxed);
}

.sr-key-takeaways__item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.sr-key-takeaways__item svg {
    flex-shrink: 0;
    margin-top: 2px;
    opacity: 0.9;
}

/* ==========================================================================
   FAQ Section
   ========================================================================== */

.sr-faq {
    margin: var(--sr-space-10) 0;
}

.sr-faq__title {
    display: flex;
    align-items: center;
    gap: var(--sr-space-3);
    font-size: var(--sr-text-2xl);
    font-weight: var(--sr-font-bold);
    margin-bottom: var(--sr-space-6);
}

.sr-faq__title svg {
    color: var(--sr-primary);
}

.sr-faq__list {
    display: flex;
    flex-direction: column;
    gap: var(--sr-space-3);
}

.sr-faq__item {
    background-color: var(--sr-surface);
    border: 1px solid var(--sr-border);
    border-radius: var(--sr-radius-lg);
    overflow: hidden;
}

.sr-faq__question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--sr-space-5);
    background: none;
    border: none;
    text-align: left;
    font-size: var(--sr-text-base);
    font-weight: var(--sr-font-semibold);
    color: var(--sr-text-primary);
    cursor: pointer;
    transition: all var(--sr-transition-fast);
}

.sr-faq__question:hover {
    background-color: var(--sr-surface-hover);
}

.sr-faq__icon {
    flex-shrink: 0;
    transition: transform var(--sr-transition-fast);
    color: var(--sr-text-muted);
}

.sr-faq__question[aria-expanded="true"] .sr-faq__icon {
    transform: rotate(180deg);
}

.sr-faq__answer {
    padding: 0 var(--sr-space-5) var(--sr-space-5);
    color: var(--sr-text-secondary);
    line-height: var(--sr-leading-relaxed);
}

.sr-faq__answer[hidden] {
    display: none;
}

/* ==========================================================================
   Definition Box
   ========================================================================== */

.sr-definition {
    margin: var(--sr-space-6) 0;
    padding: var(--sr-space-5);
    background-color: var(--sr-surface);
    border-left: 4px solid var(--sr-primary);
    border-radius: var(--sr-radius-lg);
}

.sr-definition__header {
    display: flex;
    align-items: center;
    gap: var(--sr-space-2);
    margin-bottom: var(--sr-space-3);
}

.sr-definition__header svg {
    color: var(--sr-primary);
}

.sr-definition__label {
    font-size: var(--sr-text-xs);
    font-weight: var(--sr-font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--sr-tracking-wider);
    color: var(--sr-primary);
}

.sr-definition__term {
    display: block;
    font-size: var(--sr-text-lg);
    margin-bottom: var(--sr-space-2);
}

.sr-definition__text {
    color: var(--sr-text-secondary);
    line-height: var(--sr-leading-relaxed);
    margin-bottom: var(--sr-space-2);
}

.sr-definition__source {
    font-size: var(--sr-text-sm);
    font-style: normal;
    color: var(--sr-text-muted);
}

/* ==========================================================================
   Summary Box
   ========================================================================== */

.sr-summary {
    margin: var(--sr-space-8) 0;
    padding: var(--sr-space-6);
    background-color: var(--sr-surface);
    border: 2px dashed var(--sr-border);
    border-radius: var(--sr-radius-xl);
}

.sr-summary__header {
    display: flex;
    align-items: center;
    gap: var(--sr-space-2);
    margin-bottom: var(--sr-space-4);
}

.sr-summary__header svg {
    color: var(--sr-primary);
}

.sr-summary__title {
    font-size: var(--sr-text-base);
    font-weight: var(--sr-font-semibold);
    margin: 0;
    color: var(--sr-text-primary);
}

.sr-summary__content {
    color: var(--sr-text-secondary);
    line-height: var(--sr-leading-relaxed);
}

.sr-summary__content p:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   Sources & References
   ========================================================================== */

.sr-sources {
    margin: var(--sr-space-10) 0;
    padding-top: var(--sr-space-8);
    border-top: 1px solid var(--sr-border);
}

.sr-sources__title {
    display: flex;
    align-items: center;
    gap: var(--sr-space-2);
    font-size: var(--sr-text-lg);
    font-weight: var(--sr-font-semibold);
    margin-bottom: var(--sr-space-4);
}

.sr-sources__title svg {
    color: var(--sr-primary);
}

.sr-sources__list {
    margin: 0;
    padding-left: var(--sr-space-6);
}

.sr-sources__item {
    margin-bottom: var(--sr-space-2);
    font-size: var(--sr-text-sm);
    color: var(--sr-text-secondary);
}

.sr-sources__item a {
    color: var(--sr-primary);
}

.sr-sources__item a:hover {
    text-decoration: underline;
}

.sr-sources__author {
    color: var(--sr-text-muted);
}

/* ==========================================================================
   Last Updated Badge
   ========================================================================== */

.sr-last-updated {
    display: inline-flex;
    align-items: center;
    gap: var(--sr-space-2);
    padding: var(--sr-space-2) var(--sr-space-3);
    background-color: var(--sr-surface);
    border-radius: var(--sr-radius-full);
    font-size: var(--sr-text-xs);
    color: var(--sr-text-muted);
}

.sr-last-updated svg {
    color: var(--sr-accent);
}

.sr-last-updated time {
    font-weight: var(--sr-font-medium);
    color: var(--sr-text-secondary);
}

/* ==========================================================================
   Fact Check Badge
   ========================================================================== */

.sr-fact-check {
    display: inline-flex;
    align-items: center;
    gap: var(--sr-space-2);
    padding: var(--sr-space-2) var(--sr-space-3);
    background-color: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.3);
    border-radius: var(--sr-radius-full);
    font-size: var(--sr-text-xs);
    color: #10b981;
}

.sr-fact-check svg {
    color: #10b981;
}

.sr-fact-check__text {
    font-weight: var(--sr-font-semibold);
}

.sr-fact-check__reviewer {
    font-weight: var(--sr-font-normal);
    opacity: 0.8;
}

/* ==========================================================================
   Article Trust Signals Bar
   ========================================================================== */

.sr-trust-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--sr-space-4);
    margin: var(--sr-space-6) 0;
    padding: var(--sr-space-4);
    background-color: var(--sr-surface);
    border-radius: var(--sr-radius-lg);
}

/* ==========================================================================
   Pros and Cons Box (for reviews)
   ========================================================================== */

.sr-pros-cons {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sr-space-6);
    margin: var(--sr-space-8) 0;
}

@media (min-width: 640px) {
    .sr-pros-cons {
        grid-template-columns: 1fr 1fr;
    }
}

.sr-pros,
.sr-cons {
    padding: var(--sr-space-5);
    border-radius: var(--sr-radius-lg);
}

.sr-pros {
    background-color: rgba(16, 185, 129, 0.08);
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.sr-cons {
    background-color: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.2);
}

.sr-pros__title,
.sr-cons__title {
    display: flex;
    align-items: center;
    gap: var(--sr-space-2);
    font-size: var(--sr-text-base);
    font-weight: var(--sr-font-semibold);
    margin-bottom: var(--sr-space-4);
}

.sr-pros__title {
    color: #10b981;
}

.sr-cons__title {
    color: #ef4444;
}

.sr-pros__list,
.sr-cons__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sr-pros__item,
.sr-cons__item {
    display: flex;
    align-items: flex-start;
    gap: var(--sr-space-2);
    margin-bottom: var(--sr-space-2);
    font-size: var(--sr-text-sm);
    color: var(--sr-text-secondary);
}

.sr-pros__item svg {
    flex-shrink: 0;
    color: #10b981;
}

.sr-cons__item svg {
    flex-shrink: 0;
    color: #ef4444;
}

/* ==========================================================================
   Rating Stars
   ========================================================================== */

.sr-rating {
    display: flex;
    align-items: center;
    gap: var(--sr-space-2);
}

.sr-rating__stars {
    display: flex;
    gap: 2px;
}

.sr-rating__star {
    color: var(--sr-border);
}

.sr-rating__star--filled {
    color: #fbbf24;
}

.sr-rating__value {
    font-weight: var(--sr-font-bold);
    color: var(--sr-text-primary);
}

.sr-rating__count {
    font-size: var(--sr-text-sm);
    color: var(--sr-text-muted);
}