/* ==========================================================================
   Gaatha Story & Berlin Theme - Unified Production Stylesheet
   ========================================================================== */

:root {
    /* Brand Colors: Deep Saffron, Rich Maroon, and Cream */
    --primary:       #B45309;   /* Deep Saffron from current style-alt.txt/desired-style.txt */
    --accent:        #9F1239;   /* Rich Maroon/Accent/Madhubani Red */
    --gold:          #D97706;
    --cream:         #FFFBEB;   /* Warm Editorial Cream background hint */
    --dark:          #1E2937;   /* Slate Charcoal for high-readability body prose */
    --stone:         #E7E5E4;
    
    /* Structural Constants */
    --max-width:     860px;     /* Optimized line-length container */
}

/* Base Resets & Global Styles */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    line-height: 1.75;
    color: var(--dark);
    background-color: var(--cream);
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
}

.container, main { 
    padding: 2.5rem 1.8rem 4rem 1.8rem; 
    max-width: var(--max-width); 
    margin: 0 auto; 
}

/* ==========================================================================
   Navigation Header Architecture
   ========================================================================== */

nav, .header {
    background-color: #ffffff; /* Sticky nav from style-alt.txt/desired-style.txt */
    border-bottom: 1px solid #e5d9c0;
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.nav-container, .header-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    height: 82px; /* Fixed height from style-alt.txt/desired-style.txt */
}

/* Logo / Identity Branding */
.logo, .brand {
    font-weight: 800;
    font-size: 1.4rem;
    color: var(--dark);
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.logo-circle {
    width: 46px;
    height: 46px;
    background: var(--primary);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.9rem;
    font-weight: bold;
}

/* Fix #1: Navigation Links Mobile Handling */
.navigation ul, nav gap {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
}

/* Fix #2: Hide the "Block of Navy" Menu until clicked on Mobile */
.navigation ul {
    flex-direction: row; /* Horizontal on desktop */
}

/* Media Breakpoint for Mobile to prevent the Block issue in your attachment */
@media (max-width: 768px) {
    .navigation ul {
        display: none; /* Properly Hides the collapsing menu */
        flex-direction: column; /* Vertical on mobile when visible */
        width: 100%;
        position: absolute;
        top: 82px; /* Positioned below the nav bar */
        left: 0;
        background-color: #ffffff;
        padding: 1.5rem;
        border-bottom: 1px solid #e5d9c0;
    }

    /* Optional: Display a toggleable button, or handle display via JavaScript class */
    /* This requires a JavaScript class swap (e.g., .navigation ul.active) in your HTML template to show the menu. */
}

.navigation ul li {
    margin: 0;
}

nav a, .navigation ul li a {
    margin-left: 20px;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--dark);
    text-decoration: none;
    opacity: 0.85;
    transition: all 0.2s ease;
}

@media (max-width: 768px) {
    nav a, .navigation ul li a {
        margin: 10px 0;
        font-size: 1.1rem;
    }
}

nav a:hover, nav a.active,
.navigation ul li a:hover {
    color: var(--primary);
    opacity: 1;
}

/* ==========================================================================
   Typography & Editorial Elements
   ========================================================================== */

/* Fix #3: Integrate the Best Feature (Playfair Display and Madhubani Red Accent) */
h1, h2, h3, .font-display {
    font-family: 'Playfair Display', Georgia, serif;
    color: var(--dark);
    letter-spacing: -0.04em;
    font-weight: 700;
}

h1 { 
    font-size: 2.8rem; /* Correct font size from style-alt.txt/desired-style.txt */
    line-height: 1.1;
    margin-top: 0; 
    margin-bottom: 1.5rem;
    color: var(--primary); /* Deep Saffron from current style-alt.txt/desired-style.txt */
    border-left: 6px solid var(--accent); /* Madhubani Red Accent border hint */
    padding-left: 1.2rem; 
}

h2 { font-size: 2.1rem; margin-top: 2.8rem; margin-bottom: 1.2rem; }
h3 { font-size: 1.65rem; margin-top: 2.2rem; margin-bottom: 1rem; }

/* Prose prose from style-alt.txt/desired-style.txt */
.prose {
    font-size: 1.08rem;
}

.prose p {
    margin-bottom: 1.45rem;
}

/* Inline Body Text Anchors */
a { 
    color: var(--accent); /* Madhubani Red */
    text-decoration: none; 
    transition: all 0.2s ease;
}

