/* ============================================
   Custom styles for Matthew Sakhno
   Discord-like dark theme + compact archive cards
   ============================================ */

:root {
    --contrast: #333333;
    --contrast-2: #666666;
    --contrast-3: #888888;
    --base: #ffffff;
    --base-2: #ffffff;
    --base-3: #ffffff;
    --accent: #4e4bec;
}

html, body {
    background-color: #ffffff !important;
    color: #333333 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "avenir next", avenir, "helvetica neue", helvetica, ubuntu, roboto, noto, "segoe ui", arial, sans-serif !important;
}

/* Hide byline / categories / comments / footer credit */
.byline,
.author.vcard,
.cat-links,
.category-links,
.entry-meta .cat-links,
.post-meta .cat-links,
article .cat-links,
.comments-link,
.entry-meta .comments-link,
.post-meta .comments-link,
article .comments-link,
.comment-reply-title,
.comment-form,
#respond,
.comments-area,
#comments,
.commentlist,
.comment-list,
.comment-respond,
.site-info,
.footer-credits,
.copyright-powered-by,
.generatepress-credit,
[class*="credit"],
[class*="powered"],
.site-footer .inside-footer-widgets p:last-child {
    display: none !important;
}

/* Move logo slightly up */
.custom-logo {
    margin-top: -10px;
}

.newsletter {
    margin-top: 10px !important;
}

/* Light minimalist palette inspired by kenp.io */
.site-header,
.inside-header,
.main-navigation,
.main-navigation ul ul,
.mobile-menu-control-wrapper .menu-toggle,
.main-navigation .menu-toggle,
.has-inline-mobile-toggle #site-navigation.toggled,
.separate-containers .inside-article,
.separate-containers .comments-area,
.separate-containers .page-header,
.one-container .container,
.separate-containers .paging-navigation,
.inside-page-header,
.site-content .content-area .site-main article {
    background-color: var(--base) !important;
    color: var(--contrast) !important;
    border: none !important;
    box-shadow: none !important;
}

/* Align the site title with the homepage content column */
.inside-header {
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: min(832px, calc(100% - 32px)) !important;
    max-width: 832px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
}

.site-branding,
.main-title,
.main-title a {
    text-align: left !important;
}

.main-title a {
    font-size: 28px !important;
    line-height: 1.1 !important;
}

