/* ==========================================================================
   TechNode HQ — Components
   Reusable UI components: Cards, Buttons, Badges, Tags, Newsletter CTA,
   Sponsor Block, Ad Zone, Author Bio, Search Overlay, Progress Bar,
   Toast Notifications, Skeleton Loaders
   ========================================================================== */


/* ==========================================================================
   1. CARDS (.tnhq-card)
   Glassmorphism article cards used across the entire theme.
   ========================================================================== */

.tnhq-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--tnhq-glass-bg);
    border: 1px solid var(--tnhq-glass-border);
    border-radius: var(--tnhq-radius-lg);
    overflow: hidden;
    backdrop-filter: blur(var(--tnhq-glass-blur));
    -webkit-backdrop-filter: blur(var(--tnhq-glass-blur));
    transition:
        transform var(--tnhq-ease-base),
        box-shadow var(--tnhq-ease-base),
        border-color var(--tnhq-ease-base);
}

.tnhq-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--tnhq-shadow-glow);
    border-color: var(--tnhq-accent);
}

/* Card Image
   ------------------------------------------------------------------ */
.tnhq-card__image {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--tnhq-bg-surface);
}

.tnhq-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--tnhq-ease-slow);
}

.tnhq-card:hover .tnhq-card__image img {
    transform: scale(1.05);
}

/* Card Body
   ------------------------------------------------------------------ */
.tnhq-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: var(--tnhq-space-5);
    gap: var(--tnhq-space-3);
}

/* Card Meta — date · author · reading time */
.tnhq-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--tnhq-space-3);
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
    letter-spacing: var(--tnhq-tracking-wide);
    text-transform: uppercase;
}

.tnhq-card__meta span + span::before {
    content: "·";
    margin-right: var(--tnhq-space-3);
    color: var(--tnhq-text-tertiary);
}

/* Card Category Badge */
.tnhq-card__category {
    display: inline-block;
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
    font-size: var(--tnhq-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    border-radius: var(--tnhq-radius-full);
    line-height: 1.4;
    white-space: nowrap;
}

/* Card Title */
.tnhq-card__title {
    font-family: var(--tnhq-font-heading);
    font-size: var(--tnhq-text-lg);
    font-weight: 700;
    line-height: var(--tnhq-leading-snug);
    color: var(--tnhq-text-primary);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color var(--tnhq-ease-fast);
}

.tnhq-card__title a {
    color: inherit;
    text-decoration: none;
}

/* Make entire card clickable via stretched link */
.tnhq-card__title a::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 10;
}

.tnhq-card__title a:hover {
    color: var(--tnhq-accent);
}

/* Card Excerpt */
.tnhq-card__excerpt {
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-secondary);
    line-height: var(--tnhq-leading-normal);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Card Footer */
.tnhq-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--tnhq-space-4) var(--tnhq-space-5);
    border-top: 1px solid var(--tnhq-border-light);
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
    margin-top: auto;
}

/* ---- Card Variant: Horizontal ---- */
.tnhq-card--horizontal {
    flex-direction: row;
}

.tnhq-card--horizontal .tnhq-card__image {
    width: 260px;
    min-width: 260px;
    aspect-ratio: auto;
}

.tnhq-card--horizontal .tnhq-card__body {
    justify-content: center;
}

.tnhq-card--horizontal .tnhq-card__title {
    font-size: var(--tnhq-text-base);
    -webkit-line-clamp: 2;
}

.tnhq-card--horizontal .tnhq-card__excerpt {
    -webkit-line-clamp: 2;
}

/* ---- Card Variant: Featured ---- */
.tnhq-card--featured .tnhq-card__title {
    font-size: var(--tnhq-text-2xl);
    -webkit-line-clamp: unset;
    overflow: visible;
}

.tnhq-card--featured .tnhq-card__excerpt {
    -webkit-line-clamp: 3;
    font-size: var(--tnhq-text-base);
}

/* ---- Card Variant: Sponsored ---- */
.tnhq-card--sponsored {
    border-left: 3px solid var(--tnhq-sponsored);
}

.tnhq-card--sponsored .tnhq-card__sponsored-label {
    display: inline-flex;
    align-items: center;
    gap: var(--tnhq-space-1);
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    background: var(--tnhq-warning-muted);
    color: var(--tnhq-sponsored);
    font-size: var(--tnhq-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    border-radius: var(--tnhq-radius-full);
}


/* ==========================================================================
   2. BUTTONS (.tnhq-btn)
   ========================================================================== */

.tnhq-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--tnhq-space-2);
    padding: var(--tnhq-space-3) var(--tnhq-space-6);
    font-family: var(--tnhq-font-body);
    font-size: var(--tnhq-text-sm);
    font-weight: 600;
    line-height: 1;
    border: 2px solid transparent;
    border-radius: var(--tnhq-radius-md);
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition:
        background var(--tnhq-ease-fast),
        color var(--tnhq-ease-fast),
        border-color var(--tnhq-ease-fast),
        box-shadow var(--tnhq-ease-fast),
        transform var(--tnhq-ease-fast);
}

