/*
 Theme Name: Kadence Child
 Theme URI: https://thedelay.com/
 Description: A custom child theme for Kadence - Terminal Theme
 Author: jdelay
 Author URI: https://thedelay.com/
 Template: kadence
 Version: 2.4.1
 Text Domain: kadence-child
*/

/* ==========================================================================
   TERMINAL THEME - Phase 1: Foundation
   Design Spec: TERMINAL_THEME_DESIGN.md
   ========================================================================== */

/* --------------------------------------------------------------------------
   Self-hosted JetBrains Mono (replaces Google Fonts CDN for privacy)
   Variable font: one file covers weights 400/500/700
   -------------------------------------------------------------------------- */

/* Latin (primary) */
@font-face {
    font-family: 'JetBrains Mono';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('./assets/fonts/JetBrainsMono-Regular-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'JetBrains Mono';
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url('./assets/fonts/JetBrainsMono-Italic-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Latin Extended (accented characters) */
@font-face {
    font-family: 'JetBrains Mono';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('./assets/fonts/JetBrainsMono-Regular-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: 'JetBrains Mono';
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url('./assets/fonts/JetBrainsMono-Italic-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* --------------------------------------------------------------------------
   CSS Custom Properties (Dracula-inspired palette)
   -------------------------------------------------------------------------- */
:root {
    /* Background */
    --term-bg: #282a36;
    --term-bg-alt: #1e1f29;
    --term-bg-card: #323443;

    /* Foreground */
    --term-fg: #f8f8f2;
    --term-dim: #6272a4;

    /* Accent Colors (Dracula) */
    --term-cyan: #8be9fd;
    --term-green: #50fa7b;
    --term-orange: #ffb86c;
    --term-pink: #ff79c6;
    --term-purple: #bd93f9;
    --term-red: #ff5555;
    --term-yellow: #f1fa8c;

    /* Phosphor Green (Special Accents) */
    --term-phosphor: #00ff41;
    --term-phosphor-dim: #00aa2a;

    /* Category Colors */
    --term-cat-homelab: var(--term-cyan);
    --term-cat-infosec: var(--term-red);
    --term-cat-fantasy: var(--term-green);
    --term-cat-general: var(--term-purple);
    --term-cat-ai: var(--term-pink);

    /* Typography */
    --term-font: 'JetBrains Mono', 'Fira Code', 'Source Code Pro', 'Consolas', monospace;

    /* Effects */
    --term-glow: 0 0 5px var(--term-phosphor);
    --term-glow-subtle: 0 0 3px rgba(0, 255, 65, 0.3);

    /* Spacing */
    --term-spacing: 1rem;

    /* Override Kadence's width constraints */
    --global-content-width: 2200px !important;
    --global-content-narrow-width: 1600px !important;
    --global-calc-content-width: 2200px !important;
}

/* --------------------------------------------------------------------------
   Base Styles
   -------------------------------------------------------------------------- */
body {
    background-color: var(--term-bg);
    color: var(--term-fg);
    font-family: var(--term-font);
    font-size: 16px;
    line-height: 1.7;
}

/* --------------------------------------------------------------------------
   Typography
   -------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6, .entry-title {
    color: var(--term-cyan) !important;  /* Bright cyan - override Kadence customizer */
    font-family: var(--term-font);
    font-weight: 700;
    margin-top: 1.5em;
    margin-bottom: 0.8em;
    line-height: 1.3;
}

/* Prompt-style section headers */
h1::before,
h2::before,
.entry-title::before {
    content: '$ ';
    color: var(--term-dim);  /* Muted prompt - hierarchy: content > chrome */
    font-weight: 400;
}

h3::before {
    content: '> ';
    color: var(--term-dim);
    font-weight: 400;
}

/* Entry titles - special treatment */
.entry-title {
    font-size: 1.75rem;
}

.entry-title a {
    color: var(--term-cyan) !important;  /* Match heading color for linked titles */
    text-decoration: none;
}

.entry-title a:hover {
    color: var(--term-fg);  /* Brighten to white on hover */
    text-shadow: 0 0 8px var(--term-cyan);  /* Cyan glow on hover */
}

/* Article card titles - flush left for readability
   Title needs to escape both card padding (20px) and entry-content-wrap padding (2rem) */
article.loop-entry .entry-title,
.loop-entry .entry-title,
article.loop-entry .entry-content-wrap .entry-title {
    margin-left: calc(-20px - 2rem) !important;
    padding-left: 0 !important;
}

/* Paragraphs */
p {
    margin-bottom: 1em;
}

/* --------------------------------------------------------------------------
   Links
   -------------------------------------------------------------------------- */
a {
    color: var(--term-cyan);
    text-decoration: none;
    transition: color 0.2s ease, text-shadow 0.2s ease;
}

a:hover {
    color: var(--term-phosphor);
    text-shadow: var(--term-glow-subtle);
}

a:visited {
    color: var(--term-purple);
}

a:focus {
    outline: 2px solid var(--term-phosphor);
    outline-offset: 2px;
}

/* --------------------------------------------------------------------------
   Cursor Blink Animation
   -------------------------------------------------------------------------- */
@keyframes blink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0; }
}

.cursor::after,
.blink::after {
    content: '█';
    color: var(--term-phosphor);
    animation: blink 1s infinite;
    margin-left: 2px;
}

/* Add cursor to site title on homepage only (not article cards) */
.home .site-title::after {
    content: '█';
    color: var(--term-phosphor);
    animation: blink 1s infinite;
    margin-left: 4px;
    font-weight: 400;
}

/* --------------------------------------------------------------------------
   Card Styling for Post Listings
   -------------------------------------------------------------------------- */
article.loop-entry {
    background-color: var(--term-bg-card);
    border: 1px solid var(--term-dim);
    border-left: 3px solid var(--term-phosphor);
    border-radius: 0;
    padding: 20px;
    margin-bottom: 24px;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

article.loop-entry:hover {
    border-left-color: var(--term-cyan);
    background-color: var(--term-bg-alt);
}

/* --------------------------------------------------------------------------
   Category Color Coding
   -------------------------------------------------------------------------- */
/* Base category link style */
a[class*="category-link-"] {
    padding: 4px 8px;
    border-radius: 0;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid currentColor;
    background-color: transparent;
    transition: background-color 0.2s ease;
}

a.category-link-homelab {
    color: var(--term-cat-homelab);
}
a.category-link-homelab:hover {
    background-color: var(--term-cat-homelab);
    color: var(--term-bg);
}

a.category-link-information-security {
    color: var(--term-cat-infosec);
}
a.category-link-information-security:hover {
    background-color: var(--term-cat-infosec);
    color: var(--term-bg);
}

a.category-link-fantasy-football {
    color: var(--term-cat-fantasy);
}
a.category-link-fantasy-football:hover {
    background-color: var(--term-cat-fantasy);
    color: var(--term-bg);
}

/* General/Uncategorized */
a.category-link-uncategorized,
a.category-link-general {
    color: var(--term-cat-general);
}
a.category-link-uncategorized:hover,
a.category-link-general:hover {
    background-color: var(--term-cat-general);
    color: var(--term-bg);
}

/* AI */
a.category-link-ai {
    color: var(--term-cat-ai);
}
a.category-link-ai:hover {
    background-color: var(--term-cat-ai);
    color: var(--term-bg);
}

/* --------------------------------------------------------------------------
   Code Blocks (native terminal feel)
   -------------------------------------------------------------------------- */
pre, code {
    font-family: var(--term-font);
    background-color: var(--term-bg-alt);
    color: var(--term-fg);
}

pre {
    padding: 1rem;
    border: 1px solid var(--term-dim);
    border-left: 3px solid var(--term-green);
    overflow-x: auto;
}

code {
    padding: 2px 6px;
    font-size: 0.9em;
}

/* Inline code in paragraphs */
p code, li code {
    background-color: var(--term-bg-alt);
    border: 1px solid var(--term-dim);
}

/* --------------------------------------------------------------------------
   Blockquotes (terminal output style)
   -------------------------------------------------------------------------- */
blockquote {
    border-left: 3px solid var(--term-dim);
    padding-left: 1rem;
    margin-left: 0;
    color: var(--term-dim);
    font-style: normal;
}

blockquote::before {
    content: '// ';
    color: var(--term-green);
}

/* --------------------------------------------------------------------------
   Layout - Wide but Controlled
   -------------------------------------------------------------------------- */

/* Expand Kadence's default content width */
.site-container,
.site-inner,
.content-wrap,
.content-container {
    max-width: 2400px !important;
    width: 98% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Site main - wide container */
.site-main {
    max-width: 2200px !important;
    width: 96% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 2rem;
}

/* Force single-column layout for post loops */
.loop-content,
.content-area,
.site-main > .loop-content {
    display: block !important;
    width: 100% !important;
}

/* Post listings - full width within container, stacked vertically */
.loop-entry,
article.loop-entry {
    display: block !important;
    max-width: 100% !important;
    width: 100% !important;
    margin-bottom: 2rem !important;
    overflow: hidden;
    box-sizing: border-box;
}

/* Ensure text wraps properly inside articles */
.loop-entry *,
article.loop-entry *,
.entry-content * {
    max-width: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
}

/* Entry content on single posts */
.entry-content,
.entry-header {
    max-width: 1800px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 2rem;
    padding-right: 2rem;
    box-sizing: border-box;
}

/* Single posts - wider for reading */
.single .entry-content {
    max-width: 1400px !important;
}

/* Override Kadence's constrained layouts */
.is-layout-constrained > * {
    max-width: 100% !important;
}

/* Kadence row containers */
.kb-row-layout-wrap {
    max-width: 2200px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* --------------------------------------------------------------------------
   Header & Navigation
   -------------------------------------------------------------------------- */
.site-header {
    background-color: var(--term-bg-alt);
    border-bottom: 1px solid var(--term-dim);
}

.main-navigation a {
    color: var(--term-fg);
    font-family: var(--term-font);
    font-size: 0.9rem;
    text-transform: lowercase;
}

.main-navigation a:hover {
    color: var(--term-phosphor);
}

.main-navigation a::before {
    content: './';
    color: var(--term-dim);
    font-weight: 400;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.site-footer {
    background-color: var(--term-bg-alt);
    border-top: 1px solid var(--term-dim);
    color: var(--term-dim);
    font-size: 0.85rem;
}

.site-footer a {
    color: var(--term-dim);
}

.site-footer a:hover {
    color: var(--term-phosphor);
}

/* --------------------------------------------------------------------------
   Sidebar Widgets
   -------------------------------------------------------------------------- */
.widget {
    background-color: var(--term-bg-card);
    border: 1px solid var(--term-dim);
    padding: 1rem;
    margin-bottom: 1rem;
}

.widget-title {
    color: var(--term-cyan);
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-bottom: 1px solid var(--term-dim);
    padding-bottom: 0.5rem;
    margin-bottom: 1rem;
}

.widget-title::before {
    content: '# ';
    color: var(--term-phosphor);
}

/* --------------------------------------------------------------------------
   Forms & Inputs
   -------------------------------------------------------------------------- */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea {
    background-color: var(--term-bg-alt);
    border: 1px solid var(--term-dim);
    color: var(--term-fg);
    font-family: var(--term-font);
    padding: 0.5rem;
}

input:focus,
textarea:focus {
    border-color: var(--term-phosphor);
    outline: none;
    box-shadow: var(--term-glow-subtle);
}

button,
input[type="submit"],
.button,
.wp-block-button__link {
    background-color: transparent;
    border: 1px solid var(--term-phosphor);
    color: var(--term-phosphor);
    font-family: var(--term-font);
    font-weight: 700;
    padding: 0.5rem 1rem;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.wp-block-button__link:hover {
    background-color: var(--term-phosphor);
    color: var(--term-bg);
}

/* --------------------------------------------------------------------------
   Accessibility: Focus States
   -------------------------------------------------------------------------- */
*:focus {
    outline: 2px solid var(--term-phosphor);
    outline-offset: 2px;
}

/* Skip link for keyboard navigation */
.skip-link:focus {
    background-color: var(--term-phosphor);
    color: var(--term-bg);
}

/* --------------------------------------------------------------------------
   Selection Highlight
   -------------------------------------------------------------------------- */
::selection {
    background-color: var(--term-purple);
    color: var(--term-fg);
}

::-moz-selection {
    background-color: var(--term-purple);
    color: var(--term-fg);
}

/* --------------------------------------------------------------------------
   Scrollbar Styling (Webkit)
   -------------------------------------------------------------------------- */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--term-bg-alt);
}

::-webkit-scrollbar-thumb {
    background: var(--term-dim);
    border-radius: 0;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--term-phosphor);
}

/* ==========================================================================
   TERMINAL THEME - Phase 2: Visual Polish
   ========================================================================== */

/* --------------------------------------------------------------------------
   CRT Scanline Effect (Decorative Elements Only)
   Apply with .crt-effect class - NOT for body text/content
   -------------------------------------------------------------------------- */
.crt-effect {
    position: relative;
}

.crt-effect::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    background: repeating-linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.1),
        rgba(0, 0, 0, 0.1) 1px,
        transparent 1px,
        transparent 2px
    );
    z-index: 1;
}

/* Apply CRT effect to decorative areas */
.site-header,
.site-footer,
.widget-title {
    position: relative;
}

.site-header::after,
.site-footer::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    background: repeating-linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.05),
        rgba(0, 0, 0, 0.05) 1px,
        transparent 1px,
        transparent 3px
    );
    z-index: 0;
}

