/*
Theme Name:   GoDigitopia
Theme URI:    https://godigitopia.com
Description:  Premium editorial child theme for godigitopia.com. Inter throughout, charcoal text on white canvas, violet→cyan brand accent. Soft hairline cards, generous whitespace, Stripe/Vercel-style minimalism. Built on Kadence parent.
Author:       GoDigitopia Editorial
Version:      1.0.0
Template:     kadence
Text Domain:  godigitopia-child
*/

/* ==========================================================================
   DESIGN TOKENS
   ========================================================================== */
:root {
    --fk-ink:        #0F172A;
    --fk-ink-muted:  #4B5563;
    --fk-ink-soft:   #6B7280;
    --fk-paper:      #FFFFFF;
    --fk-surface:    #F8FAFC;
    --fk-surface-2:  #F1F5F9;
    --fk-hairline:   #E5E7EB;
    --fk-hairline-2: #D1D5DB;
    --fk-blue:       #6D28D9;
    --fk-blue-hover: #5B21B6;
    --fk-blue-soft:  #EDE9FE;
    --fk-cyan:       #06B6D4;

    --fk-shadow-sm:  0 1px 2px rgba(15, 23, 42, 0.04);
    --fk-shadow-md:  0 4px 16px rgba(15, 23, 42, 0.06), 0 1px 2px rgba(15, 23, 42, 0.04);
    --fk-shadow-lg:  0 12px 32px rgba(15, 23, 42, 0.08), 0 2px 4px rgba(15, 23, 42, 0.04);

    --fk-container:  1140px;
    --fk-gutter:     clamp(1rem, 4vw, 2rem);
    --fk-radius:     12px;
    --fk-radius-sm:  8px;
    --fk-radius-lg:  16px;

    --fk-font:       "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    --fk-ease:       cubic-bezier(0.22, 1, 0.36, 1);
}

/* ==========================================================================
   BASE
   ========================================================================== */
