/* Github Actions Test */

/* CSS Variables for Theme */
:root {
    --bg-color: #171514;
    /* Less Rich Dark Mocha */
    --text-color: #dcd3c1;
    /* Washed-out Newspaper */
    --accent-color: #cbb0a8;
    /* Brighter Taupe (Date Color) */
    --link-color: #ccc2b0;
    /* Pale Latte (Adjusted for Newspaper theme) */
    --title-color: #faf3e0;
    /* Distinct Parchment for Titles */
    --chip-bg: #3e322e;
    /* Dark Espresso Chip */
    --chip-hover: #5d4037;
    /* Lighter Roast Hover */

    --content-link-color: #f8f1e5;
    /* Brighter mocha/parchment for Content Links */

    --font-primary: "Archivo", sans-serif;

    --container-width: 61.25rem;
    --container-padding: 1.5rem;
}

/* Global Components */
.back-btn {
    display: inline-block;
    color: var(--accent-color);
    font-weight: 500;
    text-decoration: none;
    margin-bottom: 1.25rem;
}

.back-btn:hover {
    color: var(--text-color);
    text-decoration: underline;
}

/* Tag Chips */
.tag {
    display: inline-block;
    background-color: var(--chip-bg);
    color: var(--link-color);
    padding: 0.0625rem 0.375rem;
    /* Smaller padding */
    border-radius: 0.1875rem;
    font-size: 0.6875rem;
    /* Smaller font */
    text-transform: uppercase;
    letter-spacing: 0.03125rem;
    margin-left: 0.5rem;
    text-decoration: none;
    /* Ensure no underline */
    /* Removed transition for instant 2-state color change */
}

.tag:hover {
    background-color: var(--chip-hover);
    color: var(--text-color);
    text-decoration: none;
}

/* Base Styles */
body {
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: var(--font-primary);
    margin: 0;
    padding: 0;
    padding: 0;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

img {
    max-width: 100%;
    height: auto;
}

/* Unified Content Typography */
.ql-editor,
.post-content,
.post-excerpt {
    font-size: 1rem !important;
    line-height: 1.5 !important;
    font-family: var(--font-primary) !important;
}

.ql-editor p,
.post-content p,
.post-excerpt p,
.post-content h1,
.post-content h2,
.post-content h3,
.post-excerpt h1,
.post-excerpt h2,
.post-excerpt h3,
.ql-editor h1,
.ql-editor h2,
.ql-editor h3 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
}

.ql-editor>*:first-child,
.post-content>*:first-child,
.post-excerpt>*:first-child {
    margin-top: 0 !important;
}

a {
    color: var(--link-color);
    text-decoration: none;
    transition: opacity 0.2s ease;
}

a:hover {
    text-decoration: underline;
    opacity: 0.8;
}

/* Perfect Content Link Synchronization */
.ql-snow .ql-editor a,
.post-content a,
.post-excerpt a {
    color: var(--content-link-color) !important;
    text-decoration: underline dashed !important;
    text-underline-offset: 0px !important;
    /* Unitless 0 is fine, keeping explicit */
    text-decoration-thickness: 0.09375rem !important;
    /* Scalable thickness */
    text-underline-position: under !important;
    text-decoration-skip-ink: none !important;
    transition: color 0.2s, opacity 0.2s;
}

.post-content a:hover,
.post-excerpt a:hover,
.ql-editor a:hover {
    color: var(--title-color) !important;
    opacity: 1;
}

/* Layout container */
.site-wrapper {
    width: 95%;
    max-width: 68.75rem;
    margin: 0 auto;
    padding: 3.75rem 1.25rem;
    display: flex;
    flex-wrap: wrap;
    /* Wraps on mobile */
    gap: 3.75rem;
}

/* Sidebar Styles */
.site-sidebar {
    flex: 0 0 15rem;
    /* Fixed width sidebar */
    text-align: left;
}

.avatar-container {
    margin-bottom: 1.5rem;
}

.avatar {
    width: 7.5rem;
    height: 7.5rem;
    border-radius: 0.5rem;
    /* Slightly rounded corners */
    object-fit: cover;
    background-color: #333;
    /* Placeholder color before load */
}

.site-title {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 0 1.5rem 0;
}

.site-title a {
    color: var(--title-color);
}

.site-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.site-nav li {
    margin-bottom: 0.75rem;
}

.site-nav a {
    font-size: 1rem;
    color: var(--title-color);
    font-weight: 500;
}

/* Main Content Styles */
.site-content {
    flex: 1;
    /* Takes remaining space */
    min-width: 0;
    /* Prevents flex overflow issues */
}

.post-preview {
    margin-bottom: 3.75rem;
}

