:root {
    --fy-bg: #f4f1ea;
    --fy-surface: #fffcf7;
    --fy-text: #1c1c1c;
    --fy-muted: #6b6b6b;
    --fy-accent: #2f5d50;
    --fy-accent-soft: rgba(47, 93, 80, 0.12);
    --fy-line: rgba(28, 28, 28, 0.12);
    --fy-max: 42rem;
    --fy-radius: 0.35rem;
    --fy-page-pad-x: 1.5rem;
    --fy-font: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Source Han Sans SC", "Noto Sans SC", sans-serif;
    --fy-footer-pad-y: 1.5rem;
    --fy-footer-text-size: 0.82rem;
    --fy-footer-line-h: 1.4375rem;
    --fy-glass-bg: rgba(244, 241, 234, 0.72);
    --fy-glass-panel-bg: rgba(255, 252, 247, 0.94);
    --fy-glass-blur: blur(14px) saturate(1.12);
    --fy-glass-panel-blur: blur(20px) saturate(1.08);
    --fy-glass-border: rgba(28, 28, 28, 0.07);
    --fy-glass-panel-border: rgba(28, 28, 28, 0.1);
    --fy-glass-shadow: 0 4px 24px rgba(28, 28, 28, 0.04);
    --fy-glass-panel-shadow: 0 10px 40px rgba(28, 28, 28, 0.1);
    --fy-dock-bar-h: 2.8125rem;
    --fy-dock-bottom: max(
        calc(var(--fy-footer-pad-y) + (var(--fy-footer-line-h) - var(--fy-dock-bar-h)) / 2),
        calc(var(--fy-footer-pad-y) + (var(--fy-footer-line-h) - var(--fy-dock-bar-h)) / 2 + env(safe-area-inset-bottom, 0px))
    );
}

html[data-fy-theme="dark"] {
    color-scheme: dark;
    --fy-bg: #171714;
    --fy-surface: #222220;
    --fy-text: #eceae4;
    --fy-muted: #9a9994;
    --fy-accent: #6aab98;
    --fy-accent-soft: rgba(106, 171, 152, 0.16);
    --fy-line: rgba(236, 234, 228, 0.12);
    --fy-glass-bg: rgba(23, 23, 20, 0.78);
    --fy-glass-panel-bg: rgba(34, 34, 32, 0.94);
    --fy-glass-border: rgba(236, 234, 228, 0.08);
    --fy-glass-panel-border: rgba(236, 234, 228, 0.1);
    --fy-glass-shadow: 0 4px 24px rgba(0, 0, 0, 0.32);
    --fy-glass-panel-shadow: 0 10px 40px rgba(0, 0, 0, 0.45);
}

html[data-fy-theme="dark"] .fy-comment-replies {
    background: rgba(255, 255, 255, 0.04);
}

html[data-fy-theme="dark"] .markdown h1,
html[data-fy-theme="dark"] .markdown h2 {
    border-bottom-color: var(--fy-line);
}

html[data-fy-theme="dark"] .markdown h6 {
    color: var(--fy-muted);
}

html[data-fy-theme="dark"] .markdown blockquote {
    color: var(--fy-muted);
    border-left-color: var(--fy-line);
}

html[data-fy-theme="dark"] .fy-post-body .fy-img-wrap.is-loading:not(.has-ratio) {
    background-color: #2a2a27;
}

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

html {
    scroll-behavior: auto;
}

html.fy-scroll-smooth {
    scroll-behavior: smooth;
}

html.fy-scroll-restore {
    scroll-behavior: auto;
}

body {
    margin: 0;
    color: var(--fy-text);
    background: var(--fy-bg);
    font-family: var(--fy-font);
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.75;
    font-synthesis: none;
    -webkit-font-smoothing: antialiased;
}

a {
    color: inherit;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

a:hover {
    opacity: 0.65;
}

.fy-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
    overflow-x: clip;
}

.fy-topbar-sticky {
    position: sticky;
    top: 0;
    z-index: 200;
    width: 100%;
}

.fy-topbar-shell {
    position: relative;
    z-index: 2;
}

.fy-topbar-glass {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    visibility: hidden;
    background-color: transparent;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    border-bottom: 1px solid transparent;
    transform: translateZ(0);
}

html.fy-topbar-scrolled .fy-topbar-glass,
.fy-topbar-sticky.is-scrolled .fy-topbar-glass,
.fy-topbar-sticky.is-search-active .fy-topbar-glass,
.fy-topbar-sticky:has(.fy-nav.is-open) .fy-topbar-glass,
.fy-topbar-sticky:has(.fy-nav-has-sub.is-sub-open) .fy-topbar-glass {
    visibility: visible;
    background-color: var(--fy-glass-bg);
    -webkit-backdrop-filter: var(--fy-glass-blur);
    backdrop-filter: var(--fy-glass-blur);
    border-bottom-color: var(--fy-glass-border);
}

.fy-topbar-sticky.is-search-active .fy-topbar-glass {
    border-bottom-color: transparent;
}

.fy-topbar-sticky:has(.fy-nav.is-drawer-open) .fy-topbar-glass {
    visibility: hidden;
}

.fy-topbar {
    position: relative;
    z-index: 1;
    max-width: calc(var(--fy-max) + 3rem);
    margin: 0 auto;
    padding: 1.25rem var(--fy-page-pad-x);
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
}

.fy-topbar-end {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 1;
    min-width: 0;
    margin-left: auto;
}

.fy-brand {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    font-size: 1.25rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    white-space: nowrap;
    line-height: 1.2;
}

.fy-brand-logo {
    display: block;
    height: 1.75rem;
    width: auto;
    max-width: 10rem;
    object-fit: contain;
}

.fy-brand-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    flex-shrink: 0;
    min-width: 0;
}

.fy-brand-wrap .switch {
    --INITIAL-SWITCH-TRACK-COLOR: #fffbeb;
    --INITIAL-THUMB-COLOR: #ff5722;
    --OVERALL-TRANSITION-DURATION: 500ms;
    --fy-switch-track-w: 3.75em;
    --fy-switch-track-h: 1.85em;
    --fy-switch-travel: calc(var(--fy-switch-track-w) - var(--fy-switch-track-h));
    font-size: 11px;
    position: relative;
    display: inline-block;
    width: var(--fy-switch-track-w);
    height: var(--fy-switch-track-h);
    flex-shrink: 0;
}

.fy-brand-wrap .switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.fy-brand-wrap .switch .slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--INITIAL-SWITCH-TRACK-COLOR);
    transition: var(--OVERALL-TRANSITION-DURATION);
    border-radius: 30px;
    overflow: hidden;
}

.fy-brand-wrap .switch .slider:before {
    position: absolute;
    content: "";
    height: 100%;
    width: var(--fy-switch-track-h);
    border-radius: 50%;
    left: 0;
    top: 0;
    background-color: var(--INITIAL-THUMB-COLOR);
    transition: var(--OVERALL-TRANSITION-DURATION);
}

.fy-brand-wrap .switch input:checked + .slider {
    background-color: var(--INITIAL-THUMB-COLOR);
}

.fy-brand-wrap .switch input:checked + .slider::before {
    transform-origin: left center;
    background-color: var(--INITIAL-SWITCH-TRACK-COLOR);
    animation: fy-theme-switch-wobble var(--OVERALL-TRANSITION-DURATION) cubic-bezier(0.075, 0.82, 0.165, 1);
    transform: translateX(var(--fy-switch-travel));
}

.fy-brand-wrap .switch input:not(:checked) + .slider::before {
    transform-origin: right center;
    animation: fy-theme-switch-reverse-wobble var(--OVERALL-TRANSITION-DURATION) cubic-bezier(0.075, 0.82, 0.165, 1);
}

@keyframes fy-theme-switch-wobble {
    0% {
        transform: translateX(0) scale(1, 1);
    }

    50% {
        transform: translateX(calc(var(--fy-switch-travel) * 0.5)) scale(2.2, 1);
    }

    100% {
        transform: translateX(var(--fy-switch-travel)) scale(1, 1);
    }
}

@keyframes fy-theme-switch-reverse-wobble {
    0% {
        transform: translateX(var(--fy-switch-travel)) scale(1, 1);
    }

    50% {
        transform: translateX(calc(var(--fy-switch-travel) * 0.5)) scale(2.2, 1);
    }

    100% {
        transform: translateX(0) scale(1, 1);
    }
}

.fy-nav {
    flex-shrink: 1;
    min-width: 0;
    overflow: visible;
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.125rem;
}

.fy-nav:not(.is-nav-ready) .fy-nav-list {
    position: absolute;
    width: max-content;
    left: -9999px;
    visibility: hidden;
    pointer-events: none;
}

.fy-nav:not(.is-nav-ready) .fy-nav-drawer-toggle {
    visibility: hidden;
}

