/* Theme tokens: dark default, .light overrides */
.full-info,
.full__title {
    --fi-text: #f5f5f7;
    --fi-text-muted: #a1a1a6;
    --fi-surface: #3f4640;
    --fi-surface-border: rgba(152, 188, 31, 0.16);
    --fi-surface-shadow: 0 2px 10px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.04);
    --fi-divider: rgba(255, 255, 255, 0.08);
    --fi-tabs-bg: rgba(152, 188, 31, 0.1);
    --fi-tabs-border: rgba(152, 188, 31, 0.14);
    --fi-tab-text: #b0baa8;
    --fi-tab-active-bg: #4a524a;
    --fi-tab-active-text: #f5f5f7;
    --fi-accent: #98bc1f;
    --fi-accent-soft: rgba(152, 188, 31, 0.18);
    --fi-accent-text: #c8e06a;
    --fi-alt-text: #d1d1d6;
    --fi-settings-bg: #2e332f;
    --fi-settings-border: #5d6958;
    --fi-settings-icon: #c8e06a;
    --fi-settings-shadow: 1px 1px 1px #1a1c1a, inset 1px 1px 1px #4a504a;
    --fi-hint-bg: #2a3128;
    --fi-hint-text: #f0f4eb;
    --fi-hint-border: #4a5644;
    --fi-focus: #98bc1f;
}

.light .full-info,
.light .full__title {
    --fi-text: #1c1c1e;
    --fi-text-muted: #8e8e93;
    --fi-surface: #fff;
    --fi-surface-border: #dfe8c8;
    --fi-surface-shadow: 0 1px 4px rgba(47, 63, 31, 0.06);
    --fi-divider: #eef2e0;
    --fi-tabs-bg: #e2ebc8;
    --fi-tabs-border: rgba(172, 206, 13, 0.2);
    --fi-tab-text: #5f6f45;
    --fi-tab-active-bg: #fff;
    --fi-tab-active-text: #1c1c1e;
    --fi-accent: #7fa318;
    --fi-accent-soft: #edf5d4;
    --fi-accent-text: #5a7a10;
    --fi-alt-text: #3a3a3c;
    --fi-settings-bg: #d9f1a7;
    --fi-settings-border: #a0b771;
    --fi-settings-icon: #6a8f12;
    --fi-settings-shadow: 1px 1px 1px #96ad65, inset 1px 1px 1px #fff;
    --fi-hint-bg: #fff;
    --fi-hint-text: #1c1c1e;
    --fi-hint-border: #dfe8c8;
}