.tnhq-btn:active {
    transform: scale(0.97);
}

/* Primary — filled accent */
.tnhq-btn--primary {
    background: var(--tnhq-accent);
    color: var(--tnhq-text-inverse);
    border-color: var(--tnhq-accent);
}

.tnhq-btn--primary:hover {
    background: var(--tnhq-accent-hover);
    border-color: var(--tnhq-accent-hover);
    color: var(--tnhq-text-inverse);
    box-shadow: var(--tnhq-shadow-glow);
}

/* Secondary — outlined */
.tnhq-btn--secondary {
    background: transparent;
    color: var(--tnhq-accent);
    border-color: var(--tnhq-accent);
}

.tnhq-btn--secondary:hover {
    background: var(--tnhq-accent);
    color: var(--tnhq-text-inverse);
    box-shadow: var(--tnhq-shadow-glow);
}

/* Ghost — no border, subtle text */
.tnhq-btn--ghost {
    background: transparent;
    color: var(--tnhq-text-secondary);
    border-color: transparent;
}

.tnhq-btn--ghost:hover {
    color: var(--tnhq-accent);
    background: var(--tnhq-accent-subtle);
}

/* Size: Small */
.tnhq-btn--sm {
    padding: var(--tnhq-space-2) var(--tnhq-space-4);
    font-size: var(--tnhq-text-xs);
}

/* Size: Large */
.tnhq-btn--lg {
    padding: var(--tnhq-space-4) var(--tnhq-space-8);
    font-size: var(--tnhq-text-base);
}

/* Icon button — square */
.tnhq-btn--icon {
    padding: var(--tnhq-space-3);
    aspect-ratio: 1;
}

.tnhq-btn--icon svg {
    width: 18px;
    height: 18px;
}

/* Disabled state */
.tnhq-btn:disabled,
.tnhq-btn[aria-disabled="true"] {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}


/* ==========================================================================
   3. BADGES (.tnhq-badge)
   Small pill labels for categories, content types, and status indicators.
   ========================================================================== */

.tnhq-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--tnhq-space-1);
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    font-size: var(--tnhq-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    line-height: 1.4;
    border-radius: var(--tnhq-radius-full);
    white-space: nowrap;
    /* Default colors — accent */
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
}

/* Semantic variants */
.tnhq-badge--accent {
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
}

.tnhq-badge--alert {
    background: var(--tnhq-alert-muted);
    color: var(--tnhq-alert);
}

.tnhq-badge--success {
    background: var(--tnhq-success-muted);
    color: var(--tnhq-success);
}

.tnhq-badge--warning {
    background: var(--tnhq-warning-muted);
    color: var(--tnhq-warning);
}

.tnhq-badge--sponsored {
    background: var(--tnhq-warning-muted);
    color: var(--tnhq-sponsored);
}

/* ---- Per-Category Color Badges ---- */

/* AI & Machine Learning — Electric Purple */
.tnhq-badge--cat-ai {
    background: rgba(123, 97, 255, 0.12);
    color: #7B61FF;
}

/* Consumer Tech — Coral */
.tnhq-badge--cat-consumer {
    background: rgba(255, 107, 107, 0.12);
    color: #FF6B6B;
}

/* Enterprise IT — Accent Cyan */
.tnhq-badge--cat-enterprise {
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
}

/* Hardware & Silicon — Amber */
.tnhq-badge--cat-hardware {
    background: rgba(255, 184, 0, 0.12);
    color: #FFB800;
}

/* Networking & Cloud — Emerald */
.tnhq-badge--cat-networking {
    background: rgba(0, 255, 136, 0.12);
    color: #00FF88;
}

/* Reviews & Comparisons — Pink */
.tnhq-badge--cat-reviews {
    background: rgba(255, 51, 102, 0.12);
    color: #FF3366;
}


/* ==========================================================================
   4. TAGS (.tnhq-tag)
   Smaller inline labels for article tags / taxonomy terms.
   ========================================================================== */

.tnhq-tag {
    display: inline-flex;
    align-items: center;
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    font-size: var(--tnhq-text-xs);
    font-weight: 500;
    color: var(--tnhq-text-secondary);
    background: var(--tnhq-bg-surface);
    border: 1px solid var(--tnhq-border-light);
    border-radius: var(--tnhq-radius-full);
    text-decoration: none;
    transition:
        background var(--tnhq-ease-fast),
        color var(--tnhq-ease-fast),
        border-color var(--tnhq-ease-fast);
}