/* --------------------------------------------------------------------------
   Text Glow Effects
   -------------------------------------------------------------------------- */
/* Subtle glow for headers */
h1, h2, .entry-title {
    text-shadow: 0 0 2px rgba(248, 248, 242, 0.3);
}

/* Phosphor glow for active/hover states */
.entry-title a:hover,
.main-navigation a:hover,
a:hover {
    text-shadow:
        0 0 5px var(--term-phosphor),
        0 0 10px rgba(0, 255, 65, 0.3);
}

/* Intense glow utility class */
.glow-intense {
    text-shadow:
        0 0 5px currentColor,
        0 0 10px currentColor,
        0 0 20px currentColor;
}

/* Phosphor glow for special elements */
.term-phosphor,
.cursor::after,
.blink::after {
    text-shadow: 0 0 8px var(--term-phosphor);
}

/* --------------------------------------------------------------------------
   Box-Drawing Character Borders
   -------------------------------------------------------------------------- */
/* Terminal window style for widgets */
.widget {
    border: none;
    background-color: var(--term-bg-card);
    position: relative;
    padding: 1.5rem 1rem 1rem 1rem;
}

/* Top border with title area */
.widget::before {
    content: '┌─────────────────────────────────────────────────────────────┐';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    color: var(--term-dim);
    font-family: var(--term-font);
    font-size: 0.75rem;
    white-space: nowrap;
    overflow: hidden;
    line-height: 1;
}