.full-info {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* Title row + settings */
.full__title {
    overflow: visible;
}

.full__title-row {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 auto;
    gap: 8px;
    min-width: 0;
    padding-left: 80px;
    padding-right: 4px;
}

.full__title-row h1 {
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
    padding: 0;
    text-align: center;
}

.full-info__settings-btn {
    position: relative;
    flex: 0 0 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    margin: 0;
    border: 1px solid var(--fi-settings-border);
    border-radius: 10px;
    background: var(--fi-settings-bg);
    color: var(--fi-settings-icon);
    box-shadow: var(--fi-settings-shadow);
    cursor: pointer;
}

.full-info__settings-btn:hover {
    opacity: 0.9;
}

.full-info__settings-btn:focus-visible {
    outline: 2px solid var(--fi-focus);
    outline-offset: 2px;
}

.full-info__settings-hint {
    position: absolute;
    right: 0;
    bottom: calc(100% + 8px);
    z-index: 12;
    width: max-content;
    max-width: 240px;
    padding: 10px 12px;
    border: 1px solid var(--fi-hint-border);
    border-radius: 10px;
    background: var(--fi-hint-bg);
    color: var(--fi-hint-text);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.4;
    text-align: left;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
    opacity: 0;
    visibility: hidden;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
    pointer-events: none;
}

.full-info__settings-hint::before {
    content: "";
    position: absolute;
    right: 14px;
    bottom: -6px;
    width: 10px;
    height: 10px;
    background: inherit;
    border-right: 1px solid var(--fi-hint-border);
    border-bottom: 1px solid var(--fi-hint-border);
    transform: rotate(45deg);
}

.full-info__settings-btn:hover .full-info__settings-hint,
.full-info__settings-btn.is-hint-visible .full-info__settings-hint {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Tabs */
.full-info__tabs {
    display: flex;
    gap: 3px;
    margin: 0 0 10px;
    padding: 4px;
    border-radius: 11px;
    border: 1px solid var(--fi-tabs-border);
    background: var(--fi-tabs-bg);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-snap-type: x proximity;
}

.full-info__tabs::-webkit-scrollbar {
    display: none;
}

.full-info__tab {
    flex: 1 1 0;
    min-width: max-content;
    scroll-snap-align: start;
    margin: 0;
    border: 0;
    border-radius: 8px;
    padding: 8px 12px;
    background: transparent;
    color: var(--fi-tab-text);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.2;
    cursor: pointer;
    white-space: nowrap;
    -webkit-appearance: none;
    appearance: none;
}

.full-info__tab.is-active,
.light .full-info .full-info__tab.is-active {
    background: var(--fi-tab-active-bg);
    color: var(--fi-tab-active-text);
    font-weight: 600;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.full-info__tab:focus-visible {
    outline: 2px solid var(--fi-focus);
    outline-offset: 1px;
}

/* Panels */
.full-info__panel {
    display: none;
    background: none !important;
}

.full-info__panel[hidden] {
    display: none !important;
}

.full-info .full-info__panel.is-active {
    display: block;
    background: none !important;
    color: var(--fi-text);
}

/* Content card */
.full-info .full-info__content {
    background: var(--fi-surface);
    border-radius: 16px;
    padding: 0;
    font-size: 15px;
    line-height: 1.45;
    color: var(--fi-text);
    border: 1px solid var(--fi-surface-border);
    box-shadow: var(--fi-surface-shadow);
    overflow: hidden;
}

.full-info__sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.full-info .full__data,
.full-info .full__description {
    margin: 0;
    padding: 0;
    background: none;
    border: 0;
    color: inherit;
    font-size: inherit;
    line-height: inherit;
}

/* Stats */
.full-info .full__data-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border-bottom: 1px solid var(--fi-divider);
}

.full-info .full__data-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 14px 8px;
    text-align: center;
}

.full-info .full__data-stat + .full__data-stat {
    border-left: 1px solid var(--fi-divider);
}

.full-info .full__data-stat__label {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--fi-text-muted);
}

.full-info .full__data-stat__value {
    font-size: 14px;
    font-weight: 600;
    color: inherit;
    line-height: 1.3;
}

/* List rows */
.full-info .full__data-list {
    margin: 0;
    padding: 0;
}

.full-info .full__data-row {
    display: block;
    padding: 12px 16px;
    border-top: 1px solid var(--fi-divider);
}

.full-info .full__data-row:first-child {
    border-top: 0;
}

.full-info .full__data-row dt {
    margin: 0 0 6px;
    font-size: 12px;
    font-weight: 500;
    color: var(--fi-text-muted);
}

.full-info .full__data-row dd {
    margin: 0;
    font-size: 15px;
    line-height: 1.45;
    color: inherit;
    word-break: break-word;
}

/* Genre tags */
.full-info .full__data-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 0;
    line-height: 0;
}

.full-info .full__data-tags a {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 5px 12px;
    border-radius: 999px;
    background: var(--fi-accent);
    color: #fff !important;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.2;
    text-decoration: none;
}

.full-info .full__data-tags a:hover {
    opacity: 0.9;
}