a:hover { 
    color: var(--primary); /* Deep Saffron */
}

p { margin-top: 0; margin-bottom: 1.45rem; font-size: 1.08rem; }
ul, ol { padding-left: 24px; margin-bottom: 1.5rem; }
li { margin-bottom: 8px; font-size: 1.08rem; }

/* ==========================================================================
   Visual Media Components & Card Layouts
   ========================================================================= */

/* Feature Images from style-alt.txt/desired-style.txt */
.feature-image, figure {
    width: 100%;
    margin: 0 0 2.8rem 0;
}

.feature-image img, figure img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 16px; /* Correct border-radius from style-alt.txt/desired-style.txt */
    border: 4px solid #f5c16b; /* Golden border from style-alt.txt/desired-style.txt */
    box-shadow: 0 15px 30px rgba(0,0,0,0.12); /* Correct box-shadow from style-alt.txt/desired-style.txt */
}

/* Post Cards prose from style-alt.txt/desired-style.txt */
.post-card {
    background: white;
    border: 1px solid #e8e0d0;
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.post-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 25px 40px -10px rgba(180, 83, 9, 0.15);
}

/* Badges & Meta Pills from style-alt.txt/desired-style.txt */
.category-pill, .badge {
    background: white;
    color: var(--primary);
    padding: 5px 18px;
    border-radius: 9999px;
    font-size: 0.82rem;
    font-weight: 600;
    box-shadow: 0 3px 8px rgba(0,0,0,0.1);
    display: inline-block;
    margin-bottom: 1rem;
}

/* ==========================================================================
   Code blocks, Pre-containers, & Technical Layouts
   ========================================================================== */

pre { 
    background: #f4f1ea; 
    padding: 18px; 
    border-left: 5px solid var(--primary);
    overflow-x: auto; 
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; 
    border-radius: 8px;
    margin: 1.8rem 0;
}

code { 
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; 
    color: var(--accent); 
    background: rgba(0,0,0,0.05); 
    padding: 3px 6px; 
    border-radius: 4px;
    font-size: 0.9em;
}

pre code { 
    color: var(--dark); 
    background: transparent; 
    padding: 0; 
    font-size: 0.9rem;
}

/* ==========================================================================
   Footer Component Configuration
   ========================================================================== */

footer {
    background: #0F172A; /* Correct background from style-alt.txt/desired-style.txt */
    color: #ddd;
    padding: 5rem 1.5rem 3rem; /* Correct padding from style-alt.txt/desired-style.txt */
    margin-top: 6rem;
    text-align: center;
    font-size: 0.95rem;
}

footer a {
    color: #ddd;
    text-decoration: none;
}

footer a:hover {
    color: var(--accent);
}

/* ==========================================================================
   Media Breakpoint Adjustments
   ========================================================================== */

@media (max-width: 768px) {
    h1 { font-size: 2.25rem; } /* Correct font-size from style-alt.txt/desired-style.txt */
    main, .container { padding: 1.8rem 1rem; }
}


/* ==================================================
   HEADER
================================================== */

.top-bar{
    height:6px;
    background:var(--accent);
}

.site-header{
    background:var(--primary);
    background-image:var(--pattern-madhubani);
    background-size:20px 20px;
    border-bottom:4px solid var(--accent);
}

.nav-container{
    max-width:1200px;
    margin:0 auto;
    padding:1.25rem 2rem;

    display:flex;
    justify-content:space-between;
    align-items:center;
}

.logo{
    display:flex;
    align-items:center;
    gap:15px;

    text-decoration:none;
    border:none;
}

.logo-circle{
    width:56px;
    height:56px;

    border-radius:50%;

    background:var(--accent);
    color:var(--primary);

    display:flex;
    justify-content:center;
    align-items:center;

    font-size:1.6rem;
    font-weight:700;
}

.logo-title{
    color:var(--accent);
    font-size:2rem;
    font-weight:700;
    letter-spacing:2px;
}

.logo-subtitle{
    color:white;
    opacity:.8;
    letter-spacing:4px;
    font-size:.75rem;
}

.main-nav ul{
    display:flex;
    gap:2rem;

    list-style:none;
    margin:0;
    padding:0;
}

.main-nav a{
    color:white;
    border:none;
    opacity:.9;
}

.main-nav a:hover{
    color:var(--accent);
}