.widget::after {
    content: '└─────────────────────────────────────────────────────────────┘';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    color: var(--term-dim);
    font-family: var(--term-font);
    font-size: 0.75rem;
    white-space: nowrap;
    overflow: hidden;
    line-height: 1;
}

/* Bordered box utility class */
.box-border {
    border: 1px solid var(--term-dim);
    position: relative;
}

.box-border::before {
    content: '╔';
    position: absolute;
    top: -1px;
    left: -1px;
    color: var(--term-cyan);
    font-family: var(--term-font);
}

.box-border::after {
    content: '╝';
    position: absolute;
    bottom: -1px;
    right: -1px;
    color: var(--term-cyan);
    font-family: var(--term-font);
}

/* Terminal-style article cards with side borders */
article.loop-entry {
    position: relative;
}

article.loop-entry::before {
    content: '│';
    position: absolute;
    top: 20px;
    bottom: 20px;
    left: -15px;
    color: var(--term-dim);
    font-family: var(--term-font);
    font-size: 1rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    writing-mode: vertical-lr;
    letter-spacing: -2px;
}

/* --------------------------------------------------------------------------
   ASCII Spinners
   -------------------------------------------------------------------------- */
/* Spinner animation keyframes */
@keyframes spin-classic {
    0% { content: '\\'; }
    25% { content: '|'; }
    50% { content: '/'; }
    75% { content: '-'; }
    100% { content: '\\'; }
}