html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body,
body.wp-singular,
.site,
.entry-content,
.content-container {
    background: var(--fk-paper) !important;
    color: var(--fk-ink) !important;
    font-family: var(--fk-font) !important;
    font-size: 17px;
    line-height: 1.65;
    font-weight: 400;
    font-feature-settings: "ss01", "kern";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection { background: var(--fk-blue); color: #FFF; }

img, video, iframe, embed, object, svg {
    max-width: 100%;
    height: auto;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[role="button"]:focus-visible {
    outline: 2px solid var(--fk-blue);
    outline-offset: 2px;
    border-radius: var(--fk-radius-sm);
}

.skip-link:focus {
    background: var(--fk-blue);
    color: #FFF;
    padding: 8px 16px;
    z-index: 10000;
}

/* ==========================================================================
   TYPOGRAPHY
   ========================================================================== */
h1, h2, h3, h4, h5, h6,
.entry-title, .page-title,
.wp-block-heading,
.kadence-title, .site-title {
    font-family: var(--fk-font) !important;
    color: var(--fk-ink) !important;
    font-weight: 700;
    letter-spacing: -0.025em;
    line-height: 1.15;
    margin-top: 1.5em;
    margin-bottom: 0.6em;
}

h1, .entry-title, .page-title {
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.05;
}
h2 { font-size: clamp(1.5rem, 2.8vw, 1.875rem); margin-top: 2em; }
h3 { font-size: clamp(1.25rem, 2vw, 1.4rem); margin-top: 1.6em; }
h4 { font-size: 1.15rem; }
h5 { font-size: 1.05rem; }
h6 { font-size: 0.95rem; }

p, ul, ol, blockquote {
    margin: 0 0 1.4em;
}

a {
    color: var(--fk-ink);
    text-decoration: none;
    transition: color 180ms var(--fk-ease);
}
a:hover { color: var(--fk-blue); }

.entry-content a:not(.button):not(.wp-block-button__link):not(.more-link):not(.bsmm-footer-grid a):not(.kadence-svg-iconset),
.bsmm-related-posts a {
    color: var(--fk-blue);
    text-decoration: underline;
    text-decoration-color: var(--fk-hairline-2);
    text-decoration-thickness: 1.5px;
    text-underline-offset: 3px;
}
.entry-content a:hover {
    text-decoration-color: var(--fk-blue);
    color: var(--fk-blue-hover);
}

strong, b { font-weight: 600; color: var(--fk-ink); }

blockquote {
    border-left: 3px solid var(--fk-blue);
    padding: 4px 0 4px 20px;
    margin: 32px 0;
    font-size: 1.15rem;
    line-height: 1.5;
    color: var(--fk-ink);
    font-weight: 500;
    font-style: normal;
}
blockquote p { margin-bottom: 0.4em; }
blockquote cite {
    display: block;
    font-size: 0.875rem;
    color: var(--fk-ink-soft);
    font-weight: 500;
    font-style: normal;
    margin-top: 0.5em;
}

ul, ol { padding-left: 1.5em; }
ul li, ol li { margin-bottom: 0.5em; }

code {
    background: var(--fk-surface);
    border: 1px solid var(--fk-hairline);
    border-radius: 4px;
    padding: 2px 6px;
    font-size: 0.9em;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
pre {
    background: var(--fk-ink);
    color: #F1F5F9;
    border-radius: var(--fk-radius);
    padding: 20px;
    overflow-x: auto;
    font-size: 0.9rem;
    line-height: 1.5;
    margin-bottom: 1.4em;
}
pre code { background: transparent; border: 0; padding: 0; color: inherit; }

hr {
    border: 0;
    border-top: 1px solid var(--fk-hairline);
    margin: 48px 0;
}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header,
.kadence-header,
#masthead {
    position: sticky !important;
    top: 0 !important;
    z-index: 100 !important;
    background: rgba(255, 255, 255, 0.85) !important;
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--fk-hairline) !important;
    box-shadow: none !important;
}
.site-header-inner-wrap,
.site-header-row-container-inner,
.site-header-main-section-wrap {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    background: transparent !important;
}

.site-branding img.custom-logo {
    height: 36px !important;
    width: auto !important;
    max-width: 200px;
}
@media (min-width: 768px) {
    .site-branding img.custom-logo { height: 40px !important; max-width: 220px; }
}

.site-branding .site-title,
.site-branding .site-title-wrap,
.site-branding .site-description {
    display: none !important;
}

.header-navigation .menu > li > a,
.main-navigation .menu > li > a {
    font-family: var(--fk-font) !important;
    font-size: 14.5px !important;
    font-weight: 500;
    color: var(--fk-ink-muted) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    padding: 8px 14px !important;
    border-radius: var(--fk-radius-sm) !important;
    transition: all 180ms var(--fk-ease);
    text-decoration: none !important;
}
.header-navigation .menu > li > a:hover {
    color: var(--fk-ink) !important;
    background: var(--fk-surface) !important;
}
.header-navigation .menu > li.current-menu-item > a,
.header-navigation .menu > li.current-menu-parent > a,
.header-navigation .menu > li.current-post-ancestor > a {
    color: var(--fk-ink) !important;
}
.header-navigation .menu > li.current-menu-item > a {
    box-shadow: none !important;
}

.header-mobile-navigation-style-standard .mobile-toggle-open {
    color: var(--fk-ink) !important;
    background: transparent !important;
    border: 0 !important;
}

/* ==========================================================================
   PAGE / ARCHIVE HEADER
   ========================================================================== */
.page-title-wrap,
.archive-header,
.entry-hero,
.entry-hero-container-inner {
    background: var(--fk-paper) !important;
    padding: 64px 0 32px !important;
    margin: 0 !important;
    border-bottom: 1px solid var(--fk-hairline);
}
@media (min-width: 768px) {
    .page-title-wrap,
    .archive-header,
    .entry-hero { padding: 96px 0 56px !important; }
}

.page-title-wrap .entry-header,
.archive-header .archive-header-inner,
.entry-hero-container-inner .entry-header {
    max-width: var(--fk-container);
    margin: 0 auto;
    padding: 0 var(--fk-gutter);
    text-align: left !important;
}

.archive-header h1,
.page-title-wrap .entry-title,
.entry-hero .entry-title {
    font-size: clamp(2rem, 5vw, 3rem) !important;
    font-weight: 800 !important;
    letter-spacing: -0.035em !important;
    line-height: 1.05 !important;
    color: var(--fk-ink) !important;
    margin: 0 0 16px !important;
    max-width: 22ch;
}

.archive-header .archive-description,
.page-description {
    font-size: clamp(1.05rem, 1.5vw, 1.25rem);
    color: var(--fk-ink-muted);
    line-height: 1.5;
    max-width: 56ch;
    font-weight: 400;
}

/* ==========================================================================
   ARCHIVE
   ========================================================================== */
ul#archive-container {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 auto !important;
    max-width: var(--fk-container);
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    padding: 48px var(--fk-gutter) !important;
}

@media (min-width: 700px) {
    ul#archive-container {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 32px 24px !important;
    }
}
@media (min-width: 1100px) {
    ul#archive-container {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (min-width: 768px) {
    ul#archive-container > li.entry-list-item:first-child {
        grid-column: 1 / -1 !important;
    }
    ul#archive-container > li.entry-list-item:first-child > article.loop-entry {
        display: grid !important;
        grid-template-columns: 1.15fr 1fr !important;
        align-items: stretch !important;
    }
    ul#archive-container > li:first-child article.loop-entry > a.post-thumbnail,
    ul#archive-container > li:first-child article.loop-entry > .post-thumbnail {
        margin: 0 !important;
        aspect-ratio: auto !important;
        min-height: 380px;
        height: 100%;
        overflow: hidden;
    }
    ul#archive-container > li:first-child article.loop-entry > .post-thumbnail .post-thumbnail-inner,
    ul#archive-container > li:first-child article.loop-entry > a.post-thumbnail .post-thumbnail-inner {
        height: 100%;
    }
    ul#archive-container > li:first-child article.loop-entry > .post-thumbnail img,
    ul#archive-container > li:first-child article.loop-entry > a.post-thumbnail img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }
    ul#archive-container > li:first-child .entry-content-wrap {
        padding: clamp(28px, 4vw, 48px) !important;
        display: flex !important;
        flex-direction: column;
        justify-content: center;
    }
    ul#archive-container > li:first-child .entry-title {
        font-size: clamp(1.5rem, 2.6vw, 2rem) !important;
    }
    ul#archive-container > li:first-child .entry-summary {
        display: block !important;
    }
}