.tnhq-tag:hover {
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
    border-color: transparent;
}


/* ==========================================================================
   5. NEWSLETTER CTA (.tnhq-newsletter)
   Full-width sign-up call to action with gradient background.
   ========================================================================== */

.tnhq-newsletter {
    position: relative;
    padding: var(--tnhq-space-16) var(--tnhq-space-6);
    background:
        linear-gradient(135deg,
            rgba(0, 212, 255, 0.06) 0%,
            rgba(123, 97, 255, 0.06) 50%,
            rgba(0, 212, 255, 0.03) 100%
        ),
        var(--tnhq-bg-surface);
    border-top: 1px solid var(--tnhq-border-light);
    border-bottom: 1px solid var(--tnhq-border-light);
    text-align: center;
    overflow: hidden;
}

/* Decorative glow orb behind the section */
.tnhq-newsletter::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 500px;
    height: 500px;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(0, 212, 255, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.tnhq-newsletter__inner {
    position: relative;
    max-width: 600px;
    margin: 0 auto;
}

.tnhq-newsletter__heading {
    font-family: var(--tnhq-font-heading);
    font-size: var(--tnhq-text-3xl);
    font-weight: 700;
    color: var(--tnhq-text-primary);
    margin-bottom: var(--tnhq-space-3);
}

.tnhq-newsletter__text {
    font-size: var(--tnhq-text-base);
    color: var(--tnhq-text-secondary);
    margin-bottom: var(--tnhq-space-8);
    line-height: var(--tnhq-leading-relaxed);
}

.tnhq-newsletter__form {
    display: flex;
    gap: var(--tnhq-space-3);
    max-width: 480px;
    margin: 0 auto var(--tnhq-space-4);
}

.tnhq-newsletter__input {
    flex: 1;
    padding: var(--tnhq-space-3) var(--tnhq-space-5);
    background: var(--tnhq-bg-primary);
    border: 1px solid var(--tnhq-border);
    border-radius: var(--tnhq-radius-md);
    color: var(--tnhq-text-primary);
    font-size: var(--tnhq-text-sm);
    transition: border-color var(--tnhq-ease-fast);
}

.tnhq-newsletter__input::placeholder {
    color: var(--tnhq-text-tertiary);
}

.tnhq-newsletter__input:focus {
    outline: none;
    border-color: var(--tnhq-accent);
    box-shadow: 0 0 0 3px var(--tnhq-accent-muted);
}

.tnhq-newsletter__proof {
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
    margin-top: var(--tnhq-space-2);
}

/* Newsletter Consent & Message Styling */
.tnhq-newsletter__consent {
    margin-top: var(--tnhq-space-4);
    text-align: left;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

.tnhq-newsletter__consent-label {
    display: flex;
    align-items: flex-start;
    gap: var(--tnhq-space-2);
    cursor: pointer;
}

.tnhq-newsletter__consent-checkbox {
    margin-top: 4px;
    accent-color: var(--tnhq-accent);
}

.tnhq-newsletter__consent-text {
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-secondary);
    line-height: 1.4;
}

.tnhq-newsletter__consent-link {
    color: var(--tnhq-accent);
    text-decoration: underline;
}

.tnhq-newsletter__consent-link:hover {
    color: var(--tnhq-accent-hover);
}

.tnhq-newsletter__message {
    margin-top: var(--tnhq-space-4);
    font-size: var(--tnhq-text-sm);
    font-weight: 500;
    padding: var(--tnhq-space-3);
    border-radius: var(--tnhq-radius-sm);
    display: none;
    text-align: center;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

.tnhq-newsletter__message.is-success {
    display: block;
    background: rgba(0, 255, 136, 0.1);
    color: var(--tnhq-success);
    border: 1px solid rgba(0, 255, 136, 0.2);
}

.tnhq-newsletter__message.is-error {
    display: block;
    background: rgba(255, 51, 102, 0.1);
    color: var(--tnhq-alert);
    border: 1px solid rgba(255, 51, 102, 0.2);
}

form.is-submitting {
    opacity: 0.8;
}

/* Stack form on mobile — handled in responsive.css, but base is inline */


/* ==========================================================================
   6. SPONSOR BLOCK (.tnhq-sponsor)
   Disclosure banner shown on sponsored/partner content.
   ========================================================================== */

.tnhq-sponsor {
    display: flex;
    align-items: center;
    gap: var(--tnhq-space-4);
    padding: var(--tnhq-space-4) var(--tnhq-space-5);
    background: var(--tnhq-bg-surface);
    border: 1px solid var(--tnhq-border-light);
    border-left: 3px solid var(--tnhq-sponsored);
    border-radius: var(--tnhq-radius-md);
    margin-bottom: var(--tnhq-space-6);
}

.tnhq-sponsor__badge {
    display: inline-flex;
    align-items: center;
    gap: var(--tnhq-space-1);
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    background: var(--tnhq-warning-muted);
    color: var(--tnhq-sponsored);
    font-size: var(--tnhq-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    border-radius: var(--tnhq-radius-full);
    white-space: nowrap;
}

.tnhq-sponsor__info {
    flex: 1;
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-secondary);
    line-height: var(--tnhq-leading-snug);
}

.tnhq-sponsor__name {
    font-weight: 600;
    color: var(--tnhq-text-primary);
}

.tnhq-sponsor__logo {
    width: 80px;
    height: auto;
    object-fit: contain;
    flex-shrink: 0;
}


/* ==========================================================================
   6b. SPONSOR BLOCK CTA (.tnhq-sponsor-block)
   In-grid promotional card for sponsorship opportunities.
   ========================================================================== */

.tnhq-sponsor-block {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--tnhq-radius-lg);
    background: linear-gradient(135deg,
        var(--tnhq-bg-surface) 0%,
        var(--tnhq-bg-surface-hover) 100%);
    border: 1px solid var(--tnhq-border-light);
    padding: var(--tnhq-space-6);
    min-height: 280px;
    transition: border-color var(--tnhq-ease-base);
}

.tnhq-sponsor-block:hover {
    border-color: var(--tnhq-sponsored);
}

.tnhq-sponsor-block__inner {
    text-align: center;
    max-width: 280px;
}

.tnhq-sponsor-block__label {
    display: inline-flex;
    align-items: center;
    gap: var(--tnhq-space-1);
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    background: rgba(255, 184, 0, 0.1);
    color: var(--tnhq-sponsored);
    font-size: var(--tnhq-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    border-radius: var(--tnhq-radius-full);
    margin-bottom: var(--tnhq-space-4);
}

.tnhq-sponsor-block__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--tnhq-space-3);
}