.fy-nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 1.25rem;
    font-size: 0.92rem;
    line-height: 1.2;
    color: var(--fy-muted);
    white-space: nowrap;
}

.fy-nav-item {
    position: relative;
}

.fy-nav-has-sub::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 0.5rem;
}

.fy-nav-dropdown {
    position: absolute;
    top: calc(100% + 5px);
    right: 0;
    min-width: 9rem;
    list-style: none;
    margin: 0;
    padding: 0.35rem;
    background: var(--fy-surface);
    border: 1px solid var(--fy-line);
    border-radius: calc(var(--fy-radius) * 2);
    box-shadow: 0 8px 24px rgba(28, 28, 28, 0.1);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(4px);
    transition:
        opacity 0.18s ease 0.12s,
        visibility 0.18s ease 0.12s,
        transform 0.18s ease 0.12s;
    z-index: 210;
}

.fy-nav-dropdown li {
    margin: 0;
    padding: 0;
    width: 100%;
}

.fy-nav-dropdown a {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 0.45rem 0.65rem;
    border-radius: var(--fy-radius);
    font-size: 0.88rem;
    color: var(--fy-text);
    white-space: nowrap;
    text-decoration: none;
    line-height: 1.45;
}

.fy-nav-dropdown a:hover {
    opacity: 1;
    background: var(--fy-accent-soft);
}

.fy-nav-has-sub:hover .fy-nav-dropdown,
.fy-nav-has-sub:focus-within .fy-nav-dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition-delay: 0s;
}

.fy-nav-parent-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.125rem;
    line-height: 1.2;
}

.fy-nav-list a {
    white-space: nowrap;
    line-height: 1.2;
    display: inline-block;
}

.fy-nav-sub-toggle {
    font-size: 0.92rem;
    line-height: 1.2;
    width: 1.2em;
    height: 1.2em;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin: 0;
    position: relative;
    top: -2px;
    color: var(--fy-muted);
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

.fy-nav-toggle-icon {
    width: 0.7rem;
    height: 0.7rem;
    display: block;
    flex-shrink: 0;
    transform-origin: center;
    transition: transform 0.25s ease;
    position: relative;
    top: 2px;
}

.fy-nav-has-sub:hover .fy-nav-sub-toggle .fy-nav-toggle-icon,
.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub.is-sub-open .fy-nav-sub-toggle .fy-nav-toggle-icon {
    transform: rotate(180deg);
}

.fy-nav-sub-toggle:focus-visible {
    outline: 2px solid var(--fy-accent);
    outline-offset: 2px;
    border-radius: 999px;
}

.fy-nav-drawer-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--fy-text);
    cursor: pointer;
    border-radius: var(--fy-radius);
    flex-shrink: 0;
}

.fy-nav-drawer-toggle:hover,
.fy-nav-drawer-toggle:focus-visible {
    background: var(--fy-accent-soft);
}

.fy-nav-drawer-icon {
    display: block;
    width: 1.15rem;
    height: auto;
}

.fy-nav.is-compact .fy-nav-drawer-toggle {
    display: inline-flex;
}

.fy-nav.is-compact .fy-nav-list {
    display: none;
}