/* ==========================================================================
   RELATED POSTS
   ========================================================================== */
.entry-related,
.entry-author,
.related-posts,
.related-posts-style-related,
.entry-related-carousel {
    display: none !important;
}

.bsmm-related {
    margin: 56px auto;
    max-width: 720px;
    padding: 0;
}
.bsmm-related-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fk-ink-soft) !important;
    margin: 0 0 20px !important;
    border: 0 !important;
    padding: 0 !important;
}
.bsmm-related-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}
@media (min-width: 700px) {
    .bsmm-related-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 16px;
    }
}
.bsmm-related-card {
    display: flex !important;
    flex-direction: column;
    background: var(--fk-paper);
    border: 1px solid var(--fk-hairline);
    border-radius: var(--fk-radius);
    overflow: hidden;
    text-decoration: none !important;
    transition: box-shadow 220ms var(--fk-ease), transform 220ms var(--fk-ease), border-color 220ms var(--fk-ease);
    color: var(--fk-ink) !important;
}
.bsmm-related-card:hover {
    box-shadow: var(--fk-shadow-md);
    transform: translateY(-2px);
    border-color: var(--fk-hairline-2);
}
.bsmm-related-thumb {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--fk-surface);
}
.bsmm-related-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    transition: transform 600ms var(--fk-ease);
}
.bsmm-related-card:hover .bsmm-related-thumb img { transform: scale(1.03); }
.bsmm-related-body {
    padding: 16px;
}
.bsmm-related-cat {
    font-size: 12px;
    font-weight: 600;
    color: var(--fk-blue) !important;
    margin-bottom: 6px;
    display: block;
}
.bsmm-related-h {
    font-size: 14.5px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    letter-spacing: -0.015em !important;
    color: var(--fk-ink) !important;
    margin: 0 !important;
    border: 0 !important;
    padding: 0 !important;
}
.bsmm-related-card:hover .bsmm-related-h { color: var(--fk-blue) !important; }

