/*
Theme Name: Stalk.dev Gothic
Theme URI: https://stalk.dev
Description: A standalone Gothic Comic Realism theme for stalk.dev. Medium-style layout with ink-stained parchment aesthetic, blood-red accents, crosshatch textures, and dramatic noir typography. No Elementor required.
Author: stalk.dev
Author URI: https://stalk.dev
Version: 1.0.0
Tags: dark, gothic, blog, custom-menu, featured-images, sticky-post, threaded-comments
Text Domain: stalkdev
License: Private
*/

/* ═══════════════════════════════════════════════════════
   GOTHIC COMIC REALISM — VARIABLES
   ═══════════════════════════════════════════════════════ */
:root {
    --ink:          #0d0a08;
    --ink-2:        #110e0b;
    --ink-3:        #1a1410;
    --parchment:    #f2ead8;
    --parchment-2:  #e8dcc4;
    --bone:         #c8b99a;
    --ash:          #3d3530;
    --ash-2:        #2a2420;
    --blood:        #8b0000;
    --blood-2:      #6b0000;
    --blood-bright: #c0392b;
    --gold:         #b8922a;
    --font-display: 'Cinzel Decorative', serif;
    --font-body:    'Special Elite', cursive;
    --font-mono:    'Courier Prime', monospace;
    --font-serif:   'IM Fell English', serif;
    --header-height:64px;
    --content-max:  1100px;
    --reading-max:  740px;
    --shadow-ink:   0 4px 24px rgba(0,0,0,.7);
    --border-ink:   1px solid rgba(139,0,0,.25);
}

/* ═══════════════════════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    background-color:var(--ink);
    background-image:
        repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(255,255,255,.012) 2px,rgba(255,255,255,.012) 4px),
        repeating-linear-gradient(-45deg,transparent,transparent 2px,rgba(255,255,255,.008) 2px,rgba(255,255,255,.008) 4px);
    color:var(--parchment);
    font-family:var(--font-body);
    font-size:16px;
    line-height:1.7;
    min-height:100vh;
    padding-top:var(--header-height);
}
body.modal-open{overflow:hidden;padding-right:15px}
body.sidebar-open,body.comments-sidebar-open{overflow:hidden}
a{color:var(--blood-bright);text-decoration:none;transition:color .2s}
a:hover{color:var(--parchment)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--parchment);line-height:1.3;letter-spacing:.05em}
img{max-width:100%;height:auto;display:block}
input,textarea,select,button{font-family:inherit}
.site-wrapper{max-width:var(--content-max);margin:0 auto;padding:0 20px}
#content{min-height:100vh}

/* ═══════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════ */
#custom-main-header{
    position:fixed;top:0;left:0;width:100%;height:var(--header-height);z-index:1000;
    background:rgba(13,10,8,.97);
    border-bottom:2px solid var(--blood);
    box-shadow:0 2px 20px rgba(139,0,0,.3),0 4px 40px rgba(0,0,0,.8);
    display:flex;align-items:center;padding:0 24px;
}
#custom-main-header::before{
    content:'';position:absolute;inset:0;pointer-events:none;
    background-image:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,.015) 3px,rgba(255,255,255,.015) 4px);
}
.header-content-wrapper{width:100%;max-width:var(--content-max);margin:0 auto;position:relative;z-index:1}
.logged-out-container,.logged-in-container{display:flex;align-items:center;gap:16px;width:100%}
.site-branding{margin-right:auto}
.site-branding a,.site-branding-footer a{
    font-family:var(--font-display);font-size:1rem;font-weight:900;
    color:var(--parchment);letter-spacing:.1em;
    text-shadow:1px 1px 0 var(--blood),2px 2px 0 rgba(0,0,0,.5);
    text-decoration:none;
}
.custom-logo-link img{max-height:36px;width:auto;filter:sepia(.2)}
#header-navigation{flex-grow:1;padding:0 16px}
.header-menu-list{display:flex;list-style:none;gap:16px}
.header-menu-list a{
    font-family:var(--font-mono);font-size:.72rem;letter-spacing:.15em;
    text-transform:uppercase;color:var(--bone);opacity:.8;
    text-decoration:none;transition:color .2s,opacity .2s;
}
.header-menu-list a:hover{color:var(--blood-bright);opacity:1}
.header-action-link{
    font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;
    color:var(--bone);text-decoration:none;opacity:.8;transition:opacity .2s;
}
.header-action-link:hover{opacity:1;color:var(--parchment)}
.get-started-btn{
    background:transparent;border:1px solid var(--blood);color:var(--parchment);
    font-family:var(--font-display);font-size:.6rem;font-weight:700;
    letter-spacing:.2em;text-transform:uppercase;padding:7px 16px;
    cursor:pointer;box-shadow:2px 2px 0 var(--blood-2);transition:all .15s;
}
.get-started-btn:hover{background:var(--blood);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--blood-2);color:var(--parchment)}
.menu-toggle-button,.profile-image-btn{
    background:none;border:none;color:var(--parchment);cursor:pointer;
    padding:6px;border-radius:50%;transition:background .2s;display:flex;align-items:center;
}
.menu-toggle-button:hover,.profile-image-btn:hover{background:rgba(139,0,0,.2)}
.header-search-form{flex-grow:1;max-width:360px;margin:0 10px;position:relative}
.header-search-form input[type="search"]{
    width:100%;height:36px;
    background:rgba(255,255,255,.04)!important;border:1px solid var(--ash)!important;
    border-left:2px solid var(--blood)!important;color:var(--parchment)!important;
    font-family:var(--font-mono)!important;font-size:.78rem!important;
    padding:0 12px 0 34px!important;border-radius:0!important;outline:none;
    transition:border-color .2s;
}
.header-search-form input[type="search"]:focus{border-color:var(--blood-bright)!important}
.header-search-form::before{
    content:'search';font-family:'Material Icons';position:absolute;
    left:8px;top:50%;transform:translateY(-50%);
    color:var(--ash);font-size:18px;pointer-events:none;
}
.header-action-btn{
    display:flex;align-items:center;gap:5px;
    font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
    padding:6px 10px;text-decoration:none;color:var(--parchment);transition:background .2s;
}
.header-action-btn:hover{background:rgba(139,0,0,.2);color:var(--parchment)}
.header-action-btn .material-icons{font-size:18px}
.write-btn{
    background:var(--blood)!important;box-shadow:2px 2px 0 var(--blood-2);
    color:var(--parchment)!important;font-size:.65rem;border:none;
}
.write-btn:hover{background:var(--blood-bright)!important}
.profile-image-btn img{width:32px;height:32px;border-radius:50%;border:2px solid var(--blood);filter:sepia(.3)}