@keyframes spin-dots {
    0% { content: '⠋'; }
    10% { content: '⠙'; }
    20% { content: '⠹'; }
    30% { content: '⠸'; }
    40% { content: '⠼'; }
    50% { content: '⠴'; }
    60% { content: '⠦'; }
    70% { content: '⠧'; }
    80% { content: '⠇'; }
    90% { content: '⠏'; }
    100% { content: '⠋'; }
}

@keyframes spin-braille {
    0% { content: '⣾'; }
    12.5% { content: '⣽'; }
    25% { content: '⣻'; }
    37.5% { content: '⢿'; }
    50% { content: '⡿'; }
    62.5% { content: '⣟'; }
    75% { content: '⣯'; }
    87.5% { content: '⣷'; }
    100% { content: '⣾'; }
}

@keyframes spin-grow {
    0% { content: '▏'; }
    12.5% { content: '▎'; }
    25% { content: '▍'; }
    37.5% { content: '▌'; }
    50% { content: '▋'; }
    62.5% { content: '▊'; }
    75% { content: '▉'; }
    87.5% { content: '█'; }
    100% { content: '▏'; }
}

/* Spinner base styles */
.spinner,
.spinner-classic,
.spinner-dots,
.spinner-braille,
.spinner-grow {
    display: inline-block;
    font-family: var(--term-font);
    color: var(--term-phosphor);
    text-shadow: 0 0 5px var(--term-phosphor);
}

.spinner::after,
.spinner-classic::after {
    content: '\\';
    animation: spin-classic 0.5s steps(4, end) infinite;
}

.spinner-dots::after {
    content: '⠋';
    animation: spin-dots 0.8s steps(10, end) infinite;
}

.spinner-braille::after {
    content: '⣾';
    animation: spin-braille 0.8s steps(8, end) infinite;
}

.spinner-grow::after {
    content: '▏';
    animation: spin-grow 0.8s steps(8, end) infinite;
}

/* Loading indicator for images/content */
.loading {
    position: relative;
    min-height: 100px;
}

.loading::before {
    content: 'Loading...';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--term-dim);
    font-family: var(--term-font);
}

.loading::after {
    content: '⠋';
    position: absolute;
    top: 50%;
    left: calc(50% + 60px);
    transform: translateY(-50%);
    animation: spin-dots 0.8s steps(10, end) infinite;
    color: var(--term-phosphor);
    text-shadow: 0 0 5px var(--term-phosphor);
}

/* --------------------------------------------------------------------------
   Progress Bar (Reading Progress)
   -------------------------------------------------------------------------- */
.progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    width: 0%;
    height: 3px;
    background: linear-gradient(
        90deg,
        var(--term-phosphor) 0%,
        var(--term-cyan) 100%
    );
    box-shadow: 0 0 10px var(--term-phosphor);
    z-index: 9999;
    transition: width 0.1s ease;
}

/* Terminal-style progress bar utility */
.progress-terminal {
    font-family: var(--term-font);
    color: var(--term-fg);
}

.progress-terminal::before {
    content: '[';
    color: var(--term-dim);
}

.progress-terminal::after {
    content: ']';
    color: var(--term-dim);
}

/* --------------------------------------------------------------------------
   Enhanced Widget Styling
   -------------------------------------------------------------------------- */
.widget-title {
    position: relative;
    padding-left: 0;
}

.widget-title::before {
    content: '┤ ';
    color: var(--term-dim);
}

.widget-title::after {
    content: ' ├──';
    color: var(--term-dim);
}

/* --------------------------------------------------------------------------
   Utility Classes (Phase 1 + Phase 2)
   -------------------------------------------------------------------------- */
.term-glow {
    text-shadow: var(--term-glow);
}

.term-phosphor {
    color: var(--term-phosphor);
}

.term-dim {
    color: var(--term-dim);
}

/* Screen flicker (optional - for future retro mode toggle) */
@keyframes flicker {
    0% { opacity: 0.97; }
    50% { opacity: 1; }
    100% { opacity: 0.98; }
}

.retro-mode {
    animation: flicker 0.15s infinite;
}

/* "New" content badge */
.badge-new,
.fresh-content::before {
    content: '● NEW';
    display: inline-block;
    font-size: 0.65rem;
    color: var(--term-phosphor);
    text-shadow: 0 0 5px var(--term-phosphor);
    margin-left: 0.5rem;
    letter-spacing: 0.1em;
    animation: blink 2s infinite;
}

/* Responsive: hide complex box-drawing on small screens */
@media (max-width: 768px) {
    .widget::before,
    .widget::after,
    article.loop-entry::before {
        display: none;
    }

    .widget {
        border: 1px solid var(--term-dim);
        border-left: 3px solid var(--term-phosphor);
    }

    /* Reduce glow intensity on mobile for performance */
    h1, h2, .entry-title {
        text-shadow: none;
    }

    .entry-title a:hover {
        text-shadow: 0 0 3px var(--term-phosphor);
    }
}

/* --------------------------------------------------------------------------
   Meta Information (dates, author, etc.)
   -------------------------------------------------------------------------- */