.post-preview h2 {
    font-size: 1.75rem;
    margin: 0 0 0 0;
    /* Reduced from 12px to hug date */
    font-weight: 700;
    line-height: 1.0;
}

.post-preview header {
    margin-bottom: 0.4rem;
}

.post-preview h2 a {
    color: var(--title-color);
}

.post-meta {
    font-size: 0.9375rem;
    color: var(--accent-color);
    margin-bottom: 1.25rem;
    /* Visual gap equivalent of 1.5rem (1.25 margin + 0.25 body leading) */
    font-family: var(--font-primary);
    line-height: 1.0;
}

.post-excerpt {
    font-size: 1.125rem;
    line-height: 1.6;
    margin-bottom: 1rem;
    color: var(--text-color);
    /* Line Clamp */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.post-excerpt img {
    max-width: 100%;
    height: auto;
    display: block;
    /* Ensure it respects block layout */
    margin: 0.625rem 0;
}

.single-post-container img {
    max-width: 100% !important;
    height: auto !important;
}

.read-more {
    font-size: 0.9375rem;
    font-weight: 600;
    border-bottom: 1px solid transparent;
    /* Border exception */
}

.read-more:hover {
    border-bottom-color: var(--link-color);
    text-decoration: none;
}

.site-footer {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 0.875rem;
    color: var(--accent-color);
}

/* Responsive */
@media (max-width: 48rem) {

    /* 768px -> 48rem */
    .site-wrapper {
        flex-direction: column;
        gap: 2.5rem;
        padding: 2.5rem 1.25rem;
    }

    .site-sidebar {
        flex: 0 0 auto;
        text-align: center;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        padding-bottom: 1.875rem;
    }

}





/* Admin Components */
.dashboard-card {
    display: block;
    padding: 1.875rem;
    background: #222;
    border: 1px solid #333;
    color: var(--text-color);
    text-decoration: none;
    transition: transform 0.2s, background 0.2s, border-color 0.2s;
    box-sizing: border-box;
    border-radius: 0.25rem;
}

.dashboard-card:hover {
    transform: translateY(-0.3125rem);
    background: #2a2a2a;
    border-color: var(--accent-color);
    text-decoration: none;
}

.help-icon {
    display: inline-block;
    width: 1.125rem;
    height: 1.125rem;
    border-radius: 50%;
    background: #444;
    color: var(--text-color);
    text-align: center;
    line-height: 1.125rem;
    font-size: 0.75rem;
    cursor: help;
    margin-left: 0.625rem;
    position: relative;
}

.help-icon:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    left: 120%;
    top: 50%;
    transform: translateY(-50%);
    background: #333;
    border: 1px solid #555;
    color: var(--text-color);
    padding: 0.625rem;
    width: 12.5rem;
    font-size: 0.8125rem;
    line-height: 1.4;
    z-index: 100;
    border-radius: 0.25rem;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.5);
    font-weight: normal;
}

.image-card.selected {
    border-color: #00bcd4 !important;
    box-shadow: 0 0 0 2px #00bcd4;
    /* Exception: 2px shadow "border" */
    opacity: 1 !important;
}

.image-card.selected::after {
    content: '✓';
    position: absolute;
    top: 0.3125rem;
    right: 0.3125rem;
    background: #00bcd4;
    color: #000;
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 50%;
    text-align: center;
    line-height: 1.25rem;
    font-weight: bold;
    font-size: 0.875rem;
}

/* 3-Second Delayed Tooltip */
.tooltip-container {
    position: relative;
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    /* Ensure pointer shows */
}

.tooltip-container:hover .tooltip-text {
    visibility: visible;
    opacity: 1;
    transition-delay: 3s;
    /* The magic 3s delay before showing */
}

.tooltip-text {
    visibility: hidden;
    opacity: 0;
    width: 7.5rem;
    background-color: #333;
    color: var(--text-color);
    text-align: center;
    border-radius: 0.25rem;
    padding: 0.3125rem;
    position: absolute;
    z-index: 100;
    font-size: 0.75rem;
    border: 1px solid #555;

    /* Position Top */
    bottom: 120%;
    left: 50%;
    transform: translateX(-50%);

    /* Fast fade in once delay is over */
    transition: opacity 0.2s linear;
}

.tooltip-text::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: #333 transparent transparent transparent;
}

/* Admin Dashboard Rows */
.post-item {
    cursor: pointer;
}

/* Post Actions Container */
.post-actions {
    display: flex;
    align-items: center;
}

/* Visible Toggle (Replaces inline styles) */
.visible-toggle {
    display: flex;
    align-items: center;
    margin-right: 1.25rem;
}