/* ═══════════════════════════════════════════════════════
   ANNOUNCEMENT BAR
   ═══════════════════════════════════════════════════════ */
#announcement-bar-wrapper{display:none}
#announcement-bar{
    background:linear-gradient(90deg,var(--blood-2),var(--blood),var(--blood-2));
    border-bottom:1px solid var(--blood-bright);padding:8px 24px;
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
    color:var(--parchment);border-radius:0;border:none;box-shadow:none;
}
.announcement-content{flex:1}
.announcement-content a{color:var(--parchment-2)}
#close-announcement{
    background:none;border:none;color:var(--parchment);
    cursor:pointer;opacity:.7;transition:opacity .2s;display:flex;align-items:center;
}
#close-announcement:hover{opacity:1}

/* ═══════════════════════════════════════════════════════
   HOME LAYOUT
   ═══════════════════════════════════════════════════════ */
.home-layout{display:flex;gap:40px;padding:40px 0 60px;align-items:flex-start}
#main-post-feed{flex:1;min-width:0}
.gothic-section-divider{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.gothic-section-divider::before,.gothic-section-divider::after{
    content:'';flex:1;height:1px;
    background:linear-gradient(to right,transparent,var(--blood),transparent);
}
.gothic-section-title{
    font-family:var(--font-display);font-size:.65rem;letter-spacing:.3em;
    color:var(--blood-bright);text-transform:uppercase;white-space:nowrap;
}
.section-title-gothic{
    font-family:var(--font-display);font-size:.75rem;letter-spacing:.25em;
    color:var(--gold);text-transform:uppercase;display:flex;align-items:center;gap:8px;
    margin-bottom:20px;
}
.section-title-gothic .material-icons{font-size:1rem;color:var(--gold)}
.featured-staff-pick-large{margin-bottom:48px;padding-bottom:40px;border-bottom:1px solid rgba(139,0,0,.3)}

/* ═══════════════════════════════════════════════════════
   HOME FEED CARDS
   ═══════════════════════════════════════════════════════ */
.home-feed-list{display:flex;flex-direction:column;gap:0}
.home-feed-item{
    display:flex;gap:20px;padding:24px 0;
    border-bottom:1px solid var(--ash-2);position:relative;
    animation:feedIn .5s ease both;transition:background .2s;
}
.home-feed-item:hover{background:rgba(139,0,0,.03)}
@keyframes feedIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.feed-thumbnail-wrap{
    flex-shrink:0;width:155px;height:105px;overflow:hidden;
    border:1px solid var(--ash);box-shadow:3px 3px 0 var(--blood-2);position:relative;
}
.feed-thumbnail-wrap::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,transparent 60%,rgba(139,0,0,.15));pointer-events:none;
}
.feed-thumbnail-wrap img{
    width:100%;height:100%;object-fit:cover;
    filter:sepia(.15) contrast(1.05);transition:filter .3s,transform .4s;
}
.home-feed-item:hover .feed-thumbnail-wrap img{filter:sepia(.05) contrast(1.1);transform:scale(1.04)}
.feed-no-image{
    width:100%;height:100%;background:var(--ash-2);display:flex;
    align-items:center;justify-content:center;
    color:var(--ash);font-family:var(--font-display);font-size:.45rem;
    letter-spacing:.2em;text-transform:uppercase;
}
.feed-content-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:7px}
.feed-author-row{display:flex;align-items:center;gap:8px}
.feed-author-row img{width:20px;height:20px;border-radius:50%;border:1px solid var(--blood);filter:sepia(.3);flex-shrink:0}
.feed-author-name{
    font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;
    text-transform:uppercase;color:var(--bone);text-decoration:none;transition:color .2s;
}
.feed-author-name:hover{color:var(--blood-bright)}
.feed-title{font-family:var(--font-display);font-size:1rem;font-weight:700;line-height:1.35;letter-spacing:.03em;margin:0}
.feed-title a{color:var(--parchment);text-decoration:none;transition:color .2s}
.feed-title a:hover{color:var(--blood-bright)}
.feed-excerpt{
    font-family:var(--font-body);font-size:.83rem;color:var(--bone);line-height:1.6;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.feed-meta{display:flex;align-items:center;gap:10px;margin-top:auto;padding-top:5px}
.feed-meta-item{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.1em;color:var(--ash);text-transform:uppercase}
.feed-category-tag{
    font-family:var(--font-mono);font-size:.55rem;letter-spacing:.1em;
    color:var(--blood-bright);text-transform:uppercase;
    border:1px solid rgba(139,0,0,.3);padding:2px 7px;text-decoration:none;transition:all .15s;
}
.feed-category-tag:hover{background:rgba(139,0,0,.2);color:var(--parchment)}
.load-more-wrap{text-align:center;padding:28px 0}
#load-more-btn{
    background:transparent;border:1px solid var(--blood);color:var(--parchment);
    font-family:var(--font-display);font-size:.6rem;letter-spacing:.25em;
    text-transform:uppercase;padding:10px 28px;cursor:pointer;
    box-shadow:3px 3px 0 var(--blood-2);transition:all .15s;
}
#load-more-btn:hover{background:var(--blood);transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--blood-2)}
#infinite-scroll-loader{text-align:center;padding:20px;display:none}
.gothic-spinner{
    width:22px;height:22px;border:2px solid var(--ash);
    border-top-color:var(--blood-bright);border-radius:50%;
    animation:spin .7s linear infinite;margin:0 auto;
}
@keyframes spin{to{transform:rotate(360deg)}}
.end-of-content-message{
    font-family:var(--font-mono);font-size:.62rem;letter-spacing:.25em;
    color:var(--ash);text-transform:uppercase;text-align:center;padding:20px 0;
}