.entry-meta,
.post-meta,
.entry-footer {
    color: var(--term-dim);
    font-size: 0.85rem;
}

.entry-meta a,
.post-meta a,
.entry-footer a {
    color: var(--term-dim);
}

.entry-meta a:hover,
.post-meta a:hover,
.entry-footer a:hover {
    color: var(--term-phosphor);
}

/* Hide Kadence dot dividers in entry meta */
.entry-meta > .posted-by::after {
    content: '' !important;
    display: none !important;
}

/* Date styling - terminal timestamp format */
.posted-on {
    margin-left: 0.4em;
}

.posted-on::before {
    content: '[';
    color: var(--term-dim);
}

.posted-on::after {
    content: ']' !important;
    display: inline !important;
    background-color: transparent !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    border-radius: 0 !important;
    color: var(--term-dim);
}

/* ==========================================================================
   TERMINAL THEME - Phase 3: Interactivity
   ========================================================================== */

/* --------------------------------------------------------------------------
   Typing Effect
   -------------------------------------------------------------------------- */
.typing-active {
    min-height: 1em;
}

.typing-cursor {
    color: var(--term-phosphor);
    animation: blink 1s infinite;
    font-weight: 400;
    margin-left: 2px;
}

.cursor-fade {
    animation: cursor-fade-out 1s forwards;
}

@keyframes cursor-fade-out {
    0% { opacity: 1; }
    100% { opacity: 0; }
}

/* Hide the $ prefix while typing (it looks odd with the effect) */
.typing-active::before {
    display: none;
}

.typing-complete::before {
    display: inline;
}

/* --------------------------------------------------------------------------
   Keyboard Help Overlay
   -------------------------------------------------------------------------- */
.keyboard-help-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(30, 31, 41, 0.95);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
}

.keyboard-help {
    background-color: var(--term-bg-card);
    border: 1px solid var(--term-dim);
    max-width: 400px;
    width: 90%;
    font-family: var(--term-font);
}

.keyboard-help-header {
    padding: 1rem;
    border-bottom: 1px solid var(--term-dim);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 700;
    color: var(--term-fg);
}

.keyboard-help-close {
    cursor: pointer;
    color: var(--term-dim);
    font-size: 1.5rem;
    line-height: 1;
    padding: 0 0.5rem;
    transition: color 0.2s ease;
}

.keyboard-help-close:hover {
    color: var(--term-red);
}

.keyboard-help-content {
    padding: 1rem;
}

.keyboard-help-row {
    display: flex;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(98, 114, 164, 0.2);
}

.keyboard-help-row:last-child {
    border-bottom: none;
}

.keyboard-help-row kbd {
    background-color: var(--term-bg-alt);
    border: 1px solid var(--term-dim);
    border-radius: 3px;
    padding: 0.25rem 0.5rem;
    min-width: 2rem;
    text-align: center;
    font-family: var(--term-font);
    font-size: 0.85rem;
    color: var(--term-phosphor);
    margin-right: 1rem;
}

.keyboard-help-row span {
    color: var(--term-dim);
}

/* --------------------------------------------------------------------------
   Image Loading States
   -------------------------------------------------------------------------- */
.image-loading-wrapper {
    position: relative;
    background-color: var(--term-bg-alt);
    min-height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.image-loading-wrapper.loading img {
    opacity: 0.3;
    transition: opacity 0.3s ease;
}

.image-loading-wrapper:not(.loading) img {
    opacity: 1;
}

.image-loading-wrapper.load-error::before {
    content: '// Error loading image';
    color: var(--term-red);
}

.image-loading-wrapper.load-error::after {
    display: none;
}

/* --------------------------------------------------------------------------
   Skip to Content (Accessibility Enhancement)
   -------------------------------------------------------------------------- */
.skip-to-content {
    position: absolute;
    top: -100%;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--term-phosphor);
    color: var(--term-bg);
    padding: 0.5rem 1rem;
    font-family: var(--term-font);
    z-index: 10001;
    transition: top 0.2s ease;
}

.skip-to-content:focus {
    top: 10px;
}

/* --------------------------------------------------------------------------
   Terminal Console Log Hint (shown in footer)
   -------------------------------------------------------------------------- */
.console-hint {
    font-size: 0.75rem;
    color: var(--term-dim);
    margin-top: 1rem;
}

.console-hint::before {
    content: '// ';
    color: var(--term-green);
}

/* --------------------------------------------------------------------------
   Responsive Adjustments for Phase 3
   -------------------------------------------------------------------------- */
@media (max-width: 768px) {
    /* Disable typing effect on mobile - can be jarring on small screens */
    .typing-cursor {
        display: none;
    }

    /* Smaller keyboard help on mobile */
    .keyboard-help {
        max-width: 95%;
    }

    .keyboard-help-row {
        padding: 0.75rem 0;
    }
}

/* ==========================================================================
   TERMINAL THEME - Phase 4: Content Enhancement
   ========================================================================== */

/* --------------------------------------------------------------------------
   Terminal Sidebar (Left Margin on Wide Screens)
   Contains: MOTD Banner, System Stats (future), etc.
   -------------------------------------------------------------------------- */

/* Base MOTD styles (shared across all screen sizes) */
.motd-banner {
    font-family: var(--term-font);
    font-size: 0.85rem;
    line-height: 1.4;
}

.motd-frame {
    background-color: var(--term-bg-alt);
    border-radius: 0;
    overflow: hidden;
    position: relative;
}