.tnhq-sponsor-block__title {
    font-family: var(--tnhq-font-heading);
    font-size: var(--tnhq-text-lg);
    font-weight: 600;
    color: var(--tnhq-text-primary);
    line-height: var(--tnhq-leading-snug);
    margin: 0;
}

.tnhq-sponsor-block__text {
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-secondary);
    line-height: var(--tnhq-leading-normal);
    margin: 0;
}

/* ==========================================================================
   7. AD ZONE (.tnhq-ad-zone)
   Container for Google AdSense or house ad placements.
   ========================================================================== */

.tnhq-ad-zone {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--tnhq-space-4);
    margin: var(--tnhq-space-8) 0;
    background: var(--tnhq-bg-surface);
    border: 1px dashed var(--tnhq-border-light);
    border-radius: var(--tnhq-radius-md);
    min-height: 100px;
}

.tnhq-ad-zone__label {
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    color: var(--tnhq-text-tertiary);
    margin-bottom: var(--tnhq-space-2);
    opacity: 0.6;
}

.tnhq-ad-zone__content {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    width: 100%;
}

/* In-article ad zones need extra vertical breathing room */
.tnhq-ad-zone--inline {
    margin: var(--tnhq-space-10) 0;
}

/* Sidebar ad zone — slightly different bg to blend */
.tnhq-ad-zone--sidebar {
    margin: 0 0 var(--tnhq-space-6) 0;
    border-style: solid;
    background: var(--tnhq-accent-subtle);
}


/* ==========================================================================
   8. AUTHOR BIO (.tnhq-author)
   Author card shown on article pages and author archives.
   ========================================================================== */

.tnhq-author {
    display: flex;
    align-items: flex-start;
    gap: var(--tnhq-space-5);
    padding: var(--tnhq-space-6);
    background: var(--tnhq-bg-surface);
    border: 1px solid var(--tnhq-border-light);
    border-radius: var(--tnhq-radius-lg);
}

.tnhq-author__avatar {
    width: 72px;
    height: 72px;
    border-radius: var(--tnhq-radius-full);
    object-fit: cover;
    flex-shrink: 0;
    border: 2px solid var(--tnhq-border);
}

.tnhq-author__info {
    flex: 1;
}

.tnhq-author__name {
    font-family: var(--tnhq-font-heading);
    font-size: var(--tnhq-text-lg);
    font-weight: 700;
    color: var(--tnhq-text-primary);
    margin-bottom: var(--tnhq-space-2);
}

.tnhq-author__name a {
    color: inherit;
    text-decoration: none;
}

.tnhq-author__name a:hover {
    color: var(--tnhq-accent);
}