/* Card itself */
.entry.loop-entry,
article.loop-entry {
    background: var(--fk-paper) !important;
    border: 1px solid var(--fk-hairline) !important;
    border-radius: var(--fk-radius-lg) !important;
    overflow: hidden !important;
    box-shadow: var(--fk-shadow-sm);
    padding: 0 !important;
    transition: box-shadow 220ms var(--fk-ease), transform 220ms var(--fk-ease), border-color 220ms var(--fk-ease);
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}
.entry.loop-entry:hover {
    box-shadow: var(--fk-shadow-md) !important;
    transform: translateY(-2px);
    border-color: var(--fk-hairline-2) !important;
}

.loop-entry .post-thumbnail,
.loop-entry .post-thumbnail.kadence-thumbnail-ratio-2-3,
.loop-entry .post-thumbnail.kadence-thumbnail-ratio-3-4,
.loop-entry .post-thumbnail.kadence-thumbnail-ratio-1-1,
.loop-entry .post-thumbnail.kadence-thumbnail-ratio-9-16,
.loop-entry .post-thumbnail.kadence-thumbnail-ratio-1-2 {
    margin: 0 !important;
    aspect-ratio: 16 / 10 !important;
    background: var(--fk-surface);
    overflow: hidden;
    border-radius: 0 !important;
    padding-bottom: 0 !important;
    height: auto !important;
    position: relative;
}
.loop-entry .post-thumbnail .post-thumbnail-inner {
    aspect-ratio: 16 / 10 !important;
    height: auto !important;
    padding-bottom: 0 !important;
}
.loop-entry .post-thumbnail img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    position: absolute !important;
    inset: 0;
    transition: transform 600ms var(--fk-ease);
}
.loop-entry:hover .post-thumbnail img { transform: scale(1.03); }