.fy-nav-drawer-layer {
    display: none;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-drawer-layer {
    display: block;
}

.fy-nav-drawer-backdrop {
    position: fixed;
    inset: 0;
    z-index: 320;
    background: rgba(16, 22, 20, 0.42);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.fy-nav-list-wrap {
    display: contents;
}

.fy-nav-drawer-close {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 322;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    color: rgba(255, 252, 247, 0.95);
    cursor: pointer;
    box-shadow: none;
}

.fy-nav-drawer-close svg {
    width: 1.35rem;
    height: 1.35rem;
    display: block;
}

.fy-nav-drawer-close:hover,
.fy-nav-drawer-close:focus-visible {
    background: transparent;
    opacity: 0.72;
    outline: none;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-list-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    inset: 0;
    z-index: 321;
    padding: 4.5rem 1.5rem 2rem;
    box-sizing: border-box;
    pointer-events: none;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-list {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0.35rem;
    position: static;
    inset: auto;
    transform: none;
    z-index: auto;
    width: max-content;
    max-width: min(20rem, 88vw);
    height: auto;
    max-height: none;
    overflow: visible;
    margin: 0 auto;
    padding: 0;
    box-sizing: border-box;
    white-space: normal;
    text-align: left;
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
    pointer-events: auto;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-item {
    width: 100%;
    pointer-events: auto;
    text-align: left;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-list a,
.fy-nav.is-compact.is-drawer-open .fy-nav-parent--toggle {
    display: block;
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: var(--fy-radius);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--fy-text);
    text-decoration: none;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: inherit;
    text-align: left;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-list a:hover,
.fy-nav.is-compact.is-drawer-open .fy-nav-parent--toggle:hover {
    opacity: 1;
    background: rgba(255, 252, 247, 0.55);
}

.fy-nav-parent--toggle {
    background: transparent;
    border: none;
    cursor: pointer;
    font: inherit;
    color: inherit;
    padding: 0;
    text-align: left;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-parent {
    flex: 0 1 auto;
    width: auto;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub > .fy-nav-parent-wrap {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.2rem;
    width: 100%;
    padding: 0.75rem 1rem;
    box-sizing: border-box;
    text-align: left;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub .fy-nav-parent,
.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub .fy-nav-parent--toggle {
    display: inline;
    width: auto;
    padding: 0;
    font-size: 1.05rem;
    font-weight: 600;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub .fy-nav-parent:hover,
.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub .fy-nav-parent--toggle:hover {
    background: transparent;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-dropdown {
    display: none;
    position: static;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    min-width: 0;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
    text-align: left;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-has-sub.is-sub-open > .fy-nav-dropdown {
    display: block;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-dropdown a {
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--fy-muted);
    padding: 0.55rem 1rem;
    text-align: left;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-parent-wrap {
    width: 100%;
}

.fy-nav.is-compact.is-drawer-open .fy-nav-sub-toggle {
    margin-left: 0.25rem;
}

body.fy-nav-drawer-open {
    overflow: hidden;
}

.fy-search {
    position: relative;
    flex-shrink: 0;
}

.fy-search-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--fy-muted);
    border-radius: 999px;
    cursor: pointer;
    transition: color 0.2s ease, background-color 0.2s ease;
}

.fy-search-toggle:hover,
.fy-search-toggle:focus-visible {
    color: var(--fy-text);
    background: var(--fy-accent-soft);
    outline: none;
}

.fy-search-icon {
    width: 1.15rem;
    height: 1.15rem;
    display: block;
}

.fy-topbar-sticky.is-search-active .fy-topbar-shell {
    z-index: 221;
}

.fy-search-backdrop {
    position: fixed;
    inset: 0;
    z-index: 210;
    background: transparent;
    visibility: hidden;
    pointer-events: none;
}

.fy-topbar-sticky.is-search-active:not(.is-search-closing) .fy-search-backdrop {
    visibility: visible;
    pointer-events: auto;
}

.fy-search-panel {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 220;
    visibility: hidden;
    pointer-events: none;
    max-height: 0;
    overflow: hidden;
    background-color: transparent;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    border: none;
    box-shadow: none;
    transform: translateZ(0);
    transition: max-height 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

.fy-topbar-sticky.is-search-active:not(.is-search-closing) .fy-search-panel,
.fy-topbar-sticky.is-search-closing .fy-search-panel {
    background-color: var(--fy-glass-bg);
    -webkit-backdrop-filter: var(--fy-glass-blur);
    backdrop-filter: var(--fy-glass-blur);
}

.fy-topbar-sticky.is-search-active:not(.is-search-closing) .fy-search-panel {
    visibility: visible;
    max-height: min(24rem, 70vh);
    pointer-events: none;
}

.fy-search-panel-inner {
    max-width: calc(var(--fy-max) + 3rem);
    margin: 0 auto;
    padding: 0.85rem var(--fy-page-pad-x) 1.05rem;
    box-sizing: border-box;
    pointer-events: auto;
}

.fy-topbar-sticky.is-search-closing .fy-search-panel {
    visibility: visible;
    max-height: 0;
    pointer-events: none;
}

.fy-topbar-sticky.is-search-active .fy-search-toggle {
    color: var(--fy-text);
    background: var(--fy-accent-soft);
}

.fy-search-panel[hidden] {
    display: block;
}

.fy-search-panel-body {
    transform: none;
}

.fy-search-form {
    margin: 0;
}

.fy-search-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.fy-search-input {
    width: 100%;
    margin: 0;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--fy-line);
    border-radius: var(--fy-radius);
    background: var(--fy-surface);
    color: var(--fy-text);
    font: inherit;
    font-size: 0.95rem;
    line-height: 1.4;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.fy-search-input:focus {
    outline: none;
    border-color: var(--fy-accent);
    box-shadow: 0 0 0 3px var(--fy-accent-soft);
}

.fy-search-random {
    margin: 0.9rem 0 0;
    padding-top: 0.85rem;
    border-top: 1px solid var(--fy-line);
}

.fy-search-random-label {
    margin: 0 0 0.55rem;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fy-muted);
}

.fy-search-random-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.fy-search-random-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.48rem 0.62rem;
    border-radius: var(--fy-radius);
    color: var(--fy-text);
    text-decoration: none;
    font-size: 0.88rem;
    line-height: 1.45;
    transition: background-color 0.18s ease, color 0.18s ease;
}

.fy-search-random-link:hover {
    opacity: 1;
    background: var(--fy-accent-soft);
}

.fy-search-random-title {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.fy-search-random-arrow {
    flex-shrink: 0;
    color: var(--fy-muted);
    font-size: 0.82rem;
    line-height: 1;
    transition: transform 0.18s ease, color 0.18s ease;
}

.fy-search-random-link:hover .fy-search-random-arrow {
    transform: translateX(2px);
    color: var(--fy-accent);
}

.fy-main {
    flex: 1;
    max-width: calc(var(--fy-max) + 3rem);
    margin: 0 auto;
    padding: 1.5rem 1.5rem 4rem;
    width: 100%;
}

#fy-swap {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

#fy-swap.is-pjax-loading {
    pointer-events: none;
}

.fy-pjax-overlay {
    position: fixed;
    inset: 0;
    z-index: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(244, 241, 234, 0.42);
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease, visibility 0.18s ease;
}

html[data-fy-theme="dark"] .fy-pjax-overlay {
    background: rgba(23, 23, 20, 0.52);
}

.fy-pjax-overlay.is-visible {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.fy-pjax-spinner {
    width: 2rem;
    height: 2rem;
    border: 2px solid var(--fy-line);
    border-top-color: var(--fy-accent);
    border-radius: 50%;
    animation: fy-spin 0.72s linear infinite;
}

@keyframes fy-spin {
    to {
        transform: rotate(360deg);
    }
}

.fy-shell--no-topbar .fy-main {
    padding-top: 1.25rem;
}

.fy-main.fy-home {
    padding-bottom: 2rem;
}

.fy-home .fy-hero {
    margin-bottom: 2rem;
}

.fy-home .fy-section {
    margin-bottom: 1.75rem;
}

.fy-home .fy-section:last-child {
    margin-bottom: 0;
}

.fy-hero {
    margin-bottom: 4rem;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.fy-hero-visual {
    flex-shrink: 0;
}

.fy-hero-avatar {
    margin: 0;
}

.fy-hero-avatar img {
    width: clamp(4.5rem, 12vw, 6rem);
    height: clamp(4.5rem, 12vw, 6rem);
    border-radius: 50%;
    object-fit: cover;
    display: block;
    border: 1px solid var(--fy-line);
}

.fy-intro {
    flex: 1;
    min-width: 0;
}

.fy-intro p {
    margin: 0 0 1rem;
    max-width: 36rem;
}

.fy-intro-sub {
    color: var(--fy-muted);
}

@media (min-width: 641px) {
    .fy-hero {
        flex-direction: row;
        align-items: flex-start;
        gap: 1rem;
    }

    .fy-hero-visual {
        width: clamp(6rem, 14vw, 8rem);
    }

    .fy-intro p {
        max-width: none;
    }
}

.fy-section {
    margin-bottom: 3.5rem;
    min-width: 0;
}

.fy-section-head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.fy-section-head .fy-section-title {
    margin: 0;
    flex-shrink: 0;
}

.fy-section-all {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    min-width: 0;
    flex-shrink: 0;
    font-size: 0.82rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: var(--fy-muted);
    text-decoration: none;
}

.fy-section-all::before {
    content: '';
    flex: 1;
    min-width: 1rem;
    border-top: 1px dashed var(--fy-line);
}

.fy-section-all:hover {
    opacity: 0.65;
}

.fy-section-title {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fy-muted);
    margin: 0 0 1.25rem;
}

.fy-section-title::before {
    content: '';
    flex-shrink: 0;
    width: 3px;
    height: 1em;
    background: var(--fy-text);
}

.fy-list {
    list-style: none;
    margin: 0;
    padding: 0;
    min-width: 0;
}

.fy-list-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    column-gap: 1rem;
    align-items: baseline;
    padding: 0.5rem 0;
}

.fy-list-link {
    position: relative;
    display: block;
    grid-column: 1;
    min-width: 0;
    width: 100%;
    max-width: 100%;
    font-size: 1.05rem;
    font-weight: 500;
    color: inherit;
    text-decoration: none;
    line-height: 1.375;
    overflow: hidden;
}

.fy-list-link:hover,
.fy-list-link:focus-visible {
    opacity: 1;
    outline: none;
}

.fy-link-label {
    display: inline-block;
    position: relative;
    min-width: 0;
    max-width: 100%;
    padding-right: 1rem;
    line-height: inherit;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    word-break: normal;
    overflow-wrap: normal;
    vertical-align: bottom;
}

.fy-link-label::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 11px;
    height: 11px;
    opacity: 0;
    transform: translateY(-50%) translateX(-3px);
    transition: opacity 0.24s ease, transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
    background-color: currentColor;
    pointer-events: none;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 11 11' fill='none'%3E%3Cpath d='M2.5 8.5L8.5 2.5M8.5 2.5H4M8.5 2.5V7' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 11 11' fill='none'%3E%3Cpath d='M2.5 8.5L8.5 2.5M8.5 2.5H4M8.5 2.5V7' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

.fy-list-link:hover .fy-link-label::before,
.fy-list-link:focus-visible .fy-link-label::before {
    opacity: 0.8;
    transform: translateY(-50%) translateX(0);
}

.fy-link-label::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: var(--fy-text);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.38s cubic-bezier(0.22, 1, 0.36, 1);
    pointer-events: none;
    backface-visibility: hidden;
}

.fy-list-link:hover .fy-link-label::after,
.fy-list-link:focus-visible .fy-link-label::after {
    transform: scaleX(1);
}

.fy-list-meta {
    grid-column: 2;
    grid-row: 1;
    flex: 0 0 auto;
    font-size: 0.88rem;
    color: var(--fy-muted);
    white-space: nowrap;
}

.fy-empty {
    padding: 1.5rem 0;
    color: var(--fy-muted);
}

.fy-friend-links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem 1.25rem;
}

.fy-friend-link {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    text-decoration: none;
    color: inherit;
    line-height: 1.75;
}

.fy-friend-link:hover .fy-friend-link-label {
    opacity: 0.65;
}

.fy-friend-link-icon {
    position: relative;
    width: 1em;
    height: 1em;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--fy-muted);
    border-radius: 0.25rem;
}

.fy-friend-link-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.fy-friend-link-fallback svg {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    border-radius: 0.25rem;
}

.fy-friend-link-icon svg.fy-friend-link-globe {
    transform: translateY(1px);
}

.fy-friend-link-icon img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    border-radius: 0.25rem;
    opacity: 0;
    transition: opacity 0.12s ease;
}

.fy-friend-link-icon.has-favicon {
    width: 20px;
    height: 20px;
}

.fy-friend-link-icon.has-favicon img.is-loaded {
    opacity: 1;
}

.fy-friend-link-fallback[hidden],
.fy-friend-link-icon img[hidden] {
    display: none !important;
}

.fy-friend-link-label {
    text-decoration: none;
}

.fy-dot {
    margin: 0 0.35rem;
    color: var(--fy-muted);
}

#links .fy-section-title {
    margin-bottom: 0.5rem;
}

#links .fy-empty {
    padding: 0;
    margin: 0;
}

#links .fy-friend-links {
    line-height: 1.75;
}

#links .fy-friend-link-label {
    line-height: inherit;
}

.fy-footer {
    border-top: 1px solid var(--fy-line);
    padding: var(--fy-footer-pad-y) 0;
}

.fy-footer-inner {
    max-width: calc(var(--fy-max) + 3rem);
    margin: 0 auto;
    padding: 0 var(--fy-page-pad-x);
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 1.5rem;
    font-size: var(--fy-footer-text-size);
    line-height: var(--fy-footer-line-h);
    color: var(--fy-muted);
}

.fy-footer-copy {
    margin-left: auto;
    text-align: right;
}

@media (max-width: 768px) {
    .fy-footer-inner {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .fy-footer-copy {
        margin-left: 0;
        text-align: center;
    }
}

.fy-page-head {
    margin-bottom: 2rem;
}

.fy-page-title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    margin: 0 0 0.5rem;
}

.fy-page-desc {
    margin: 0;
    color: var(--fy-muted);
}

.fy-post-head {
    margin-bottom: 2rem;
}

.fy-post-title {
    font-size: clamp(1.6rem, 4vw, 2.4rem);
    line-height: 1.25;
    margin: 0 0 1rem;
    letter-spacing: -0.02em;
}

.fy-post-meta {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.88rem;
    color: var(--fy-muted);
}

.fy-post-meta-left,
.fy-post-meta-right {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 1rem;
    white-space: nowrap;
}

.fy-post-meta-right {
    flex-shrink: 0;
    margin-left: auto;
    text-align: right;
}

.fy-post-meta a {
    text-decoration: none;
}

.fy-post-meta a:hover {
    opacity: 0.65;
}

.fy-post-meta-sort:empty {
    display: none;
}

.fy-post-body {
    margin-bottom: 2rem;
}

#articleContent.fy-article-pending {
    opacity: 0;
}