/* ═══════════════════════════════════════════════════════
   HOME SIDEBAR
   ═══════════════════════════════════════════════════════ */
#home-sidebar{
    width:290px;flex-shrink:0;position:sticky;
    top:calc(var(--header-height) + 20px);
    max-height:calc(100vh - var(--header-height) - 40px);
    overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--blood-2) transparent;
}
.home-sidebar-section{margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--ash-2)}
.home-sidebar-section:last-child{border-bottom:none}
.staff-pick-card{display:flex;flex-direction:column;gap:10px}
.staff-pick-thumb{display:block;overflow:hidden;border:1px solid var(--ash);box-shadow:3px 3px 0 var(--blood-2)}
.staff-pick-thumb img{
    width:100%;height:150px;object-fit:cover;
    filter:sepia(.2) contrast(1.05);transition:filter .3s,transform .4s;
}
.staff-pick-thumb:hover img{filter:sepia(.05);transform:scale(1.04)}
.staff-pick-author{display:flex;align-items:center;gap:7px}
.staff-pick-author img{width:20px;height:20px;border-radius:50%;border:1px solid var(--blood);filter:sepia(.3)}
.staff-pick-author-name{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;color:var(--bone);text-transform:uppercase;text-decoration:none}
.staff-pick-title{font-family:var(--font-display);font-size:.82rem;line-height:1.4;margin:0}
.staff-pick-title a{color:var(--parchment)}
.staff-pick-title a:hover{color:var(--blood-bright)}
.staff-pick-excerpt{
    font-family:var(--font-body);font-size:.76rem;color:var(--bone);
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.home-sidebar-section .widget-title{
    font-family:var(--font-mono);font-size:.6rem;letter-spacing:.25em;
    color:var(--blood-bright);text-transform:uppercase;margin-bottom:12px;
}
.about-stalkdev p{font-family:var(--font-body);font-size:.8rem;color:var(--bone);line-height:1.7}
.about-stalkdev a{
    font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;
    color:var(--blood-bright);text-transform:uppercase;border-bottom:1px dotted var(--blood);
    text-decoration:none;display:inline-block;margin-top:10px;
}

/* ═══════════════════════════════════════════════════════
   SINGLE POST
   ═══════════════════════════════════════════════════════ */
.single-post-wrap{max-width:var(--reading-max);margin:0 auto;padding:48px 0 80px}
.post-categories{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.category-tag{
    font-family:var(--font-mono);font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;
    color:var(--blood-bright);border:1px solid rgba(139,0,0,.4);padding:3px 10px;
    text-decoration:none;transition:all .15s;
}
.category-tag:hover{background:rgba(139,0,0,.2);color:var(--parchment)}
.entry-header .entry-title{
    font-family:var(--font-display);
    font-size:clamp(1.5rem,4vw,2.4rem);font-weight:900;
    line-height:1.2;letter-spacing:.04em;margin-bottom:22px;
    color:var(--parchment);text-shadow:2px 2px 0 var(--blood),4px 4px 0 rgba(0,0,0,.3);
}
.entry-featured-image{
    margin-bottom:26px;overflow:hidden;
    border:1px solid var(--ash);box-shadow:5px 5px 0 var(--blood-2),8px 8px 0 rgba(0,0,0,.4);
    position:relative;
}
.entry-featured-image::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,transparent 70%,rgba(139,0,0,.1));pointer-events:none;
}
.featured-image-single{width:100%;height:auto;filter:sepia(.1) contrast(1.06);display:block}
.post-meta-author{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:36px;padding-bottom:22px;border-bottom:1px solid var(--ash-2);
}
.author-info{display:flex;align-items:center;gap:12px}
.author-info img{width:40px;height:40px;border-radius:50%;border:2px solid var(--blood);filter:sepia(.3)}
.author-details{display:flex;flex-direction:column;gap:2px}
.author-name{
    font-family:var(--font-mono);font-size:.76rem;letter-spacing:.1em;
    text-transform:uppercase;color:var(--parchment);text-decoration:none;
}
.author-name:hover{color:var(--blood-bright)}
.post-date{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;color:var(--ash);text-transform:uppercase}
.entry-content{
    font-family:var(--font-serif);font-size:1.05rem;line-height:1.85;color:var(--parchment-2);
}
.entry-content p{margin-bottom:1.4em}
.entry-content h2{
    font-family:var(--font-display);font-size:1.25rem;color:var(--parchment);
    letter-spacing:.06em;margin:2em 0 .8em;border-left:3px solid var(--blood);padding-left:14px;
}
.entry-content h3{
    font-family:var(--font-display);font-size:.95rem;color:var(--blood-bright);
    letter-spacing:.1em;text-transform:uppercase;margin:1.5em 0 .6em;
}
.entry-content a{color:var(--blood-bright);border-bottom:1px dotted var(--blood)}
.entry-content a:hover{color:var(--parchment);border-bottom-style:solid}
.entry-content blockquote{
    border-left:3px solid var(--blood);background:rgba(139,0,0,.08);
    padding:16px 20px;margin:1.5em 0;font-style:italic;color:var(--bone);
}
.entry-content code{
    background:rgba(0,0,0,.4);border:1px solid var(--ash);color:var(--blood-bright);
    font-family:var(--font-mono);font-size:.85em;padding:2px 6px;
}
.entry-content pre{
    background:var(--ink-2);border:1px solid var(--ash);border-left:3px solid var(--blood);
    padding:16px;overflow-x:auto;margin:1.5em 0;
}
.entry-content img{margin:1.5em 0;box-shadow:4px 4px 0 var(--blood-2)}
.entry-content ul,.entry-content ol{padding-left:1.4em;margin-bottom:1.4em}
.entry-content li{margin-bottom:.4em}
.entry-content ul li::marker{color:var(--blood)}
.entry-footer{margin-top:44px;padding-top:22px;border-top:1px solid var(--ash-2)}
.post-bottom-interaction-bar{display:flex;align-items:center;justify-content:space-between}
.left-actions,.right-actions{display:flex;align-items:center;gap:8px}
.left-actions button,.right-actions button{
    background:none;border:none;color:var(--ash);cursor:pointer;
    display:flex;align-items:center;gap:4px;
    font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;
    padding:6px;transition:color .2s;
}
.left-actions button:hover,.right-actions button:hover{color:var(--blood-bright)}
.left-actions button.liked{color:var(--blood-bright)!important}
.likes-count,.comment-count{font-family:var(--font-mono);font-size:.75rem;color:var(--bone);min-width:16px}