.loop-entry .entry-content-wrap {
    padding: 24px !important;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.loop-entry .entry-meta {
    font-size: 12.5px !important;
    color: var(--fk-ink-soft) !important;
    margin-bottom: 12px !important;
    border: 0 !important;
    padding: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 500;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
.loop-entry .entry-meta > span,
.loop-entry .entry-meta a {
    color: var(--fk-ink-soft) !important;
    font-weight: 500 !important;
}
.loop-entry .entry-meta a:hover { color: var(--fk-ink) !important; }
.loop-entry .entry-meta .category-style,
.loop-entry .category-style,
.loop-entry .post-categories a {
    color: var(--fk-blue) !important;
    font-weight: 600 !important;
}

.loop-entry .entry-title {
    font-size: clamp(1.1rem, 1.6vw, 1.25rem) !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em !important;
    line-height: 1.25 !important;
    margin: 0 0 10px !important;
}
.loop-entry .entry-title a {
    color: var(--fk-ink) !important;
    text-decoration: none !important;
}
.loop-entry .entry-title a:hover { color: var(--fk-blue) !important; }

.loop-entry .entry-summary,
.loop-entry .entry-summary p {
    color: var(--fk-ink-muted) !important;
    font-size: 14.5px !important;
    line-height: 1.55 !important;
    margin: 0 0 16px !important;
    max-width: none;
}

.loop-entry .more-link {
    margin-top: auto;
    font-size: 13px;
    font-weight: 600;
    color: var(--fk-blue) !important;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    align-self: flex-start;
}
.loop-entry .more-link::after {
    content: "→";
    transition: transform 180ms var(--fk-ease);
}
.loop-entry:hover .more-link::after { transform: translateX(3px); }

/* ==========================================================================
   SINGLE POST
   ========================================================================== */
.single .entry-hero-container-inner,
.single .page-title-wrap,
.single .entry-header {
    text-align: left !important;
}

.single .entry-hero-container-inner .entry-header,
.single .page-title-wrap .entry-header {
    max-width: 720px;
    margin: 0 auto;
    padding: 80px var(--fk-gutter) 32px;
}

.single .entry-title {
    font-size: clamp(2rem, 4vw, 3rem) !important;
    font-weight: 800 !important;
    letter-spacing: -0.03em !important;
    line-height: 1.08 !important;
    margin: 16px 0 20px !important;
    max-width: 22ch;
}

.single .entry-meta-divider-dot,
.single .entry-categories,
.single .entry-categories-style-pill {
    margin: 0 0 16px !important;
    border: 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
}
.single .post-categories a,
.single .entry-categories a,
.single .category-style {
    display: inline-block;
    background: var(--fk-blue-soft);
    color: var(--fk-blue) !important;
    font-weight: 600 !important;
    padding: 5px 11px !important;
    border-radius: 6px !important;
    font-size: 12.5px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
    margin: 0 6px 0 0 !important;
    border: 0 !important;
}
.single .post-categories a:hover {
    background: var(--fk-blue);
    color: #FFF !important;
}

.single .entry-meta {
    display: flex !important;
    align-items: center;
    gap: 12px;
    padding: 16px 0 !important;
    border-top: 1px solid var(--fk-hairline) !important;
    border-bottom: 1px solid var(--fk-hairline) !important;
    font-size: 14px !important;
    color: var(--fk-ink-soft) !important;
    margin: 32px 0 0 !important;
    flex-wrap: wrap;
}
.single .entry-meta a {
    color: var(--fk-ink) !important;
    font-weight: 500;
    text-decoration: none !important;
}
.single .entry-meta .author-meta a { font-weight: 600; }

.single .post-thumbnail,
.single .featured-image,
.single .single-featured-image,
.single .article-post-thumbnail,
.single .article-post-thumbnail.kadence-thumbnail-ratio-2-3,
.single .article-post-thumbnail.kadence-thumbnail-ratio-3-4,
.single .article-post-thumbnail.kadence-thumbnail-ratio-1-1,
.single .article-post-thumbnail.kadence-thumbnail-ratio-9-16,
.single .article-post-thumbnail.kadence-thumbnail-ratio-1-2 {
    max-width: 1000px !important;
    margin: 32px auto 48px !important;
    padding: 0 var(--fk-gutter) !important;
    position: static !important;
    z-index: auto !important;
    aspect-ratio: auto !important;
    height: auto !important;
}
.single .post-thumbnail::after,
.single .article-post-thumbnail::after,
.single .kadence-thumbnail-position-behind::after {
    display: none !important;
    background: none !important;
    content: none !important;
}
.single .post-thumbnail-inner,
.single .article-post-thumbnail .post-thumbnail-inner {
    overflow: hidden;
    border-radius: var(--fk-radius-lg);
    background: var(--fk-surface);
    aspect-ratio: auto !important;
    height: auto !important;
    padding-bottom: 0 !important;
}
.single .post-thumbnail img,
.single .featured-image img,
.single .article-post-thumbnail img,
.single .post-top-featured {
    border-radius: var(--fk-radius-lg) !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
    position: static !important;
}

.single .entry-content {
    max-width: 720px !important;
    margin: 0 auto !important;
    padding: 0 var(--fk-gutter) !important;
    font-size: 17px !important;
    line-height: 1.75 !important;
    color: var(--fk-ink) !important;
}
.single .entry-content > * { max-width: 720px; }
.single .entry-content > .alignwide,
.single .entry-content > .alignfull {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

.single .entry-content p {
    color: var(--fk-ink) !important;
    margin: 0 0 24px !important;
    font-size: 17px !important;
    line-height: 1.75 !important;
}
.single .entry-content > p:first-of-type {
    font-size: clamp(1.1rem, 2vw, 1.3rem) !important;
    line-height: 1.5 !important;
    color: var(--fk-ink-muted) !important;
    font-weight: 400;
    margin-bottom: 32px !important;
}

.single .entry-content h2 {
    font-size: clamp(1.5rem, 3vw, 1.875rem) !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    line-height: 1.2 !important;
    margin: 56px 0 16px !important;
    border: 0 !important;
    padding: 0 !important;
}
.single .entry-content h3 {
    font-size: clamp(1.2rem, 2vw, 1.4rem) !important;
    font-weight: 700 !important;
    margin: 40px 0 12px !important;
    border: 0 !important;
    padding: 0 !important;
}

.single .entry-content ul li,
.single .entry-content ol li {
    margin-bottom: 10px;
}

.single .entry-content h3 + p {
    color: var(--fk-ink-muted) !important;
}

/* ==========================================================================
   POST BADGES (published / updated / reading time)
   ========================================================================== */
.bsmm-post-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 24px !important;
}
.bsmm-badge {
    display: inline-block;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid var(--fk-hairline);
    color: var(--fk-ink-soft);
    background: var(--fk-paper);
}
.bsmm-badge-updated {
    background: var(--fk-blue-soft);
    color: var(--fk-blue);
    border-color: transparent;
}

/* ==========================================================================
   METHODOLOGY NOTICE (reviews)
   ========================================================================== */
.bsmm-methodology-notice {
    background: var(--fk-surface);
    border: 1px solid var(--fk-hairline);
    border-left: 3px solid var(--fk-blue);
    padding: 14px 18px;
    border-radius: var(--fk-radius-sm);
    font-size: 14.5px;
    color: var(--fk-ink-muted);
    margin: 0 0 32px;
}
.bsmm-methodology-notice a {
    color: var(--fk-blue);
    font-weight: 600;
    text-decoration: underline;
    text-decoration-color: var(--fk-hairline-2);
    text-underline-offset: 3px;
}

/* ==========================================================================
   BREADCRUMBS
   ========================================================================== */
.bsmm-breadcrumbs {
    max-width: 720px;
    margin: 0 auto;
    padding: 24px var(--fk-gutter) 0;
    font-size: 13px;
    color: var(--fk-ink-soft);
}
.bsmm-breadcrumbs a {
    color: var(--fk-ink-soft);
    text-decoration: none;
}
.bsmm-breadcrumbs a:hover { color: var(--fk-blue); }

/* ==========================================================================
   AUTHOR BOX
   ========================================================================== */
.author-box,
.entry-author-style-center {
    background: var(--fk-surface) !important;
    border: 1px solid var(--fk-hairline) !important;
    border-radius: var(--fk-radius) !important;
    padding: 24px !important;
    margin: 48px auto !important;
    max-width: 720px;
}

/* ==========================================================================
   ToC
   ========================================================================== */
#ez-toc-container {
    background: var(--fk-surface) !important;
    border: 1px solid var(--fk-hairline) !important;
    border-radius: var(--fk-radius) !important;
    box-shadow: none !important;
    padding: 20px !important;
}
#ez-toc-container .ez-toc-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--fk-ink) !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
#ez-toc-container ul li a {
    color: var(--fk-ink-muted) !important;
    text-decoration: none !important;
    font-size: 14px !important;
}
#ez-toc-container ul li a:hover { color: var(--fk-blue) !important; }

