/*
Theme Name: Fontchuviet
Theme URI: https://example.com/
Author: Your Name
Author URI: https://example.com/
Description: A pure white, minimal WordPress theme
Version: 1.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: fontchuviet
Tags: white, minimal, blank
*/

.fc-chip.fc-chip-highlight {
    border-width: 2px !important;
    border-color: #ff9800 !important;
    font-weight: 700;
    box-shadow: 0 2px 8px 0 rgba(255, 152, 0, 0.08);
    position: relative;
    z-index: 1;
}

:root {
    color-scheme: light;
}

html {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--fc-font-family-base, "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
    font-size: var(--fc-font-size-body, 16px);
    background: var(--fc-color-bg, #ffffff);
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

.fc-generic-page-content iframe.wp-embedded-content,
.fc-blog-single-content iframe.wp-embedded-content {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 12px 0;
}

@media (max-width: 480px) {
    .fc-generic-page-content iframe.wp-embedded-content,
    .fc-blog-single-content iframe.wp-embedded-content {
        margin: 8px 0;
    }
}

body.fc-download-modal-open {
    overflow: hidden;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

#page {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    width: 100%;
    max-width: 100%;
}

.fc-site-header {
    width: 100%;
    padding: 14px 15px;
    border-bottom: 1px solid #ececf2;
    background: var(--fc-color-bg, #ffffff);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

body.fontchuviet-has-sidebar .fc-site-header {
    padding-top: 14px;
    padding-right: 37px;
    padding-bottom: 16px;
    padding-left: 37px;
}

.fc-site-header .fc-main-topbar {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 20px;
    min-height: 0;
    margin-bottom: 0;
}

.fc-site-header .fc-topbar-logo {
    max-width: 180px;
    max-height: 36px;
    width: auto;
    height: auto;
}

.fc-site-header .fc-main-topbar.has-search {
    grid-template-columns: minmax(180px, auto) minmax(420px, 1fr) auto;
}

body.fontchuviet-has-sidebar .fc-site-header .fc-main-topbar.has-search {
    grid-template-columns: var(--fc-layout-sidebar-width, 248px) minmax(0, 1fr) auto;
    gap: 22px;
}

.fc-site-header .fc-main-topbar-brand,
.fc-site-header .fc-main-topbar-title {
    justify-self: start;
}

.fc-site-header .fc-topbar-user {
    justify-self: end;
}

body.fontchuviet-has-sidebar .fc-site-header .fc-topbar-user {
    display: flex;
    align-items: center;
}

body.fontchuviet-has-sidebar .fc-main .fc-header .fc-header-right {
    display: none;
}

.fc-main-topbar-search {
    width: 100%;
    margin: 0;
}

.fc-app {
    display: grid;
    grid-template-columns: minmax(248px, var(--fc-layout-sidebar-width, 248px)) minmax(0, 1fr);
    flex: 1 0 auto;
    min-height: 0;
    width: 100%;
    max-width: 100%;
    padding: 0 15px;
}

.fc-mobile-overlay {
    position: fixed;
    inset: 0;
    min-height: 100svh;
    height: 100dvh;
    z-index: 39;
    background: rgba(18, 18, 24, 0.44);
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms ease;
}

.fc-sidebar {
    position: sticky;
    top: 15px;
    z-index: 20;
    width: var(--fc-layout-sidebar-width, 248px);
    height: calc(100vh - 30px);
    align-self: start;
    overflow-y: auto;
    padding: 24px 0 28px;
    border-right: 1px solid var(--fc-color-sidebar-border, #ededf2);
    background: var(--fc-color-bg, #ffffff);
}

body.fontchuviet-has-sidebar .fc-app > .fc-main {
    grid-column: 2;
}

.fc-sidebar-top {
    display: none;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    padding: 0 10px;
    margin-bottom: 12px;
}

.fc-brand {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
    color: inherit;
    text-decoration: none;
}

.fc-brand-mark {
    width: var(--fc-size-brand-mark, 22px);
    height: var(--fc-size-brand-mark, 22px);
    border-radius: 8px;
    background: linear-gradient(135deg, var(--fc-color-brand-start, #87d8ff) 0%, var(--fc-color-brand-mid, #b98bff) 48%, var(--fc-color-brand-end, #ff9dc4) 100%);
    box-shadow: inset 0 0 0 4px rgba(255,255,255,0.7);
}

.fc-brand-name {
    font-size: calc(var(--fc-font-size-title, 14px) + 1px);
    font-weight: 600;
}

.fc-brand-logo,
.fc-topbar-logo {
    display: block;
    width: auto;
    object-fit: contain;
}

.fc-brand-logo {
    max-width: 180px;
    max-height: 36px;
}

.fc-topbar-logo {
    max-width: 150px;
    max-height: 28px;
}

.fc-sidebar-close,
.fc-mobile-toggle {
    border: 0;
    cursor: pointer;
}

.fc-sidebar-close {
    display: none;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-right: 12px;
    border-radius: 999px;
    background: #141418;
    color: #ffffff;
    font-size: 28px;
    line-height: 1;
    flex-shrink: 0;
}

.fc-quota {
    display: block;
    margin: 0 18px 14px;
    padding: 14px 14px 12px;
    border: 1px solid rgba(232, 235, 244, 0.95);
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
    box-shadow: 0 10px 24px rgba(18, 18, 24, 0.04);
    color: inherit;
    text-decoration: none;
}

.fc-quota:hover,
.fc-quota:focus-visible {
    text-decoration: none;
    border-color: rgba(117, 109, 255, 0.22);
    box-shadow: 0 14px 28px rgba(117, 109, 255, 0.08);
}

.fc-quota-top {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 7px;
}

.fc-coin {
    width: var(--fc-size-quota-coin, 18px);
    height: var(--fc-size-quota-coin, 18px);
    border-radius: 50%;
    background: linear-gradient(180deg, rgba(117, 109, 255, 0.12) 0%, rgba(138, 120, 255, 0.22) 100%);
    box-shadow: inset 0 0 0 2px rgba(255,255,255,0.7);
}

.fc-quota-top strong {
    font-size: 16px;
    font-weight: 600;
    color: var(--fc-color-primary, #756dff);
}

.fc-quota-top span {
    font-size: 14px;
    color: #666f7d;
}

.fc-quota-plus {
    margin-left: auto;
    color: var(--fc-color-text-muted, #9a9aa2);
    font-size: 20px;
    line-height: 1;
}

.fc-quota-month {
    margin-bottom: 4px;
    color: #5a4cc8;
    font-size: 12px;
    font-weight: 500;
}

.fc-quota-status {
    margin-bottom: 4px;
    color: var(--fc-color-text, #1d1d1f);
    font-size: 13px;
    font-weight: 600;
}

.fc-quota-status-vip {
    color: var(--fc-color-primary, #756dff);
}

.fc-quota-status-free {
    color: var(--fc-color-text, #1d1d1f);
}

.fc-quota-meta {
    margin-bottom: 8px;
    color: var(--fc-color-text-soft, #62626a);
    font-size: 12px;
    line-height: 1.45;
}

.fc-progress {
    height: var(--fc-progress-height, 5px);
    overflow: hidden;
    border-radius: 999px;
    background: var(--fc-color-border, #ececf2);
}

.fc-progress span {
    display: block;
    width: 82%;
    height: 100%;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
}

.fc-side-section-title {
    margin: 24px 18px 10px;
    padding-top: 14px;
    border-top: 1px solid #eceff6;
    font-size: 11px;
    font-weight: 600;
    color: #6b7280;
}

.fc-side-section-title-first {
    margin-top: 8px;
    padding-top: 0;
    border-top: 0;
}

.fc-menu {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 0 18px;
}

.fc-menu-item {
    --fc-menu-row-height: 22px;
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: var(--fc-size-menu-min-height, 42px);
    padding: 0 14px;
    border-radius: var(--fc-radius-lg, 12px);
    color: #2e2e33;
    text-decoration: none;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.2;
    transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.fc-menu-label {
    display: inline-flex;
    align-items: center;
    height: var(--fc-menu-row-height);
    line-height: 1.15;
}

.fc-menu-item:hover,
.fc-menu-item:focus-visible {
    color: #1f1f25;
    background: rgba(117, 109, 255, 0.08);
    box-shadow: 0 8px 18px rgba(117, 109, 255, 0.12);
    transform: translateX(2px);
}

.fc-menu-item.active {
    color: #ffffff;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    box-shadow: var(--fc-shadow-primary, 0 10px 24px rgba(117, 109, 255, 0.25));
}

.fc-menu-item.active:hover,
.fc-menu-item.active:focus-visible {
    color: #ffffff;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    box-shadow: var(--fc-shadow-primary, 0 10px 24px rgba(117, 109, 255, 0.25));
    transform: translateX(0);
}

.fc-menu-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--fc-menu-row-height);
    height: var(--fc-menu-row-height);
    flex-shrink: 0;
    line-height: 0;
    color: #5f6675;
    overflow: visible;
}

.fc-menu-icon svg {
    display: block;
    width: 18px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.65;
    stroke-linecap: round;
    stroke-linejoin: round;
    overflow: visible;
}

.fc-menu-item.active .fc-menu-icon {
    color: #ffffff;
}

.fc-upgrade {
    margin: 30px 18px 0;
    padding: 20px 16px 16px;
    border-radius: var(--fc-radius-3xl, 18px);
    background: linear-gradient(180deg, #eff9de 0%, #e7f5d6 100%);
    text-align: center;
}

.fc-upgrade-visual {
    width: var(--fc-size-upgrade-visual, 76px);
    height: var(--fc-size-upgrade-visual, 76px);
    margin: 0 auto 12px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 38%, #ffffff 0%, #ffffff 19px, transparent 20px),
        radial-gradient(circle at 50% 50%, rgba(162, 227, 176, 0.9) 0%, rgba(162, 227, 176, 0.9) 32px, transparent 33px),
        linear-gradient(180deg, #d7f1ba 0%, #eef8de 100%);
}

.fc-upgrade-copy {
    margin: 0;
    color: var(--fc-color-text, #1d1d1f);
    font-size: var(--fc-font-size-ui, 12px);
    line-height: 1.5;
    font-weight: 400;
}

.fc-upgrade button,
.fc-upgrade .fc-upgrade-button {
    margin-top: 14px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    border: 1px solid #27272c;
    border-radius: var(--fc-radius-lg, 12px);
    background: var(--fc-color-surface, #ffffff);
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 600;
    color: #111111;
    text-decoration: none;
}

.fc-main {
    padding: var(--fc-layout-main-padding, 18px 14px 18px 22px);
    min-width: 0;
    width: 100%;
    max-width: 100%;
}

.fc-footer {
    width: 100%;
    margin-top: auto;
    border-top: 1px solid #ececf2;
    background: linear-gradient(180deg, #fcfcfe 0%, #f8f9fc 100%);
}

.fc-footer-inner {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 52px 15px 18px;
}

body.fontchuviet-has-sidebar .fc-footer-inner {
    padding-left: 37px;
    padding-right: 37px;
}

.fc-footer-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.4fr) repeat(3, minmax(160px, 1fr));
    gap: 32px;
    align-items: start;
}

.fc-footer-column {
    min-width: 0;
}

.fc-footer-title {
    margin: 0 0 18px;
    color: #142033;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.35;
}

.fc-footer-contact {
    margin: 0;
    color: #556075;
    font-size: 14px;
    line-height: 1.8;
}

.fc-footer-contact strong {
    color: #334155;
}

.fc-footer-links {
    margin: 0;
    padding: 0;
    list-style: none;
}

.fc-footer-links a {
    font-size: 12px;
    line-height: 1.5;
}

.fc-footer-links li + li {
    margin-top: 8px;
}

.fc-footer a {
    color: #667085;
    text-decoration: none;
    transition: color 180ms ease;
}

.fc-footer a:hover,
.fc-footer a:focus-visible {
    color: #1f4ed8;
}

.fc-footer-socials {
    display: flex;
    align-items: center;
    gap: 12px;
}

.fc-footer-social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid #d7dbe4;
    border-radius: 999px;
    background: #ffffff;
    color: #667085;
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.05);
}

.fc-footer-social svg {
    display: block;
    width: 18px;
    height: 18px;
    fill: currentColor;
}

.fc-footer-bottom {
    margin-top: 42px;
    padding-top: 20px;
    border-top: 1px solid #e5e7ee;
    text-align: center;
}

.fc-footer-bottom p {
    margin: 0;
    color: #667085;
    font-size: 14px;
    line-height: 1.65;
}

.fc-footer-bottom p + p {
    margin-top: 2px;
}

.fc-main-topbar {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}

.fc-mobile-toggle {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    width: 44px;
    height: 44px;
    padding: 0 11px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    box-shadow: var(--fc-shadow-primary, 0 10px 24px rgba(117, 109, 255, 0.25));
}

.fc-mobile-toggle span {
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: #ffffff;
}

.fc-main-topbar-title {
    display: inline-flex;
    justify-self: center;
    align-items: center;
    color: var(--fc-color-text, #1d1d1f);
    text-decoration: none;
    font-size: 15px;
    font-weight: 700;
}

.fc-main-topbar-brand {
    display: inline-flex;
    justify-self: center;
    align-items: center;
}

.fc-main-topbar-spacer {
    display: inline-block;
    width: 40px;
    height: 40px;
}

.fc-topbar-user {
    display: none;
}

.fc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--fc-layout-gap-xl, 20px);
    margin-bottom: var(--fc-layout-gap-xl, 20px);
}

.fc-title {
    margin: 0;
    font-size: var(--fc-font-size-title, 14px);
    font-weight: 700;
}

.fc-header-right {
    display: flex;
    align-items: center;
    gap: var(--fc-layout-gap-md, 14px);
}

.fc-header-icons {
    display: flex;
    align-items: center;
    gap: 12px;
}

.fc-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--fc-size-icon, 20px);
    height: var(--fc-size-icon, 20px);
    color: var(--fc-color-text, #1d1d1f);
}

.fc-icon-link {
    position: relative;
    text-decoration: none;
}

.fc-icon svg {
    display: block;
    width: 100%;
    height: 100%;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.fc-icon.bookmark {
    width: 21px;
    height: 21px;
    transform: translateY(1px);
}

.fc-icon.bell {
    width: 22px;
    height: 22px;
    transform: translateY(1px);
}

.fc-notification-menu {
    position: relative;
}

.fc-notification-menu summary {
    list-style: none;
    cursor: pointer;
}

.fc-notification-menu summary::-webkit-details-marker {
    display: none;
}

.fc-notification-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: -8px;
    width: min(320px, calc(100vw - 24px));
    padding: 12px;
    border: 1px solid rgba(17, 24, 39, 0.08);
    border-radius: 12px;
    background: #ffffff;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
    z-index: 40;
}

.fc-notification-title {
    font-size: 13px;
    font-weight: 700;
    color: #111827;
}

.fc-notification-time {
    margin-top: 3px;
    font-size: 11px;
    color: #6b7280;
}

.fc-notification-divider {
    margin-top: 8px;
    border-top: 1px solid #e5e7eb;
}

.fc-notification-message {
    margin-top: 10px;
    font-size: 12px;
    line-height: 1.45;
    color: #111827;
    white-space: normal;
}

.fc-notification-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 12px;
    padding: 7px 10px;
    border-radius: 8px;
    border: 1px solid #d1d5db;
    color: #111827;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
}

.fc-notification-action:hover,
.fc-notification-action:focus-visible {
    border-color: #9ca3af;
    background: #f9fafb;
    text-decoration: none;
}

.fc-icon-badge {
    position: absolute;
    top: -7px;
    right: -10px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 999px;
    background: #756dff;
    color: #ffffff;
    font-size: 9px;
    font-weight: 700;
    line-height: 16px;
    text-align: center;
    box-shadow: 0 4px 10px rgba(117, 109, 255, 0.28);
}

.fc-icon .fc-icon-accent {
    fill: var(--fc-color-alert, #ff6d6d);
    stroke: #ffffff;
    stroke-width: 1.15;
}

.fc-user {
    display: flex;
    align-items: center;
    gap: 10px;
    color: inherit;
    text-decoration: none;
}

.fc-user-menu {
    position: relative;
}

.fc-user-menu summary {
    list-style: none;
    cursor: pointer;
}

.fc-user-menu summary::-webkit-details-marker {
    display: none;
}

.fc-user:hover,
.fc-user:focus-visible {
    text-decoration: none;
}

.fc-user-menu[open] .fc-chevron {
    transform: rotate(-45deg);
}

.fc-user.is-guest .fc-user-avatar {
    background: linear-gradient(135deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
}

.fc-user.is-guest .fc-user-name {
    color: var(--fc-color-primary, #756dff);
}

.fc-user-avatar {
    width: var(--fc-size-user-avatar, 34px);
    height: var(--fc-size-user-avatar, 34px);
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(135deg, var(--fc-color-avatar-start, #ffbd94) 0%, var(--fc-color-avatar-end, #ef8a61) 100%);
}

.fc-user-avatar img,
.fc-user-avatar-initials {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.fc-user-avatar img {
    object-fit: cover;
}

.fc-user-avatar-initials {
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 0;
}

.fc-user-avatar-initials svg {
    display: block;
    width: 22px;
    height: 26px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
    overflow: visible;
}

.fc-user-copy {
    line-height: 1.15;
}

.fc-user-name {
    font-size: var(--fc-font-size-meta, 11px);
    font-weight: 700;
}

.fc-user-mail {
    font-size: var(--fc-font-size-caption, 10px);
    color: var(--fc-color-text-muted, #9a9aa2);
}

.fc-user-mail-link {
    color: inherit;
    text-decoration: none;
}

.fc-user-mail-link:hover,
.fc-user-mail-link:focus-visible {
    color: var(--fc-color-text-soft, #62626a);
    text-decoration: none;
}

.fc-badge {
    display: inline-block;
    margin-left: 4px;
    padding: 2px 5px;
    border-radius: 999px;
    background: var(--fc-color-badge, #5f4dd6);
    color: #ffffff;
    font-size: var(--fc-font-size-badge, 8px);
    font-weight: 700;
    vertical-align: middle;
}

.fc-chevron {
    width: calc(var(--fc-size-icon, 16px) / 2);
    height: calc(var(--fc-size-icon, 16px) / 2);
    border-top: 1.5px solid #5f5f66;
    border-right: 1.5px solid #5f5f66;
    transform: rotate(135deg);
    transition: transform 180ms ease;
}

.fc-user-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    z-index: 40;
    min-width: 180px;
    padding: 6px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 14px;
    background: var(--fc-color-surface, #ffffff);
    box-shadow: 0 18px 32px rgba(20, 20, 20, 0.12);
}

.fc-user-dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    color: var(--fc-color-text, #1d1d1f);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
}

.fc-user-dropdown-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    padding: 1px;
    flex-shrink: 0;
    overflow: visible;
    color: #6f7482;
}

.fc-user-dropdown-icon svg {
    display: block;
    width: 100%;
    height: 100%;
    overflow: visible;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.65;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.fc-user-dropdown-item:hover,
.fc-user-dropdown-item:focus-visible {
    background: #f7f8fc;
}

.fc-user-dropdown-item:hover .fc-user-dropdown-icon,
.fc-user-dropdown-item:focus-visible .fc-user-dropdown-icon {
    color: var(--fc-color-primary, #756dff);
}

.fc-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 84px 132px;
    gap: var(--fc-layout-gap-sm, 10px);
    margin-bottom: 12px;
    position: relative;
    z-index: 12;
}

.fc-toolbar--filters {
    grid-template-columns: 84px 132px;
    justify-content: end;
}

.fc-header-filters {
    display: inline-flex;
    align-items: center;
    gap: var(--fc-layout-gap-sm, 10px);
    margin-left: auto;
}

.fc-header-filters .fc-vip-filter-button {
    width: 84px;
}

.fc-header-filters .fc-filter-wrap {
    width: 132px;
}

.fc-search,
.fc-control,
.fc-filter-button {
    height: var(--fc-control-height, 46px);
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: var(--fc-radius-md, 10px);
    background: var(--fc-color-surface, #ffffff);
}

.fc-vip-filter-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    text-decoration: none;
    color: #ffffff;
    font-weight: 600;
    border-color: #ff9c43;
    background: linear-gradient(90deg, #ffb84d 0%, #ff8a3d 100%);
    box-shadow: 0 8px 18px rgba(255, 138, 61, 0.26);
}

.fc-vip-filter-button,
.fc-vip-filter-button:visited,
.fc-vip-filter-button:hover,
.fc-vip-filter-button:focus-visible {
    color: #ffffff;
}

.fc-vip-filter-button.is-active {
    border-color: #f08a3a;
    color: #f1762a;
    background: #ffffff;
    box-shadow: 0 8px 18px rgba(241, 118, 42, 0.16);
}

.fc-vip-filter-button.is-active:visited,
.fc-vip-filter-button.is-active:hover,
.fc-vip-filter-button.is-active:focus-visible {
    color: #f1762a;
}

.fc-search {
    display: flex;
    align-items: center;
    padding: 0 16px;
    color: #6b7280;
    font-size: calc(var(--fc-font-size-ui, 12px) + 1px);
    position: relative;
    z-index: 14;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, transform 0.18s ease;
}

.fc-mobile-content-search {
    display: none;
}

.fc-search:hover,
.fc-search:focus-within {
    border-color: rgba(117, 109, 255, 0.34);
    box-shadow: 0 10px 24px rgba(117, 109, 255, 0.10);
    background: linear-gradient(180deg, #ffffff 0%, #fbfbff 100%);
    transform: translateY(-1px);
}

.fc-search-icon {
    position: relative;
    width: var(--fc-size-search-icon, 12px);
    height: var(--fc-size-search-icon, 12px);
    border: 1.5px solid currentColor;
    border-radius: 50%;
}

.fc-search-icon::after {
    content: "";
    position: absolute;
    right: -4px;
    bottom: -1px;
    width: 5px;
    height: 1.5px;
    background: currentColor;
    transform: rotate(45deg);
    border-radius: 999px;
}

.fc-search-input {
    flex: 1 1 auto;
    min-width: 0;
    margin-left: 12px;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--fc-color-text, #1d1d1f);
    font-size: calc(var(--fc-font-size-ui, 12px) + 2px);
    font-weight: 600;
    outline: none;
    transition: color 0.18s ease;
}

.fc-search:hover .fc-search-input,
.fc-search:focus-within .fc-search-input {
    color: #17171a;
}

.fc-control,
.fc-filter-button {
    padding: 0 16px;
    font-size: calc(var(--fc-font-size-ui, 12px) + 2px);
}

.fc-search-input::placeholder {
    color: #6b7280;
    font-weight: 500;
}

.fc-search-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 92px;
    height: var(--fc-control-height, 46px);
    margin-left: 0;
    padding: 0 14px;
    border: 0;
    border-radius: var(--fc-radius-md, 10px);
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    flex-shrink: 0;
}

.fc-search-submit:hover,
.fc-search-submit:focus-visible {
    opacity: 0.94;
}

.fc-search-suggestions {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    padding: 6px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 14px;
    background: var(--fc-color-surface, #ffffff);
    box-shadow: 0 18px 32px rgba(20, 20, 20, 0.12);
    z-index: 24;
}

.fc-search-suggestions[hidden] {
    display: none !important;
}

.fc-search-suggestion,
.fc-search-suggestion-empty {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 8px;
    border-radius: 10px;
    text-decoration: none;
}

.fc-search-suggestion:hover,
.fc-search-suggestion:focus-visible {
    background: #f7f8fc;
}

.fc-search-suggestion-thumb,
.fc-search-suggestion-placeholder {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    overflow: hidden;
    background: #f1f2f7;
}

.fc-search-suggestion-thumb img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fc-search-suggestion-title {
    color: var(--fc-color-text, #1d1d1f);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
}

.fc-search-suggestion-meta {
    margin-top: 2px;
    color: var(--fc-color-text-soft, #62626a);
    font-size: 10px;
    line-height: 1.35;
}

.fc-search-suggestion-empty {
    grid-template-columns: 1fr;
    color: var(--fc-color-text-soft, #62626a);
    font-size: 11px;
    font-weight: 600;
}

/* Search history */
.fc-search-history-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 8px 4px;
}

.fc-search-history-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--fc-color-text-soft, #62626a);
}

.fc-search-history-clear {
    padding: 2px 8px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: var(--fc-color-primary, #5b6af8);
    font-size: 10px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
}

.fc-search-history-clear:hover {
    background: var(--fc-color-primary-soft, rgba(91, 106, 248, 0.08));
}

.fc-search-history-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 8px;
    border-radius: 10px;
    cursor: pointer;
    transition: background 0.15s;
}

.fc-search-history-item:hover {
    background: #f7f8fc;
}

.fc-search-history-icon {
    flex-shrink: 0;
    color: var(--fc-color-text-soft, #62626a);
}

.fc-search-history-text {
    flex: 1;
    font-size: 12px;
    font-weight: 600;
    color: var(--fc-color-text, #1d1d1f);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.fc-search-history-delete {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--fc-color-text-soft, #62626a);
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.15s, background 0.15s;
}

.fc-search-history-item:hover .fc-search-history-delete {
    opacity: 1;
}

.fc-search-history-delete:hover {
    background: #ecedf4;
    color: var(--fc-color-text, #1d1d1f);
}

.fc-search-empty {
    margin-top: 18px;
    padding: 18px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 14px;
    background: #fbfbfd;
    color: var(--fc-color-text-soft, #62626a);
    font-size: 12px;
    font-weight: 600;
}

.fc-control,
.fc-filter-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 600;
    color: var(--fc-color-text, #1d1d1f);
    white-space: nowrap;
}

.fc-caret {
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
}

.fc-filter-wrap {
    position: relative;
    min-width: 132px;
    z-index: 13;
}

.fc-filter-wrap summary {
    list-style: none;
    cursor: pointer;
}

.fc-filter-wrap summary::-webkit-details-marker {
    display: none;
}

.fc-dropdown {
    display: none;
    position: absolute;
    top: 42px;
    left: 0;
    width: 132px;
    padding: 4px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: var(--fc-radius-md, 10px);
    background: var(--fc-color-surface, #ffffff);
    box-shadow: var(--fc-shadow-dropdown, 0 14px 26px rgba(35, 35, 42, 0.12));
    z-index: 3;
}

.fc-filter-wrap[open] .fc-dropdown {
    display: block;
    z-index: 20;
}

.fc-dropdown a {
    display: block;
    padding: 7px 8px;
    border-radius: 6px;
    font-size: var(--fc-font-size-meta, 11px);
    color: var(--fc-color-text-soft, #62626a);
    text-decoration: none;
}

.fc-dropdown .active {
    background: var(--fc-color-primary-tint, #f3eeff);
    color: var(--fc-color-primary, #756dff);
}

.fc-dropdown a:hover,
.fc-dropdown a:focus-visible {
    background: #f7f8fc;
    color: var(--fc-color-text, #1d1d1f);
}

.fc-filter-lines {
    position: relative;
    width: 12px;
    height: 10px;
}

.fc-filter-lines::before,
.fc-filter-lines::after,
.fc-filter-lines span {
    content: "";
    position: absolute;
    left: 0;
    width: 12px;
    height: 1.5px;
    background: currentColor;
    border-radius: 999px;
}

.fc-filter-lines::before {
    top: 1px;
}

.fc-filter-lines span {
    top: 4px;
}

.fc-filter-lines::after {
    top: 7px;
}

.fc-suggested {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    font-size: var(--fc-font-size-meta, 11px);
    color: var(--fc-color-text-soft, #62626a);
    flex: 1;
    min-width: 0;
}

.fc-category-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 24px;
}

.fc-category-nav {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    padding-top: 1px;
}

.fc-category-nav-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    border: 1px solid var(--fc-color-border, #ececf2);
    background: var(--fc-color-surface-soft, #f7f7fa);
    color: var(--fc-color-text, #1d1d1f);
    text-decoration: none;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
    cursor: pointer;
}

.fc-category-nav-btn:hover {
    background: var(--fc-color-surface, #ffffff);
    border-color: #c8cad6;
    color: var(--fc-color-primary, #756dff);
}

.fc-category-nav-btn.is-disabled {
    opacity: 0.35;
    cursor: default;
    pointer-events: none;
}

.fc-category-nav-paged {
    font-size: 11px;
    font-weight: 600;
    color: var(--fc-color-text-soft, #62626a);
    padding: 0 4px;
    white-space: nowrap;
    line-height: 32px;
}

.fc-chip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 11px;
    background: var(--fc-color-surface-soft, #f7f7fa);
    color: var(--fc-color-text-soft, #62626a);
    font-size: 11px;
    text-decoration: none;
    font-weight: 600;
}

.fc-chip:hover,
.fc-chip:focus-visible {
    border-color: #d8dbe7;
    background: #f1f2f8;
    color: #333847;
}

.fc-chip.is-active {
    border-color: #d9d2ff;
    background: #f3eeff;
    color: #4c3fb5;
}

.fc-gallery {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: var(--fc-layout-gap-lg, 18px);
    align-items: start;
}

.fc-gallery--mobile {
    display: none;
}

.fc-pagination {
    margin-top: 16px;
}

.fc-pagination .page-numbers {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.fc-pagination .page-numbers li {
    display: flex;
}

.fc-pagination a,
.fc-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 12px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 10px;
    background: var(--fc-color-surface, #ffffff);
    color: var(--fc-color-text, #1d1d1f);
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    box-shadow: 0 8px 20px rgba(20, 20, 20, 0.04);
}

.fc-pagination a:hover,
.fc-pagination a:focus-visible {
    border-color: #d8dbe7;
    background: #f7f8fc;
}

.fc-pagination .current {
    border-color: #d9d2ff;
    background: #f3eeff;
    color: var(--fc-color-primary, #756dff);
}

.fc-column {
    display: grid;
    gap: var(--fc-layout-gap-md, 14px);
}

.fc-card {
    display: grid;
    gap: 10px;
}

.fc-card-media-shell {
    position: relative;
}

.fc-card-badges {
    position: absolute;
    top: 10px;
    left: 10px;
    right: 10px;
    z-index: 4;
    display: flex;
    align-items: center;
    gap: 6px;
    pointer-events: none;
}

.fc-card-badges > * {
    pointer-events: auto;
}

.fc-card-file-count {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    height: 24px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: lowercase;
    background: rgba(23, 27, 36, 0.9);
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(16, 18, 27, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.14);
    white-space: nowrap;
}

.fc-card-file-count-icon {
    flex-shrink: 0;
    fill: currentColor;
}

.fc-card-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    box-shadow: 0 8px 18px rgba(16, 18, 27, 0.14);
}

.fc-card-badge-vip {
    background: linear-gradient(90deg, #ffb84d 0%, #ff8a3d 100%);
    color: #ffffff;
}

.fc-card-badge-free {
    background: rgba(255, 255, 255, 0.92);
    color: #2f3b4c;
}

.fc-card-link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.fc-card-media {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    border-radius: var(--fc-radius-2xl, 16px);
    background: var(--fc-color-surface-card, #f0f0f0);
    box-shadow: var(--fc-shadow-card, 0 10px 28px rgba(30, 30, 35, 0.05));
    isolation: isolate;
    transition: transform 220ms ease, box-shadow 220ms ease;
}

.fc-card-media::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(17, 18, 27, 0.1) 0%, rgba(17, 18, 27, 0.04) 38%, rgba(17, 18, 27, 0.18) 100%);
}

.fc-card-media::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 46%;
    z-index: 1;
    background: linear-gradient(180deg, rgba(15, 16, 24, 0) 0%, rgba(15, 16, 24, 0.14) 30%, rgba(15, 16, 24, 0.5) 100%);
}

.fc-card-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fc-card:hover .fc-card-media,
.fc-card:focus-within .fc-card-media {
    transform: translateY(-2px);
    box-shadow: var(--fc-shadow-primary, 0 10px 24px rgba(117, 109, 255, 0.25));
}

.fc-card-actions,
.fc-card-hover {
    position: absolute;
    left: 14px;
    right: 14px;
    z-index: 3;
}

.fc-card-actions {
    top: 10px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    opacity: 0;
    transform: translateY(-8px);
    pointer-events: none;
    transition: opacity 220ms ease, transform 220ms ease;
}

.fc-card:hover .fc-card-actions,
.fc-card:focus-within .fc-card-actions {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.fc-card-action {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: calc(var(--fc-size-card-action, 22px) + 14px);
    height: calc(var(--fc-size-card-action, 22px) + 14px);
    padding: 0;
    border: 0;
    border-radius: 12px;
    background: #ffffff;
    box-shadow: 0 8px 18px rgba(16, 18, 27, 0.14);
    appearance: none;
    cursor: pointer;
    transition: transform 180ms ease, box-shadow 180ms ease;
}

.fc-card-action:hover,
.fc-card-action:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(16, 18, 27, 0.22);
}

.fc-card-action:focus-visible {
    outline: 2px solid rgba(117, 109, 255, 0.3);
    outline-offset: 2px;
}

.fc-card-action.is-active {
    background: #fff8f7;
    box-shadow: 0 10px 22px rgba(16, 18, 27, 0.16);
}

.fc-card-action[data-font-action="save"].is-active {
    background: #f5f1ff;
}

.fc-card-action-icon {
    width: 18px;
    height: 18px;
    display: block;
    transition: fill 180ms ease, transform 180ms ease, opacity 180ms ease;
}

.fc-card-action-like .fc-card-action-icon {
    fill: #8d95a5;
    opacity: 0.88;
}

.fc-card-action-save .fc-card-action-icon {
    fill: var(--fc-color-text-soft, #62626a);
}

.fc-card-action[data-font-action="like"].is-active .fc-card-action-icon {
    fill: #e24a63;
    opacity: 1;
    transform: scale(1.08);
}

.fc-card-action[data-font-action="save"].is-active .fc-card-action-icon {
    fill: var(--fc-color-primary, #756dff);
}

.fc-card-overlay-title {
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 12px;
    z-index: 2;
    padding: 0;
    border-radius: 0;
    background: transparent;
    color: #ffffff;
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 600;
    line-height: 1.28;
    text-shadow: 0 1px 10px rgba(0,0,0,0.35);
}

.fc-card-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 0 2px;
    font-size: 12px;
    color: #5c6472;
}

.fc-card-author-text,
.fc-card-stats {
    display: flex;
    align-items: center;
    gap: 7px;
    min-width: 0;
}

.fc-card-author-text {
    min-width: 0;
    font-size: 12px;
    font-weight: 400;
    color: #5f6878;
}

.fc-card-stats {
    justify-content: flex-end;
    gap: 14px;
    font-size: 11px;
    color: #8a92a0;
}

.fc-card-stat {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: auto;
    padding: 0;
}

.fc-card-stat-plain {
    color: var(--fc-color-text-soft, #62626a);
}

.fc-card-stat-icon {
    width: 16px;
    height: 16px;
    display: block;
}

.fc-card-stat-like {
    fill: #b8b8bf;
}

.fc-card-stat-view {
    fill: #b8b8bf;
}

.fc-h-1,
.fc-h-2,
.fc-h-3,
.fc-h-4,
.fc-h-5,
.fc-h-6 {
    height: auto;
}

.fc-card-hover {
    top: 50%;
    bottom: auto;
    display: flex;
    justify-content: center;
    gap: 10px;
    opacity: 0;
    transform: translateY(calc(-50% + 10px));
    transition: opacity 220ms ease, transform 220ms ease;
}

.fc-card:hover .fc-card-hover,
.fc-card:focus-within .fc-card-hover {
    opacity: 1;
    transform: translateY(-50%);
}

.fc-card:hover .fc-card-overlay-title,
.fc-card:focus-within .fc-card-overlay-title {
    opacity: 1;
}

.fc-card-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: var(--fc-size-card-hover-button-min-width, 112px);
    height: var(--fc-size-card-hover-button-height, 34px);
    padding: 0 16px;
    border: 1px solid rgba(255,255,255,0.28);
    border-radius: var(--fc-radius-lg, 12px);
    background: rgba(255,255,255,0.16);
    color: #ffffff;
    text-decoration: none;
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 700;
    backdrop-filter: blur(12px);
    cursor: pointer;
}

.fc-card-cta-primary {
    border-color: transparent;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    box-shadow: var(--fc-shadow-primary, 0 10px 24px rgba(117, 109, 255, 0.25));
}

.fc-card-cta-primary.is-locked,
.fc-single-download-button.is-locked {
    border-color: transparent;
    background: linear-gradient(90deg, #ffb74d 0%, #ff9800 100%);
    box-shadow: 0 10px 24px rgba(255, 152, 0, 0.24);
}

.fc-card-cta.is-disabled {
    border-color: rgba(255,255,255,0.18);
    background: rgba(17, 18, 27, 0.32);
    color: rgba(255,255,255,0.78);
    box-shadow: none;
    cursor: not-allowed;
}

.fc-download-modal[hidden] {
    display: none !important;
}

.fc-download-modal [hidden] {
    display: none !important;
}

.fc-download-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    padding: 24px;
}

.fc-download-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(9, 12, 20, 0.58);
    backdrop-filter: blur(6px);
}

.fc-download-modal-dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 980px);
    padding: 28px;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 28px 60px rgba(15, 18, 27, 0.24);
}

.fc-download-modal-layout {
    display: grid;
    grid-template-columns: minmax(260px, 1.1fr) minmax(320px, 0.9fr);
    gap: 24px;
}

.fc-download-modal-ad,
.fc-download-modal-main {
    min-width: 0;
}

.fc-download-modal-ad {
    padding-bottom: 10px;
}

.fc-download-modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 50%;
    background: #f3f4f8;
    color: #4a5160;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
}

.fc-download-modal-eyebrow {
    margin: 0 0 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8a90a2;
}

.fc-download-modal-title {
    margin: 0;
    font-size: 22px;
    line-height: 1.2;
    color: #161922;
}

.fc-download-modal-copy {
    margin: 12px 0 0;
    font-size: 14px;
    line-height: 1.7;
    color: #5a6273;
}

.fc-download-modal-preview {
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    background: transparent;
    aspect-ratio: auto;
    border: 0;
    border-radius: 0;
}

.fc-download-modal-preview img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.fc-download-modal-image-placeholder {
    display: grid;
    place-items: center;
    height: 100%;
    padding: 24px;
    color: #7a8293;
    text-align: center;
}

.fc-download-modal-content {
    margin-top: 22px;
}

.fc-download-modal-countdown {
    margin: 14px 0 0;
    font-size: 14px;
    font-weight: 700;
    color: #586174;
}

.fc-download-modal-countdown-value {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    margin: 0 4px;
    padding: 2px 8px;
    border-radius: 999px;
    background: #fff0c2;
    color: #d46b08;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.1;
}

.fc-download-modal-slot {
    display: grid;
    place-items: center;
    min-height: 100%;
    margin-top: 12px;
    padding: 18px;
    border: 1px dashed #cfd5df;
    border-radius: 18px;
    background: linear-gradient(180deg, #fbfbfd 0%, #f4f6fb 100%);
    color: #7a8293;
    text-align: center;
}

.fc-download-modal-actions {
    display: flex;
    gap: 12px;
}

.fc-download-modal-footer .fc-download-modal-actions {
    margin-top: 0;
}

.fc-download-modal-footer {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 20px;
}

.fc-download-modal-file-info {
    font-size: 13px;
    color: #7a8293;
    white-space: nowrap;
    flex-shrink: 0;
}

.fc-download-modal-file-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
}

.fc-download-modal-file-list .fc-download-modal-button {
    min-width: auto;
    height: auto;
    padding: 10px 14px;
    border-radius: 12px;
    font-size: 12px;
    line-height: 1.35;
    box-shadow: 0 10px 22px rgba(117, 109, 255, 0.18);
}

.fc-download-modal-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 140px;
    height: 44px;
    padding: 0 18px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
    box-shadow: 0 14px 28px rgba(117, 109, 255, 0.24);
    cursor: pointer;
}

.fc-download-modal-button.is-disabled {
    background: #edf1f6;
    color: #7e8798;
    box-shadow: none;
    cursor: not-allowed;
}

.fc-download-modal-button.is-secondary {
    border: 1px solid rgba(255, 152, 0, 0.18);
    background: #fff4e5;
    color: #ff9800;
    box-shadow: none;
}

.fc-access-modal[hidden] {
    display: none !important;
}

.fc-access-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: grid;
    place-items: center;
    padding: 24px;
}

.fc-access-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(9, 12, 20, 0.58);
    backdrop-filter: blur(6px);
}

.fc-access-modal-dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 460px);
    padding: 28px;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 28px 60px rgba(15, 18, 27, 0.24);
}

.fc-access-modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 50%;
    background: #f3f4f8;
    color: #4a5160;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
}

.fc-access-modal-eyebrow {
    margin: 0 0 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8a90a2;
}

.fc-access-modal-title {
    margin: 0;
    font-size: 24px;
    line-height: 1.2;
    color: #161922;
}

.fc-access-modal-message {
    margin: 14px 0 0;
    font-size: 15px;
    line-height: 1.75;
    color: #5a6273;
}

.fc-access-modal-details {
    display: grid;
    gap: 10px;
    margin-top: 18px;
    padding: 14px 16px;
    border-radius: 16px;
    background: #f8f9fc;
    border: 1px solid #eceff5;
}

.fc-access-modal-details[hidden],
.fc-access-modal-note[hidden] {
    display: none !important;
}

.fc-access-modal-detail-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.fc-access-modal-detail-row span {
    color: #7a8396;
    font-size: 13px;
    line-height: 1.5;
}

.fc-access-modal-detail-row strong {
    color: #161922;
    font-size: 13px;
    line-height: 1.5;
    font-weight: 700;
    text-align: right;
}

.fc-access-modal-note {
    margin-top: 16px;
    padding: 14px 16px;
    border: 1px solid rgba(255, 152, 0, 0.24);
    border-radius: 16px;
    background: linear-gradient(180deg, #fffaf2 0%, #fff3df 100%);
}

.fc-access-modal-note strong {
    display: block;
    margin-bottom: 6px;
    color: #9a5400;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.4;
}

.fc-access-modal-note p {
    margin: 0;
    color: #6a4c2b;
    font-size: 12px;
    line-height: 1.6;
}

.fc-access-modal-actions {
    display: flex;
    gap: 12px;
    margin-top: 24px;
}

.fc-access-modal-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 140px;
    height: 46px;
    padding: 0 18px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(90deg, #ffb74d 0%, #ff9800 100%);
    color: #ffffff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    box-shadow: 0 14px 28px rgba(255, 152, 0, 0.24);
    cursor: pointer;
}

.fc-access-modal-button.is-secondary {
    background: #f3f4f8;
    color: #4a5160;
    box-shadow: none;
}

@media (max-width: 760px) {
    .fc-download-modal {
        padding: 14px;
        align-items: start;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .fc-download-modal-dialog {
        width: 100%;
        max-height: calc(100vh - 28px);
        overflow-y: auto;
        padding: 20px;
        border-radius: 18px;
        -webkit-overflow-scrolling: touch;
    }

    .fc-download-modal-layout {
        grid-template-columns: 1fr;
    }

    .fc-download-modal-slot {
        min-height: 180px;
    }

    .fc-download-modal-actions {
        flex-direction: column;
    }

    .fc-download-modal-button {
        width: 100%;
    }
}

.fc-single-main {
    padding-right: 28px;
}

.single-font_item .fc-app {
    grid-template-columns: 1fr;
}

.page .fc-app {
    grid-template-columns: 1fr;
}

.page.fontchuviet-has-sidebar .fc-app {
    grid-template-columns: minmax(248px, var(--fc-layout-sidebar-width, 248px)) minmax(0, 1fr);
}

.single-font_item .fc-single-main {
    padding-left: 22px;
    padding-right: 22px;
}

.fc-single-topbar {
    margin-bottom: 18px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(236, 236, 242, 0.9);
    background: var(--fc-color-bg, #ffffff);
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 20px;
    align-items: center;
}

body.single-font_item .fc-single-topbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 30;
    padding-top: 14px;
    padding-left: 37px;
    padding-right: 37px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

body.single-font_item.admin-bar .fc-single-topbar {
    top: 32px;
}

.single-font_item .fc-single {
    padding-top: 92px;
}

.fc-single-brand {
    margin-bottom: 0;
    padding: 0;
    color: inherit;
    text-decoration: none;
}

.fc-single-topbar .fc-brand-name {
    font-size: calc(var(--fc-font-size-title, 14px) + 1px);
}

.fc-single-header-center {
    min-width: 0;
    display: grid;
    justify-items: center;
    gap: 4px;
    padding: 4px 10px 0;
}

.fc-single-header-kicker {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8b92a3;
}

.fc-single-header-breadcrumb {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    color: #5e6677;
    font-size: 10px;
    font-weight: 600;
}

.fc-single-header-breadcrumb a {
    color: #5e6677;
    text-decoration: none;
}

.fc-single-header-breadcrumb a:hover,
.fc-single-header-breadcrumb a:focus-visible {
    color: #2f3645;
}

.fc-single {
    max-width: 1080px;
    margin: 0 auto;
}

.fc-single-back-row {
    margin-bottom: 12px;
}

.fc-single-back-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    gap: 8px;
    padding: 0 16px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 999px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfbfd 100%);
    color: var(--fc-color-text-soft, #62626a);
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 8px 18px rgba(20, 20, 20, 0.04);
}

.fc-single-back-button::before {
    content: "";
    width: 7px;
    height: 7px;
    border-left: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
}

.fc-single-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: 18px;
    align-items: start;
}

.fc-single-primary,
.fc-single-sidebar-column {
    min-width: 0;
}

.fc-single-sidebar-column {
    align-self: start;
    position: sticky;
    top: 24px;
}

.fc-single-primary {
    display: grid;
    gap: 16px;
}

.fc-single-panel:not(.fc-single-visual-panel) {
    padding: 18px;
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: var(--fc-radius-3xl, 18px);
    background: linear-gradient(180deg, #ffffff 0%, #fcfcfe 100%);
    box-shadow: 0 12px 28px rgba(20, 20, 20, 0.045);
}

.fc-single-visual-panel {
    padding: 0;
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: var(--fc-radius-3xl, 18px);
    box-shadow: 0 12px 28px rgba(20, 20, 20, 0.045);
    background:
        radial-gradient(circle at top right, rgba(138, 120, 255, 0.08), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #fafafe 100%);
}

.fc-single-sidebar-card {
    background:
        radial-gradient(circle at top right, rgba(117, 109, 255, 0.09), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #fbfbfe 100%);
}

.fc-single-meta-stack {
    display: grid;
    gap: 14px;
}

.fc-single-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 62px;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.fc-single-status-vip {
    background: linear-gradient(90deg, #ffb84d 0%, #ff8a3d 100%);
    color: #ffffff;
}

.fc-single-status-free {
    background: #f4f6fb;
    color: #425066;
}

.fc-single-breadcrumb {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    font-size: 12px;
    color: var(--fc-color-text-muted, #9a9aa2);
}

.fc-single-breadcrumb a {
    color: inherit;
    text-decoration: none;
}

.fc-single-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 420px);
    gap: 24px;
    align-items: start;
    margin-bottom: 28px;
    padding: 26px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: var(--fc-radius-3xl, 18px);
    background: linear-gradient(180deg, #ffffff 0%, #fbfbfd 100%);
    box-shadow: var(--fc-shadow-soft, 0 8px 24px rgba(20, 20, 20, 0.04));
}

.fc-single-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.fc-single-pill {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 999px;
    background: #ffffff;
    font-size: 12px;
    font-weight: 600;
    color: var(--fc-color-text, #1d1d1f);
}

.fc-single-title {
    margin: 0;
    font-size: clamp(22px, 2.8vw, 30px);
    line-height: 1.12;
    letter-spacing: -0.03em;
}

.fc-single-excerpt {
    max-width: none;
    margin-bottom: 0;
    font-size: calc(var(--fc-font-size-ui, 12px) + 1px);
    line-height: 1.6;
    color: var(--fc-color-text-muted, #6f6f78);
}

.fc-single-info-list {
    display: grid;
    gap: 8px;
}

.fc-single-info-item {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: 14px;
    background: rgba(247, 247, 250, 0.72);
}

.fc-single-info-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #6e7685;
}

.fc-single-info-item strong {
    font-size: calc(var(--fc-font-size-ui, 12px) + 1px);
    color: #1f2430;
    text-align: right;
}

.fc-single-action-row {
    display: grid;
    gap: 10px;
}

.fc-single-notice {
    padding: 14px 16px;
    border: 1px solid rgba(255, 152, 0, 0.2);
    border-radius: 16px;
    background: linear-gradient(180deg, #fffaf2 0%, #fff5e7 100%);
}

.fc-single-notice strong {
    display: block;
    margin-bottom: 6px;
    color: #9a5b12;
    font-size: 13px;
    font-weight: 700;
}

.fc-single-notice p {
    margin: 0;
    color: #6a5336;
    font-size: 13px;
    line-height: 1.65;
}

.fc-single-download-button {
    width: 100%;
}

.fc-single-floating-download {
    position: fixed;
    left: 50%;
    bottom: 18px;
    z-index: 9990;
    transform: translateX(-50%);
    width: min(880px, calc(100vw - 42px));
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border: 1px solid rgba(225, 228, 238, 0.95);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 20px 40px rgba(17, 21, 31, 0.16);
    backdrop-filter: blur(8px);
}

.fc-single-floating-download[hidden] {
    display: none;
}

.fc-single-floating-download__thumb {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    overflow: hidden;
    background: #f4f6fb;
    display: grid;
    place-items: center;
    color: #4e5a72;
    font-size: 20px;
    font-weight: 800;
    text-transform: uppercase;
}

.fc-single-floating-download__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.fc-single-floating-download__meta {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.fc-single-floating-download__label {
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
    color: #7a8396;
}

.fc-single-floating-download__title {
    display: block;
    color: #1f2633;
    font-size: 14px;
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.fc-single-floating-download__action {
    width: min(240px, 100%);
}

.fc-single-floating-download__button {
    width: 100%;
    min-height: 44px;
}

body.fc-single-floating-download-active {
    padding-bottom: 102px;
}

@media (max-width: 1023px) {
    .fc-single-floating-download {
        width: calc(100vw - 16px);
        left: 8px;
        right: 8px;
        bottom: calc(8px + env(safe-area-inset-bottom));
        transform: none;
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 8px;
        padding: 8px;
        border-radius: 14px;
        box-shadow: 0 14px 30px rgba(17, 21, 31, 0.2);
    }

    .fc-single-floating-download__thumb {
        width: 42px;
        height: 42px;
        border-radius: 10px;
    }

    .fc-single-floating-download__label {
        font-size: 9px;
    }

    .fc-single-floating-download__title {
        font-size: 12px;
    }

    .fc-single-floating-download__action {
        width: 132px;
    }

    .fc-single-floating-download__button {
        min-height: 38px;
        padding-left: 10px;
        padding-right: 10px;
        border-radius: 11px;
        font-size: 12px;
    }

    body.fc-single-floating-download-active {
        padding-bottom: calc(72px + env(safe-area-inset-bottom));
    }
}

.fc-single-secondary-actions {
    display: flex;
    gap: 10px;
}

.fc-single-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 36px;
    padding: 0 12px;
    border: 1px solid var(--fc-color-border, #ececf2);
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fafe 100%);
    color: var(--fc-color-text-soft, #62626a);
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 8px 18px rgba(20, 20, 20, 0.035);
}

.fc-single-icon-button svg {
    width: 14px;
    height: 14px;
    fill: currentColor;
    transition: color 180ms ease, transform 180ms ease, opacity 180ms ease;
}

.fc-single-icon-button:first-child svg {
    color: #8d95a5;
    opacity: 0.88;
}

.fc-single-icon-button.is-copied {
    border-color: #cfe7d2;
    color: #177245;
}

.fc-single-icon-button.is-active {
    border-color: #e6dfff;
    background: #f7f3ff;
    color: #4b3ed1;
}

.fc-single-icon-button[data-font-action="like"].is-active {
    border-color: #ffd8d8;
    background: #fff6f6;
    color: #d94b4b;
}

.fc-single-icon-button[data-font-action="like"].is-active svg {
    color: #e24a63;
    opacity: 1;
    transform: scale(1.08);
}

[data-font-action].is-loading {
    opacity: 0.68;
    cursor: wait;
}

.fc-auth-notice {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 10001;
    width: min(360px, calc(100vw - 28px));
    padding: 14px 16px;
    border: 1px solid #e7e9f1;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 18px 40px rgba(15, 18, 27, 0.18);
    color: #273041;
    font-size: 13px;
    line-height: 1.6;
}

.fc-auth-notice strong {
    display: block;
    margin-bottom: 4px;
    font-size: 13px;
}

.fc-auth-notice-links {
    display: flex;
    gap: 10px;
    margin-top: 10px;
}

.fc-auth-notice-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
}

.fc-auth-notice-links a:first-child {
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
}

.fc-auth-notice-links a:last-child {
    border: 1px solid #e7e9f1;
    background: #ffffff;
    color: #495163;
}

.fc-single-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.fc-single-section-head h2 {
    margin: 0;
    font-size: calc(var(--fc-font-size-title, 14px) + 3px);
    color: var(--fc-color-text, #1d1d1f);
    letter-spacing: -0.02em;
}

.fc-single-section-head a {
    color: var(--fc-color-primary, #756dff);
    text-decoration: none;
    font-size: var(--fc-font-size-ui, 12px);
    font-weight: 700;
}

.fc-single-taxonomies {
    display: grid;
    gap: 16px;
}

.fc-single-tax-group {
    display: grid;
    gap: 8px;
    padding-top: 4px;
}

.fc-single-tax-group strong {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6e7685;
}

.fc-single-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.fc-single-chip-list .fc-chip {
    height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    background: #f7f7fb;
    font-size: 10px;
    color: #4a5160;
    text-decoration: none;
    border-color: #e4e7f0;
    font-weight: 600;
}

.fc-single-chip-list a.fc-chip:hover,
.fc-single-chip-list a.fc-chip:focus-visible {
    color: #2f3645;
    background: #f0f2f8;
    text-decoration: none;
}

.fc-single-visual {
    overflow: hidden;
    border-radius: 16px;
    background: #f8f8fb;
    min-height: 260px;
    max-width: 100%;
}

.fc-single-visual img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.fc-single-content {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.fc-single-content > :first-child {
    margin-top: 0;
}

.fc-single-content > :last-child {
    margin-bottom: 0;
}

.fc-single-content p,
.fc-single-content li {
    font-size: 15px;
    line-height: 1.75;
    color: var(--fc-color-text, #1d1d1f);
}

.fc-single-content h2,
.fc-single-content h3,
.fc-single-content h4 {
    margin-top: 1.7em;
    margin-bottom: 0.6em;
    font-size: 1.2em;
    letter-spacing: -0.02em;
    color: var(--fc-color-text, #1d1d1f);
}

.fc-single-content a {
    color: var(--fc-color-primary, #756dff);
}

.fc-single-related {
    max-width: 1080px;
    margin-top: 22px;
    padding: 18px;
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: var(--fc-radius-3xl, 18px);
    background: linear-gradient(180deg, #ffffff 0%, #fcfcfe 100%);
    box-shadow: 0 12px 28px rgba(20, 20, 20, 0.045);
}

.fc-single-related-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.fontchuviet-account-page .fc-app {
    display: block !important;
    grid-template-columns: none;
}

.fontchuviet-account-page .fc-app > .fc-main,
.fontchuviet-account-page .fc-footer {
    grid-column: 1;
}

.fc-app:has(> .fc-account-main) {
    display: block !important;
    grid-template-columns: none;
}

body.fontchuviet-auth-page .fc-app {
    grid-template-columns: minmax(0, 1fr);
}

body.fontchuviet-auth-page .fc-sidebar,
body.fontchuviet-auth-page .fc-mobile-toggle,
body.fontchuviet-auth-page .fc-mobile-overlay {
    display: none;
}

.fc-auth-main {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 34px 18px 46px;
}

body.fontchuviet-auth-page .fc-app > .fc-auth-main {
    grid-column: 1 / -1;
}

.fc-auth-shell .fc-account-panel {
    width: min(100%, 760px);
    padding: 28px;
}

.fc-auth-main .fc-account-panel-head {
    margin-bottom: 16px;
}

.fc-auth-shell {
    width: min(100%, 760px);
    display: grid;
    gap: 10px;
}

.fc-auth-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 4px;
    color: #6b7280;
    font-size: 13px;
    line-height: 1.3;
}

.fc-auth-breadcrumb-home {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #4f46e5;
    text-decoration: none;
    white-space: nowrap;
}

.fc-auth-breadcrumb-home:hover,
.fc-auth-breadcrumb-home:focus-visible {
    text-decoration: underline;
}

.fc-auth-breadcrumb-icon {
    width: 14px;
    height: 14px;
    flex: 0 0 auto;
    display: block;
}

.fc-auth-breadcrumb-separator {
    color: #a3abb8;
}

.fc-auth-breadcrumb-current {
    color: #111827;
    font-weight: 500;
    white-space: nowrap;
}

@media (max-width: 520px) {
    .fc-auth-shell {
        gap: 10px;
    }

    .fc-auth-breadcrumb {
        padding: 0 2px;
        font-size: 12px;
        flex-wrap: wrap;
    }
}

.fc-auth-main .fc-generic-page-content {
    display: grid;
    gap: 14px;
    justify-items: center;
}

.fc-auth-google-login {
    display: flex;
    justify-content: center;
    width: 100%;
}

.fc-auth-google-login > * {
    width: 100%;
    max-width: 420px;
}

.fc-auth-divider {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #798297;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    width: min(100%, 640px);
}

.fc-auth-divider::before,
.fc-auth-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: #e7eaf3;
}

.fc-auth-divider::before {
    margin-right: 10px;
}

.fc-auth-divider::after {
    margin-left: 10px;
}

.fc-auth-main form {
    display: grid;
    gap: 10px;
    width: min(100%, 460px);
}

.fc-auth-main .fc-auth-links,
.fc-auth-main .fc-auth-admin-warning,
.fc-auth-main .fc-generic-page-content > p {
    width: min(100%, 460px);
}

.fc-auth-main form label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #3a4252;
}

.fc-auth-main input[type="text"],
.fc-auth-main input[type="email"],
.fc-auth-main input[type="password"] {
    width: 100%;
    min-height: 44px;
    padding: 10px 12px;
    border: 1px solid #dfe5ef;
    border-radius: 12px;
    background: #ffffff;
    font-size: 14px;
}

.fc-auth-main .fc-password-input-wrap {
    position: relative;
    display: block;
    width: 100%;
}

.fc-auth-main .fc-password-input-wrap input[type="password"],
.fc-auth-main .fc-password-input-wrap input[type="text"] {
    padding-right: 44px;
}

.fc-auth-main .fc-password-toggle {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border: 0 !important;
    border-radius: 10px;
    background: transparent !important;
    box-shadow: none !important;
    appearance: none;
    color: #5c6475;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.fc-auth-main .fc-password-toggle:hover {
    background: #f1f3f8;
    color: #2e3442;
}

.fc-auth-main .fc-password-toggle:focus-visible {
    outline: 2px solid #98a6ff;
    outline-offset: 1px;
}

.fc-auth-main .fc-password-toggle-eye {
    font-size: 16px;
}

.fc-auth-main .fc-password-toggle-icon {
    width: 18px;
    height: 18px;
    display: block;
}

.fc-auth-main input[type="text"]:focus,
.fc-auth-main input[type="email"]:focus,
.fc-auth-main input[type="password"]:focus {
    border-color: #98a6ff;
    box-shadow: 0 0 0 3px rgba(117, 109, 255, 0.15);
    outline: none;
}

.fc-auth-main .login-remember label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
    font-weight: 500;
}

.fc-auth-main input[type="submit"],
.fc-auth-main .button.button-primary,
.fc-auth-main a.button.button-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 16px;
    border: 1px solid #756dff;
    border-radius: 12px;
    background: #756dff;
    color: #ffffff;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}

.fc-auth-main .button.button-primary:hover,
.fc-auth-main a.button.button-primary:hover,
.fc-auth-main input[type="submit"]:hover {
    background: #635bdc;
    border-color: #635bdc;
}

.fc-auth-links {
    margin: 0;
    font-size: 14px;
    line-height: 1.8;
}

.fc-auth-admin-warning {
    margin: 0;
    padding: 12px 14px;
    border: 1px solid #f1d8a1;
    border-radius: 12px;
    background: #fff7e6;
    color: #624800;
    font-size: 13px;
    line-height: 1.6;
}

.fc-auth-admin-warning a {
    color: #7a4d00;
    font-weight: 700;
}

.fc-auth-links a {
    color: #2f4cff;
    text-decoration: none;
    font-weight: 600;
}

.fc-auth-links a:hover {
    text-decoration: underline;
}

@media (max-width: 767px) {
    .fc-auth-main {
        padding: 20px 10px 26px;
    }

    .fc-auth-main .fc-account-panel {
        padding: 18px;
    }
}

.fontchuviet-account-page .fc-main,
.fontchuviet-account-page .fc-main * {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.fc-account-main {
    padding-top: 92px;
    padding-left: 0;
    padding-right: 0;
    width: 100%;
    max-width: 100%;
    justify-self: stretch;
}

.fc-app > .fc-account-main {
    display: block;
    min-width: 0;
}

.fc-account-main > .fc-single-topbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 30;
    margin-bottom: 0;
    padding-top: 14px;
    padding-left: 37px;
    padding-right: 37px;
    padding-bottom: 16px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

body.admin-bar .fc-account-main > .fc-single-topbar {
    top: 32px;
}

.fc-account-shell {
    width: 100%;
    max-width: 1360px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 22px;
    padding-right: 22px;
}

.fc-account-main .fc-account-layout,
.fontchuviet-account-page .fc-account-layout {
    width: 100%;
    max-width: none;
    margin: 0;
}

.fc-account-layout {
    display: grid;
    grid-template-columns: minmax(190px, 220px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    min-width: 0;
}

.fc-account-content-stack {
    min-width: 0;
}

.fc-account-sidebar-card,
.fc-account-panel {
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: var(--fc-radius-3xl, 18px);
    background: linear-gradient(180deg, #ffffff 0%, #fcfcfe 100%);
    box-shadow: 0 12px 28px rgba(20, 20, 20, 0.045);
}

.fc-account-sidebar-card {
    position: sticky;
    top: 24px;
    padding: 18px;
}

.fc-account-sidebar-title {
    margin-bottom: 12px;
    font-size: 15px;
    font-weight: 800;
    color: #1f2430;
}

.fc-account-nav {
    display: grid;
    gap: 8px;
}

.fc-account-nav-item {
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 0 14px;
    border-radius: 14px;
    color: #394150;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.fc-account-nav-item:hover,
.fc-account-nav-item:focus-visible {
    background: rgba(117, 109, 255, 0.08);
    box-shadow: 0 8px 18px rgba(117, 109, 255, 0.10);
    color: #1f2430;
    transform: translateX(2px);
}

.fc-account-nav-item.is-active {
    background: linear-gradient(180deg, rgba(117, 109, 255, 0.12) 0%, rgba(138, 120, 255, 0.18) 100%);
    box-shadow: inset 0 0 0 1px rgba(117, 109, 255, 0.16);
    color: var(--fc-color-primary, #756dff);
    font-weight: 600;
}

.fc-account-nav-item.is-active:hover,
.fc-account-nav-item.is-active:focus-visible {
    background: linear-gradient(180deg, rgba(117, 109, 255, 0.12) 0%, rgba(138, 120, 255, 0.18) 100%);
    box-shadow: inset 0 0 0 1px rgba(117, 109, 255, 0.16);
    color: var(--fc-color-primary, #756dff);
    transform: translateX(0);
}

.fc-account-content-stack {
    display: grid;
    gap: 18px;
}

.fc-account-panel {
    padding: 24px 26px;
}

.fc-account-panel-head {
    display: grid;
    gap: 6px;
    margin-bottom: 18px;
}

.fc-account-panel-head h1,
.fc-account-panel-head h2 {
    margin: 0;
    font-size: clamp(20px, 2vw, 26px);
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: #1d1d1f;
}

.fc-account-panel-head h2 {
    font-size: clamp(18px, 1.8vw, 24px);
}

.fc-account-panel-head p {
    margin: 0;
    font-size: 14px;
    line-height: 1.7;
    color: #656c7b;
}

.fc-account-saved-panel .fc-account-panel-head h1 {
    order: 1;
}

.fc-account-saved-panel .fc-account-panel-head p {
    display: none;
}

.fc-account-saved-panel .fc-account-panel-head .fc-account-saved-total {
    display: block;
    order: 2;
}

.fc-account-summary-list {
    display: grid;
}

.fc-account-summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 0;
    border-bottom: 1px solid rgba(231, 234, 242, 0.9);
}

.fc-account-summary-row:first-child {
    padding-top: 0;
}

.fc-account-summary-row:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.fc-account-summary-row span {
    font-size: 14px;
    color: #6a7283;
}

.fc-account-summary-row strong {
    font-size: 16px;
    font-weight: 600;
    color: var(--fc-color-text-soft, #62626a);
    text-align: right;
}

.fc-account-summary-row strong.is-highlight {
    color: var(--fc-color-primary, #756dff);
}

.fc-account-package-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 18px;
}

.fc-account-saved-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.fc-account-package-alert {
    margin-bottom: 16px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid #dfe5f2;
    background: #f8fbff;
}

.fc-account-package-alert strong {
    display: block;
    margin: 0 0 4px;
    font-size: 14px;
    line-height: 1.4;
    color: #1d1d1f;
}

.fc-account-package-alert p {
    margin: 0;
    font-size: 13px;
    line-height: 1.6;
    color: #4f586b;
}

.fc-account-package-alert.is-success {
    border-color: #b7e4c7;
    background: #edf9f1;
}

.fc-account-package-alert.is-pending {
    border-color: #ffe2aa;
    background: #fff8ea;
}

.fc-account-package-alert.is-error {
    border-color: #f2c2c2;
    background: #fff0f0;
}

.fc-account-package-alert-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: #1d1d1f;
    color: #ffffff;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.fc-account-package-alert-link:hover,
.fc-account-package-alert-link:focus-visible {
    background: #111114;
    box-shadow: 0 10px 20px rgba(29, 29, 31, 0.18);
    transform: translateY(-1px);
}

.fc-account-package-card {
    display: grid;
    position: relative;
    gap: 16px;
    align-content: start;
    padding: 20px 20px 22px;
    border: 1px solid rgba(228, 231, 240, 0.95);
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #fcfcfe 100%);
    box-shadow: 0 10px 24px rgba(20, 20, 20, 0.045);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.fc-account-package-card:hover,
.fc-account-package-card:focus-within {
    transform: translateY(-2px);
    box-shadow: 0 16px 30px rgba(20, 20, 20, 0.08);
}

.fc-account-package-card.tone-primary {
    border-color: rgba(117, 109, 255, 0.22);
    box-shadow: 0 10px 24px rgba(117, 109, 255, 0.05);
}

.fc-account-package-card.tone-accent {
    border-color: rgba(117, 109, 255, 0.18);
    box-shadow: 0 10px 24px rgba(117, 109, 255, 0.04);
}

.fc-account-package-card.is-best-value {
    border-color: rgba(255, 152, 0, 0.3);
    background: linear-gradient(180deg, #fff8ef 0%, #fff2dc 100%);
    box-shadow: 0 14px 30px rgba(255, 152, 0, 0.14);
}

.fc-account-package-badge {
    position: absolute;
    top: -12px;
    right: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(117, 109, 255, 0.18);
    background: #ffffff;
    color: var(--fc-color-primary, #756dff);
    font-size: 11px;
    font-weight: 700;
    box-shadow: 0 4px 12px rgba(20, 20, 20, 0.05);
}

.fc-account-package-card.tone-accent .fc-account-package-badge {
    border-color: rgba(117, 109, 255, 0.16);
    background: #ffffff;
    color: var(--fc-color-primary, #756dff);
    box-shadow: 0 4px 12px rgba(20, 20, 20, 0.05);
}

.fc-account-package-badge.is-best-value {
    border-color: rgba(255, 152, 0, 0.2);
    background: linear-gradient(135deg, #ffb74d 0%, #ff9800 100%);
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(255, 152, 0, 0.22);
}

.fc-account-package-head {
    display: grid;
    justify-items: center;
    gap: 8px;
    padding-top: 2px;
    text-align: center;
}

.fc-account-package-eyebrow {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #8b92a3;
}

.fc-account-package-card h3 {
    margin: 0;
    font-size: clamp(16px, 1.55vw, 21px);
    line-height: 1.12;
    color: #1d1d1f;
}

.fc-account-package-price {
    font-size: clamp(20px, 1.95vw, 28px);
    font-weight: 800;
    color: var(--fc-color-primary, #756dff);
}

.fc-account-package-card.tone-neutral .fc-account-package-price {
    color: var(--fc-color-text, #1d1d1f);
}

.fc-account-package-card.tone-accent .fc-account-package-price {
    color: var(--fc-color-primary, #756dff);
}

.fc-account-package-card.is-best-value .fc-account-package-price {
    color: #ff9800;
}

.fc-account-package-note {
    margin: 0;
    font-size: 13px;
    line-height: 1.5;
    color: #727b8d;
}

.fc-account-package-summary-box {
    display: grid;
    gap: 6px;
    justify-items: center;
    padding: 16px 14px;
    border: 1px solid rgba(230, 233, 240, 0.95);
    border-radius: 16px;
    background: #fbfbfd;
    text-align: center;
}

.fc-account-package-card.tone-primary .fc-account-package-summary-box {
    border-color: rgba(117, 109, 255, 0.18);
    background: linear-gradient(180deg, rgba(117, 109, 255, 0.08) 0%, rgba(138, 120, 255, 0.04) 100%);
}

.fc-account-package-card.tone-accent .fc-account-package-summary-box {
    border-color: rgba(117, 109, 255, 0.14);
    background: linear-gradient(180deg, rgba(117, 109, 255, 0.06) 0%, rgba(138, 120, 255, 0.03) 100%);
}

.fc-account-package-card.is-best-value .fc-account-package-summary-box {
    border-color: rgba(255, 152, 0, 0.16);
    background: linear-gradient(180deg, rgba(255, 152, 0, 0.14) 0%, rgba(255, 248, 239, 0.98) 100%);
}

.fc-account-package-summary-label {
    font-size: 12px;
    font-weight: 600;
    color: #70788a;
}

.fc-account-package-summary-value {
    font-size: clamp(15px, 1.5vw, 20px);
    font-weight: 700;
    line-height: 1.15;
    color: var(--fc-color-primary, #756dff);
}

.fc-account-package-summary-value.is-compact {
    font-size: clamp(13px, 1.25vw, 17px);
    line-height: 1.22;
}

.fc-account-package-card.tone-neutral .fc-account-package-summary-value {
    color: var(--fc-color-text, #1d1d1f);
}

.fc-account-package-card.tone-accent .fc-account-package-summary-value {
    color: var(--fc-color-primary, #756dff);
}

.fc-account-package-card.is-best-value .fc-account-package-summary-value {
    color: #ff9800;
}

.fc-account-package-summary-caption {
    font-size: 12px;
    line-height: 1.5;
    color: #8a92a3;
}

.fc-account-package-features {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.fc-account-package-features li {
    position: relative;
    padding-left: 20px;
    font-size: 13px;
    line-height: 1.6;
    color: #394150;
}

.fc-account-package-features li::before {
    content: "✓";
    position: absolute;
    top: 0;
    left: 0;
    color: var(--fc-color-primary, #756dff);
    font-size: 13px;
    font-weight: 700;
}

.fc-account-package-features li.is-disabled::before {
    content: "×";
    color: #9aa1b1;
}

.fc-account-package-features li.is-disabled {
    color: #6f7788;
}

.fc-account-package-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 14px;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    box-shadow: 0 10px 22px rgba(117, 109, 255, 0.14);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.fc-account-package-button:hover,
.fc-account-package-button:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(117, 109, 255, 0.22);
    filter: brightness(1.02);
}

.fc-account-package-card.tone-neutral .fc-account-package-button {
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    box-shadow: 0 10px 22px rgba(117, 109, 255, 0.14);
}

.fc-account-package-card.tone-accent .fc-account-package-button {
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    box-shadow: 0 10px 22px rgba(117, 109, 255, 0.14);
}

.fc-account-package-card.is-best-value .fc-account-package-button {
    background: linear-gradient(90deg, #ffb74d 0%, #ff9800 100%);
    box-shadow: 0 12px 24px rgba(255, 152, 0, 0.22);
}

.fc-account-note-box {
    padding: 18px 20px;
    border-radius: 16px;
    background: #f7f9fc;
}

.fc-account-note-box p,
.fc-account-note-box li {
    font-size: 15px;
    line-height: 1.85;
    color: #2f3645;
}

.fc-account-note-box > :first-child {
    margin-top: 0;
}

.fc-account-note-box > :last-child {
    margin-bottom: 0;
}

.fc-account-note-box ul {
    margin: 0;
    padding-left: 18px;
}

.fc-account-note-box h3 {
    margin: 18px 0 10px;
    font-size: 28px;
    line-height: 1.1;
    color: #1d1d1f;
}

.fc-account-empty {
    padding: 22px 18px;
    border: 1px dashed #d8dcea;
    border-radius: 16px;
    background: #fbfcff;
    color: #667085;
    font-size: 14px;
    text-align: center;
}

.fc-account-orders-table-wrap {
    overflow-x: auto;
}

.fc-account-orders-table {
    width: 100%;
    border-collapse: collapse;
}

.fc-account-orders-table th,
.fc-account-orders-table td {
    padding: 14px 12px;
    border-bottom: 1px solid rgba(231, 234, 242, 0.9);
    font-size: 14px;
    text-align: left;
    color: #2f3645;
}

.fc-account-orders-table th {
    font-size: 12px;
    font-weight: 800;
    color: #7a8293;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.fc-account-order-grant {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid #d9deea;
    background: #f4f6fb;
    color: #495163;
    font-size: 11px;
    font-weight: 700;
    white-space: nowrap;
}

.fc-account-order-grant.is-success {
    border-color: #b7e4c7;
    background: #edf9f1;
    color: #23643a;
}

.fc-account-order-grant.is-pending {
    border-color: #ffe2aa;
    background: #fff8ea;
    color: #9a5b00;
}

.fc-account-order-grant.is-error {
    border-color: #f2c2c2;
    background: #fff0f0;
    color: #9f2f2f;
}

/* Generic page (Page post type) — centred narrow layout */
.fc-generic-page-wrap {
    max-width: 760px;
    margin: 0 auto;
    display: grid;
    gap: 14px;
}

.fc-generic-page-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px 7px 10px;
    border-radius: 999px;
    border: 1px solid var(--fc-color-border, #ececf2);
    background: var(--fc-color-surface, #ffffff);
    color: var(--fc-color-text-soft, #62626a);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    width: fit-content;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.fc-generic-page-back:hover {
    background: #f4f5fb;
    color: var(--fc-color-text, #1d1d1f);
    border-color: #d4d6e4;
}

.fc-generic-page-content {
    line-height: 1.75;
    font-size: 15px;
    color: var(--fc-color-text, #1d1d1f);
}

.fc-generic-page-content h2,
.fc-generic-page-content h3,
.fc-generic-page-content h4 {
    margin: 1.4em 0 0.5em;
    line-height: 1.25;
    letter-spacing: -0.02em;
    color: #1d1d1f;
}

.fc-generic-page-content h2 { font-size: clamp(18px, 1.8vw, 22px); }
.fc-generic-page-content h3 { font-size: clamp(15px, 1.5vw, 18px); }

.fc-generic-page-content p {
    margin: 0 0 1em;
}

.fc-generic-page-content ul,
.fc-generic-page-content ol {
    margin: 0 0 1em 1.4em;
    padding: 0;
}

.fc-generic-page-content li {
    margin-bottom: 0.35em;
}

.fc-generic-page .woocommerce .button,
.fc-generic-page .woocommerce a.button,
.fc-generic-page .woocommerce button.button,
.fc-generic-page .woocommerce input.button,
.fc-generic-page .woocommerce #respond input#submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid transparent;
    border-radius: 12px;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 10px 20px rgba(117, 109, 255, 0.16);
}

.fc-generic-page .woocommerce .button:hover,
.fc-generic-page .woocommerce .button:focus-visible,
.fc-generic-page .woocommerce a.button:hover,
.fc-generic-page .woocommerce a.button:focus-visible,
.fc-generic-page .woocommerce button.button:hover,
.fc-generic-page .woocommerce button.button:focus-visible,
.fc-generic-page .woocommerce input.button:hover,
.fc-generic-page .woocommerce input.button:focus-visible {
    opacity: 0.94;
}

.fc-generic-page .woocommerce .button.alt,
.fc-generic-page .woocommerce a.button.alt,
.fc-generic-page .woocommerce button.button.alt,
.fc-generic-page .woocommerce input.button.alt,
.fc-generic-page .woocommerce a.checkout-button {
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
}

.fc-generic-page .wc-block-components-button.wc-block-cart__submit-button,
.fc-generic-page a.wc-block-components-button.wp-element-button.wc-block-cart__submit-button.contained {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 46px;
    padding: 0 18px !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%) !important;
    color: #ffffff !important;
    text-decoration: none !important;
    box-shadow: 0 10px 20px rgba(117, 109, 255, 0.16);
}

.fc-generic-page .wc-block-components-button.wc-block-cart__submit-button:hover,
.fc-generic-page .wc-block-components-button.wc-block-cart__submit-button:focus-visible,
.fc-generic-page a.wc-block-components-button.wp-element-button.wc-block-cart__submit-button.contained:hover,
.fc-generic-page a.wc-block-components-button.wp-element-button.wc-block-cart__submit-button.contained:focus-visible {
    opacity: 0.94;
}

.fc-generic-page .wc-block-components-button.wc-block-cart__submit-button .wc-block-components-button__text,
.fc-generic-page a.wc-block-components-button.wp-element-button.wc-block-cart__submit-button.contained .wc-block-components-button__text {
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
}

.fc-generic-page .woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
    width: 100%;
    margin-top: 12px;
}

.fc-generic-page .woocommerce .quantity .qty {
    min-height: 40px;
    border: 1px solid #d8ddea;
    border-radius: 10px;
    padding: 0 10px;
}

.fc-generic-page .woocommerce table.shop_table {
    border: 1px solid #e7eaf2;
    border-radius: 16px;
    overflow: hidden;
}

.fc-generic-page .woocommerce .cart_totals,
.fc-generic-page .woocommerce .woocommerce-checkout-review-order {
    border: 1px solid #e7eaf2;
    border-radius: 16px;
    padding: 14px 14px 8px;
    background: #ffffff;
}

.fc-generic-page .fc-woo-fixed-qty {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    min-height: 40px;
    padding: 0 10px;
    border: 1px solid #d8ddea;
    border-radius: 10px;
    background: #f8f9fc;
    font-size: 13px;
    font-weight: 700;
    color: #2f3645;
}

.fc-collection-page {
    padding-right: 28px;
}

.fc-collection-hero,
.fc-collection-detail-head {
    margin-bottom: 18px;
    padding: 22px;
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: var(--fc-radius-3xl, 18px);
    background:
        radial-gradient(circle at top right, rgba(117, 109, 255, 0.08), transparent 28%),
        linear-gradient(180deg, #ffffff 0%, #fcfcfe 100%);
    box-shadow: 0 12px 28px rgba(20, 20, 20, 0.045);
}

.fc-collection-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
    gap: 18px;
    align-items: center;
}

.fc-collection-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(250px, 0.8fr);
    gap: 18px;
    align-items: start;
}

.fc-collection-hero-copy {
    display: grid;
    gap: 10px;
}

.fc-collection-eyebrow {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8b92a3;
}

.fc-collection-hero-copy h1 {
    margin: 0;
    font-size: clamp(24px, 3vw, 34px);
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: #1d1d1f;
}

.fc-collection-hero-copy p {
    margin: 0;
    max-width: 720px;
    font-size: 14px;
    line-height: 1.7;
    color: #656c7b;
}

.fc-collection-hero-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.fc-collection-toolbar {
    margin-bottom: 16px;
}

.fc-collection-search-form {
    display: flex;
    align-items: center;
    gap: 12px;
}

.fc-collection-toolbar .fc-search {
    width: 100%;
    max-width: 420px;
}

.fc-collection-stat {
    display: grid;
    gap: 6px;
    padding: 14px 16px;
    border: 1px solid rgba(232, 234, 241, 0.95);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.82);
}

.fc-collection-stat span {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #8b92a3;
}

.fc-collection-stat strong {
    font-size: 22px;
    line-height: 1;
    color: #1f2430;
}

.fc-collection-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.fc-collection-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 18px;
    border: 1px solid rgba(236, 236, 242, 0.85);
    border-radius: var(--fc-radius-3xl, 18px);
    background: linear-gradient(180deg, #ffffff 0%, #fcfcfe 100%);
    box-shadow: 0 12px 28px rgba(20, 20, 20, 0.045);
}

.fc-collection-card-cover {
    position: relative;
    overflow: hidden;
    min-height: 210px;
    border-radius: 16px;
    background: linear-gradient(135deg, #f4f5fb 0%, #eef1f8 100%);
    text-decoration: none;
}

.fc-collection-card-preview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(2, minmax(0, 1fr));
    gap: 6px;
    width: 100%;
    height: 100%;
    min-height: 210px;
    padding: 6px;
}

.fc-collection-card-preview-tile {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, #eef1f8 0%, #f8f9fd 100%);
}

.fc-collection-card-preview-tile img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fc-collection-card-preview-tile.is-empty {
    background: linear-gradient(135deg, #f1f3fa 0%, #e9edf8 100%);
}

.fc-collection-card-placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: linear-gradient(135deg, #756dff 0%, #8a78ff 100%);
    color: #ffffff;
    box-shadow: 0 16px 36px rgba(117, 109, 255, 0.24);
}

.fc-collection-card-placeholder svg {
    width: 26px;
    height: 26px;
    stroke: #ffffff;
}

.fc-collection-card-count {
    position: absolute;
    left: 12px;
    bottom: 12px;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(18, 20, 28, 0.72);
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    backdrop-filter: blur(8px);
}

.fc-collection-card-body {
    display: grid;
    align-content: start;
    gap: 8px;
}

.fc-collection-card-meta {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8b92a3;
}

.fc-collection-card-body h2 {
    margin: 0;
    font-size: 20px;
    line-height: 1.1;
}

.fc-collection-card-body h2 a {
    color: #1d1d1f;
    text-decoration: none;
}

.fc-collection-card-body p {
    margin: 0;
    font-size: 13px;
    line-height: 1.7;
    color: #656c7b;
    min-height: 44px;
}

.fc-collection-card-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 16px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--fc-color-primary, #756dff) 0%, var(--fc-color-primary-soft, #8a78ff) 100%);
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
    justify-self: start;
}

.fc-collection-card-link:hover,
.fc-collection-card-link:focus-visible {
    opacity: 0.92;
}

.fc-collection-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    font-size: 11px;
    font-weight: 600;
    color: #6b7280;
}

.fc-collection-breadcrumb a {
    color: #4f46e5;
    text-decoration: none;
}

.fc-collection-detail-side {
    display: grid;
    gap: 12px;
}

.fc-collection-sort-wrap {
    width: 100%;
}

.fc-collection-sort-wrap .fc-control {
    width: 100%;
}

.fc-collection-font-grid {
    margin-bottom: 20px;
}

.fc-collection-empty {
    padding: 24px 18px;
    border: 1px dashed #d8dcea;
    border-radius: 18px;
    background: #fbfcff;
    color: #667085;
    font-size: 14px;
    text-align: center;
}

/* Blog Page Styles - 3 Column Layout */
.fc-blog-page {
    width: 100%;
}

.fc-blog-container {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 20px;
    padding: 20px 0;
    align-items: flex-start;
    width: 100%;
    box-sizing: border-box;
}

.fc-blog-sidebar-left {
    flex: 0 0 220px;
    width: 220px;
    align-self: flex-start;
    position: sticky;
    top: 20px;
}

.fc-blog-content {
    flex: 1 1 0;
    min-width: 0;
    overflow: hidden;
}

.fc-blog-sidebar-right {
    flex: 0 0 220px;
    width: 220px;
    align-self: flex-start;
    position: sticky;
    top: 20px;
}

.fc-blog-ads {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.fc-blog-header {
    margin-bottom: 30px;
}

.fc-blog-header h1 {
    font-size: 32px;
    font-weight: 700;
    margin: 0 0 12px 0;
    color: #121218;
}

.fc-blog-header p {
    font-size: 16px;
    color: #5b5b6e;
    margin: 0;
}

/* Blog Posts Grid */
.fc-blog-main {
    min-width: 0;
}

.fc-blog-layout {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: flex-start;
    width: 100%;
    box-sizing: border-box;
}

.fc-blog-primary {
    flex: 1 1 0;
    min-width: 0;
}

.fc-blog-aside {
    position: sticky;
    top: 20px;
    flex: 0 0 300px;
    min-width: 0;
    max-width: 300px;
    overflow: hidden;
    align-self: start;
    box-sizing: border-box;
}

.fc-blog-aside > * {
    max-width: 100%;
    overflow: hidden;
}

.fc-blog-ad-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
    overflow: hidden;
}

.fc-blog-primary .fc-toolbar {
    grid-template-columns: minmax(0, 1fr);
}

.fc-blog-primary .fc-search {
    width: 100%;
}

.fc-blog-primary .fc-suggested {
    margin-bottom: 18px;
}

.fc-blog-posts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    width: 100%;
    margin-bottom: 24px;
}

.fc-blog-header-block {
    margin-bottom: 10px;
}

.fc-blog-header-title-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
}

.fc-blog-home-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid #e7e8ee;
    border-radius: 12px;
    background: #ffffff;
    color: #4b5160;
    text-decoration: none;
    box-shadow: 0 8px 20px rgba(20, 20, 20, 0.04);
    transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.fc-blog-home-button:hover,
.fc-blog-home-button:focus-visible {
    border-color: rgba(117, 109, 255, 0.28);
    background: #f8f7ff;
    color: var(--fc-color-primary, #756dff);
    transform: translateY(-1px);
}

.fc-blog-home-button svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.fc-blog-topbar-home {
    display: none;
}

.fc-blog-page-title {
    font-size: 32px;
    line-height: 1.15;
    letter-spacing: -0.02em;
}

.fc-blog-page-description {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 38px;
    margin-bottom: 18px;
    padding: 10px 14px;
    border: 1px solid #e7e8ee;
    border-radius: 12px;
    background: #f3f4f7;
    color: #5f6472;
    font-size: 13px;
    line-height: 1.5;
}

.fc-blog-single-main {
    min-width: 0;
}

.fc-blog-single-layout {
    display: grid;
    grid-template-columns: minmax(0, 800px) minmax(380px, 1fr);
    align-items: start;
}

.fc-blog-single-panel {
    max-width: 800px;
}

.fc-blog-single-aside {
    position: sticky;
    top: 20px;
    max-width: none;
    overflow: visible;
}

.fc-blog-related-card {
    border: 1px solid #ededf2;
    border-radius: 12px;
    padding: 14px;
    background: #ffffff;
}

.fc-blog-related-title {
    margin: 0 0 12px;
    font-size: 16px;
    line-height: 1.3;
    color: #1d1d1f;
}

.fc-blog-related-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.fc-blog-related-item {
    display: block;
    padding: 10px;
    border: 1px solid #eef0f4;
    border-radius: 10px;
    background: #fbfbfd;
}

.fc-blog-related-thumb-link {
    display: block;
    width: 100%;
    min-width: 0;
    margin-bottom: 10px;
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    overflow: hidden;
    background: #f5f5f7;
}

.fc-blog-related-thumb {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fc-blog-related-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.fc-blog-related-post-title {
    color: #1d1d1f;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;
}

.fc-blog-related-post-title:hover,
.fc-blog-related-post-title:focus-visible {
    color: var(--fc-color-primary, #756dff);
}

.fc-blog-related-meta {
    color: #8a8a9e;
    font-size: 12px;
}

.fc-blog-single-head {
    gap: 10px;
}

.fc-blog-single-back {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    color: var(--fc-color-primary, #756dff);
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
}

.fc-blog-single-back:hover {
    text-decoration: underline;
}

.fc-blog-single-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #8a8a9e;
}

.fc-blog-single-thumbnail {
    margin-bottom: 20px;
    border-radius: 16px;
    overflow: hidden;
}

.fc-blog-single-thumbnail img {
    display: block;
    width: 100%;
    height: auto;
}

.fc-blog-single-content {
    color: #313543;
    font-size: 15px;
    line-height: 1.8;
}

.fc-blog-single-content h2,
.fc-blog-single-content h3,
.fc-blog-single-content h4 {
    color: #1d1d1f;
    line-height: 1.25;
}

.fc-blog-single-content p:first-child {
    margin-top: 0;
}

.fc-blog-single-footer {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid rgba(231, 234, 242, 0.9);
}

.fc-blog-single-taxonomy a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    margin-right: 8px;
    margin-bottom: 8px;
    padding: 0 12px;
    border-radius: 999px;
    background: #f3eeff;
    color: var(--fc-color-primary, #756dff);
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
}

.fc-blog-single-taxonomy a:hover {
    background: #e9e0ff;
}

.fc-blog-item {
    background: #ffffff;
    border: 1px solid #ededf2;
    border-radius: 12px;
    overflow: hidden;
    transition: all 240ms ease;
    display: flex;
    flex-direction: column;
}

.fc-blog-item:hover {
    border-color: #d4d2e7;
    box-shadow: 0 8px 24px rgba(20, 20, 20, 0.08);
    transform: translateY(-2px);
}

.fc-blog-item-image-link {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #f5f5f7;
}

.fc-blog-item-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 320ms ease;
}

.fc-blog-item:hover .fc-blog-item-thumb {
    transform: scale(1.04);
}

.fc-blog-item-body {
    padding: 16px 18px 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}

.fc-blog-item-cats {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.fc-blog-item-cat {
    color: #756dff;
    text-decoration: none;
    transition: color 240ms ease;
}

.fc-blog-item-cat:hover {
    color: #5e4dd4;
}

.fc-blog-item-title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #121218;
    line-height: 1.45;
}

.fc-blog-item-title a {
    color: inherit;
    text-decoration: none;
    transition: color 240ms ease;
}

.fc-blog-item-title a:hover {
    color: #756dff;
}

.fc-blog-item-excerpt {
    font-size: 13px;
    color: #5b5b6e;
    line-height: 1.6;
    margin: 0;
    display: -webkit-box;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.fc-blog-item-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #8a8a9e;
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid #f0f0f5;
}

/* No Posts Message */
.fc-no-posts {
    text-align: center;
    padding: 40px 20px;
    color: #8a8a9e;
    font-size: 16px;
}

/* Pagination */
.fc-blog-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    margin-top: 32px;
    padding-top: 32px;
    border-top: 1px solid #ededf2;
}

.fc-blog-pagination .page-numbers {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 8px;
    border: 1px solid #ededf2;
    border-radius: 8px;
    font-size: 14px;
    color: #121218;
    text-decoration: none;
    transition: all 240ms ease;
}

.fc-blog-pagination .page-numbers:hover {
    border-color: #756dff;
    color: #756dff;
}

.fc-blog-pagination .page-numbers.current {
    background: #756dff;
    color: #ffffff;
    border-color: #756dff;
}

.fc-blog-pagination .prev,
.fc-blog-pagination .next {
    padding: 0 12px;
}

/* Filter Sidebar */
.fc-blog-filter {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.fc-filter-section {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.fc-filter-section h3 {
    margin: 0 0 8px 0;
    font-size: 14px;
    font-weight: 600;
    color: #121218;
}

.fc-search-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.fc-search-form .fc-search-input {
    padding: 10px 12px;
    border: 1px solid #ededf2;
    border-radius: 8px;
    font-size: 14px;
    color: #121218;
    transition: border-color 240ms ease;
}

.fc-search-form .fc-search-input:focus {
    outline: none;
    border-color: #756dff;
    box-shadow: 0 0 0 3px rgba(117, 109, 255, 0.1);
}

.fc-search-btn {
    padding: 10px 16px;
    background: #756dff;
    color: #ffffff;
    border: 0;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background 240ms ease;
}

.fc-search-btn:hover {
    background: #5e4dd4;
}

/* Categories List */
.fc-categories-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.fc-category-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 240ms ease;
    text-decoration: none;
    color: #121218;
    font-size: 14px;
}

.fc-category-item:hover,
.fc-category-item.active {
    background: #f0efff;
    color: #756dff;
}

.fc-filter-submit {
    padding: 10px 16px;
    background: #756dff;
    color: #ffffff;
    border: 0;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background 240ms ease;
    margin-top: 8px;
}

.fc-filter-submit:hover {
    background: #5e4dd4;
}

/* Tags Cloud */
.fc-tags-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.fc-tag-item {
    display: inline-block;
    padding: 6px 12px;
    background: #f5f5f7;
    border-radius: 20px;
    font-size: 13px;
    color: #5b5b6e;
    text-decoration: none;
    transition: all 240ms ease;
}

.fc-tag-item:hover,
.fc-tag-item.active {
    background: #756dff;
    color: #ffffff;
}

.fc-clear-filters {
    display: inline-block;
    padding: 8px 12px;
    background: #fef2f0;
    color: #d9534f;
    border: 1px solid #f5e5e2;
    border-radius: 6px;
    font-size: 13px;
    text-decoration: none;
    transition: all 240ms ease;
}

.fc-clear-filters:hover {
    background: #f5e5e2;
    color: #c1453a;
}

/* Ads Sidebar */
.fc-ads-placeholder {
    height: 500px;
    padding: 24px;
    background: #f5f5f7;
    border: 1px dashed #ededf2;
    border-radius: 12px;
    text-align: center;
    color: #8a8a9e;
    font-size: 14px;
    width: 100%;
    box-sizing: border-box;
}

/* Responsive Design */
@media (max-width: 1400px) {
    .fc-blog-sidebar-left {
        flex: 0 0 200px;
        width: 200px;
    }
    .fc-blog-sidebar-right {
        flex: 0 0 220px;
        width: 220px;
    }
}

@media (max-width: 1200px) {
    .fc-blog-layout {
        gap: 20px;
    }

    .fc-blog-primary {
        flex: 1 1 0;
        min-width: 0;
    }

    .fc-blog-aside {
        flex: 0 0 260px;
        max-width: 260px;
        overflow: hidden;
    }

    .fc-blog-single-layout {
        grid-template-columns: minmax(0, 720px) minmax(320px, 1fr);
    }

    .fc-blog-single-panel {
        max-width: 720px;
    }

    .fc-blog-single-aside {
        max-width: none;
        overflow: visible;
    }

    .fc-blog-related-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fc-blog-sidebar-left {
        display: none;
    }
    .fc-blog-sidebar-right {
        flex: 0 0 240px;
        width: 240px;
    }
    .fc-blog-posts {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .fc-blog-main {
        display: block;
        overflow: visible;
    }

    .fc-blog-layout {
        display: block;
        flex-direction: column;
        width: 100%;
        overflow: visible;
    }

    .fc-blog-primary {
        display: block;
        width: 100%;
        overflow: visible;
    }

    .fc-blog-aside {
        position: static;
        display: block;
        width: 100%;
        max-width: 100%;
        margin-top: 24px;
        overflow: visible;
    }

    .fc-blog-single-layout {
        grid-template-columns: 1fr;
    }

    .fc-blog-single-panel {
        max-width: 100%;
    }

    .fc-blog-container {
        flex-direction: column;
        gap: 16px;
    }

    .fc-blog-inner {
        flex-direction: column;
    }

    .fc-blog-sidebar-left,
    .fc-blog-sidebar-right {
        display: none;
    }

    .fc-blog-header h1 {
        font-size: 24px;
    }

    .fc-blog-posts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        align-items: start;
        margin-bottom: 32px;
        overflow: visible;
    }

    .fc-blog-item-body {
        padding: 12px;
        gap: 6px;
    }

    .fc-blog-item-title {
        font-size: 13px;
        line-height: 1.35;
    }

    .fc-blog-item-cats,
    .fc-blog-item-excerpt,
    .fc-blog-item-meta {
        font-size: 11px;
    }

    .fc-blog-pagination .page-numbers {
        min-width: 32px;
        height: 32px;
        font-size: 13px;
    }

    .fc-blog-item-meta {
        font-size: 11px;
        gap: 6px;
    }
}

@media (max-width: 1100px) {
    .fc-app {
        grid-template-columns: 1fr;
    }

    body.fontchuviet-blog-page .fc-app,
    body.page-template-page-blog .fc-app,
    body.page-template-page-blog-php .fc-app,
    .fc-app:has(> .fc-blog-main) {
        display: block !important;
        grid-template-columns: none;
    }

    body.fontchuviet-blog-page .fc-app > .fc-blog-main,
    body.page-template-page-blog .fc-app > .fc-blog-main,
    body.page-template-page-blog-php .fc-app > .fc-blog-main,
    .fc-app:has(> .fc-blog-main) > .fc-blog-main,
    body.fontchuviet-blog-page .fc-footer,
    body.page-template-page-blog .fc-footer,
    body.page-template-page-blog-php .fc-footer,
    .fc-footer {
        display: block;
        grid-column: auto;
        width: 100%;
        clear: both;
    }

    .fc-account-layout {
        grid-template-columns: 1fr;
    }

    .fc-account-saved-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fc-account-sidebar-card {
        position: static;
    }

    .fc-sidebar {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        z-index: 40;
        width: min(84vw, 320px);
        height: 100vh;
        height: 100dvh;
        min-height: 100svh;
        max-height: 100dvh;
        padding-right: 10px;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        background: var(--fc-color-bg, #ffffff);
        border-right: 1px solid var(--fc-color-sidebar-border, #ededf2);
        border-bottom: 0;
        transform: translateX(calc(-100% - 24px));
        transition: transform 240ms ease;
        box-shadow: 0 24px 48px rgba(20, 20, 20, 0.12);
    }

    body.fontchuviet-has-sidebar .fc-app > .fc-main,
    body.fontchuviet-has-sidebar .fc-footer {
        grid-column: auto;
    }

    body.fc-mobile-nav-open {
        overflow: hidden;
        overscroll-behavior: none;
    }

    body.fc-mobile-nav-open .fc-sidebar {
        transform: translateX(0);
    }

    body.fc-mobile-nav-open .fc-mobile-overlay {
        opacity: 1;
        pointer-events: auto;
    }

    .fc-sidebar-close {
        display: flex;
    }

    .fc-sidebar-top {
        display: flex;
    }

    .fc-sidebar-no-account-card .fc-sidebar-top {
        position: absolute;
        top: 14px;
        right: 12px;
        padding: 0;
        margin: 0;
    }

    .fc-sidebar-no-account-card .fc-side-section-title-first {
        margin-top: 0;
        padding-top: 0;
        padding-right: 44px;
        border-top: 0;
    }

    .fc-main-topbar {
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 8px;
    }

    .fc-site-header {
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .fc-site-header .fc-main-topbar {
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 8px;
    }

    .fc-site-header .fc-main-topbar.has-search {
        grid-template-columns: auto minmax(0, 1fr) auto;
    }

    .fc-main-topbar-search {
        display: none;
    }

    .fc-site-header .fc-main-topbar-brand,
    .fc-site-header .fc-main-topbar-title {
        justify-self: center;
    }

    .fc-mobile-toggle {
        display: inline-flex;
    }

    .fc-main-topbar-title,
    .fc-topbar-logo {
        position: static;
        transform: none;
        text-align: center;
        justify-self: center;
        white-space: nowrap;
    }

    .fc-topbar-user {
        display: flex;
        align-items: center;
    }

    .fc-topbar-user .fc-header-right {
        gap: 10px;
    }

    .fc-header .fc-title {
        display: none;
    }

    .fc-header .fc-header-right {
        display: none;
    }

    .fc-single-topbar .fc-header-right {
        display: flex;
        margin-left: auto;
    }

    .fc-blog-topbar-home {
        display: inline-flex;
        justify-self: end;
    }

    .fc-blog-header-title-wrap .fc-blog-home-button {
        display: none;
    }

    .fc-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fc-single-layout {
        grid-template-columns: 1fr;
    }

    .fc-single-sidebar-card {
        position: static;
    }

    .fc-single-related {
        max-width: none;
    }

    .fc-single-related-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fc-collection-page {
        padding-right: 0;
    }

    .fc-collection-hero,
    .fc-collection-detail-grid,
    .fc-collection-card {
        grid-template-columns: 1fr;
    }

    .fc-collection-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fc-collection-card-cover {
        min-height: 240px;
    }

    .fc-collection-card-preview-grid {
        min-height: 240px;
    }

    .fc-footer-inner {
        padding-left: 18px;
        padding-right: 18px;
    }

    body.fontchuviet-has-sidebar .fc-footer-inner {
        padding-left: 18px;
        padding-right: 18px;
    }

    .fc-footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 28px 24px;
    }
}

@media (max-width: 760px) {
    :root {
        --fc-mobile-header-side: clamp(96px, 30vw, 112px);
    }

    .fc-site-header {
        padding: 10px var(--fc-layout-mobile-padding, 10px);
        box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
    }

    body.fontchuviet-has-sidebar .fc-site-header {
        padding: 10px var(--fc-layout-mobile-padding, 10px);
    }

    .fc-site-header .fc-main-topbar,
    .fc-single-topbar {
        grid-template-columns: var(--fc-mobile-header-side) minmax(0, 1fr) var(--fc-mobile-header-side);
        column-gap: 0;
        align-items: center;
        min-height: 44px;
    }

    .fc-site-header .fc-main-topbar.has-search {
        grid-template-columns: var(--fc-mobile-header-side) minmax(0, 1fr) var(--fc-mobile-header-side);
    }

    body.fontchuviet-has-sidebar .fc-site-header .fc-main-topbar.has-search {
        grid-template-columns: var(--fc-mobile-header-side) minmax(0, 1fr) var(--fc-mobile-header-side);
        gap: 0;
    }

    .fc-site-header .fc-main-topbar-brand,
    .fc-site-header .fc-main-topbar-title {
        position: static;
        transform: none;
        justify-self: center;
        max-width: 100%;
        white-space: nowrap;
        z-index: 1;
    }

    .fc-mobile-toggle,
    .fc-site-header .fc-topbar-user {
        z-index: 2;
    }

    .fc-main {
        padding: 10px;
    }

    .fc-footer-inner {
        padding: 34px 12px 16px;
    }

    body.fontchuviet-has-sidebar .fc-footer-inner {
        padding: 34px 12px 16px;
    }

    .fc-footer-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .fc-footer-title {
        margin-bottom: 12px;
        font-size: 16px;
    }

    .fc-footer-bottom {
        margin-top: 28px;
        padding-top: 16px;
    }

    .fc-footer-bottom p {
        font-size: 13px;
    }

    .fc-main-topbar {
        gap: 10px;
        margin-bottom: 12px;
    }

    .fc-mobile-toggle {
        justify-self: start;
        width: 32px;
        height: 32px;
        padding: 0 8px;
        border-radius: 9px;
        gap: 3px;
    }

    .fc-main-topbar-title {
        font-size: 13px;
    }

    .fc-blog-topbar-home {
        width: 32px;
        height: 32px;
        border-radius: 9px;
        box-shadow: none;
    }

    .fc-blog-topbar-home svg {
        width: 14px;
        height: 14px;
    }

    .fc-site-header .fc-topbar-logo,
    .fc-topbar-logo,
    .fc-single-topbar .fc-brand-logo {
        max-width: min(118px, 100%);
        max-height: 24px;
    }

    .fc-site-header .fc-topbar-user {
        justify-self: end;
        width: var(--fc-mobile-header-side);
        max-width: var(--fc-mobile-header-side);
        min-width: 0;
        display: flex;
        justify-content: flex-end;
    }

    .fc-site-header .fc-topbar-user .fc-header-right {
        width: var(--fc-mobile-header-side);
        justify-content: flex-end;
    }

    .fc-site-header .fc-topbar-user .fc-header-icons {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .fc-site-header .fc-topbar-user .fc-header-right,
    .fc-single-topbar .fc-header-right {
        gap: 6px;
        flex-wrap: nowrap;
    }

    .fc-site-header .fc-topbar-user .fc-user,
    .fc-site-header .fc-topbar-user .fc-user-menu,
    .fc-site-header .fc-topbar-user .fc-user.is-guest {
        display: inline-flex;
        align-items: center;
    }

    .fc-site-header .fc-topbar-user .fc-user {
        gap: 0;
        width: 28px;
        height: 28px;
        min-width: 28px;
        justify-content: center;
        padding: 0;
    }

    .fc-site-header .fc-topbar-user .fc-user-copy,
    .fc-site-header .fc-topbar-user .fc-chevron,
    .fc-site-header .fc-topbar-user .fc-user > .fc-chevron,
    .fc-site-header .fc-topbar-user .fc-user ~ .fc-chevron {
        display: none;
    }

    .fc-site-header .fc-topbar-user .fc-user-avatar {
        width: 24px;
        height: 24px;
        flex-shrink: 0;
    }

    .fc-site-header .fc-topbar-user .fc-icon.bookmark {
        width: 18px;
        height: 18px;
    }

    .fc-site-header .fc-topbar-user .fc-icon.bell {
        width: 18px;
        height: 18px;
    }

    .fc-sidebar {
        width: min(82vw, 280px);
        padding-top: 14px;
    }

    .fc-sidebar-top {
        padding: 0 10px 0 14px;
    }

    .fc-sidebar-no-account-card .fc-sidebar-top {
        top: 14px;
        right: 12px;
    }

    .fc-sidebar-close {
        width: 28px;
        height: 28px;
        font-size: 18px;
        margin-right: 0;
        border-radius: 8px;
    }

    .fc-brand {
        gap: 8px;
        padding: 0 0 12px;
        flex: 1 1 auto;
        min-width: 0;
    }

    .fc-brand-logo {
        max-width: 120px;
        max-height: 28px;
    }

    .fc-brand-mark {
        width: 18px;
        height: 18px;
    }

    .fc-brand-name {
        font-size: 13px;
    }

    .fc-side-section-title {
        margin: 20px 12px 8px;
        padding-top: 12px;
        font-size: 10px;
    }

    .fc-quota,
    .fc-sidebar-note,
    .fc-upgrade {
        margin-left: 12px;
        margin-right: 8px;
    }

    .fc-quota {
        margin-bottom: 18px;
        padding: 10px;
        border-radius: 12px;
    }

    .fc-menu {
        gap: 5px;
        padding: 0 12px;
    }

    .fc-menu-item {
        --fc-menu-row-height: 24px;
        min-height: 34px;
        gap: 10px;
        padding: 0 10px;
        border-radius: 10px;
        font-size: 11px;
        line-height: 1.2;
        overflow: visible;
    }

    .fc-menu-icon {
        width: var(--fc-menu-row-height);
        height: var(--fc-menu-row-height);
        flex-shrink: 0;
    }

    .fc-menu-icon svg {
        width: 18px;
        height: 24px;
    }

    .fc-menu-item:hover,
    .fc-menu-item:focus-visible {
        transform: none;
        box-shadow: 0 6px 14px rgba(117, 109, 255, 0.10);
    }

    .fc-upgrade {
        margin-top: 18px;
        padding: 14px 12px 12px;
        border-radius: 14px;
    }

    .fc-upgrade-visual {
        width: 60px;
        height: 60px;
        margin-bottom: 10px;
    }

    .fc-upgrade-copy {
        font-size: 11px;
    }

    .fc-upgrade button {
        height: 30px;
        padding: 0 14px;
        font-size: 11px;
    }

    .fc-header,
    .fc-suggested {
        display: grid;
        grid-template-columns: 1fr;
    }

    .fc-header {
        gap: 12px;
        margin-bottom: 14px;
        justify-content: flex-end;
    }

    .fc-main > .fc-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
    }

    .fc-main > .fc-header .fc-title {
        display: block;
        flex: 1 1 auto;
        min-width: 0;
        font-size: 13px;
        line-height: 1.35;
    }

    .fc-main > .fc-header .fc-header-filters {
        flex: 0 0 auto;
        gap: 8px;
        margin-left: 0;
    }

    .fc-main > .fc-header .fc-vip-filter-button {
        display: inline-flex !important;
        width: auto;
        min-width: 58px;
        height: 32px;
        padding: 0 12px;
        border-radius: 8px;
        font-size: 11px;
    }

    .fc-main > .fc-header .fc-filter-wrap {
        width: auto;
        min-width: 104px;
    }

    .fc-main > .fc-header .fc-filter-wrap > .fc-control {
        width: 100%;
        height: 32px;
        max-width: none;
        justify-content: center;
        border-radius: 8px;
        font-size: 11px;
    }

    .fc-mobile-content-search {
        display: flex;
        width: 100%;
        height: 40px;
        margin: 10px 0 18px;
        padding: 0 10px 0 14px;
        border-radius: 10px;
        box-shadow: none;
    }

    .fc-mobile-content-search:hover,
    .fc-mobile-content-search:focus-within {
        transform: none;
    }

    .fc-mobile-content-search .fc-search-input {
        margin-left: 10px;
        font-size: 12px;
    }

    .fc-mobile-content-search .fc-search-submit {
        min-width: 52px;
        height: 30px;
        margin-left: 10px;
        padding: 0 12px;
        border-radius: 8px;
        font-size: 11px;
    }

    .fc-title {
        font-size: 13px;
    }

    .fc-header-right {
        justify-content: flex-end;
        gap: 14px;
        min-width: 0;
    }

    .fc-header-icons {
        gap: 9px;
    }

    .fc-icon,
    .fc-icon.bookmark,
    .fc-icon.bell {
        width: 28px;
        height: 28px;
        transform: none;
    }

    .fc-icon svg {
        width: 17px;
        height: 17px;
    }

    .fc-notification-dropdown {
        right: -20px;
        width: min(280px, calc(100vw - 16px));
        padding: 10px;
    }

    .fc-user {
        gap: 0;
        min-width: 0;
        flex: 0 0 auto;
        justify-content: flex-end;
    }

    .fc-user-copy,
    .fc-user ~ .fc-chevron,
    .fc-user > .fc-chevron {
        display: none;
    }

    .fc-user-avatar {
        width: 28px;
        height: 28px;
        flex-shrink: 0;
    }

    .fc-user.is-guest .fc-user-avatar {
        width: 26px;
        height: 26px;
    }

    .fc-user.is-guest .fc-user-avatar-initials svg {
        width: 24px;
        height: 24px;
        stroke-width: 1.8;
    }

    .fc-user-copy {
        min-width: 0;
        overflow: hidden;
    }

    .fc-user-name {
        font-size: 10px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .fc-user-mail,
    .fc-badge {
        font-size: 8px;
    }

    .fc-user-mail {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .fc-chevron {
        flex-shrink: 0;
    }


        .fc-toolbar {
            display: flex;
            flex-direction: row;
            flex-wrap: nowrap;
            width: 100%;
            max-width: 100vw;
            margin: 0;
            padding: 0 0px 10px 0px;
            box-sizing: border-box;
            gap: 8px;
            align-items: stretch;
        }
        .fc-search {
            flex: 1 1 0;
            min-width: 0;
        }
        .fc-filter-button, .fc-control {
            flex: 0 0 auto;
            width: auto;
            min-width: 64px;
            max-width: 120px;
            box-sizing: border-box;
        }
        .fc-toolbar .fc-vip-filter-button {
            display: none !important;
        }
        .fc-search {
            flex: 1 1 0;
            min-width: 0;
            max-width: 100%;
        }

        .fc-search,
        .fc-control,
        .fc-filter-button {
            height: 38px;
            border-radius: 9px;
            width: 100%;
            box-sizing: border-box;
            margin: 0;
        }

        .fc-search {
            min-width: 0;
            padding: 0 12px;
            font-size: 11px;
            width: 100%;
            box-sizing: border-box;
            margin: 0;
        }

        .fc-search-input,
        .fc-control,
        .fc-filter-button {
            font-size: 11px;
        }

        .fc-search-input {
            margin-left: 8px;
        }

        .fc-search-submit {
            min-width: 76px;
            height: 38px;
            margin-left: 0;
            padding: 0 10px;
            font-size: 10px;
            border-radius: 9px;
        }

    .fc-filter-wrap {
        min-width: 0;
        width: 96px;
    }

    .fc-control {
        padding: 0 12px;
        justify-content: center;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .fc-dropdown {
        top: 36px;
        width: 112px;
        left: auto;
        right: 0;
    }

    .fc-dropdown a {
        padding: 6px 7px;
        font-size: 10px;
    }

    .fc-suggested {
        display: flex;
        flex-wrap: nowrap;
        gap: 6px;
        margin-top: 10px;
        margin-bottom: 12px;
        font-size: 10px;
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        padding-bottom: 3px;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .fc-category-nav {
        display: none;
    }

    .fc-suggested::-webkit-scrollbar {
        display: none;
    }

    .fc-main > .fc-mobile-content-search {
        margin: 12px 0 0;
    }

    .fc-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .fc-account-main {
        padding-top: 0;
        padding-left: 0;
        padding-right: 0;
    }

    .fc-account-main > .fc-single-topbar {
        position: static;
        top: auto;
        left: auto;
        right: auto;
        margin-bottom: 14px;
        padding: 0 10px 12px;
        box-shadow: none;
    }

    .fc-account-shell {
        padding-left: 10px;
        padding-right: 10px;
    }

    .fc-account-shell,
    .fc-account-main .fc-account-layout,
    .fontchuviet-account-page .fc-account-layout {
        width: 100%;
        max-width: none;
    }

    .fc-account-panel,
    .fc-account-sidebar-card {
        padding: 16px;
        border-radius: 16px;
    }

    .fc-account-summary-row {
        display: grid;
        gap: 6px;
    }

    .fc-account-summary-row strong {
        text-align: left;
    }

    .fc-account-panel-head h1,
    .fc-account-panel-head h2,
    .fc-account-note-box h3 {
        font-size: 22px;
    }

    .fc-collection-hero,
    .fc-collection-detail-head,
    .fc-collection-card {
        padding: 16px;
        border-radius: 16px;
    }

    .fc-collection-hero-copy h1 {
        font-size: 22px;
    }

    .fc-collection-hero-copy p,
    .fc-collection-card-body p,
    .fc-collection-empty {
        font-size: 12px;
    }

    .fc-collection-hero-stats {
        grid-template-columns: 1fr;
    }

    .fc-collection-toolbar .fc-search {
        max-width: none;
    }

    .fc-collection-search-form {
        gap: 6px;
    }

    .fc-collection-stat strong {
        font-size: 18px;
    }

    .fc-collection-card-cover {
        min-height: 180px;
    }

    .fc-collection-card-preview-grid {
        min-height: 180px;
        gap: 5px;
        padding: 5px;
    }

    .fc-collection-card-preview-tile {
        border-radius: 10px;
    }

    .fc-collection-card-placeholder {
        width: 42px;
        height: 42px;
        border-radius: 14px;
    }

    .fc-collection-card-placeholder svg {
        width: 20px;
        height: 20px;
    }

    .fc-collection-card-body h2 {
        font-size: 18px;
    }

    .fc-collection-grid {
        grid-template-columns: 1fr;
    }

    .fc-gallery--desktop {
        display: none;
    }

    .fc-gallery--mobile {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .fc-chip {
        flex: 0 0 auto;
        min-height: 28px;
        padding: 0 10px;
        border-radius: 9px;
        font-size: 10px;
        white-space: nowrap;
    }

    .fc-card {
        gap: 7px;
    }

    .fc-card-media {
        border-radius: 12px;
        box-shadow: 0 8px 20px rgba(30, 30, 35, 0.05);
    }

    .fc-card-badges {
        top: 7px;
        left: 7px;
        right: 7px;
        gap: 4px;
    }

    .fc-card-file-count {
        height: 19px;
        padding: 0 6px;
        font-size: 8px;
        letter-spacing: 0.02em;
    }

    .fc-card-badge {
        min-width: 34px;
        height: 19px;
        padding: 0 8px;
        font-size: 8px;
        letter-spacing: 0.02em;
        box-shadow: 0 5px 12px rgba(16, 18, 27, 0.12);
    }

    .fc-card-actions,
    .fc-card-hover,
    .fc-card-overlay-title {
        left: 8px;
        right: 8px;
    }

    .fc-card-actions {
        top: 7px;
        gap: 5px;
    }

    .fc-card-action {
        width: 24px;
        height: 24px;
        border-radius: 8px;
        box-shadow: 0 5px 12px rgba(16, 18, 27, 0.12);
    }

    .fc-card-action-icon {
        width: 11px;
        height: 11px;
    }

    .fc-card-overlay-title {
        bottom: 8px;
        font-size: 10px;
        line-height: 1.22;
    }

    .fc-card-meta-row {
        gap: 8px;
        padding: 0;
        font-size: 10px;
    }

    .fc-card-author-text {
        font-size: 10px;
    }

    .fc-card-stats {
        gap: 8px;
        font-size: 9px;
    }

    .fc-card-stat {
        gap: 4px;
    }

    .fc-card-stat-icon {
        width: 12px;
        height: 12px;
    }

    .fc-card-hover {
        top: 50%;
        bottom: auto;
        gap: 6px;
    }

    .fc-card-cta {
        min-width: 0;
        height: 28px;
        padding: 0 10px;
        border-radius: 10px;
        font-size: 9px;
    }

    .fc-card-top,
    .fc-card-bottom,
    .fc-card-hover {
        left: 8px;
        right: 8px;
    }

    .fc-card-top,
    .fc-card-bottom,
    .fc-card-hover {
        gap: 6px;
    }

    .fc-card-top,
    .fc-card-bottom {
        flex-direction: column;
        align-items: flex-start;
    }

    .fc-card-stats,
    .fc-card-hover {
        justify-content: flex-start;
    }

    .fc-single-main {
        padding-right: var(--fc-layout-mobile-padding, 14px);
    }

    .single-font_item .fc-single-main {
        padding-left: var(--fc-layout-mobile-padding, 14px);
        padding-right: var(--fc-layout-mobile-padding, 14px);
    }

    .fc-pagination {
        margin-top: 16px;
    }

    .fc-pagination .page-numbers {
        gap: 4px;
    }

    .fc-pagination a,
    .fc-pagination span {
        min-width: 30px;
        height: 30px;
        padding: 0 8px;
        border-radius: 9px;
        font-size: 11px;
    }

    .fc-single-topbar {
        position: static;
        left: auto;
        right: auto;
        margin-bottom: 14px;
        padding-bottom: 12px;
    }

    body.single-font_item .fc-single-topbar {
        position: static;
        top: auto;
        left: auto;
        right: auto;
        width: 100vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        padding-left: var(--fc-layout-mobile-padding, 14px);
        padding-right: var(--fc-layout-mobile-padding, 14px);
    }

    body.single-font_item.admin-bar .fc-single-topbar {
        top: auto;
    }

    .single-font_item .fc-single {
        padding-top: 0;
    }

    .fc-single-topbar {
        grid-template-columns: auto 1fr auto;
        justify-items: start;
    }

    .fc-single-header-center {
        display: none;
    }

    .fc-single-panel,
    .fc-single-related {
        padding: 18px;
    }

    .fc-single-visual-panel {
        padding: 0;
    }

    .fc-single-visual {
        min-height: 0;
    }

    .fc-single-secondary-actions,
    .fc-single-section-head {
        grid-template-columns: 1fr;
    }

    .fc-single-secondary-actions {
        flex-direction: column;
    }

    .fc-single-icon-button {
        width: 100%;
    }

    .fc-single-related-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 520px) {
    .fc-main > .fc-header {
        flex-wrap: nowrap;
        align-items: center;
        gap: 6px;
        margin-bottom: 8px;
    }

    .fc-main > .fc-header .fc-title {
        flex: 1 1 auto;
        flex-basis: auto;
        align-self: center;
    }

    .fc-main > .fc-header .fc-header-filters {
        flex: 0 0 auto;
        width: auto;
        align-items: center;
        justify-content: flex-end;
        gap: 6px;
    }
}