/* Alt titles */
.full-info .full__data-row--alt dd {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.full-info .full__data-alt {
    font-size: 14px;
    line-height: 1.5;
    color: var(--fi-alt-text);
}

.full-info .full__data-alt.is-collapsed {
    max-height: 4.5em;
    overflow: hidden;
}

.full-info .full__data-alt-toggle {
    display: inline-block;
    margin: 0;
    padding: 6px 14px;
    border: 0;
    border-radius: 999px;
    background: var(--fi-accent-soft);
    color: var(--fi-accent-text);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
}

.full-info .full__data-alt-toggle:hover {
    opacity: 0.85;
}

/* Badges */
.full-info .age_rating_18 {
    display: inline-block;
    background: var(--fi-accent);
    border-radius: 6px;
    padding: 2px 8px;
    color: #fff;
    font-weight: 700;
    font-size: 13px;
}

.full-info .full__data-status {
    display: inline-block;
    padding: 5px 12px;
    border-radius: 999px;
    background: var(--fi-accent-soft);
    color: var(--fi-accent-text);
    font-size: 13px;
    font-weight: 500;
}

.full-info .full__data-next {
    font-weight: 600;
    color: var(--fi-accent-text);
}

/* Story */
.full-info .full-info__content.full__description {
    padding: 16px;
}

.full-info .story_anime p,
.full-info .full__description p {
    margin: 0;
    font-size: 15px;
    line-height: 1.55;
    color: inherit;
}

.full-info .story_anime p + p,
.full-info .full__description p + p {
    margin-top: 12px;
}

.full-info__empty {
    margin: 0;
    padding: 28px 16px;
    text-align: center;
    font-size: 14px;
    color: var(--fi-text-muted);
}

/* Page layout */
.full-page-layout {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.full-page-block {
    content-visibility: auto;
    contain-intrinsic-size: auto 500px;
}

/* Settings modal form */
#anime-settings-modal {
    --fi-modal-text: #f5f5f7;
    --fi-form-bg: #2f332f;
    --fi-form-border: #5e6a60;
    --fi-form-ghost: rgba(255, 255, 255, 0.08);
    --fi-btn-primary-bg: #7fa318;
    --fi-btn-primary-text: #fff;
    --fi-btn-ghost-text: #c8e06a;
}

.light #anime-settings-modal {
    --fi-modal-text: #1c1c1e;
    --fi-form-bg: #f8faf3;
    --fi-form-border: #dfe8c8;
    --fi-form-ghost: #edf5d4;
    --fi-btn-primary-bg: #6a8f12;
    --fi-btn-primary-text: #fff;
    --fi-btn-ghost-text: #5a7a10;
}

#anime-settings-modal .anime-notify-dialog {
    color: var(--fi-modal-text);
}

#anime-settings-modal .anime-settings-form {
    display: grid;
    gap: 12px;
}

#anime-settings-modal .anime-settings-field {
    display: grid;
    gap: 6px;
}

#anime-settings-modal .anime-settings-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--fi-modal-text);
}

#anime-settings-modal .anime-settings-select {
    width: 100%;
    min-height: 40px;
    padding: 8px 12px;
    border: 1px solid var(--fi-form-border);
    border-radius: 10px;
    background: var(--fi-form-bg);
    color: var(--fi-modal-text);
    font-size: 14px;
    cursor: pointer;
}

#anime-settings-modal .anime-settings-actions {
    display: flex;
    gap: 8px;
    margin-top: 14px;
}

#anime-settings-modal .anime-settings-btn {
    flex: 1 1 0;
    min-height: 40px;
    border: 0;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}

#anime-settings-modal .anime-settings-btn_primary {
    background: var(--fi-btn-primary-bg);
    color: var(--fi-btn-primary-text);
}

#anime-settings-modal .anime-settings-btn_primary:hover {
    filter: brightness(1.05);
}

#anime-settings-modal .anime-settings-btn_ghost {
    background: var(--fi-form-ghost);
    color: var(--fi-btn-ghost-text);
}

@media (max-width: 720px) {
    .full__title-row {
        padding-left: 72px;
        padding-right: 0;
        gap: 6px;
    }

    .full__title-row h1 {
        font-size: 16px;
        line-height: 1.25;
        text-align: left;
    }

    .full-info__settings-btn {
        flex-basis: 32px;
        width: 32px;
        height: 32px;
    }

    .full-info__settings-hint {
        right: -4px;
        max-width: min(220px, calc(100vw - 32px));
    }

    .full-info__tab {
        flex: 0 0 auto;
        font-size: 12px;
        padding: 7px 10px;
    }

    .full-info .full__data-stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .full-info .full__data-stat {
        padding: 12px 4px;
    }

    .full-info .full__data-stat__value {
        font-size: 13px;
    }

    .full-info .full__data-row {
        padding: 11px 14px;
    }

    #anime-settings-modal .anime-settings-actions {
        flex-direction: column;
    }
}

@media (max-width: 420px) {
    .full__title {
        padding: 16px 14px;
    }

    .full__title-row {
        padding-left: 64px;
    }

    .full__title-row h1 {
        font-size: 15px;
    }
}