/* ==========================================================================
   POST NAVIGATION
   ========================================================================== */
.post-navigation {
    max-width: 720px;
    margin: 56px auto 0;
    padding: 24px var(--fk-gutter) 0;
    border-top: 1px solid var(--fk-hairline);
}
.post-navigation .nav-links {
    display: flex !important;
    justify-content: space-between;
    gap: 16px;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
}
.post-navigation .nav-previous,
.post-navigation .nav-next {
    flex: 1;
    max-width: 48%;
}
.post-navigation .nav-next { text-align: right; }
.post-navigation a {
    display: block;
    padding: 16px 20px;
    background: var(--fk-paper);
    border: 1px solid var(--fk-hairline);
    border-radius: var(--fk-radius);
    color: var(--fk-ink) !important;
    text-decoration: none !important;
    font-size: 14.5px;
    font-weight: 600;
    transition: border-color 180ms var(--fk-ease), box-shadow 180ms var(--fk-ease);
}
.post-navigation a:hover {
    border-color: var(--fk-blue);
    box-shadow: var(--fk-shadow-sm);
    color: var(--fk-blue) !important;
}
.post-navigation .post-navigation-sub small {
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fk-ink-soft);
    margin-bottom: 4px;
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */
.pagination,
.nav-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    padding: 56px var(--fk-gutter);
    max-width: var(--fk-container);
    margin: 0 auto;
}
.pagination a,
.pagination span,
.nav-links a,
.nav-links span,
.page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    min-height: 40px;
    padding: 8px 14px;
    font-weight: 500;
    color: var(--fk-ink) !important;
    background: var(--fk-paper);
    border: 1px solid var(--fk-hairline);
    border-radius: var(--fk-radius-sm);
    text-decoration: none !important;
    transition: all 180ms var(--fk-ease);
}
.pagination a:hover {
    border-color: var(--fk-blue);
    color: var(--fk-blue) !important;
}
.pagination .current,
.page-numbers.current {
    background: var(--fk-ink) !important;
    color: var(--fk-paper) !important;
    border-color: var(--fk-ink) !important;
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.button,
.wp-block-button__link,
input[type="submit"],
button.submit,
.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--fk-ink);
    color: var(--fk-paper) !important;
    font-family: inherit;
    font-size: 15px;
    font-weight: 600;
    padding: 11px 20px;
    border-radius: var(--fk-radius-sm) !important;
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 180ms var(--fk-ease);
}
.button:hover,
.wp-block-button__link:hover,
input[type="submit"]:hover {
    background: var(--fk-blue);
    color: #FFF !important;
    transform: translateY(-1px);
    box-shadow: var(--fk-shadow-md);
}
.wp-block-button.is-style-outline .wp-block-button__link {
    background: var(--fk-paper);
    color: var(--fk-ink) !important;
    border-color: var(--fk-hairline-2);
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
    border-color: var(--fk-ink);
    color: var(--fk-ink) !important;
    background: var(--fk-paper);
}