/* ═══════════════════════════════════════════════════════
   COMMENTS
   ═══════════════════════════════════════════════════════ */
.comments-area{margin-top:60px;padding-top:30px;border-top:2px solid var(--blood)}
.comments-title{
    font-family:var(--font-display);font-size:.78rem;letter-spacing:.25em;
    color:var(--blood-bright);text-transform:uppercase;margin-bottom:24px;
}
.comment-list{list-style:none;padding:0}
.comment-list li{margin-bottom:0}
.comment-body{padding:18px 0;border-bottom:1px solid var(--ash-2)}
.comment-author.vcard{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px}
.comment-author img{width:38px;height:38px;border-radius:50%;border:2px solid var(--blood);filter:sepia(.3);flex-shrink:0}
.comment-meta{display:flex;flex-direction:column;gap:2px}
.comment-meta .fn{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--parchment)}
.comment-meta .fn a{color:var(--parchment);text-decoration:none}
.comment-meta time,.commentmetadata a{
    font-family:var(--font-mono);font-size:.58rem;letter-spacing:.08em;color:var(--ash);
    text-transform:uppercase;text-decoration:none;
}
.comment-content{font-family:var(--font-body);font-size:.88rem;color:var(--bone);line-height:1.7;margin-left:50px}
.comment-content p{margin-bottom:.5em}
.comment-interaction{margin-left:50px;margin-top:7px;display:flex;gap:12px}
.comment-interaction a,.comment-interaction .reply a{
    font-family:var(--font-mono);font-size:.58rem;letter-spacing:.1em;
    text-transform:uppercase;color:var(--ash);text-decoration:none;transition:color .2s;
}
.comment-interaction a:hover{color:var(--blood-bright)}
.comment-awaiting-moderation{font-family:var(--font-mono);font-size:.62rem;color:var(--ash);font-style:italic}
.no-comments{font-family:var(--font-body);font-size:.85rem;color:var(--ash);text-align:center;padding:20px 0}
.view-more-comments-button{
    display:block;margin:18px auto 0;background:transparent;
    border:1px solid var(--blood);color:var(--parchment);
    font-family:var(--font-display);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
    padding:8px 20px;cursor:pointer;box-shadow:2px 2px 0 var(--blood-2);transition:all .15s;
}
.view-more-comments-button:hover{background:var(--blood);transform:translate(-1px,-1px)}
.comment-reply-title{
    font-family:var(--font-display);font-size:.72rem;letter-spacing:.2em;
    text-transform:uppercase;color:var(--blood-bright);margin-bottom:14px;margin-top:28px;
}
#commentform{margin-top:22px}
.comment-form-comment textarea{
    width:100%;background:rgba(255,255,255,.03)!important;
    border:1px solid var(--ash)!important;border-left:2px solid var(--blood)!important;
    color:var(--parchment)!important;font-family:var(--font-body)!important;
    font-size:.9rem!important;padding:14px!important;border-radius:0!important;
    resize:vertical;min-height:110px;outline:none;transition:border-color .2s;box-sizing:border-box;
}
.comment-form-comment textarea:focus{border-color:var(--blood-bright)!important}
.comment-form-comment textarea::placeholder{color:var(--ash);font-style:italic}
#commentform .submit{
    background:var(--blood)!important;border:none!important;color:var(--parchment)!important;
    font-family:var(--font-display)!important;font-size:.58rem!important;
    letter-spacing:.2em!important;text-transform:uppercase!important;
    padding:10px 24px!important;cursor:pointer;box-shadow:3px 3px 0 var(--blood-2);
    border-radius:0!important;margin-top:12px;transition:all .15s;
}
#commentform .submit:hover{background:var(--blood-bright)!important;transform:translate(-1px,-1px)}
.logged-in-as{font-family:var(--font-mono);font-size:.62rem;color:var(--ash);margin-bottom:12px;letter-spacing:.05em}
.logged-in-as a{color:var(--blood-bright)}