#articleContent.fy-article-layout-ready {
    opacity: 1;
}

.fy-post-body .fy-img-wrap {
    position: relative;
    display: block;
    width: 100%;
    max-width: 100%;
    margin: 1.25rem 0;
    border-radius: 0.2rem;
    overflow: hidden;
    contain: layout style paint;
}

.fy-post-body .fy-img-wrap.is-loading {
    background-color: #e8e6e1;
}

.fy-post-body .fy-img-wrap.is-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    margin: auto;
    width: 1.85rem;
    height: 1.85rem;
    border: 2px solid var(--fy-line);
    border-top-color: var(--fy-accent);
    border-radius: 50%;
    animation: fy-spin 0.72s linear infinite;
    pointer-events: none;
}

.fy-post-body .fy-img-wrap.is-loading:not(.has-ratio) {
    aspect-ratio: 16 / 9;
    max-height: 70vh;
    margin: 1.25rem 0;
}

.fy-post-body .fy-img-wrap.is-loaded {
    background: transparent;
    animation: none;
}

.fy-post-body .fy-img-wrap.has-ratio > a,
.fy-post-body .fy-img-wrap.has-ratio > img {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    line-height: 0;
}

.fy-post-body .fy-img-wrap.is-portrait {
    width: auto;
    max-width: 100%;
    max-height: min(70vh, 34rem);
    margin-left: auto;
    margin-right: auto;
}

.fy-post-body .fy-img-wrap > a {
    display: block;
    margin: 0;
    line-height: 0;
}

.fy-post-body .fy-img-wrap .fy-lazy-img,
.fy-post-body .fy-img-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: inherit;
    object-fit: contain;
    object-position: center;
    opacity: 0;
    filter: blur(18px);
    transition: filter 0.62s ease;
}

.fy-post-body .fy-img-wrap.is-loading .fy-lazy-img,
.fy-post-body .fy-img-wrap.is-loading img {
    opacity: 0;
}

.fy-post-body .fy-img-wrap.is-revealing .fy-lazy-img,
.fy-post-body .fy-img-wrap.is-revealing img {
    opacity: 1;
    filter: blur(18px);
}

.fy-post-body .fy-img-wrap.is-loaded .fy-lazy-img,
.fy-post-body .fy-img-wrap.is-loaded img {
    opacity: 1;
    filter: blur(0);
}

.fy-post-body .fy-img-wrap.is-error {
    background: rgba(28, 28, 28, 0.05);
    animation: none;
}

.fy-post-body .fy-img-wrap.is-error .fy-lazy-img,
.fy-post-body .fy-img-wrap.is-error img {
    filter: none;
    opacity: 0.4;
}

.fy-post-body .fy-img-gallery {
    --fy-gallery-gap: 0.65rem;
    column-count: 2;
    column-gap: var(--fy-gallery-gap);
    column-fill: balance;
    margin: 1.25rem 0;
    line-height: 0;
}

.fy-post-body .fy-img-gallery--3 {
    column-count: 3;
}

.fy-post-body .fy-img-gallery .fy-img-wrap {
    display: block;
    width: 100%;
    margin: 0 0 var(--fy-gallery-gap);
    min-width: 0;
    line-height: normal;
    break-inside: avoid;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
}

.fy-post-body .fy-img-gallery .fy-img-wrap.is-loading {
    background-color: rgba(28, 28, 28, 0.05);
}

html[data-fy-theme="dark"] .fy-post-body .fy-img-gallery .fy-img-wrap.is-loading {
    background-color: rgba(255, 255, 255, 0.06);
}

.fy-post-body .fy-img-gallery .fy-img-wrap.is-loading:not(.has-ratio) {
    aspect-ratio: var(--fy-gallery-ratio, 4 / 5);
    max-height: none;
    margin: 0 0 var(--fy-gallery-gap);
}

.fy-post-body .fy-img-gallery .fy-img-wrap.is-portrait {
    max-height: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
}

.fy-post-body .fy-img-gallery .fy-img-wrap .fy-lazy-img,
.fy-post-body .fy-img-gallery .fy-img-wrap img {
    object-position: top center;
}

.fy-post-body .fy-audio-player {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 0.9rem;
    margin: 1.25rem 0;
    border-radius: 0.75rem;
    background: #1c1c1c;
    color: #f4f1ea;
    max-width: 26.25rem;
    font-family: var(--fy-font);
}

html[data-fy-theme="dark"] .fy-post-body .fy-audio-player {
    background: #111;
    color: #eceae4;
}

.fy-post-body .fy-audio-player audio {
    display: none;
}

.fy-post-body .fy-audio-player__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: none;
    border-radius: 0.65rem;
    background: rgba(255, 255, 255, 0.12);
    color: inherit;
    cursor: pointer;
    flex-shrink: 0;
    transition: background-color 0.2s ease;
}

html[data-fy-theme="dark"] .fy-post-body .fy-audio-player__btn {
    background: rgba(255, 255, 255, 0.1);
}

.fy-post-body .fy-audio-player__btn:hover {
    background: rgba(255, 255, 255, 0.2);
}

.fy-post-body .fy-audio-player__icon {
    width: 1rem;
    height: 1rem;
    display: block;
}

.fy-post-body .fy-audio-player__icon--pause {
    display: none;
}

.fy-post-body .fy-audio-player__btn.is-playing .fy-audio-player__icon--play {
    display: none;
}

.fy-post-body .fy-audio-player__btn.is-playing .fy-audio-player__icon--pause {
    display: block;
}

.fy-post-body .fy-audio-player__progress {
    flex: 1;
    height: 4px;
    background: rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    overflow: hidden;
    cursor: pointer;
    touch-action: none;
    user-select: none;
}

.fy-post-body .fy-audio-player__progress.is-dragging,
body.fy-audio-dragging .fy-post-body .fy-audio-player__progress {
    cursor: grabbing;
}

.fy-post-body .fy-audio-player__bar {
    height: 100%;
    width: 0;
    background: currentColor;
    border-radius: inherit;
    transition: width 0.08s linear;
    pointer-events: none;
}

.fy-post-body .fy-audio-player__progress.is-dragging .fy-audio-player__bar {
    transition: none;
}

.fy-post-body .fy-audio-player__time {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.72);
    min-width: 2.65rem;
    text-align: right;
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

.fy-post-body .fy-audio-player.is-playing .fy-audio-player__time {
    color: rgba(255, 255, 255, 0.92);
}

@media (max-width: 520px) {
    .fy-post-body .fy-img-gallery--3 {
        column-count: 2;
    }
}

@media (max-width: 360px) {
    .fy-post-body .fy-img-gallery,
    .fy-post-body .fy-img-gallery--2,
    .fy-post-body .fy-img-gallery--3 {
        column-count: 1;
    }
}

.fy-post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
}

.fy-tag {
    font-size: 0.82rem;
    padding: 0.28rem 0.75rem;
    border-radius: 999px;
    background: var(--fy-surface);
    color: var(--fy-muted);
    border: 1px solid var(--fy-line);
    transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.fy-tag:hover {
    color: var(--fy-accent);
    border-color: rgba(47, 93, 80, 0.22);
    background: var(--fy-accent-soft);
    opacity: 1;
}

html[data-fy-theme="dark"] .fy-tag:hover {
    border-color: rgba(106, 171, 152, 0.28);
}

.fy-badge {
    display: inline-block;
    font-size: 0.72rem;
    padding: 0.15rem 0.45rem;
    margin-right: 0.5rem;
    border-radius: var(--fy-radius);
    background: var(--fy-accent-soft);
    color: var(--fy-accent);
    vertical-align: middle;
}

.fy-neighbor {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin: 3rem 0 0;
}

.fy-neighbor-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
    min-width: 0;
    padding: 1.05rem 1.1rem;
    border-radius: calc(var(--fy-radius) + 0.2rem);
    background: var(--fy-surface);
    border: 1px solid var(--fy-line);
    overflow: hidden;
    text-decoration: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.fy-neighbor-card::before,
.fy-neighbor-card::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    background: var(--fy-accent-soft);
}