.tnhq-author__bio {
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-secondary);
    line-height: var(--tnhq-leading-relaxed);
    margin-bottom: var(--tnhq-space-3);
}

.tnhq-author__social {
    display: flex;
    gap: var(--tnhq-space-3);
}

.tnhq-author__social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: var(--tnhq-radius-full);
    background: var(--tnhq-bg-surface-hover);
    color: var(--tnhq-text-secondary);
    transition:
        background var(--tnhq-ease-fast),
        color var(--tnhq-ease-fast);
}

.tnhq-author__social a:hover {
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
}

.tnhq-author__social svg {
    width: 16px;
    height: 16px;
}


/* ==========================================================================
   9. SEARCH OVERLAY (.tnhq-search-overlay)
   Full-screen search modal triggered by header search icon.
   ========================================================================== */

.tnhq-search-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--tnhq-z-modal);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: var(--tnhq-space-24) var(--tnhq-space-6) var(--tnhq-space-6);
    background: rgba(10, 10, 15, 0.92);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    opacity: 0;
    visibility: hidden;
    transition:
        opacity var(--tnhq-ease-base),
        visibility var(--tnhq-ease-base);
}

.tnhq-search-overlay.is-active {
    opacity: 1;
    visibility: visible;
}

.tnhq-search-overlay__close {
    position: absolute;
    top: var(--tnhq-space-6);
    right: var(--tnhq-space-6);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--tnhq-radius-full);
    background: var(--tnhq-bg-surface);
    border: 1px solid var(--tnhq-border);
    color: var(--tnhq-text-primary);
    cursor: pointer;
    transition:
        background var(--tnhq-ease-fast),
        border-color var(--tnhq-ease-fast);
}

.tnhq-search-overlay__close:hover {
    background: var(--tnhq-bg-surface-hover);
    border-color: var(--tnhq-accent);
}

/* Search backdrop */
.tnhq-search-overlay__backdrop {
    position: fixed;
    inset: 0;
    z-index: 1;
}

.tnhq-search-overlay__content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 680px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.tnhq-search-overlay__close svg {
    width: 20px;
    height: 20px;
}

.tnhq-search-overlay__form {
    width: 100%;
    max-width: 680px;
}

.tnhq-search-overlay__input {
    width: 100%;
    padding: var(--tnhq-space-5) var(--tnhq-space-6);
    background: var(--tnhq-bg-surface);
    border: 2px solid var(--tnhq-border);
    border-radius: var(--tnhq-radius-lg);
    font-family: var(--tnhq-font-heading);
    font-size: var(--tnhq-text-2xl);
    color: var(--tnhq-text-primary);
    transition: border-color var(--tnhq-ease-fast);
}

.tnhq-search-overlay__input::placeholder {
    color: var(--tnhq-text-tertiary);
}

.tnhq-search-overlay__input:focus {
    outline: none;
    border-color: var(--tnhq-accent);
    box-shadow: var(--tnhq-shadow-glow);
}

/* Input wrapper — positions icon and ESC badge */
.tnhq-search-overlay__input-wrap {
    position: relative;
    width: 100%;
    max-width: 680px;
    display: flex;
    align-items: center;
}

.tnhq-search-overlay__icon {
    position: absolute;
    left: var(--tnhq-space-5);
    color: var(--tnhq-text-tertiary);
    pointer-events: none;
    z-index: 1;
}

.tnhq-search-overlay__input-wrap .tnhq-search-overlay__input {
    padding-left: calc(var(--tnhq-space-5) + 24px + var(--tnhq-space-3));
    padding-right: calc(var(--tnhq-space-5) + 40px);
}

.tnhq-search-overlay__kbd {
    position: absolute;
    right: var(--tnhq-space-5);
    padding: var(--tnhq-space-1) var(--tnhq-space-3);
    background: var(--tnhq-bg-surface-hover);
    border: 1px solid var(--tnhq-border);
    border-radius: var(--tnhq-radius-sm);
    font-family: var(--tnhq-font-mono);
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
    line-height: 1;
    pointer-events: none;
}

.tnhq-search-overlay__results {
    width: 100%;
    max-width: 680px;
    margin-top: var(--tnhq-space-6);
    max-height: 50vh;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: var(--tnhq-space-3);
}

/* Search result list */
.tnhq-search-overlay__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--tnhq-space-2);
}

.tnhq-search-overlay__result {
    border-radius: var(--tnhq-radius-md);
    transition:
        background var(--tnhq-ease-fast),
        border-color var(--tnhq-ease-fast);
}

.tnhq-search-overlay__result.is-selected,
.tnhq-search-overlay__result:hover {
    background: var(--tnhq-bg-surface-hover);
}