/* ═══════════════════════════════════════════════════════
   RELATED POSTS
   ═══════════════════════════════════════════════════════ */
.related-posts-section{margin-top:60px;padding-top:30px;border-top:1px solid var(--ash-2)}
.related-posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.related-post-card{
    background:var(--ink-2);border:var(--border-ink);overflow:hidden;position:relative;
    transition:transform .2s,box-shadow .2s;animation:fadeInUp .5s ease both;
}
.related-post-card::before{
    content:'';position:absolute;top:0;left:0;width:12px;height:12px;
    border-top:2px solid var(--blood);border-left:2px solid var(--blood);z-index:1;pointer-events:none;
}
.related-post-card:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--blood-2)}
.related-post-thumb{width:100%;height:110px;overflow:hidden}
.related-post-thumb img{
    width:100%;height:100%;object-fit:cover;
    filter:sepia(.2) contrast(1.05);transition:filter .3s,transform .4s;
}
.related-post-card:hover .related-post-thumb img{filter:sepia(.05);transform:scale(1.05)}
.related-post-no-img{
    width:100%;height:100%;background:var(--ash-2);
    display:flex;align-items:center;justify-content:center;color:var(--ash);font-size:1.4rem;
}
.related-post-content{padding:12px}
.related-post-title{font-family:var(--font-display);font-size:.72rem;line-height:1.4;letter-spacing:.03em;margin-bottom:5px}
.related-post-title a{color:var(--parchment);text-decoration:none}
.related-post-title a:hover{color:var(--blood-bright)}
.related-post-meta{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.08em;color:var(--ash);text-transform:uppercase}
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════
   FLOATING BAR
   ═══════════════════════════════════════════════════════ */