.fy-neighbor-card::before {
    width: 4.75rem;
    height: 4.75rem;
    top: -1.65rem;
    right: -1.1rem;
    opacity: 0.55;
}

.fy-neighbor-card::after {
    width: 2.35rem;
    height: 2.35rem;
    bottom: -0.85rem;
    left: 0.65rem;
    opacity: 0.35;
}

.fy-neighbor-card:hover {
    border-color: rgba(47, 93, 80, 0.18);
    box-shadow: 0 6px 22px rgba(28, 28, 28, 0.05);
    opacity: 1;
}

html[data-fy-theme="dark"] .fy-neighbor-card:hover {
    border-color: rgba(106, 171, 152, 0.22);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.22);
}

.fy-neighbor--random {
    grid-template-columns: minmax(0, 1fr);
}

.fy-neighbor-random {
    align-items: flex-start;
}

.fy-neighbor-prev:only-child {
    grid-column: 1;
}

.fy-neighbor-next:only-child {
    grid-column: 2;
}

.fy-neighbor-next {
    text-align: right;
    align-items: flex-end;
}

.fy-neighbor-dir {
    position: relative;
    z-index: 1;
    font-size: 0.78rem;
    color: var(--fy-muted);
    letter-spacing: 0.02em;
}

.fy-neighbor-title {
    position: relative;
    z-index: 1;
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.45;
    color: var(--fy-text);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-decoration: none;
}

.fy-comments-area {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--fy-line);
}

.fy-comments {
    margin-bottom: 0;
}

.fy-comment-form-wrap {
    margin-top: 0;
    margin-bottom: 2.5rem;
    padding-top: 0;
    border-top: none;
}

.fy-comment-form-title {
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: none;
    color: var(--fy-text);
}

.fy-comment-form-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    margin-bottom: 0.85rem;
}

.fy-comment-form-head .fy-comment-form-title {
    margin: 0;
    flex: 0 1 auto;
    min-width: 0;
}

.fy-comment-avatar-picker {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    flex: 0 0 auto;
}

.fy-comment-avatar-option {
    display: block;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 50%;
    background: transparent;
    cursor: pointer;
    overflow: hidden;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.fy-comment-avatar-option img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.fy-comment-avatar-option:hover {
    transform: translateY(-1px);
}

.fy-comment-avatar-option.is-selected {
    border-color: var(--fy-accent);
    box-shadow: 0 0 0 2px var(--fy-accent-soft);
}

.fy-comment-compose {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

.fy-comment-compose-avatar {
    flex: 0 0 auto;
    width: 2.25rem;
    height: 2.25rem;
    margin-top: 0.15rem;
    border-radius: 50%;
    object-fit: cover;
    background: var(--fy-surface);
    border: 1px solid var(--fy-line);
}

.fy-comment-compose .fy-comment-editor-wrap {
    flex: 1;
    min-width: 0;
}

.fy-post-body .fy-video-player {
    position: relative;
    width: 100%;
    margin: 1.25rem 0;
    border-radius: 0.35rem;
    overflow: hidden;
    background: #000;
    aspect-ratio: 16 / 9;
}

.fy-post-body .fy-video-player iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    background: #000;
}

.fy-comment-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.fy-comment,
.fy-comment-reply {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
}

.fy-comment-thread {
    display: grid;
    grid-template-columns: 2.25rem minmax(0, 1fr);
    column-gap: 0.85rem;
    align-items: start;
    position: relative;
}

.fy-comment-thread-avatar {
    grid-column: 1;
    grid-row: 1;
    position: relative;
    z-index: 1;
}

.fy-comment-thread-body {
    grid-column: 2;
    grid-row: 1;
    position: relative;
    z-index: 1;
}

.fy-comment-rail-line {
    position: absolute;
    left: calc(2.25rem / 2 - 0.5px);
    top: calc(0.15rem + 2.25rem);
    bottom: 0;
    width: 1px;
    background: var(--fy-line);
    z-index: 0;
    pointer-events: none;
}

.fy-comment-replies {
    grid-column: 2;
    grid-row: 2;
    margin-top: 0.65rem;
    padding: 0.85rem;
    border-radius: calc(var(--fy-radius) + 0.12rem);
    background: rgba(28, 28, 28, 0.035);
    border: 1px solid var(--fy-line);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: relative;
    z-index: 1;
}

.fy-comment-reply {
    position: relative;
}

.fy-comment-reply::before {
    content: "";
    position: absolute;
    left: -0.85rem;
    top: 1.125rem;
    width: 0.85rem;
    height: 1px;
    background: var(--fy-line);
}

.fy-comment-index {
    display: inline-flex;
    align-items: center;
    font-size: 0.76rem;
    font-weight: 600;
    color: var(--fy-muted);
    letter-spacing: 0.02em;
    margin-left: auto;
    flex-shrink: 0;
}

.fy-comment-thread-body .fy-comment-meta,
.fy-comment-reply .fy-comment-meta {
    width: 100%;
}

.fy-comment-avatar {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    margin-top: 0.15rem;
    border: 1px solid var(--fy-line);
    background: var(--fy-surface);
}

.fy-comment-body {
    flex: 1;
    min-width: 0;
}

.fy-comment-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.75rem;
    margin-bottom: 0.4rem;
}

.fy-comment-author {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--fy-text);
}

.fy-comment-meta time {
    font-size: 0.78rem;
    color: var(--fy-muted);
}

.fy-comment-content {
    --fy-inline-emoji-size: 34px;
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--fy-text);
    word-break: break-word;
}

.fy-comment-content p {
    margin: 0 0 0.5rem;
}

.fy-comment-content p:last-child {
    margin-bottom: 0;
}

.fy-comment-content img.fy-sticker {
    display: inline-block;
    width: var(--fy-inline-emoji-size);
    height: var(--fy-inline-emoji-size);
    vertical-align: text-bottom;
    margin: 0 1px;
    object-fit: contain;
}

.fy-inline-emoji {
    display: inline-block;
    height: var(--fy-inline-emoji-size);
    line-height: var(--fy-inline-emoji-size);
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
    font-size: calc(var(--fy-inline-emoji-size) * 0.82);
    vertical-align: text-bottom;
    margin: 0 1px;
    white-space: nowrap;
    user-select: all;
}

.fy-comment-foot {
    margin-top: 0.55rem;
}

#comment-post {
    --fy-comment-post-pad-x: 1.1rem;
    --fy-comment-post-pad-y: 1rem;
    --fy-comment-editor-collapsed-h: 1.65em;
    --fy-comment-editor-expanded-h: calc(6.5rem * 4 / 3);
    position: relative;
    border: 1px solid var(--fy-line);
    border-radius: calc(var(--fy-radius) + 0.15rem);
    background: var(--fy-surface);
    padding: var(--fy-comment-post-pad-y) var(--fy-comment-post-pad-x);
}

#comment-post.is-inline {
    --fy-comment-post-pad-x: 0.95rem;
    --fy-comment-post-pad-y: 0.85rem;
    margin-top: 0.85rem;
    padding: var(--fy-comment-post-pad-y) var(--fy-comment-post-pad-x);
    background: var(--fy-bg);
}

.fy-comment-reply-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--fy-line);
    font-size: 0.82rem;
    color: var(--fy-muted);
}

.fy-comment-reply-bar[hidden] {
    display: none !important;
}

.fy-comment-reply-text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.fy-comment-reply-cancel {
    flex-shrink: 0;
    border: none;
    background: none;
    padding: 0;
    font: inherit;
    font-size: 0.82rem;
    color: var(--fy-accent);
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.fy-comment-reply-cancel:hover {
    opacity: 0.7;
}

.fy-comment-form {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.fy-comment-compose {
    margin: 0;
}

.fy-comment-editor-wrap {
    position: relative;
}

.fy-comment-emoji-panel {
    --fy-emoji-gap: 4px;
    --fy-emoji-cell-min: 2.625rem;
    --fy-emoji-sticker-size: 40px;
    position: absolute;
    inset: 0;
    z-index: 5;
    display: flex;
    flex-direction: column;
    border: none;
    border-radius: inherit;
    background: var(--fy-surface);
    box-shadow: none;
    padding: 8px 10px;
    opacity: 0;
    visibility: hidden;
    transform: scale(0.985);
    transform-origin: center center;
    pointer-events: none;
    transition:
        opacity 0.24s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.24s cubic-bezier(0.16, 1, 0.3, 1),
        visibility 0.24s;
}

#comment-post.is-inline .fy-comment-emoji-panel {
    background: var(--fy-bg);
}

.fy-comment-emoji-panel.is-panel-open {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
    pointer-events: auto;
}

.fy-comment-emoji-panel[hidden] {
    display: none !important;
}

.fy-comment-emoji-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: var(--fy-emoji-gap);
    margin-bottom: var(--fy-emoji-gap);
    padding-bottom: var(--fy-emoji-gap);
    border-bottom: 1px solid var(--fy-line);
}