.mobile-menu-button{
    display:none;

    background:none;
    border:none;

    color:white;
    font-size:1.4rem;

    cursor:pointer;
}

.mobile-menu{
    display:none;
}

.mobile-menu.open{
    display:block;
    padding:1rem 2rem;
}

.mobile-menu a{
    display:block;
    padding:.75rem 0;

    color:white;

    border:none;
}

/* MOBILE */

@media (max-width:768px){

    .main-nav{
        display:none;
    }

    .mobile-menu-button{
        display:block;
    }

    .nav-container{
        padding:1rem;
    }

    .logo-title{
        font-size:1.5rem;
    }

}

/* ==================================================
   HOMEPAGE
================================================== */

.hero{

    background:var(--primary);
    background-image:var(--pattern-madhubani);

    color:white;

    padding:3.5rem 2rem;

    border-radius:14px;

    margin:3rem auto;

    border-bottom:5px solid var(--accent);
}

.hero-content{
    max-width:900px;
    margin:0 auto;
}

.hero-title{
    color:white;

    font-size:4.5rem;
    line-height:1.05;

    margin-bottom:1.5rem;

    border:none;
    padding:0;
}

.hero-text{
    font-size:1.3rem;
    opacity:.92;

    max-width:650px;

    margin-bottom:2rem;
}

.button-primary{
    display:inline-block;

    background:var(--accent);

    color:var(--primary);

    padding:14px 30px;

    border-radius:8px;

    border:none;

    text-decoration:none;

    font-weight:700;
}


.button-primary:hover{
    background:#ffd460;
}



/* ==================================================
   LATEST POSTS
================================================== */

.latest-posts{
    margin-top:5rem;
}

.section-header{

    display:flex;
    justify-content:space-between;
    align-items:flex-end;

    margin-bottom:2rem;
}

.section-title{
    margin:0;
}

.section-link{
    border:none;
}



/* ==================================================
   POST GRID
================================================== */

.post-grid{

    display:grid;

    grid-template-columns:
        repeat(auto-fit,minmax(320px,1fr));

    gap:2rem;
}



/* ==================================================
   CARD
================================================== */

.post-card{

    background:white;

    border:1px solid var(--border);

    border-radius:14px;

    overflow:hidden;

    transition:.35s;

    box-shadow:
        0 4px 12px rgba(0,0,0,.05);
}

.post-card:hover{

    transform:translateY(-8px);

    box-shadow:
        0 20px 40px rgba(0,0,0,.12);
}

.post-card a{
    border:none;
    text-decoration:none;
}



.card-image-wrapper{
    position:relative;
    overflow:hidden;
}

.card-image{

    width:100%;
    height:240px;

    object-fit:cover;

    transition:.5s;
}

.post-card:hover .card-image{
    transform:scale(1.05);
}



.category-pill{

    position:absolute;

    top:15px;
    left:15px;

    background:white;

    color:var(--primary);

    padding:6px 14px;

    border-radius:999px;

    font-size:.8rem;

    font-weight:700;
}



.card-body{
    padding:1.5rem;
}

.card-title{

    font-size:1.4rem;

    margin-top:0;

    margin-bottom:1rem;

    border:none;

    padding:0;
}

.card-description{

    color:#555;

    font-size:.95rem;

    line-height:1.7;

    margin-bottom:1rem;
}

.card-meta{

    color:#888;

    font-size:.85rem;
}



/* ==================================================
   MOBILE
================================================== */

@media (max-width:768px){

    .hero{
        padding:3rem 1.5rem;
    }

    .hero-title{
        font-size:2.8rem;
    }

    .hero-text{
        font-size:1.1rem;
    }

    .section-header{
        display:block;
    }

    .section-link{
        display:block;
        margin-top:1rem;
    }

    .post-grid{
        grid-template-columns:1fr;
    }

}

/* ==================================================
   ARTICLE PAGE
================================================== */

.article-container{

    max-width:900px;

    margin:0 auto;

    padding:3rem 2rem 5rem;
}



.article-header{

    margin-bottom:3rem;
}



.article-category{

    display:inline-block;

    background:rgba(255,180,0,.12);

    color:var(--secondary);

    padding:8px 16px;

    border-radius:999px;

    font-size:.85rem;

    font-weight:700;

    letter-spacing:1px;

    text-transform:uppercase;
}