.motd-line {
    white-space: pre;
    display: flex;
    justify-content: space-between;
}

.motd-top,
.motd-bottom {
    color: var(--term-cyan);
    text-shadow: 0 0 5px rgba(139, 233, 253, 0.3);
    display: block;
    text-align: center;
    overflow: hidden;
    font-size: 0.8rem;
}

.motd-content {
    display: flex;
}

.motd-content .motd-border {
    color: var(--term-cyan);
    text-shadow: 0 0 5px rgba(139, 233, 253, 0.3);
    flex-shrink: 0;
}

.motd-content .motd-text {
    flex-grow: 1;
    color: var(--term-fg);
    text-align: left;
    overflow: hidden;
}

.motd-highlight {
    color: var(--term-phosphor);
    text-shadow: 0 0 8px var(--term-phosphor);
    font-weight: 700;
}

.motd-timestamp {
    color: var(--term-yellow);
}

.motd-tagline {
    color: var(--term-dim);
    font-style: italic;
}

/* Command prompt below the MOTD */
.motd-prompt {
    margin-top: 0.75rem;
    padding-left: 0.25rem;
    color: var(--term-fg);
    font-size: 0.8rem;
}

.motd-user {
    color: var(--term-green);
}

.motd-separator {
    color: var(--term-fg);
}

.motd-path {
    color: var(--term-purple);
}

.motd-dollar {
    color: var(--term-fg);
    margin-left: 0.25em;
    margin-right: 0.25em;
}

.motd-prompt .cursor::after {
    content: '█';
    color: var(--term-phosphor);
    animation: blink 1s infinite;
}

/* CRT effect on the MOTD frame */
.motd-frame::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    background: repeating-linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.03),
        rgba(0, 0, 0, 0.03) 1px,
        transparent 1px,
        transparent 2px
    );
    z-index: 1;
}

/* --------------------------------------------------------------------------
   Wide Screens: Left Margin Sidebar Layout (>= 1400px)
   -------------------------------------------------------------------------- */
@media (min-width: 1400px) {
    /* Sidebar container fixed in left margin */
    .terminal-sidebar {
        position: fixed;
        left: 15px;
        top: 120px; /* Below header */
        width: 280px;
        max-width: 280px;
        z-index: 100;
        padding: 0;
        margin: 0;
    }

    /* MOTD inherits positioning from sidebar container */
    .motd-banner {
        position: static;
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
    }

    /* Shrink box-drawing to fit narrower width */
    .motd-top,
    .motd-bottom {
        font-size: 0.65rem;
        letter-spacing: -1.5px;
    }

    .motd-content .motd-text {
        font-size: 0.7rem;
    }

    .motd-prompt {
        font-size: 0.7rem;
    }

    /* System stats widget visible in sidebar */
    .terminal-sidebar-widget {
        display: block;
    }

    /* Target Kadence's actual containers with high specificity */
    body.home #main.site-main {
        margin-left: 310px !important;
        margin-right: 20px !important;
        padding-left: 0 !important;
        max-width: none !important;
        width: auto !important;
    }

    body.home #archive-container.content-wrap {
        margin-left: 0 !important;
        padding-left: 0 !important;
        max-width: none !important;
        width: 100% !important;
    }

    /* Ensure the grid uses available space */
    body.home ul.kadence-posts-list {
        margin-left: 0 !important;
        padding-left: 0 !important;
    }
}

/* --------------------------------------------------------------------------
   Medium Screens: Header Layout (1000px - 1399px)
   -------------------------------------------------------------------------- */
@media (min-width: 1000px) and (max-width: 1399px) {
    .motd-banner {
        max-width: 600px;
        margin: 2rem auto 2rem auto;
        padding: 0 1rem;
    }

    .motd-top,
    .motd-bottom {
        font-size: 0.75rem;
    }
}

/* --------------------------------------------------------------------------
   Tablet/Small Screens: Compact Header (600px - 999px)
   -------------------------------------------------------------------------- */
@media (min-width: 600px) and (max-width: 999px) {
    .motd-banner {
        max-width: 500px;
        margin: 1.5rem auto;
        padding: 0 1rem;
        font-size: 0.8rem;
    }

    .motd-top,
    .motd-bottom {
        font-size: 0.65rem;
        letter-spacing: -0.5px;
    }

    .motd-prompt {
        font-size: 0.75rem;
    }
}

/* --------------------------------------------------------------------------
   Mobile: Minimal Header (< 600px)
   -------------------------------------------------------------------------- */
@media (max-width: 599px) {
    .motd-banner {
        max-width: 100%;
        margin: 1rem auto 1.5rem auto;
        padding: 0 0.5rem;
        font-size: 0.7rem;
    }

    .motd-top,
    .motd-bottom {
        font-size: 0.55rem;
        letter-spacing: -1px;
    }

    .motd-content .motd-text {
        font-size: 0.7rem;
    }

    .motd-prompt {
        font-size: 0.7rem;
    }

    /* Tagline stays visible on mobile - it's short enough to fit */
}

/* --------------------------------------------------------------------------
   Terminal Sidebar: Widget Container
   System stats widget sits below MOTD in the sidebar on wide screens
   -------------------------------------------------------------------------- */
.terminal-sidebar-widget {
    margin-top: 1.5rem;
    font-family: var(--term-font);
    font-size: 0.8rem;
}

@media (max-width: 1399px) {
    .terminal-sidebar-widget {
        display: none;
    }
}