.fy-comment-emoji-tab {
    border: none;
    background: transparent;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font: inherit;
    font-size: 0.78rem;
    color: var(--fy-muted);
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.fy-comment-emoji-tab:hover,
.fy-comment-emoji-tab.is-active {
    color: var(--fy-accent);
    background: var(--fy-accent-soft);
}

.fy-comment-emoji-list {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(47, 93, 80, 0.32) transparent;
}

.fy-comment-emoji-list::-webkit-scrollbar {
    width: 3px;
}

.fy-comment-emoji-list::-webkit-scrollbar-track {
    background: transparent;
}

.fy-comment-emoji-list::-webkit-scrollbar-thumb {
    background: rgba(47, 93, 80, 0.28);
    border-radius: 999px;
}

.fy-comment-emoji-list::-webkit-scrollbar-thumb:hover {
    background: rgba(47, 93, 80, 0.45);
}

.fy-comment-emoji-group {
    display: none;
    grid-template-columns: repeat(auto-fill, minmax(var(--fy-emoji-cell-min), 1fr));
    gap: var(--fy-emoji-gap);
}

.fy-comment-emoji-group.is-active {
    display: grid;
}

.fy-comment-emoji-item {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-width: 0;
    aspect-ratio: 1;
    border: none;
    background: transparent;
    border-radius: 0;
    font-size: 1.45rem;
    line-height: 1;
    cursor: pointer;
    --fy-emoji-hover-circle: min(var(--fy-emoji-sticker-size), calc(100% - 4px));
}

.fy-comment-emoji-item::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 0;
    width: calc(var(--fy-emoji-hover-circle) + 0.12rem);
    height: calc(var(--fy-emoji-hover-circle) + 0.12rem);
    border-radius: 50%;
    background: var(--fy-accent-soft);
    transform: translate(-50%, -50%) scale(0.85);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease, transform 0.16s ease;
}

.fy-comment-emoji-item:hover::before {
    opacity: 1;
    transform: translate(-50%, -50%) scale(0.92);
}

.fy-comment-emoji-glyph {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.fy-comment-emoji-item.is-sticker {
    --fy-sticker-size: min(var(--fy-emoji-sticker-size), calc(100% - 4px));
    --fy-emoji-hover-circle: var(--fy-sticker-size);
}

.fy-comment-emoji-item.is-sticker img {
    position: relative;
    z-index: 1;
    display: block;
    width: var(--fy-sticker-size);
    height: var(--fy-sticker-size);
    object-fit: contain;
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .fy-comment-emoji-panel {
        transition: none;
    }

    .fy-comment-editor {
        transition: none;
    }
}

.fy-comment-emoji-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--fy-comment-toolbar-h, 2.25rem);
    height: var(--fy-comment-toolbar-h, 2.25rem);
    flex-shrink: 0;
    border: 1px solid var(--fy-line);
    border-radius: 50%;
    background: var(--fy-surface);
    color: var(--fy-muted);
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.fy-comment-emoji-toggle svg {
    width: 1.15rem;
    height: 1.15rem;
    display: block;
}

.fy-comment-emoji-toggle:hover,
.fy-comment-emoji-toggle.is-open {
    color: var(--fy-accent);
    background: var(--fy-accent-soft);
    border-color: transparent;
}