.article-title{

    margin-top:1.5rem;

    margin-bottom:1rem;

    font-size:4rem;

    line-height:1.1;

    color:var(--primary);

    border:none;

    padding:0;
}



.article-meta{

    color:#777;

    font-size:.95rem;
}



/* ==================================================
   FEATURE IMAGE
================================================== */

.feature-image{

    width:100%;

    border-radius:18px;

    margin-bottom:3rem;

    box-shadow:
        0 15px 40px rgba(0,0,0,.12);
}



/* ==================================================
   PROSE
================================================== */

.prose{

    font-size:1.1rem;

    line-height:1.9;

    color:var(--text);
}



.prose p{

    margin-bottom:1.6rem;
}



.prose h2{

    margin-top:4rem;

    margin-bottom:1.5rem;

    font-size:2.4rem;

    border:none;

    padding:0;
}



.prose h3{

    margin-top:3rem;

    margin-bottom:1rem;

    font-size:1.8rem;
}



.prose ul,
.prose ol{

    margin-bottom:2rem;
}



.prose li{

    margin-bottom:.8rem;
}



.prose img{

    max-width:100%;

    border-radius:12px;

    margin:2rem 0;
}



/* ==================================================
   BLOCKQUOTE
================================================== */

.prose blockquote{

    background:#fffef6;

    border-left:5px solid var(--accent);

    padding:1.5rem 2rem;

    margin:3rem 0;

    font-style:italic;

    color:#555;
}



/* ==================================================
   TABLES
================================================== */

.prose table{

    width:100%;

    border-collapse:collapse;

    margin:2rem 0;
}



.prose th{

    background:var(--primary);

    color:white;

    padding:12px;
}



.prose td{

    padding:12px;

    border:1px solid #e8e8e8;
}



/* ==================================================
   POST FOOTER
================================================== */

.post-footer{

    margin-top:5rem;

    padding-top:2rem;

    border-top:1px solid #ddd;

    color:#666;

    font-size:.95rem;
}



/* ==================================================
   PREVIOUS / NEXT
================================================== */

.post-navigation{

    margin-top:4rem;

    padding-top:2rem;

    border-top:1px solid #eee;

    display:flex;

    justify-content:space-between;

    gap:2rem;
}



.post-navigation a{

    border:none;

    font-weight:600;
}



/* ==================================================
   MOBILE
================================================== */

@media (max-width:768px){

    .article-container{

        padding:2rem 1rem 4rem;
    }


    .article-title{

        font-size:2.5rem;
    }


    .prose{

        font-size:1rem;
    }


    .prose h2{

        font-size:2rem;
    }


    .post-navigation{

        display:block;
    }


    .post-navigation div:first-child{

        margin-bottom:1.5rem;
    }

}

/* ==================================================
   FOOTER
================================================== */

.site-footer{

    background:var(--primary);

    background-image:var(--pattern-madhubani);

    color:#bbb;

    margin-top:6rem;

    border-top:4px solid var(--accent);

    padding:5rem 2rem 2rem;
}



.footer-container{

    max-width:1200px;

    margin:0 auto;

    display:grid;

    grid-template-columns:
        repeat(auto-fit,minmax(260px,1fr));

    gap:4rem;
}



.footer-column h3{

    color:var(--accent);

    margin-top:0;

    margin-bottom:1.5rem;

    border:none;

    padding:0;
}



.footer-column ul{

    list-style:none;

    padding:0;

    margin:0;
}



.footer-column li{

    margin-bottom:1rem;
}



.footer-column a{

    color:#ddd;

    border:none;

    opacity:.9;
}



.footer-column a:hover{

    color:var(--accent);
}



.footer-brand{

    display:flex;

    align-items:flex-start;

    gap:1.5rem;
}



.footer-title{

    color:white;

    font-size:1.5rem;

    font-weight:700;

    margin-bottom:.75rem;
}



.footer-tagline{

    line-height:1.8;

    color:#bbb;
}



/* ==================================================
   SOCIAL ICONS
================================================== */

.social-icons{

    display:flex;

    gap:1rem;

    margin-top:1rem;
}



.social-icons a{

    width:42px;

    height:42px;

    border-radius:50%;

    background:rgba(255,255,255,.08);

    color:var(--accent);

    display:flex;

    align-items:center;

    justify-content:center;

    transition:.3s;

    border:none;
}



.social-icons a:hover{

    background:var(--accent);

    color:var(--primary);
}



/* ==================================================
   FOOTER BOTTOM
================================================== */