/* --------------------------------------------------------------------------
   System Stats Widget
   -------------------------------------------------------------------------- */
.system-stats {
    color: var(--term-fg);
    line-height: 1.6;
}

/* Box-drawing borders */
.stats-border-top,
.stats-border-bottom {
    color: var(--term-dim);
    white-space: nowrap;
    overflow: hidden;
    font-size: 0.75rem;
    line-height: 1;
}

.stats-corner {
    color: var(--term-dim);
}

.stats-rule,
.stats-rule-fill {
    color: var(--term-dim);
}

.stats-title {
    color: var(--term-cyan);
    font-weight: 700;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
}

.stats-pipe {
    color: var(--term-dim);
}

/* Stat rows */
.stats-body {
    padding: 0.25rem 0;
}

.stat-row {
    padding: 0.1rem 0;
    font-size: 0.75rem;
    white-space: nowrap;
}

.stat-label {
    color: var(--term-dim);
    margin-left: 0.25rem;
}

.stat-value {
    color: var(--term-fg);
    margin-left: 0.25rem;
}

/* Sparkline in cyan */
.stat-sparkline {
    color: var(--term-cyan);
    text-shadow: 0 0 3px rgba(139, 233, 253, 0.3);
    letter-spacing: 1px;
}

/* Visitor count in phosphor green */
.stat-visitors {
    color: var(--term-phosphor);
    text-shadow: 0 0 5px rgba(0, 255, 65, 0.4);
}

/* Wide screen: tighten stats font for sidebar width */
@media (min-width: 1400px) {
    .system-stats {
        font-size: 0.7rem;
    }

    .stat-row {
        font-size: 0.7rem;
    }

    .stats-border-top,
    .stats-border-bottom {
        font-size: 0.7rem;
    }
}

/* --------------------------------------------------------------------------
   Custom Terminal Footer (replaces Kadence credit)
   -------------------------------------------------------------------------- */

/* Hide the default Kadence footer credit */
.site-footer .site-info,
.site-footer .footer-html,
.site-footer .footer-html-inner,
footer.site-footer .site-bottom-footer-wrap {
    display: none !important;
}

.terminal-footer {
    text-align: center;
    padding: 1.5rem 1rem;
    font-family: var(--term-font);
    font-size: 0.85rem;
    background-color: var(--term-bg-alt);
    border-top: 1px solid var(--term-dim);
}

.tf-user {
    color: var(--term-green);
}

.tf-sep {
    color: var(--term-fg);
}

.tf-path {
    color: var(--term-purple);
}

.tf-dollar {
    color: var(--term-fg);
}

.tf-cmd {
    color: var(--term-dim);
}

.tf-closed {
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: var(--term-dim);
}

.tf-comment {
    color: var(--term-green);
}

/* --------------------------------------------------------------------------
   Card Grid: Center Last Incomplete Row
   -------------------------------------------------------------------------- */
@media (min-width: 769px) {
    /* When Kadence uses grid, switch to flexbox for centering last row */
    ul.kadence-posts-list {
        display: flex !important;
        flex-wrap: wrap;
        justify-content: center;
        gap: 24px;
        list-style: none;
        padding: 0;
    }

    ul.kadence-posts-list > li {
        flex: 0 1 calc(33.33% - 24px);
        max-width: calc(33.33% - 24px);
    }
}

@media (min-width: 769px) and (max-width: 1099px) {
    ul.kadence-posts-list > li {
        flex: 0 1 calc(50% - 24px);
        max-width: calc(50% - 24px);
    }
}

/* ==========================================================================
   ARTICLE INDEX WIDGET - $ ls ~/articles/
   Tree-style article browser grouped by category
   ========================================================================== */

/* --------------------------------------------------------------------------
   Container & Box-Drawing Borders
   -------------------------------------------------------------------------- */
.aidx-widget {
    margin-top: 1.5rem;
    font-family: var(--term-font);
    font-size: 0.75rem;
    line-height: 1.5;
}

.aidx-border-top,
.aidx-border-bottom {
    color: var(--term-dim);
    white-space: nowrap;
    overflow: hidden;
    font-size: 0.75rem;
    line-height: 1;
}

.aidx-corner {
    color: var(--term-dim);
}

.aidx-rule,
.aidx-rule-fill {
    color: var(--term-dim);
}

.aidx-title {
    color: var(--term-cyan);
    font-weight: 700;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
}

.aidx-pipe {
    color: var(--term-dim);
}

.aidx-dim {
    color: var(--term-dim);
    font-style: italic;
}

.aidx-body {
    padding: 0.4rem 0 0.25rem 0.5rem;
}

/* --------------------------------------------------------------------------
   Outer Collapse (small screens only)
   On wide screens, the <details> is forced open and summary hidden
   -------------------------------------------------------------------------- */
.aidx-outer-collapse {
    /* Ensure no default marker */
}

.aidx-outer-collapse > .aidx-outer-summary {
    list-style: none;
    cursor: pointer;
}

.aidx-outer-collapse > .aidx-outer-summary::-webkit-details-marker {
    display: none;
}

.aidx-outer-collapse > .aidx-outer-summary::marker {
    content: '';
}

.aidx-collapsed-hint {
    color: var(--term-dim);
    font-size: 0.7rem;
    margin-left: 0.5rem;
}

/* --------------------------------------------------------------------------
   Category Folders
   -------------------------------------------------------------------------- */