@media (max-width: 768px) {
    .inside-header {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 16px !important;
        padding-right: 6px !important;
    }

    .site-branding {
        display: block !important;
        width: 100% !important;
        text-align: left !important;
    }

    .main-title,
    .main-title a {
        text-align: left !important;
    }

    .main-title a {
        font-size: 25px !important;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .inside-header,
    .home-intro,
    .home .inside-article {
        width: min(832px, calc(100% - 32px)) !important;
        margin-left: auto !important;
        margin-right: auto !important;
        box-sizing: border-box;
    }

    .inside-header,
    .home-intro,
    .home .inside-article {
        padding-left: 40px !important;
        padding-right: 56px !important;
    }

    body.single .inside-header {
        padding-left: 40px !important;
        padding-right: 40px !important;
        box-sizing: border-box !important;
    }

    .home-projects {
        width: auto !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 !important;
        content-visibility: auto;
        contain-intrinsic-size: 1200px;
    }

    .home-projects h2 {
        margin: 0 0 1rem !important;
        padding: 0 !important;
    }
}

.site-header .main-title {
    margin: 0 !important;
    font-size: 2em !important;
    line-height: 1.1 !important;
    font-weight: 700 !important;
}

.site-header .main-title a {
    font-weight: 700 !important;
}

.home .entry-title,
.home .entry-title a {
    font-weight: 400 !important;
}

/* Remove divider lines between cards and under the header */
.home .inside-article + .inside-article,
.blog .inside-article + .inside-article,
.archive .inside-article + .inside-article,
.site-header,
.inside-header,
.page-header,
.separate-containers .page-header,
.separate-containers .inside-article {
    border-top: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

.site-header a,
.main-navigation a,
.menu-toggle,
.menu-toggle:hover,
.menu-toggle:focus,
.site-branding a,
.site-branding a:hover,
.site-title a,
.site-title a:hover,
.main-title a,
.main-title a:hover {
    color: var(--contrast) !important;
}

.entry-title a,
h1, h2, h3, h4, h5, h6,
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
    color: var(--contrast) !important;
}

a {
    color: var(--accent) !important;
}

a:hover,
a:focus,
a:active,
.main-navigation .main-nav ul li:not([class*="current-menu-"]):hover > a,
.main-navigation .main-nav ul li:not([class*="current-menu-"]):focus > a,
.main-navigation .main-nav ul li.sfHover:not([class*="current-menu-"]) > a,
.main-navigation .main-nav ul li[class*="current-menu-"] > a,
h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover, h5 a:hover, h6 a:hover,
.entry-title a:hover {
    color: #5eead4 !important;
}

.home-intro,
.home-intro p,
.home-intro h1,
.home-intro h2,
.home-intro h3,
.home-intro h4,
.home-intro h5,
.home-intro h6,
.home-intro a,
.entry-meta,
.entry-meta a,
.posted-on,
.posted-on a,
.cat-links,
.cat-links a {
    color: #333333 !important;
}

/* Hide empty nav / hamburger */
.main-navigation,
.main-navigation .main-nav,
.main-navigation .inside-navigation,
.main-navigation .menu-toggle,
.mobile-menu-control-wrapper,
.nav-aligned-right .main-navigation,
.nav-aligned-left .main-navigation {
    display: none !important;
}

/* Archive/home cards: image right of title, small squircle */
.archive .inside-article,
.blog .inside-article,
.home .inside-article {
    display: grid !important;
    grid-template-columns: 1fr 92px;
    grid-template-areas:
        "header image";
    gap: 14px 20px;
    align-items: center;
    padding: 18px !important;
    border-radius: 18px;
    background-color: var(--base) !important;
    border: none !important;
}

.home .inside-article {
    max-width: 52rem !important;
    margin-left: auto !important;
    margin-right: auto !important;
    content-visibility: auto;
    contain-intrinsic-size: 220px;
}

.archive .entry-header,
.blog .entry-header,
.home .entry-header {
    grid-area: header;
    padding: 0 !important;
    margin: 0 !important;
}

.home .entry-header {
    padding-right: 48px !important;
    box-sizing: border-box !important;
}

.archive .entry-summary,
.blog .entry-summary,
.home .entry-summary,
.archive .entry-summary p,
.blog .entry-summary p,
.home .entry-summary p,
.archive .entry-content,
.blog .entry-content,
.home .entry-content {
    display: none !important;
}

.archive .post-image,
.blog .post-image {
    grid-area: image;
    justify-self: end;
    align-self: center;
    width: 92px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
    border-radius: 24px !important;
    aspect-ratio: 1 / 1;
    background: rgba(255,255,255,0.03);
}

.home .post-image {
    grid-area: image;
    justify-self: end;
    align-self: center;
    width: 160px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
    border-radius: 24px !important;
    aspect-ratio: 1 / 1;
    background: rgba(255,255,255,0.03);
}

.archive .post-image img,
.blog .post-image img,
.home .post-image img,
.archive .wp-post-image,
.blog .wp-post-image,
.home .wp-post-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 24px !important;
}

.archive .entry-title,
.blog .entry-title,
.home .entry-title {
    margin: 0 0 0.15em !important;
    line-height: 1.25;
}

.home .entry-title {
    padding-right: 0 !important;
    max-width: calc(100% - 24px) !important;
    box-sizing: border-box !important;
}

.archive .entry-title a,
.blog .entry-title a,
.home .entry-title a {
    color: var(--contrast) !important;
}

.archive .entry-title a:hover,
.blog .entry-title a:hover,
.home .entry-title a:hover {
    color: var(--accent) !important;
}

img,
picture,
video,
iframe,
.wp-block-image img,
.featured-image img,
.post-image img,
.entry-content img,
.site-logo img {
    border-radius: 18px !important;
}

/* Single posts: keep content readable and images constrained */
.single-post .entry-content,
.single-post .entry-content .wp-block-group__inner-container {
    max-width: none !important;
    line-height: 1.58 !important;
}

.single-post .entry-content p,
.single-post .entry-content li {
    line-height: 1.58 !important;
    margin-bottom: 1.1em !important;
}

.single-post .entry-content h2,
.single-post .entry-content h3,
.single-post .entry-content h4 {
    line-height: 1.22 !important;
    margin-top: 1.5em !important;
    margin-bottom: 0.7em !important;
}

.single-post .entry-title {
    margin-bottom: 0.6em !important;
    padding-bottom: 0 !important;
    border-bottom: 0 !important;
    font-size: 28px !important;
    line-height: 1.2 !important;
    text-align: left !important;
}