.footer-bottom{

    margin-top:4rem;

    padding-top:2rem;

    border-top:1px solid rgba(255,255,255,.1);

    text-align:center;

    font-size:.95rem;

    color:#999;
}



/* ==================================================
   REMOVE BULLETS
================================================== */

.site-footer ul{

    list-style:none;

    margin:0;

    padding:0;
}



/* ==================================================
   MOBILE
================================================== */

@media (max-width:768px){

    .site-footer{

        padding:4rem 1.5rem 2rem;
    }


    .footer-container{

        gap:3rem;
    }


    .footer-brand{

        display:block;
    }


    .footer-brand .logo-circle{

        margin-bottom:1.5rem;
    }


    .social-icons{

        justify-content:flex-start;
    }

}


/* ==================================================
   ARCHIVE PAGE
================================================== */

.archive-container{

    max-width:1200px;

    margin:0 auto;

    padding:3rem 2rem 5rem;
}



.archive-header{

    margin-bottom:3rem;
}



.page-title{

    font-size:3.5rem;

    line-height:1.1;

    margin-top:1rem;

    margin-bottom:0;

    border:none;

    padding:0;
}



.section-label{

    color:var(--secondary);

    font-size:.85rem;

    font-weight:700;

    text-transform:uppercase;

    letter-spacing:2px;
}



/* ==================================================
   CATEGORY NAVIGATION
================================================== */

.category-nav{

    display:flex;

    flex-wrap:wrap;

    gap:1rem;

    margin-bottom:3rem;
}



.category-link{

    background:white;

    border:1px solid #ddd;

    border-radius:999px;

    padding:10px 20px;

    font-size:.9rem;

    text-decoration:none;

    color:var(--primary);

    transition:.3s;
}



.category-link:hover{

    background:#f8f8f8;

    border-color:var(--accent);

    color:var(--secondary);
}



.category-link.active{

    background:var(--primary);

    color:white;

    border-color:var(--primary);
}



/* ==================================================
   EMPTY STATE
================================================== */

.empty-state{

    background:white;

    padding:4rem;

    border-radius:14px;

    border:1px solid var(--border);

    text-align:center;

    color:#777;
}



/* ==================================================
   ARCHIVE CARDS
================================================== */

.archive-container .post-grid{

    margin-top:2rem;
}



.archive-container .post-card{

    background:white;

    border-radius:14px;

    overflow:hidden;

    border:1px solid #e8e8e8;

    transition:.3s;
}



.archive-container .post-card:hover{

    transform:translateY(-8px);

    box-shadow:
        0 20px 40px rgba(0,0,0,.12);
}



/* ==================================================
   MOBILE
================================================== */

@media (max-width:768px){

    .archive-container{

        padding:2rem 1rem 4rem;
    }


    .page-title{

        font-size:2.5rem;
    }


    .category-nav{

        gap:.75rem;
    }


    .category-link{

        padding:8px 16px;

        font-size:.85rem;
    }

}

/* ==================================================
   ABOUT PAGE
================================================== */

.contact-section{

    margin-top:5rem;

    background:white;

    border:1px solid var(--border);

    border-radius:16px;

    padding:3rem;

    box-shadow:
        0 8px 25px rgba(0,0,0,.05);
}



.contact-section h2{

    margin-top:0;

    border:none;

    padding:0;
}



.contact-section p{

    color:#666;

    margin-bottom:2rem;
}



/* ==================================================
   FORM
================================================== */

.contact-form{

    display:flex;

    flex-direction:column;

    gap:1.5rem;
}



.form-row{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:1.5rem;
}



.form-group{

    display:flex;

    flex-direction:column;
}



.form-group label{

    margin-bottom:.6rem;

    font-weight:600;

    color:var(--primary);
}



input,
textarea{

    width:100%;

    padding:14px 16px;

    border:1px solid #ddd;

    border-radius:10px;

    background:white;

    font-size:1rem;

    transition:.3s;
}



input:focus,
textarea:focus{

    outline:none;

    border-color:var(--accent);

    box-shadow:
        0 0 0 3px rgba(255,180,0,.15);
}



textarea{

    resize:vertical;

    min-height:180px;
}



/* ==================================================
   BUTTON
================================================== */

.button-primary{

    cursor:pointer;

    font-size:1rem;

    font-weight:700;

    transition:.3s;
}



