/**
 * Theme Protection CSS
 * Loads last to override any inline styles from article content
 * @package RabbitsAndBunnies
 */

/* ===================================
   CRITICAL: Force Theme Structure
   =================================== */

/* Global Structure */
html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}

body {
    background-color: #FAF8F3 !important;
    color: #333333 !important;
}

#page {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
    width: 100% !important;
}

#content {
    flex: 1 !important;
}

/* ===================================
   HEADER - Force White Background
   =================================== */

.site-header,
#masthead {
    background: #ffffff !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    position: fixed !important;
    top: 0 !important;
    z-index: 1000 !important;
}

/* Compensate for fixed header */
.site-content:not(:has(.hero-section)) {
    padding-top: 100px !important;
}

/* Hero section starts right after header */
.hero-section {
    margin-top: 0 !important;
    padding-top: 10rem !important;
}

/* Homepage specific - no extra padding since hero is there */
.home .site-content,
.blog .site-content {
    padding-top: 0 !important;
}

.header-inner {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 1rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.site-logo {
    color: #8B6F47 !important;
}

.nav-menu {
    display: flex !important;
    list-style: none !important;
    gap: 0.5rem !important;
}

.nav-menu a {
    color: #333333 !important;
}

/* ===================================
   FOOTER - Force Brown Background
   =================================== */

.site-footer,
#colophon {
    background: #8B6F47 !important;
    color: #ffffff !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 !important;
    padding: 3rem 0 1rem !important;
}

.footer-content {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 1rem !important;
}

.footer-bottom {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 1rem !important;
    color: rgba(255, 255, 255, 0.8) !important;
}

.footer-bottom a {
    color: #ffffff !important;
    text-decoration: underline !important;
}

.footer-widget a {
    color: rgba(255, 255, 255, 0.8) !important;
}

/* ===================================
   SIDEBAR - Force Correct Position
   =================================== */

.content-area {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
    align-items: start !important;
    overflow: visible !important;
    position: relative !important;
}

.has-sidebar .content-area {
    grid-template-columns: 2fr 350px !important;
}

/* Ensure containers allow sticky positioning */
.single-post-wrapper,
.site-main {
    overflow: visible !important;
    position: relative !important;
}

.content-area > article,
.content-area > .single-post {
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
}

.content-area > .sidebar,
.content-area > #secondary {
    grid-column: 2 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
}

aside#secondary,
aside.sidebar,
.sidebar {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.5rem !important;
    position: -webkit-sticky !important;
    position: sticky !important;
    top: 100px !important;
    align-self: flex-start !important;
    max-height: calc(100vh - 120px) !important;
    overflow-y: auto !important;
    z-index: 100 !important;
    will-change: transform !important;
}

/* Ensure widgets don't break sticky */
.sidebar .widget,
#secondary .widget {
    position: relative !important;
    flex-shrink: 0 !important;
}

/* Debug: Make sidebar visible */
aside#secondary {
    background: transparent !important;
}

/* Additional sticky enforcement */
body.single aside#secondary,
body.page aside#secondary,
body.single .sidebar,
body.page .sidebar {
    position: sticky !important;
    position: -webkit-sticky !important;
    top: 100px !important;
}

/* Ensure parent allows sticky */
body.single .content-area,
body.page .content-area,
body.single .single-post-wrapper,
body.page .single-post-wrapper {
    overflow: visible !important;
    contain: none !important;
}

/* ===================================
   POST CONTENT - Prevent Overflow
   =================================== */

.single-post,
.entry-content,
article {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

.entry-content > * {
    max-width: 100% !important;
}

.entry-content table {
    width: 100% !important;
    display: block !important;
    overflow-x: auto !important;
}

/* ===================================
   COMMENTS - Fix Size
   =================================== */

.comments-area {
    max-width: 100% !important;
    margin-top: 2rem !important;
    padding: 0 !important;
    background: transparent !important;
}

.comment {
    padding: 1rem !important;
    margin-bottom: 1rem !important;
    background: #FAF8F3 !important;
    border-left: 3px solid #A8D5BA !important;
    border-radius: 8px !important;
}

.comment-respond {
    padding: 1.5rem !important;
    background: #FAF8F3 !important;
    border-radius: 8px !important;
    margin-top: 1.5rem !important;
}

.comments-title,
.comment-reply-title {
    color: #8B6F47 !important;
    font-size: 1.5rem !important;
    margin-bottom: 1rem !important;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    width: 100% !important;
    padding: 0.75rem !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 6px !important;
    background: #ffffff !important;
}

.comment-form input[type="submit"] {
    background: #8B6F47 !important;
    color: #ffffff !important;
    padding: 0.75rem 2rem !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
}

.comment-form input[type="submit"]:hover {
    background: #F4A460 !important;
}

/* ===================================
   POST NAVIGATION - Below Article
   =================================== */

.post-navigation {
    margin-top: 2rem !important;
    padding-top: 1rem !important;
    border-top: 2px solid #e0e0e0 !important;
    order: 2 !important;
}

.post-navigation .nav-links {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 1rem !important;
}

.post-navigation .nav-previous,
.post-navigation .nav-next {
    padding: 1rem !important;
    background: #FAF8F3 !important;
    border-radius: 12px !important;
}

.post-navigation a {
    color: #333333 !important;
}

.post-navigation .nav-title {
    color: #8B6F47 !important;
}

/* ===================================
   RESPONSIVE
   =================================== */

@media (max-width: 992px) {
    .has-sidebar .content-area {
        grid-template-columns: 1fr !important;
    }
    
    .content-area > .sidebar,
    .content-area > #secondary {
        grid-column: 1 !important;
        grid-row: 2 !important;
        position: relative !important;
        top: 0 !important;
    }
    
    .post-navigation .nav-links {
        grid-template-columns: 1fr !important;
    }
}

/* ===================================
   MOBILE MENU FIX
   =================================== */

@media (max-width: 768px) {
    .menu-toggle {
        display: block !important;
        background: #8B6F47 !important;
        color: #ffffff !important;
        border: none !important;
        padding: 0.5rem 1rem !important;
        border-radius: 6px !important;
        cursor: pointer !important;
    }
    
    .nav-menu {
        display: none !important;
        position: absolute !important;
        top: 100% !important;
        right: 0 !important;
        background: #ffffff !important;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12) !important;
        border-radius: 12px !important;
        padding: 1rem !important;
        min-width: 200px !important;
        flex-direction: column !important;
        margin-top: 0.5rem !important;
    }
    
    .nav-menu.active {
        display: flex !important;
    }
    
    .nav-menu li {
        width: 100% !important;
    }
    
    .nav-menu .sub-menu {
        position: static !important;
        box-shadow: none !important;
        background: #FAF8F3 !important;
        margin: 0.5rem 0 !important;
        padding-left: 1rem !important;
        border-left: 2px solid #A8D5BA !important;
    }
}