.fy-comment-form .fy-textarea,
.fy-comment-editor {
    --fy-inline-emoji-size: 34px;
    margin-bottom: 0;
    min-height: var(--fy-comment-editor-collapsed-h, 1.65em);
    border-color: transparent;
    background: transparent;
    padding: 0;
    line-height: 1.65;
    word-break: break-word;
    white-space: pre-wrap;
    overflow: hidden;
    transition: min-height 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-comment-editor.is-expanded {
    min-height: var(--fy-comment-editor-expanded-h, calc(6.5rem * 4 / 3));
    overflow: auto;
}

.fy-comment-form .fy-textarea:focus,
.fy-comment-editor:focus {
    outline: none;
    box-shadow: none;
}

.fy-comment-editor:empty::before {
    content: attr(data-placeholder);
    color: var(--fy-muted);
    pointer-events: none;
}

.fy-comment-editor img.fy-sticker {
    display: inline-block;
    width: var(--fy-inline-emoji-size);
    height: var(--fy-inline-emoji-size);
    vertical-align: text-bottom;
    margin: 0 1px;
    object-fit: contain;
}

.fy-comment-editor .fy-inline-emoji {
    display: inline-block;
    height: var(--fy-inline-emoji-size);
    line-height: var(--fy-inline-emoji-size);
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
    font-size: calc(var(--fy-inline-emoji-size) * 0.82);
    vertical-align: text-bottom;
    margin: 0 1px;
    white-space: nowrap;
    user-select: all;
}

.fy-comment-editor-input {
    display: none !important;
}

.fy-comment-toolbar {
    --fy-comment-toolbar-h: 2.25rem;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    height: var(--fy-comment-toolbar-h);
    min-height: var(--fy-comment-toolbar-h);
}

.fy-comment-toolbar .fy-comment-emoji-toggle {
    margin-right: auto;
    align-self: center;
}

.fy-comment-toolbar .fy-comment-guest-meta {
    display: flex;
    flex: 0 0 auto;
    flex-wrap: nowrap;
    align-items: center;
    align-self: center;
    gap: 0.45rem;
    min-width: 0;
    height: var(--fy-comment-toolbar-h);
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transform: translateX(-0.65rem);
    transform-origin: left center;
    transition:
        max-width 0.42s cubic-bezier(0.16, 1, 0.3, 1),
        opacity 0.3s ease 0.04s,
        transform 0.42s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-comment-form.is-info-open .fy-comment-toolbar .fy-comment-guest-meta {
    flex: 1 1 0;
    max-width: 100%;
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

.fy-comment-toolbar .fy-comment-info {
    display: contents;
}

.fy-comment-toolbar .fy-comment-guest-field,
.fy-comment-toolbar .fy-comment-captcha input[name="imgcode"],
.fy-comment-toolbar .fy-comment-captcha .captcha_input {
    height: var(--fy-comment-toolbar-h);
    min-height: var(--fy-comment-toolbar-h);
    max-height: var(--fy-comment-toolbar-h);
    margin: 0;
    padding: 0 0.5rem;
    font: inherit;
    font-size: 0.84rem;
    line-height: 1;
    border: 1px solid var(--fy-line);
    border-radius: var(--fy-radius);
    background: var(--fy-surface);
    color: var(--fy-text);
    box-sizing: border-box;
    vertical-align: middle;
}

.fy-comment-toolbar .fy-comment-guest-field {
    flex: 1 1 0;
    min-width: 3rem;
    width: auto;
}

.fy-comment-toolbar .fy-comment-guest-meta.has-captcha .fy-comment-guest-field {
    flex: 1 1 0;
    min-width: 2.25rem;
}

.fy-comment-toolbar .fy-comment-guest-field:focus,
.fy-comment-toolbar .fy-comment-captcha input[name="imgcode"]:focus,
.fy-comment-toolbar .fy-comment-captcha .captcha_input:focus {
    outline: none;
    border-color: var(--fy-accent);
    box-shadow: 0 0 0 2px var(--fy-accent-soft);
}

.fy-comment-toolbar .fy-comment-captcha {
    display: flex;
    flex: 2 1 0;
    align-items: center;
    align-self: center;
    gap: 0.45rem;
    min-width: 0;
    height: var(--fy-comment-toolbar-h);
}

.fy-comment-toolbar .fy-comment-captcha img#captcha,
.fy-comment-toolbar .fy-comment-captcha img.captcha {
    flex-shrink: 0;
    display: block;
    height: var(--fy-comment-toolbar-h);
    width: auto;
    margin: 0;
    cursor: pointer;
    border-radius: calc(var(--fy-radius) - 0.05rem);
    border: 1px solid var(--fy-line);
    box-sizing: border-box;
}

.fy-comment-toolbar .fy-comment-captcha input[name="imgcode"],
.fy-comment-toolbar .fy-comment-captcha .captcha_input {
    flex: 1 1 0;
    min-width: 2.5rem;
    width: auto;
}

.fy-comment-toolbar .fy-comment-actions {
    display: flex;
    align-items: center;
    align-self: center;
    justify-content: flex-end;
    flex-shrink: 0;
    height: var(--fy-comment-toolbar-h);
    margin: 0;
}

.fy-comment-toolbar .fy-comment-submit-btn.fy-btn {
    min-width: 0;
    width: var(--fy-comment-toolbar-h);
    height: var(--fy-comment-toolbar-h);
    min-height: var(--fy-comment-toolbar-h);
    max-height: var(--fy-comment-toolbar-h);
    margin: 0;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    flex-shrink: 0;
    line-height: 1;
    box-sizing: border-box;
    border: none;
    background: var(--fy-accent-soft);
    color: var(--fy-accent);
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.fy-comment-toolbar .fy-comment-submit-btn.fy-btn:hover {
    background: var(--fy-accent);
    color: #fff;
    opacity: 1;
}

.fy-comment-login-tip {
    margin: 0;
    width: 100%;
    font-size: 0.9rem;
    color: var(--fy-muted);
    text-align: center;
}

.fy-comment-form .fy-btn-accent:not(.fy-comment-submit-btn) {
    width: auto;
    min-width: 6.5rem;
    flex-shrink: 0;
    padding: 0.55rem 1.1rem;
    white-space: nowrap;
}

.fy-comment-submit-icon {
    width: 1.15rem;
    height: 1.15rem;
    display: block;
}

.fy-reply {
    border: none;
    background: none;
    padding: 0.15rem 0;
    font: inherit;
    font-size: 0.8rem;
    color: var(--fy-muted);
    cursor: pointer;
    text-decoration: none;
    transition: color 0.2s ease;
}

.fy-reply:hover {
    color: var(--fy-accent);
    opacity: 1;
}

.fy-textarea,
.fy-input {
    width: 100%;
    border: 1px solid var(--fy-line);
    border-radius: var(--fy-radius);
    padding: 0.75rem 0.9rem;
    font: inherit;
    background: var(--fy-surface);
    color: var(--fy-text);
    margin-bottom: 0.75rem;
}

.fy-textarea {
    resize: vertical;
    min-height: 7rem;
}

.fy-btn {
    border: 1px solid var(--fy-text);
    background: var(--fy-text);
    color: var(--fy-surface);
    padding: 0.55rem 1.2rem;
    border-radius: var(--fy-radius);
    font: inherit;
    cursor: pointer;
}

.fy-btn-ghost {
    background: transparent;
    color: var(--fy-text);
}

.fy-pagination {
    margin-top: 2rem;
}

.fy-pagination-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.fy-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    color: var(--fy-muted);
    background: var(--fy-surface);
    border: 1px solid var(--fy-line);
    transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.fy-page-btn:hover {
    color: var(--fy-accent);
    border-color: rgba(47, 93, 80, 0.22);
    background: var(--fy-accent-soft);
    opacity: 1;
}

.fy-page-btn.is-disabled {
    opacity: 0.35;
    pointer-events: none;
}

.fy-page-arrow {
    width: 1rem;
    height: 1rem;
    display: block;
}

.fy-page-arrow--next {
    transform: scaleX(-1);
}

.fy-page-nums {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.fy-page-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    font-size: 0.88rem;
    color: var(--fy-muted);
    border: 1px solid transparent;
    transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.fy-page-num:hover {
    color: var(--fy-accent);
    background: var(--fy-accent-soft);
    opacity: 1;
}

.fy-page-num.is-current {
    color: var(--fy-accent);
    background: var(--fy-accent-soft);
    border-color: rgba(47, 93, 80, 0.14);
    font-weight: 500;
}

html[data-fy-theme="dark"] .fy-page-num.is-current {
    border-color: rgba(106, 171, 152, 0.2);
}

@media (max-width: 768px) {
    .fy-neighbor {
        gap: 0.65rem;
    }

    .fy-neighbor-card {
        padding: 0.85rem 0.75rem;
    }

    .fy-neighbor-dir {
        font-size: 0.72rem;
    }

    .fy-neighbor-title {
        font-size: 0.86rem;
        -webkit-line-clamp: 2;
    }

    .fy-post-meta {
        flex-wrap: wrap;
    }

    .fy-post-meta-left,
    .fy-post-meta-right {
        flex-wrap: wrap;
    }

    #comment-post {
        --fy-comment-post-pad-x: 0.9rem;
        --fy-comment-post-pad-y: 0.85rem;
        padding: var(--fy-comment-post-pad-y) var(--fy-comment-post-pad-x);
    }

    .fy-comment-form-head {
        flex-wrap: wrap;
        align-items: center;
    }

    .fy-comment-avatar-picker {
        width: 100%;
        justify-content: flex-start;
    }

    .fy-comment-avatar-option {
        width: 1.85rem;
        height: 1.85rem;
    }

    .fy-comment-toolbar .fy-comment-guest-field,
    .fy-comment-toolbar .fy-comment-captcha input[name="imgcode"],
    .fy-comment-toolbar .fy-comment-captcha .captcha_input {
        padding: 0 0.4rem;
        font-size: 0.8rem;
    }

    .fy-comment-toolbar .fy-comment-guest-field {
        min-width: 2.5rem;
    }

    .fy-comment-toolbar .fy-comment-guest-meta.has-captcha .fy-comment-guest-field {
        min-width: 2rem;
    }

    .fy-comment-toolbar .fy-comment-captcha input[name="imgcode"],
    .fy-comment-toolbar .fy-comment-captcha .captcha_input {
        min-width: 2rem;
    }
}

.markdown {
    overflow-wrap: break-word;
}

.markdown img {
    max-width: 100%;
    height: auto;
    border-radius: 0.2rem;
}

.markdown .fy-img-wrap {
    margin: 1.25rem 0;
}

.markdown .fy-img-wrap img {
    max-width: none;
    height: 100%;
    margin: 0;
    border-radius: inherit;
}

.markdown a {
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.markdown blockquote {
    margin: 1.5rem 0;
    padding-left: 1rem;
    border-left: 3px solid var(--fy-line);
    color: var(--fy-muted);
}

.fy-pw-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.5rem;
    background: var(--fy-bg);
}

.fy-pw-shell {
    width: 100%;
    max-width: 22rem;
}

.fy-pw-brand {
    display: block;
    margin-bottom: 2rem;
    text-align: center;
    font-size: 1.25rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--fy-text);
}

.fy-pw-brand:hover {
    opacity: 0.65;
}

.fy-pw-card {
    width: 100%;
    background: var(--fy-surface);
    border: 1px solid var(--fy-line);
    border-radius: 0.25rem;
    padding: 1.75rem 1.5rem 1.5rem;
    box-shadow: 0 10px 32px rgba(28, 28, 28, 0.05);
}

.fy-pw-eyebrow {
    margin: 0 0 0.65rem;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fy-muted);
}

.fy-pw-title {
    margin: 0 0 1.5rem;
    font-size: clamp(1.2rem, 3.5vw, 1.45rem);
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: -0.02em;
}

.fy-pw-fields {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.fy-pw-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.fy-pw-card .fy-input {
    margin-bottom: 0;
}

.fy-pw-input:focus {
    outline: none;
    border-color: var(--fy-accent);
    box-shadow: 0 0 0 3px var(--fy-accent-soft);
}

.fy-btn-accent {
    width: 100%;
    background: var(--fy-accent);
    border-color: var(--fy-accent);
    color: #fff;
    padding: 0.7rem 1.2rem;
    font-weight: 500;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.fy-btn-accent:hover {
    opacity: 0.9;
}

.fy-pw-back {
    display: block;
    margin-top: 1.25rem;
    text-align: center;
    font-size: 0.88rem;
    color: var(--fy-muted);
}

.fy-pw-back:hover {
    color: var(--fy-text);
    opacity: 1;
}

.fy-404-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    text-align: center;
}

.fy-404-code {
    font-size: clamp(4rem, 12vw, 7rem);
    font-weight: 600;
    line-height: 1;
    opacity: 0.12;
    margin: 0;
}

.fy-404-msg {
    margin: 0.5rem 0 1.5rem;
    color: var(--fy-muted);
}

.fy-dock-anchor {
    position: fixed;
    left: 0;
    right: 0;
    bottom: var(--fy-dock-bottom);
    z-index: 9999;
    display: flex;
    justify-content: center;
    pointer-events: none;
}

.fy-dock-anchor[hidden] {
    display: none !important;
}

.fy-dock-anchor.fy-dock-anchor--top-only:not(:has(.fy-dock.is-scrolled)) {
    display: none !important;
}

@media (max-width: 768px) {
    .fy-dock-anchor {
        transition: bottom 0.52s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .fy-dock-anchor.is-above-footer {
        bottom: var(--fy-dock-active-bottom);
    }
}

.fy-dock {
    position: relative;
    pointer-events: auto;
    display: inline-flex;
    align-items: center;
    gap: 0;
    height: var(--fy-dock-bar-h);
    padding: 4px;
    border: 1px solid var(--fy-line);
    border-radius: 999px;
    background: var(--fy-surface);
    box-shadow: 0 8px 28px rgba(28, 28, 28, 0.08);
    overflow: visible;
    transition:
        gap 0.32s cubic-bezier(0.16, 1, 0.3, 1),
        padding 0.32s cubic-bezier(0.16, 1, 0.3, 1),
        width 0.32s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-dock.is-scrolled {
    gap: 4px;
}

.fy-dock.fy-dock--solo {
    gap: 0;
    padding: 0;
    width: var(--fy-dock-bar-h);
    justify-content: center;
}

.fy-dock.fy-dock--solo.is-scrolled {
    width: auto;
    padding: 4px;
}

.fy-dock-btn--top {
    width: 0;
    min-width: 0;
    max-width: 0;
    flex: 0 0 0;
    opacity: 0;
    transform: translateX(10px);
    pointer-events: none;
    overflow: hidden;
    transition:
        width 0.32s cubic-bezier(0.16, 1, 0.3, 1),
        min-width 0.32s cubic-bezier(0.16, 1, 0.3, 1),
        max-width 0.32s cubic-bezier(0.16, 1, 0.3, 1),
        flex-basis 0.32s cubic-bezier(0.16, 1, 0.3, 1),
        opacity 0.28s ease,
        transform 0.32s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-dock:not(.is-scrolled) .fy-dock-btn--top {
    position: absolute;
    inset: 0 auto auto 0;
    width: 0;
    height: 0;
    min-width: 0;
    max-width: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    visibility: hidden;
}

.fy-dock.is-scrolled .fy-dock-btn--top {
    position: relative;
    visibility: visible;
    width: 36px;
    min-width: 36px;
    max-width: 36px;
    flex: 0 0 36px;
    height: auto;
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

.fy-dock-btn--music {
    border-radius: 50%;
}

.fy-dock-icon--music {
    position: relative;
    border-radius: 50%;
}

.fy-dock-btn--music.is-playing .fy-dock-icon--music {
    animation: fy-dock-music-bg-breathe 3.2s ease-in-out infinite;
}

@keyframes fy-dock-music-bg-breathe {
    0%,
    100% {
        background-color: transparent;
    }

    50% {
        background-color: var(--fy-accent-soft);
    }
}

.fy-dock-icon--music svg {
    position: absolute;
    inset: 0;
    margin: auto;
    width: 18px;
    height: 18px;
    z-index: 1;
    transition:
        opacity 0.28s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-dock-music-play {
    opacity: 1;
    transform: scale(1);
}

.fy-dock-music-pause {
    opacity: 0;
    transform: scale(0.72);
}

.fy-dock-btn--music.is-playing .fy-dock-music-play {
    opacity: 0;
    transform: scale(0.72);
}

.fy-dock-btn--music.is-playing .fy-dock-music-pause {
    opacity: 1;
    transform: scale(1);
}

.fy-dock-audio {
    position: absolute;
    width: 0;
    height: 0;
    opacity: 0;
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .fy-dock-btn--music.is-playing .fy-dock-icon--music {
        animation: none;
    }
}

.fy-dock-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--fy-text);
    border-radius: 999px;
    cursor: pointer;
    font: inherit;
    line-height: 1;
    transition: background-color 0.32s ease;
}

.fy-dock-btn:hover,
.fy-dock-btn:focus-visible {
    opacity: 1;
    outline: none;
    background: var(--fy-accent-soft);
}

.fy-dock-btn:active .fy-dock-icon {
    transform: scale(0.93);
}

.fy-dock-icon {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    flex-shrink: 0;
    transition: transform 0.14s ease;
}

.fy-dock-icon svg {
    width: 18px;
    height: 18px;
    display: block;
}

.fy-dock-icon-mark {
    display: block;
    width: 18px;
    height: 18px;
    background-color: currentColor;
    -webkit-mask-image: var(--fy-dock-mask);
    mask-image: var(--fy-dock-mask);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

.fy-dock-icon--img img {
    width: 18px;
    height: 18px;
    display: block;
    object-fit: contain;
    border-radius: 4px;
}

a.fy-dock-btn--link {
    text-decoration: none;
    color: inherit;
}

.fy-dock-text {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 10px);
    transform: translateX(-50%) translateY(4px);
    opacity: 0;
    pointer-events: none;
    white-space: nowrap;
    font-size: 0.78rem;
    line-height: 1.2;
    color: #fff;
    background: #1c1c1c;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    transition: opacity 0.24s cubic-bezier(0.16, 1, 0.3, 1), transform 0.24s cubic-bezier(0.16, 1, 0.3, 1);
    z-index: 2;
}

.fy-dock-btn:hover .fy-dock-text,
.fy-dock-btn:focus-visible .fy-dock-text {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.fy-dock-toast {
    position: fixed;
    left: 50%;
    bottom: calc(var(--fy-dock-active-bottom, var(--fy-dock-bottom)) + var(--fy-dock-bar-h) + 11px);
    transform: translateX(-50%) translateY(8px);
    z-index: 10000;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    background: var(--fy-text);
    color: var(--fy-surface);
    font-size: 0.82rem;
    line-height: 1.4;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.fy-dock-toast.is-visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.fy-overlay-toast {
    position: fixed;
    inset: 0;
    z-index: 10002;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    pointer-events: none;
}

.fy-overlay-toast:not([hidden]) {
    pointer-events: auto;
}

.fy-overlay-toast__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(16, 22, 20, 0.42);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    transition: opacity 0.28s ease;
}

.fy-overlay-toast.is-visible .fy-overlay-toast__backdrop {
    opacity: 1;
}

.fy-overlay-toast__card {
    position: relative;
    z-index: 1;
    width: min(18rem, calc(100% - 3rem));
    padding: 1.35rem 1.25rem 1.2rem;
    border-radius: calc(var(--fy-radius) + 0.35rem);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: var(--fy-surface);
    box-shadow:
        0 24px 60px rgba(18, 28, 24, 0.18),
        0 8px 24px rgba(18, 28, 24, 0.08);
    text-align: center;
    opacity: 0;
    transform: scale(0.94) translateY(10px);
    transition:
        opacity 0.28s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-overlay-toast.is-visible .fy-overlay-toast__card {
    opacity: 1;
    transform: scale(1) translateY(0);
}

.fy-overlay-toast__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    margin: 0 auto 0.85rem;
    border-radius: 50%;
    background: var(--fy-accent-soft);
    color: var(--fy-accent);
}

.fy-overlay-toast.is-error .fy-overlay-toast__icon {
    background: rgba(198, 74, 74, 0.12);
    color: #c64a4a;
}

.fy-overlay-toast__icon-svg {
    width: 1.65rem;
    height: 1.65rem;
    display: none;
}

.fy-overlay-toast__icon-svg--success {
    display: block;
}

.fy-overlay-toast.is-error .fy-overlay-toast__icon-svg--success {
    display: none;
}

.fy-overlay-toast.is-error .fy-overlay-toast__icon-svg--error {
    display: block;
}

.fy-overlay-toast__text {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--fy-text);
    letter-spacing: 0.01em;
}

body.fy-dock-image-open {
    overflow: hidden;
}

.fy-dock-image-modal {
    position: fixed;
    inset: 0;
    z-index: 10003;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    pointer-events: none;
}

.fy-dock-image-modal:not([hidden]) {
    pointer-events: auto;
}

.fy-dock-image-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(16, 22, 20, 0.48);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 0;
    transition: opacity 0.28s ease;
}

.fy-dock-image-modal.is-visible .fy-dock-image-modal__backdrop {
    opacity: 1;
}

.fy-dock-image-modal__panel {
    position: relative;
    z-index: 1;
    width: min(22rem, calc(100% - 2rem));
    padding: 1.1rem 1.1rem 1.25rem;
    border-radius: calc(var(--fy-radius) + 0.35rem);
    border: 1px solid var(--fy-line);
    background: var(--fy-surface);
    box-shadow:
        0 24px 60px rgba(18, 28, 24, 0.18),
        0 8px 24px rgba(18, 28, 24, 0.08);
    text-align: center;
    opacity: 0;
    transform: scale(0.94) translateY(10px);
    transition:
        opacity 0.28s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.fy-dock-image-modal.is-visible .fy-dock-image-modal__panel {
    opacity: 1;
    transform: scale(1) translateY(0);
}

.fy-dock-image-modal__close {
    position: absolute;
    top: 0.55rem;
    right: 0.55rem;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: var(--fy-muted);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
}

.fy-dock-image-modal__close:hover,
.fy-dock-image-modal__close:focus-visible {
    color: var(--fy-text);
    background: var(--fy-accent-soft);
    outline: none;
}

.fy-dock-image-modal__title {
    margin: 0 2rem 0.85rem 0;
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: var(--fy-muted);
    text-align: left;
}

.fy-dock-image-modal__img {
    display: block;
    width: 100%;
    max-height: min(70vh, 28rem);
    margin: 0 auto;
    object-fit: contain;
    border-radius: var(--fy-radius);
    background: var(--fy-bg);
}