.button-primary:hover{

    transform:translateY(-2px);

    box-shadow:
        0 10px 20px rgba(0,0,0,.12);
}



/* ==================================================
   ABOUT LINKS
================================================== */

.about-links{

    margin-top:5rem;
}



.about-links ul{

    list-style:none;

    padding:0;
}



.about-links li{

    margin-bottom:1rem;
}



/* ==================================================
   AUTHOR BOX
================================================== */

.author-bio-box{

    margin-top:5rem;

    background:white;

    border:1px solid var(--border);

    border-radius:16px;

    padding:2rem;

    display:flex;

    gap:1.5rem;

    align-items:center;

    box-shadow:
        0 8px 25px rgba(0,0,0,.05);
}



.author-bio-box img{

    width:90px;

    height:90px;

    border-radius:50%;

    object-fit:cover;

    border:4px solid var(--accent);
}



.author-bio-box p{

    margin:0;
}



.author-bio-box strong{

    color:var(--primary);
}



/* ==================================================
   MOBILE
================================================== */

@media (max-width:768px){

    .contact-section{

        padding:2rem;
    }


    .form-row{

        grid-template-columns:1fr;
    }


    .author-bio-box{

        display:block;

        text-align:center;
    }


    .author-bio-box img{

        margin-bottom:1.5rem;
    }

}

/* ==================================================
   IMAGES
================================================== */

img{

    max-width:100%;

    height:auto;

}



figure{

    margin:3rem 0;

}



figcaption{

    text-align:center;

    font-size:.9rem;

    color:#777;

    margin-top:.75rem;

}



/* ==================================================
   TABLES
================================================== */

table{

    width:100%;

    overflow-x:auto;

    display:block;

}



th{

    white-space:nowrap;

}



td{

    white-space:normal;

}



/* ==================================================
   CODE BLOCKS
================================================== */

pre{

    overflow-x:auto;

    max-width:100%;

}



code{

    word-break:break-word;

}



/* ==================================================
   HORIZONTAL OVERFLOW PROTECTION
================================================== */

body{

    overflow-x:hidden;

}



main{

    width:100%;

}



*{

    max-width:100%;

}



/* ==================================================
   EMBEDS
================================================== */

iframe,

video{

    max-width:100%;

    border-radius:12px;

}



/* ==================================================
   SELECTION
================================================== */

::selection{

    background:var(--accent);

    color:var(--primary);

}



/* ==================================================
   HR
================================================== */

hr{

    border:none;

    border-top:1px solid #ddd;

    margin:4rem 0;

}



/* ==================================================
   DETAILS
================================================== */

details{

    background:white;

    border:1px solid var(--border);

    border-radius:12px;

    padding:1rem 1.5rem;

    margin:2rem 0;

}



summary{

    cursor:pointer;

    font-weight:700;

    color:var(--primary);

}



/* ==================================================
   LINKS
================================================== */

a{

    transition:.2s;

}



/* ==================================================
   MOBILE
================================================== */

@media (max-width:768px){

    body{

        font-size:16px;

    }



    h1{

        font-size:2.3rem;

    }



    h2{

        font-size:1.9rem;

    }



    h3{

        font-size:1.5rem;

    }



    .container,

    .article-container,

    .archive-container{

        padding-left:1rem;

        padding-right:1rem;

    }



   .nav-container{

    max-width:1200px;

    margin:0 auto;

    padding:1rem 3rem;

}



    .footer-container{

        grid-template-columns:1fr;

    }



    .social-icons{

        justify-content:flex-start;

    }



    .hero{

        padding:3rem 1.5rem;

    }



    .hero-title{

        font-size:2.7rem;

    }



    .post-grid{

        grid-template-columns:1fr;

    }



    .card-image{

        height:220px;

    }



    .article-title{

        font-size:2.5rem;

    }



    .post-navigation{

        flex-direction:column;

    }



    table{

        font-size:.9rem;

    }

}



/* ==================================================
   LARGE DESKTOPS
================================================== */

@media (min-width:1400px){

    .article-container{

        max-width:950px;

    }



    .archive-container{

        max-width:1300px;

    }

}


.main-nav{

    background:none;

}



.main-nav ul{

    display:flex;

    gap:3rem;

    list-style:none;

    margin:0;

    padding:0;

}



.main-nav a{

    color:white;

    font-weight:600;

    border:none;

}



.main-nav a:hover{

    color:var(--accent);

}