/* ==========================================================================
   FORMS
   ========================================================================== */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea,
select {
    background: var(--fk-paper);
    border: 1px solid var(--fk-hairline-2);
    border-radius: var(--fk-radius-sm);
    padding: 11px 14px;
    font-family: inherit;
    font-size: 15px;
    color: var(--fk-ink);
    width: 100%;
    transition: border-color 180ms var(--fk-ease), box-shadow 180ms var(--fk-ease);
}
input:focus,
textarea:focus,
select:focus {
    outline: 0;
    border-color: var(--fk-blue);
    box-shadow: 0 0 0 3px var(--fk-blue-soft);
}
label {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 6px;
    display: block;
    color: var(--fk-ink);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer,
.site-footer-wrap,
.site-footer-inner-wrap,
.footer-html,
.bsmm-footer-top {
    background: var(--fk-paper) !important;
    color: var(--fk-ink) !important;
    border-top: 1px solid var(--fk-hairline);
}
.site-footer .footer-html-inner,
.site-footer .bsmm-footer-grid {
    color: var(--fk-ink) !important;
    padding: 64px var(--fk-gutter) 32px;
    max-width: var(--fk-container);
    margin: 0 auto;
}
.bsmm-footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}
@media (min-width: 768px) {
    .bsmm-footer-grid { grid-template-columns: repeat(4, 1fr); }
}

.site-footer a {
    color: var(--fk-ink-muted) !important;
    text-decoration: none !important;
    transition: color 180ms var(--fk-ease);
}
.site-footer a:hover { color: var(--fk-ink) !important; }

.site-footer h4,
.site-footer .widget-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fk-ink-soft) !important;
    margin-bottom: 16px !important;
}