.tnhq-search-overlay__result-link {
    display: block;
    padding: var(--tnhq-space-4) var(--tnhq-space-5);
    text-decoration: none;
    color: inherit;
    border-radius: var(--tnhq-radius-md);
    background: var(--tnhq-bg-surface);
    border: 1px solid var(--tnhq-border-light);
    transition:
        background var(--tnhq-ease-fast),
        border-color var(--tnhq-ease-fast);
}

.tnhq-search-overlay__result-link:hover,
.tnhq-search-overlay__result.is-selected .tnhq-search-overlay__result-link {
    background: var(--tnhq-bg-surface-hover);
    border-color: var(--tnhq-accent);
}

.tnhq-search-overlay__result-meta {
    display: flex;
    align-items: center;
    gap: var(--tnhq-space-3);
    margin-bottom: var(--tnhq-space-2);
}

.tnhq-search-overlay__result-category {
    font-size: var(--tnhq-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--tnhq-tracking-wider);
    color: var(--tnhq-accent);
}

.tnhq-search-overlay__result-date {
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
}

.tnhq-search-overlay__result-title {
    font-family: var(--tnhq-font-heading);
    font-size: var(--tnhq-text-base);
    font-weight: 600;
    color: var(--tnhq-text-primary);
    margin: 0 0 var(--tnhq-space-1);
    line-height: var(--tnhq-leading-snug);
}

.tnhq-search-overlay__result-excerpt {
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-secondary);
    line-height: var(--tnhq-leading-normal);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Search text highlight */
.tnhq-search-highlight {
    background: rgba(0, 212, 255, 0.2);
    color: var(--tnhq-accent);
    border-radius: 2px;
    padding: 0 2px;
}

/* Empty state */
.tnhq-search-overlay__empty {
    text-align: center;
    padding: var(--tnhq-space-10) var(--tnhq-space-5);
    color: var(--tnhq-text-secondary);
}

.tnhq-search-overlay__empty-icon {
    margin-bottom: var(--tnhq-space-4);
    color: var(--tnhq-text-tertiary);
    opacity: 0.5;
}

.tnhq-search-overlay__empty-hint {
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-tertiary);
    margin-top: var(--tnhq-space-2);
}

/* Loading state */
.tnhq-search-overlay.is-loading .tnhq-search-overlay__input-wrap::after {
    content: '';
    position: absolute;
    right: calc(var(--tnhq-space-5) + 50px);
    width: 18px;
    height: 18px;
    border: 2px solid var(--tnhq-border);
    border-top-color: var(--tnhq-accent);
    border-radius: 50%;
    animation: tnhq-spin 0.6s linear infinite;
}

@keyframes tnhq-spin {
    to { transform: rotate(360deg); }
}


/* ==========================================================================
   10. READING PROGRESS BAR (.tnhq-progress-bar)
   Thin accent gradient bar at the very top of single article pages.
   ========================================================================== */

.tnhq-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    z-index: calc(var(--tnhq-z-header) + 10);
    background: transparent;
    pointer-events: none;
}

.tnhq-progress-bar__fill {
    height: 100%;
    width: 0%;
    background: var(--tnhq-accent-gradient);
    transition: width 80ms linear;
    border-radius: 0 var(--tnhq-radius-full) var(--tnhq-radius-full) 0;
}


/* ==========================================================================
   11. TOAST / NOTIFICATION (.tnhq-toast)
   Ephemeral notifications in the bottom-right corner.
   ========================================================================== */

.tnhq-toast-container {
    position: fixed;
    bottom: var(--tnhq-space-6);
    right: var(--tnhq-space-6);
    z-index: var(--tnhq-z-toast);
    display: flex;
    flex-direction: column;
    gap: var(--tnhq-space-3);
    pointer-events: none;
}

.tnhq-toast {
    display: flex;
    align-items: center;
    gap: var(--tnhq-space-3);
    min-width: 280px;
    max-width: 420px;
    padding: var(--tnhq-space-4) var(--tnhq-space-5);
    background: var(--tnhq-bg-elevated);
    border: 1px solid var(--tnhq-border);
    border-radius: var(--tnhq-radius-md);
    box-shadow: var(--tnhq-shadow-lg);
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-primary);
    pointer-events: auto;
    animation: tnhq-slideInRight var(--tnhq-ease-base) forwards;
}

.tnhq-toast--success {
    border-left: 3px solid var(--tnhq-success);
}

.tnhq-toast--success .tnhq-toast__icon {
    color: var(--tnhq-success);
}

.tnhq-toast--error {
    border-left: 3px solid var(--tnhq-alert);
}

.tnhq-toast--error .tnhq-toast__icon {
    color: var(--tnhq-alert);
}

.tnhq-toast--info {
    border-left: 3px solid var(--tnhq-accent);
}

.tnhq-toast--info .tnhq-toast__icon {
    color: var(--tnhq-accent);
}