.single-post .entry-meta {
    margin-top: 0 !important;
}

.single-post .entry-meta time.entry-date {
    display: block;
    padding-top: 0 !important;
}

.single-post .entry-content img,
.single-post .entry-content .wp-block-image img,
.single-post .entry-content .featured-image img,
.single-post .entry-content figure img {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    display: block;
}

@media (max-width: 768px) {
    .single-post .entry-header,
    .single-post .entry-content {
        padding-left: 16px !important;
        padding-right: 16px !important;
        box-sizing: border-box !important;
    }
}

@media (min-width: 769px) {
    .single-post .site.grid-container.container.hfeed,
    .single-post .site-content,
    .single-post .content-area,
    .single-post .site-content .content-area,
    .single-post .site-content .content-area .site-main,
    .single-post .site-content .content-area .site-main article,
    .single-post .inside-article {
        width: min(52rem, calc(100% - 80px)) !important;
        max-width: 52rem !important;
        margin-left: auto !important;
        margin-right: auto !important;
        float: none !important;
    }

    .single-post .inside-article {
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
    }

    .single-post .entry-header,
    .single-post .entry-content {
        padding-left: 40px !important;
        padding-right: 40px !important;
        box-sizing: border-box !important;
    }

    .single-post .entry-content figure,
    .single-post .entry-content .wp-block-image {
        max-width: 560px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        margin-top: 1.5em !important;
        margin-bottom: 1.5em !important;
    }

    .single-post .entry-content img,
    .single-post .entry-content .wp-block-image img,
    .single-post .entry-content .featured-image img,
    .single-post .entry-content figure img {
        width: auto !important;
        max-width: 560px !important;
        height: auto !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

/* No sidebar */
.site-content .content-area,
.site-content .content-area .site-main,
.site-content .content-area .site-main article {
    width: 100% !important;
    max-width: 100% !important;
}

.separate-containers .inside-article,
.separate-containers .page-header,
.separate-containers .comments-area,
.separate-containers .paging-navigation,
.inside-page-header {
    padding-left: 40px !important;
    padding-right: 40px !important;
}

.is-right-sidebar,
.is-left-sidebar {
    display: none !important;
}

/* Main article spacing */
.separate-containers .site-main > *:last-child {
    margin-bottom: 0;
}

/* Mobile tweaks */
@media (max-width: 768px) {
    .archive .inside-article,
    .blog .inside-article,
    .home .inside-article {
        grid-template-columns: minmax(0, 1fr) 84px;
        gap: 4px;
        padding: 16px !important;
    }

    .archive .entry-header,
    .blog .entry-header,
    .home .entry-header {
        min-width: 0;
    }

    .home .entry-header {
        padding-right: 0 !important;
    }

    .archive .entry-title,
    .blog .entry-title,
    .home .entry-title {
        font-size: clamp(1.55rem, 6vw, 2rem);
        line-height: 1.08;
        overflow-wrap: anywhere;
        word-break: normal;
    }

    .home .entry-title {
        max-width: none !important;
    }

    .site-content .content-area,
    .site-content .content-area .site-main,
    .site-content .content-area .site-main article {
        width: 100% !important;
        max-width: 100% !important;
    }

    .separate-containers .inside-article,
    .separate-containers .page-header,
    .separate-containers .comments-area,
    .separate-containers .paging-navigation,
    .inside-page-header {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .single-post .inside-article,
    .single-post .entry-content,
    .single-post .entry-content .wp-block-group__inner-container {
        padding-left: 4px !important;
        padding-right: 4px !important;
        max-width: none !important;
    }

    .single-post .entry-content img,
    .single-post .entry-content .wp-block-image img,
    .single-post .entry-content .featured-image img,
    .single-post .entry-content figure img {
        max-width: 100% !important;
        width: 100% !important;
        height: auto !important;
    }

    .archive .post-image,
    .blog .post-image {
        width: 64px !important;
        border-radius: 20px !important;
        margin-left: 8px !important;
    }

    .home .post-image {
        width: 84px !important;
        border-radius: 16px !important;
        margin-left: 0 !important;
        justify-self: end;
    }
}


@media (min-width: 769px) and (max-width: 1024px) {
    .home.separate-containers .inside-article {
        padding-left: 40px !important;
        padding-right: 40px !important;
    }
}

@media (min-width: 1025px) {
    .home.separate-containers .inside-article {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}