.aidx-cat {
    margin-bottom: 0.5rem;
}

.aidx-cat > summary {
    list-style: none;
    cursor: pointer;
    font-weight: 700;
    font-size: 0.75rem;
    padding: 0.15rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    transition: text-shadow 0.2s ease;
}

.aidx-cat > summary::-webkit-details-marker {
    display: none;
}

.aidx-cat > summary::marker {
    content: '';
}

/* Collapse indicator */
.aidx-cat > summary .aidx-folder::before {
    content: '\25B8 '; /* ▸ collapsed */
    font-size: 0.65rem;
}

.aidx-cat[open] > summary .aidx-folder::before {
    content: '\25BE '; /* ▾ expanded */
}

.aidx-cat > summary:hover {
    text-shadow: 0 0 5px currentColor;
}

.aidx-count {
    color: var(--term-dim) !important;
    font-weight: 400;
    font-size: 0.65rem;
}

/* --------------------------------------------------------------------------
   Article List & Tree Characters
   -------------------------------------------------------------------------- */
.aidx-list {
    list-style: none;
    margin: 0 0 0 0.75rem;
    padding: 0;
}

.aidx-item {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
    padding: 0.1rem 0;
    min-width: 0;
}

.aidx-tree {
    color: var(--term-dim);
    flex-shrink: 0;
    width: 1ch;
    font-size: 0.75rem;
}

.aidx-item a {
    color: var(--term-fg);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.7rem;
    transition: color 0.2s ease, text-shadow 0.2s ease;
}

.aidx-item a:visited {
    color: var(--term-fg);
}

.aidx-item a:hover {
    color: var(--term-cyan);
    text-shadow: 0 0 5px rgba(139, 233, 253, 0.4);
    font-size: 0.85rem;
}

.aidx-item:hover .aidx-new {
    display: none;
}

/* --------------------------------------------------------------------------
   NEW Badge
   -------------------------------------------------------------------------- */
.aidx-new {
    color: var(--term-phosphor);
    font-size: 0.55rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-shadow: 0 0 5px var(--term-phosphor);
    flex-shrink: 0;
    margin-left: auto;
    animation: pulse-glow 3s ease-in-out infinite;
}

@keyframes pulse-glow {
    0%, 100% { opacity: 1; text-shadow: 0 0 8px var(--term-phosphor); }
    50% { opacity: 0.4; text-shadow: 0 0 2px var(--term-phosphor); }
}

/* --------------------------------------------------------------------------
   Summary Line (bottom)
   -------------------------------------------------------------------------- */
.aidx-summary {
    color: var(--term-dim);
    font-size: 0.65rem;
    padding-top: 0.4rem;
    margin-left: -0.5rem;
}

/* --------------------------------------------------------------------------
   Wide Screens: Sidebar Layout (>= 1400px)
   Force outer <details> content visible regardless of open state
   -------------------------------------------------------------------------- */
@media (min-width: 1400px) {
    .aidx-widget {
        font-size: 0.7rem;
    }

    .aidx-border-top,
    .aidx-border-bottom {
        font-size: 0.7rem;
    }

    /* Summary acts as a static header on wide screens (details is always open) */
    .aidx-outer-summary {
        pointer-events: none;
        cursor: default;
    }

    .aidx-collapsed-hint {
        display: none;
    }

    .aidx-cat > summary {
        font-size: 0.7rem;
    }

    .aidx-item a {
        font-size: 0.65rem;
    }
}

/* --------------------------------------------------------------------------
   Small Screens: Outer summary styled as clickable toggle (< 1400px)
   -------------------------------------------------------------------------- */
@media (max-width: 1399px) {
    .aidx-outer-summary {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0.25rem 0;
    }

    .aidx-outer-collapse:not([open]) .aidx-collapsed-hint::before {
        content: '\25B8 '; /* ▸ */
        font-size: 0.6rem;
    }

    .aidx-outer-collapse[open] .aidx-collapsed-hint::before {
        content: '\25BE '; /* ▾ */
        font-size: 0.6rem;
    }
}

/* --------------------------------------------------------------------------
   Medium Screens (1000px - 1399px)
   -------------------------------------------------------------------------- */
@media (min-width: 1000px) and (max-width: 1399px) {
    .aidx-widget {
        max-width: 600px;
        margin: 1.5rem auto;
        padding: 0 1rem;
        font-size: 0.8rem;
    }

    .aidx-cat > summary {
        font-size: 0.8rem;
    }

    .aidx-item a {
        font-size: 0.75rem;
    }
}

/* --------------------------------------------------------------------------
   Tablet (600px - 999px)
   -------------------------------------------------------------------------- */
@media (min-width: 600px) and (max-width: 999px) {
    .aidx-widget {
        max-width: 500px;
        margin: 1.5rem auto;
        padding: 0 1rem;
        font-size: 0.8rem;
    }

    .aidx-cat > summary {
        font-size: 0.8rem;
    }

    .aidx-item a {
        font-size: 0.75rem;
    }
}

/* --------------------------------------------------------------------------
   Mobile (< 600px)
   -------------------------------------------------------------------------- */
@media (max-width: 599px) {
    .aidx-widget {
        max-width: 100%;
        margin: 1rem auto;
        padding: 0 0.5rem;
        font-size: 0.75rem;
    }

    .aidx-cat > summary {
        font-size: 0.75rem;
    }

    .aidx-item a {
        font-size: 0.7rem;
    }
}