#floating-interaction-bar{
    position:fixed;bottom:100px;left:50%;
    transform:translateX(-50%) translateX(-430px);
    z-index:500;background:var(--ink-2);
    border:1px solid var(--blood);box-shadow:3px 3px 0 var(--blood-2),var(--shadow-ink);
    padding:14px 0;width:50px;display:flex;flex-direction:column;align-items:center;gap:12px;
    opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
#floating-interaction-bar.visible{opacity:1;visibility:visible}
#floating-interaction-bar button{
    background:none;border:none;color:var(--ash);cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:2px;
    padding:4px;transition:color .2s;font-family:var(--font-mono);font-size:.52rem;letter-spacing:.05em;
}
#floating-interaction-bar button:hover{color:var(--blood-bright)}
#floating-interaction-bar button.liked{color:var(--blood-bright)!important}
.floating-divider{width:60%;height:1px;background:var(--ash-2)}
.floating-actions-group{display:flex;flex-direction:column;align-items:center;gap:2px}
#floating-likes-count,#floating-comments-count{font-family:var(--font-mono);font-size:.58rem;color:var(--bone)}
@media(max-width:900px){#floating-interaction-bar{display:none!important}}

/* ═══════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════ */
.kaisbox-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(4px)}
.modal-content{
    position:relative;z-index:2001;width:90%;max-width:400px;
    background:var(--ink-2);border:1px solid var(--blood);
    box-shadow:5px 5px 0 var(--blood-2),var(--shadow-ink);padding:32px;text-align:center;
}
.modal-content::before{
    content:'';position:absolute;top:0;left:0;width:18px;height:18px;
    border-top:2px solid var(--blood);border-left:2px solid var(--blood);
}
.modal-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--ash);cursor:pointer;transition:color .2s;display:flex;align-items:center}
.modal-close-btn:hover{color:var(--blood-bright)}
.modal-header{
    font-family:var(--font-display);font-size:1.05rem;font-weight:900;
    letter-spacing:.1em;color:var(--parchment);text-shadow:1px 1px 0 var(--blood);
    margin-bottom:22px;text-transform:uppercase;
}
.modal-form-area form p{margin-bottom:12px;text-align:left}
.modal-form-area label{
    display:block;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;
    text-transform:uppercase;color:var(--bone);margin-bottom:4px;
}
.modal-form-area input:not([type="submit"]){
    width:100%;box-sizing:border-box;background:rgba(255,255,255,.03)!important;
    border:1px solid var(--ash)!important;border-left:2px solid var(--blood)!important;
    color:var(--parchment)!important;font-family:var(--font-mono)!important;
    font-size:.8rem!important;padding:10px 12px!important;border-radius:0!important;outline:none;
}
.modal-form-area input:not([type="submit"]):focus{border-color:var(--blood-bright)!important}
.modal-form-area input[type="submit"]{
    width:100%;background:var(--blood)!important;border:none!important;color:var(--parchment)!important;
    font-family:var(--font-display)!important;font-size:.6rem!important;font-weight:700!important;
    letter-spacing:.2em!important;text-transform:uppercase!important;padding:12px!important;
    border-radius:0!important;cursor:pointer;box-shadow:3px 3px 0 var(--blood-2);margin-top:10px;transition:all .15s;
}
.modal-form-area input[type="submit"]:hover{background:var(--blood-bright)!important;transform:translate(-1px,-1px)}
.modal-footer-link{margin-top:18px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;color:var(--ash)}
.modal-footer-link a{color:var(--blood-bright);border-bottom:1px dotted var(--blood);text-decoration:none}
.modal-footer-link a:hover{color:var(--parchment)}
.share-modal-content{max-width:330px}
.share-links{display:flex;flex-direction:column;margin-bottom:14px}
.share-link{
    display:flex;align-items:center;gap:10px;padding:10px 0;
    font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
    color:var(--bone);border-bottom:1px solid var(--ash-2);text-decoration:none;transition:color .2s;
}
.share-link:last-child{border-bottom:none}
.share-link:hover{color:var(--blood-bright)}
.share-link .material-icons{font-size:1rem}
.share-link-copy{display:flex;align-items:center;gap:8px;padding-top:10px}
#share-link-input{
    flex:1;background:rgba(255,255,255,.03)!important;border:1px solid var(--ash)!important;
    color:var(--bone)!important;font-family:var(--font-mono)!important;font-size:.66rem!important;
    padding:8px!important;border-radius:0!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