.tnhq-toast__icon {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
}

.tnhq-toast__message {
    flex: 1;
}

.tnhq-toast__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--tnhq-radius-full);
    color: var(--tnhq-text-tertiary);
    cursor: pointer;
    flex-shrink: 0;
    transition: background var(--tnhq-ease-fast);
}

.tnhq-toast__close:hover {
    background: var(--tnhq-bg-surface-hover);
    color: var(--tnhq-text-primary);
}

/* Fade-out for removing toasts */
.tnhq-toast.is-leaving {
    animation: tnhq-fadeOut var(--tnhq-ease-fast) forwards;
}

@keyframes tnhq-fadeOut {
    from {
        opacity: 1;
        transform: translateX(0);
    }
    to {
        opacity: 0;
        transform: translateX(20px);
    }
}


/* ==========================================================================
   12. SKELETON LOADER (.tnhq-skeleton)
   Animated shimmer placeholders for async/loading states.
   ========================================================================== */

.tnhq-skeleton {
    background: linear-gradient(
        90deg,
        var(--tnhq-bg-surface) 25%,
        var(--tnhq-bg-surface-hover) 50%,
        var(--tnhq-bg-surface) 75%
    );
    background-size: 200% 100%;
    animation: tnhq-shimmer 1.5s ease-in-out infinite;
    border-radius: var(--tnhq-radius-sm);
}

/* Text skeleton — single line */
.tnhq-skeleton--text {
    height: 14px;
    width: 100%;
    margin-bottom: var(--tnhq-space-3);
    border-radius: var(--tnhq-radius-sm);
}

/* Narrower text line — for varying widths */
.tnhq-skeleton--text-short {
    width: 60%;
}

/* Image skeleton — 16:9 block */
.tnhq-skeleton--image {
    aspect-ratio: 16 / 9;
    width: 100%;
    border-radius: var(--tnhq-radius-md);
}

/* Avatar skeleton — circle */
.tnhq-skeleton--avatar {
    width: 48px;
    height: 48px;
    border-radius: var(--tnhq-radius-full);
}

/* Full card skeleton — composite placeholder */
.tnhq-skeleton--card {
    display: flex;
    flex-direction: column;
    background: var(--tnhq-bg-surface);
    border: 1px solid var(--tnhq-border-light);
    border-radius: var(--tnhq-radius-lg);
    overflow: hidden;
}

.tnhq-skeleton--card .tnhq-skeleton__image {
    aspect-ratio: 16 / 9;
    background: linear-gradient(
        90deg,
        var(--tnhq-bg-surface-hover) 25%,
        var(--tnhq-bg-surface-active) 50%,
        var(--tnhq-bg-surface-hover) 75%
    );
    background-size: 200% 100%;
    animation: tnhq-shimmer 1.5s ease-in-out infinite;
}

.tnhq-skeleton--card .tnhq-skeleton__body {
    padding: var(--tnhq-space-5);
    display: flex;
    flex-direction: column;
    gap: var(--tnhq-space-3);
}

.tnhq-skeleton--card .tnhq-skeleton__line {
    height: 14px;
    background: linear-gradient(
        90deg,
        var(--tnhq-bg-surface-hover) 25%,
        var(--tnhq-bg-surface-active) 50%,
        var(--tnhq-bg-surface-hover) 75%
    );
    background-size: 200% 100%;
    animation: tnhq-shimmer 1.5s ease-in-out infinite;
    border-radius: var(--tnhq-radius-sm);
}

.tnhq-skeleton--card .tnhq-skeleton__line:nth-child(1) { width: 40%; }
.tnhq-skeleton--card .tnhq-skeleton__line:nth-child(2) { width: 100%; height: 18px; }
.tnhq-skeleton--card .tnhq-skeleton__line:nth-child(3) { width: 90%; }
.tnhq-skeleton--card .tnhq-skeleton__line:nth-child(4) { width: 70%; }


/* ==========================================================================
   13. SIDEBAR CATEGORIES (.tnhq-sidebar__categories)
   Category list widget in the right sidebar.
   ========================================================================== */

.tnhq-sidebar__categories-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--tnhq-space-1);
}

.tnhq-sidebar__categories-item {
    border-radius: var(--tnhq-radius-sm);
}

.tnhq-sidebar__categories-link {
    display: flex;
    align-items: center;
    gap: var(--tnhq-space-3);
    padding: var(--tnhq-space-2) var(--tnhq-space-3);
    font-size: var(--tnhq-text-sm);
    color: var(--tnhq-text-secondary);
    text-decoration: none;
    border-radius: var(--tnhq-radius-sm);
    transition:
        background var(--tnhq-ease-fast),
        color var(--tnhq-ease-fast);
}