.site-footer .menu {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.site-footer .menu li::before { display: none; }
.site-footer .menu a {
    font-size: 14.5px;
    font-weight: 500;
    border: 0 !important;
    padding: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.site-info,
.site-footer-wrap .site-info-wrap,
.bsmm-footer-bottom {
    background: var(--fk-paper) !important;
    color: var(--fk-ink-soft) !important;
    font-size: 13px;
    border-top: 1px solid var(--fk-hairline) !important;
    padding: 24px var(--fk-gutter) !important;
}
.site-info-wrap-inner {
    max-width: var(--fk-container);
    margin: 0 auto;
}

/* ==========================================================================
   BACK TO TOP BUTTON
   ========================================================================== */
#bsmm-to-top {
    position: fixed;
    right: 20px;
    bottom: 20px;
    width: 44px;
    height: 44px;
    background: var(--fk-ink);
    color: #fff;
    border: 0;
    border-radius: 50%;
    cursor: pointer;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--fk-shadow-md);
    transition: background 180ms var(--fk-ease), transform 180ms var(--fk-ease);
}
#bsmm-to-top:hover {
    background: var(--fk-blue);
    transform: translateY(-2px);
}

/* ==========================================================================
   ADD-TO-ANY
   ========================================================================== */
.addtoany_share_save_container {
    margin: 32px 0;
    padding: 16px 0;
    border-top: 1px solid var(--fk-hairline);
    border-bottom: 1px solid var(--fk-hairline);
}
.addtoany_list a:not(.addtoany_special_service) {
    background: var(--fk-surface) !important;
    border-radius: var(--fk-radius-sm) !important;
    transition: background 180ms var(--fk-ease);
}
.addtoany_list a:not(.addtoany_special_service):hover {
    background: var(--fk-blue-soft) !important;
}
.addtoany_list a svg { fill: var(--fk-ink) !important; }

/* ==========================================================================
   COMMENTS
   ========================================================================== */
.comments-area {
    max-width: 720px;
    margin: 64px auto;
    padding: 0 var(--fk-gutter);
}
.comments-title { font-size: 1.5rem; font-weight: 700; }

/* ==========================================================================
   SIDEBAR / WIDGETS
   ========================================================================== */
.widget-area .widget,
.sidebar-primary .widget {
    background: var(--fk-surface);
    border: 1px solid var(--fk-hairline);
    border-radius: var(--fk-radius);
    padding: 20px;
    margin-bottom: 24px;
}
.widget-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fk-ink-soft) !important;
    margin-bottom: 12px !important;
    border: 0 !important;
    padding: 0 !important;
}

/* ==========================================================================
   MOBILE
   ========================================================================== */
@media (max-width: 767px) {
    .archive-header,
    .single .entry-header,
    .page-title-wrap { padding: 56px var(--fk-gutter) 32px !important; }
    .archive-header .archive-header-inner,
    .single .entry-header { padding: 0 !important; }

    .kadence-posts-list,
    ul#archive-container { padding: 32px var(--fk-gutter) !important; gap: 16px !important; }

    .kadence-posts-list > li:first-child > article.loop-entry,
    ul#archive-container > li:first-child > article.loop-entry {
        grid-template-columns: 1fr !important;
    }

    .single .entry-content { padding: 0 var(--fk-gutter) !important; }
    .single .post-thumbnail { padding: 0 var(--fk-gutter) !important; margin: 24px auto 32px !important; }
    .single .post-thumbnail img { border-radius: var(--fk-radius) !important; }

    .button, .wp-block-button__link, input[type="submit"] { min-height: 44px; padding: 12px 18px; }
    .pagination a, .pagination span { min-width: 44px; min-height: 44px; }
}

/* ==========================================================================
   ACCESSIBILITY
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .loop-entry:hover { transform: none !important; }
    .loop-entry:hover .post-thumbnail img { transform: none !important; }
}

/* ==========================================================================
   PRINT
   ========================================================================== */
@media print {
    .site-header, .site-footer, .nav-links, .addtoany_share_save_container,
    .pagination, .related-posts, #ez-toc-container { display: none !important; }
    body { background: #FFF !important; color: #000 !important; }
    a { color: #000 !important; text-decoration: underline !important; }
}