#copy-link-btn{
    flex-shrink:0;background:var(--blood)!important;border:none!important;color:var(--parchment)!important;
    font-family:var(--font-mono)!important;font-size:.62rem!important;letter-spacing:.1em!important;
    text-transform:uppercase!important;padding:8px 12px!important;border-radius:0!important;cursor:pointer;transition:background .15s;
}
#copy-link-btn:hover{background:var(--blood-bright)!important}
.copy-success-message{
    position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
    background:var(--blood);color:var(--parchment);font-family:var(--font-mono);
    font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;display:none;
}

/* ═══════════════════════════════════════════════════════
   PRIMARY SIDEBAR (logged-in nav)
   ═══════════════════════════════════════════════════════ */
#primary-sidebar{
    position:fixed;top:0;left:0;width:300px;height:100vh;z-index:1500;
    background:var(--ink-2);border-right:2px solid var(--blood);
    box-shadow:4px 0 20px rgba(139,0,0,.2);
    transform:translateX(-100%);transition:transform .3s ease;
    padding:24px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;
}
#primary-sidebar.active{transform:translateX(0)}
.sidebar-branding{padding-bottom:14px;border-bottom:1px solid var(--ash-2)}
.close-sidebar-btn{
    background:none;border:none;color:var(--ash);cursor:pointer;
    align-self:flex-end;display:flex;align-items:center;transition:color .2s;
}
.close-sidebar-btn:hover{color:var(--blood-bright)}
#sidebar-navigation{flex:1}
.sidebar-menu-list{list-style:none;display:flex;flex-direction:column;gap:2px}
.sidebar-menu-list a{
    display:block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;
    text-transform:uppercase;color:var(--bone);text-decoration:none;
    padding:9px 12px;border-left:2px solid transparent;transition:all .15s;
}
.sidebar-menu-list a:hover{color:var(--parchment);border-left-color:var(--blood);background:rgba(139,0,0,.08)}
.sidebar-menu-list .current-menu-item a{color:var(--blood-bright);border-left-color:var(--blood)}
.mobile-search-form-wrapper{padding-top:14px;border-top:1px solid var(--ash-2)}
#sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1499;display:none}
#user-profile-popup{
    position:fixed;top:var(--header-height);right:20px;z-index:1200;
    background:var(--ink-2);border:1px solid var(--blood);
    box-shadow:4px 4px 0 var(--blood-2),var(--shadow-ink);min-width:210px;padding:16px;display:none;
}
#user-profile-popup.active{display:block}
.profile-info{display:flex;align-items:center;gap:10px;padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid var(--ash-2)}
.profile-info img{width:38px;height:38px;border-radius:50%;border:2px solid var(--blood);filter:sepia(.3)}
.user-display-name{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--parchment)}
.glassy-divider{border:none;border-top:1px solid var(--ash-2);margin:8px 0}
.user-popup-menu-list{list-style:none}
.user-popup-menu-list a{
    display:block;padding:7px 0;font-family:var(--font-mono);font-size:.66rem;
    letter-spacing:.1em;text-transform:uppercase;color:var(--bone);text-decoration:none;transition:color .2s;
}
.user-popup-menu-list a:hover{color:var(--blood-bright)}
.user-popup-logout{
    display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.62rem;
    letter-spacing:.1em;text-transform:uppercase;color:var(--ash);text-decoration:none;
    padding-top:9px;margin-top:9px;border-top:1px solid var(--ash-2);transition:color .2s;
}
.user-popup-logout:hover{color:var(--blood-bright)}
.user-popup-logout .material-icons{font-size:.9rem}