.tnhq-sidebar__categories-link:hover {
    background: var(--tnhq-accent-subtle);
    color: var(--tnhq-text-primary);
}

.tnhq-sidebar__categories-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--tnhq-radius-full);
    flex-shrink: 0;
}

.tnhq-sidebar__categories-name {
    flex: 1;
    font-weight: 500;
}

.tnhq-sidebar__categories-count {
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
    background: var(--tnhq-bg-surface-hover);
    padding: var(--tnhq-space-1) var(--tnhq-space-2);
    border-radius: var(--tnhq-radius-full);
    min-width: 24px;
    text-align: center;
    line-height: 1.4;
}


/* ==========================================================================
   14. SIDEBAR RECENT POSTS (.tnhq-sidebar__recent)
   Recent posts list in the article sidebar.
   ========================================================================== */

.tnhq-sidebar__recent-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--tnhq-space-3);
}

.tnhq-sidebar__recent-item {
    padding-bottom: var(--tnhq-space-3);
    border-bottom: 1px solid var(--tnhq-border-light);
}

.tnhq-sidebar__recent-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.tnhq-sidebar__recent-link {
    display: block;
    font-size: var(--tnhq-text-sm);
    font-weight: 500;
    color: var(--tnhq-text-primary);
    text-decoration: none;
    line-height: var(--tnhq-leading-snug);
    margin-bottom: var(--tnhq-space-1);
    transition: color var(--tnhq-ease-fast);
}

.tnhq-sidebar__recent-link:hover {
    color: var(--tnhq-accent);
}

.tnhq-sidebar__recent-date {
    font-size: var(--tnhq-text-xs);
    color: var(--tnhq-text-tertiary);
}


/* ==========================================================================
   15. SIDEBAR SEARCH (.tnhq-sidebar__search)
   Search form widget in the sidebar.
   ========================================================================== */

.tnhq-sidebar__search .search-form {
    display: flex;
    gap: var(--tnhq-space-2);
}

.tnhq-sidebar__search .search-field {
    flex: 1;
    padding: var(--tnhq-space-2) var(--tnhq-space-4);
    background: var(--tnhq-bg-primary);
    border: 1px solid var(--tnhq-border);
    border-radius: var(--tnhq-radius-md);
    color: var(--tnhq-text-primary);
    font-size: var(--tnhq-text-sm);
    font-family: var(--tnhq-font-body);
    transition: border-color var(--tnhq-ease-fast);
}

.tnhq-sidebar__search .search-field::placeholder {
    color: var(--tnhq-text-tertiary);
}

.tnhq-sidebar__search .search-field:focus {
    outline: none;
    border-color: var(--tnhq-accent);
    box-shadow: 0 0 0 3px var(--tnhq-accent-muted);
}

.tnhq-sidebar__search .search-submit {
    padding: var(--tnhq-space-2) var(--tnhq-space-4);
    background: var(--tnhq-accent);
    color: var(--tnhq-text-inverse);
    border: none;
    border-radius: var(--tnhq-radius-md);
    font-size: var(--tnhq-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--tnhq-ease-fast);
}

.tnhq-sidebar__search .search-submit:hover {
    background: var(--tnhq-accent-hover);
}


/* ==========================================================================
   16. FOCUS INDICATORS (WCAG 2.4.7)
   ========================================================================== */

/* Card focus — glow border when any child is focused */
.tnhq-card:focus-within {
    box-shadow: var(--tnhq-shadow-glow);
    border-color: var(--tnhq-accent);
}

/* Card title link focus */
.tnhq-card__title a:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: 2px;
}

/* Tags */
.tnhq-tag:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: 2px;
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
    border-color: transparent;
}

/* Sidebar category links */
.tnhq-sidebar__categories-link:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: -2px;
    background: var(--tnhq-accent-subtle);
    color: var(--tnhq-text-primary);
}

/* Sidebar recent post links */
.tnhq-sidebar__recent-link:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: 2px;
    color: var(--tnhq-accent);
}

/* Search result links */
.tnhq-search-overlay__result-link:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: -2px;
    border-color: var(--tnhq-accent);
    background: var(--tnhq-bg-surface-hover);
}

/* Sidebar search submit */
.tnhq-sidebar__search .search-submit:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: 2px;
}

/* Newsletter subscribe button */
.tnhq-newsletter__input:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: -2px;
}

/* Author social links */
.tnhq-author__social a:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: 2px;
    background: var(--tnhq-accent-muted);
    color: var(--tnhq-accent);
}

/* Toast close button */
.tnhq-toast__close:focus-visible {
    outline: 2px solid var(--tnhq-accent);
    outline-offset: -2px;
    background: var(--tnhq-bg-surface-hover);
}