.visible-toggle label {
    color: #aaa;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    cursor: pointer;
    margin: 0;
}

.visible-toggle input {
    width: auto;
    margin: 0 0 0 0.375rem;
    cursor: pointer;
}

/* Button Groups (Flushed Buttons) */
.btn-group {
    display: flex;
}

.btn-group .btn {
    border-radius: 0;
    margin: 0;
}

.btn-group .btn:first-child {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.btn-group .btn:last-child {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-left: 0;
    /* Merge borders */
}

.btn-delete {
    color: #ff4444;
}

.btn-delete:hover {
    background-color: #3e2020;
    /* Dark red bg on hover */
    color: #ff6b6b;
}

/* --- Resizer Handles --- */
.resizer-handle {
    position: absolute;
    width: 0.625rem;
    height: 0.625rem;
    background-color: var(--text-color);
    border: 1px solid #000;
    z-index: 1000;
    pointer-events: auto;
    cursor: pointer;
}

#editor img {
    border: 0.25rem solid transparent;
    /* Horizontal spacing for cursor */
    border-top-width: 0;
    border-bottom-width: 0;
    display: inline-block;
    box-sizing: border-box;
    vertical-align: bottom;
    /* Fix line-height/cursor alignment issues */
}

/* Hide native selection blue tint on images */
#editor img::selection {
    background: transparent;
}

/* Modal Cancel Button */
.btn-cancel {
    background: transparent;
    color: #aaa;
    border: 1px solid #444;
    padding: 0.625rem 1.25rem;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
    height: 2.375rem;
    line-height: 1.125rem;
    box-sizing: border-box;
    border-radius: 0;
    /* Sharp corners */
    transition: all 0.2s;
}

.btn-cancel:hover {
    background: #333;
    color: var(--text-color);
    border-color: #666;
}

/* --- Quill Editor Theme Overrides --- */

/* Toolbar Border and Background */
.ql-toolbar.ql-snow {
    border-color: #444 !important;
    background-color: #1a1817;
    /* Slightly lighter than body bg */
}

/* Standard Toolbar Buttons Hover/Active */
.ql-snow.ql-toolbar button:hover,
.ql-snow .ql-toolbar button:hover,
.ql-snow.ql-toolbar button:focus,
.ql-snow .ql-toolbar button:focus,
.ql-snow.ql-toolbar button.ql-active,
.ql-snow .ql-toolbar button.ql-active {
    color: var(--accent-color) !important;
}

.ql-snow.ql-toolbar button:hover .ql-fill,
.ql-snow .ql-toolbar button:hover .ql-fill,
.ql-snow.ql-toolbar button:focus .ql-fill,
.ql-snow .ql-toolbar button:focus .ql-fill,
.ql-snow.ql-toolbar button.ql-active .ql-fill,
.ql-snow .ql-toolbar button.ql-active .ql-fill {
    fill: var(--accent-color) !important;
}

.ql-snow.ql-toolbar button:hover .ql-stroke,
.ql-snow .ql-toolbar button:hover .ql-stroke,
.ql-snow.ql-toolbar button:focus .ql-stroke,
.ql-snow .ql-toolbar button:focus .ql-stroke,
.ql-snow.ql-toolbar button.ql-active .ql-stroke,
.ql-snow .ql-toolbar button.ql-active .ql-stroke {
    stroke: var(--accent-color) !important;
}

/* Picker (Dropdown) Label Hover/Active */
.ql-snow.ql-toolbar .ql-picker-label:hover,
.ql-snow .ql-toolbar .ql-picker-label:hover,
.ql-snow.ql-toolbar .ql-picker-label.ql-active,
.ql-snow .ql-toolbar .ql-picker-label.ql-active {
    color: var(--accent-color) !important;
}

.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,
.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,
.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,
.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke {
    stroke: var(--accent-color) !important;
}

/* Dropdown Options Box */
.ql-snow .ql-picker-options {
    background-color: #2a2a2a !important;
    border: 1px solid #444 !important;
    box-shadow: 0 0.25rem 0.625rem rgba(0, 0, 0, 0.5) !important;
}

/* Picker Items (the options inside the dropdown) */
.ql-snow .ql-picker-options .ql-picker-item {
    color: #aaa !important;
}

.ql-snow .ql-picker-options .ql-picker-item:hover,
.ql-snow .ql-picker-options .ql-picker-item.ql-selected {
    color: var(--accent-color) !important;
}

/* Fix for Picker Arrows in Expanded State */
.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke {
    stroke: var(--accent-color) !important;
}

/* Header Live Link */
#header-live-link {
    transition: color 0.2s;
}

#header-live-link:hover {
    color: var(--link-color) !important;
    text-decoration: underline !important;
}