/* ═══════════════════════════════════════════════════════
   COMMENTS SIDEBAR
   ═══════════════════════════════════════════════════════ */
#comments-sidebar{
    position:fixed;top:0;right:0;width:100%;max-width:400px;height:100vh;z-index:2500;
    background:var(--ink-2);border-left:2px solid var(--blood);
    box-shadow:-4px 0 20px rgba(139,0,0,.2);
    transform:translateX(100%);transition:transform .3s ease;
    padding:24px;display:flex;flex-direction:column;box-sizing:border-box;
}
#comments-sidebar.active{transform:translateX(0)}
#comments-sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:2499;display:none;cursor:pointer}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--ash-2)}
.sidebar-title{font-family:var(--font-display);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--blood-bright)}
.close-comments-sidebar-btn{background:none;border:none;color:var(--ash);cursor:pointer;transition:color .2s;display:flex;align-items:center}
.close-comments-sidebar-btn:hover{color:var(--blood-bright)}
.sidebar-content{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--blood-2) transparent}
#comments-sidebar .comment-body{background:transparent;border:none;padding:0}
#comments-sidebar .comment-content{margin-left:44px}
.sidebar-comment-form{margin-top:18px;padding-top:18px;border-top:1px solid var(--ash-2)}
.sidebar-submit-btn{margin-top:10px!important;float:right}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
#custom-main-footer{
    background:var(--ink-2);border-top:2px solid var(--blood);
    box-shadow:0 -2px 20px rgba(139,0,0,.2);padding:36px 24px 22px;margin-top:60px;
    position:relative;overflow:hidden;
}
#custom-main-footer::before{
    content:'';position:absolute;inset:0;pointer-events:none;
    background-image:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,.01) 3px,rgba(255,255,255,.01) 4px);
}
.footer-content-wrapper{max-width:var(--content-max);margin:0 auto;position:relative;z-index:1}
.footer-top{
    display:flex;align-items:flex-start;justify-content:space-between;
    padding-bottom:24px;margin-bottom:18px;border-bottom:1px solid var(--ash-2);
    gap:30px;flex-wrap:wrap;
}
.site-branding-footer .tagline{
    font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;
    text-transform:uppercase;color:var(--ash);margin-top:5px;
}
.footer-menu-list{list-style:none;display:flex;gap:16px;flex-wrap:wrap}
.footer-menu-list a{
    font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;
    text-transform:uppercase;color:var(--ash);text-decoration:none;transition:color .2s;
}
.footer-menu-list a:hover{color:var(--blood-bright)}
.footer-bottom{text-align:center}
.copyright{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ash)}

/* ═══════════════════════════════════════════════════════
   FORM INPUTS (global)
   ═══════════════════════════════════════════════════════ */
input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]),
textarea,select{
    background:rgba(255,255,255,.03)!important;border:1px solid var(--ash)!important;
    color:var(--parchment)!important;border-radius:0!important;padding:10px!important;
    font-family:var(--font-mono)!important;outline:none!important;
}

/* ═══════════════════════════════════════════════════════
   BLOCK EDITOR COMPATIBILITY
   ═══════════════════════════════════════════════════════ */
.wp-block-image{margin:1.5em 0}
.wp-block-quote{border-left:3px solid var(--blood);background:rgba(139,0,0,.08);padding:16px 20px}
.wp-block-code{background:var(--ink-2);border:1px solid var(--ash);border-left:3px solid var(--blood)}
.wp-block-separator{border-color:var(--blood);opacity:.4}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media(max-width:1024px){
    .home-layout{gap:24px}
    #home-sidebar{width:255px}
    .related-posts-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .home-layout{flex-direction:column}
    #home-sidebar{width:100%;position:static;max-height:none;border-top:1px solid var(--ash-2);padding-top:28px}
    .home-feed-item{flex-direction:column-reverse;gap:10px}
    .feed-thumbnail-wrap{width:100%;height:170px}
    .related-posts-grid{grid-template-columns:1fr}
    .entry-header .entry-title{font-size:1.4rem}
    #header-navigation{display:none}
    .logged-out-container .header-action-link{display:none}
}
@media(max-width:480px){
    .single-post-wrap{padding:24px 0 44px}
    .post-meta-author{flex-direction:column;align-items:flex-start;gap:10px}
}
