/*
Theme Name: Twenty Twenty-Five Child
Theme URI: https://www.enciclopediapoetica.org/
Author: Alejandro Egas Biava
Author URI: https://www.enciclopediapoetica.org/
Description: Child theme for Twenty Twenty-Five.
Template: twentytwentyfive
Version: 1.0.0
Text Domain: twentytwentyfive-child
*/

/* Add child theme custom CSS below this line */

:root {
	--nt-bg: #0b001f; /* almost black violet */
	--nt-bg-card: rgb(34, 0, 67);
	--nt-bg-card-accent: rgb(42, 0, 84);
	--nt-text: #f6f6fb; /* very light, almost white */
	--nt-muted: rgba(246,246,252,0.75);
	--nt-accent: rgb(247, 255, 233);
	--nt-accent-2: #99ff00;
	--nt-link:  rgb(146, 192, 67);
	--nt-link-2: #99ff00;
	--nt-border: rgba(255,255,255,0.06);
    --nt-bg-btn: rgb(0, 0, 0);;
}

html, body {
	background-color: var(--nt-bg);
	color: var(--nt-text);
	height: 100%;
}

/* Global text and content */
body, .site, .site-main, .site-content, .entry-content, .widget, .site-footer, .site-header {
	background: transparent;
	color: var(--nt-text);
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
	color: var(--nt-text);
}

/* Links and accents */
a, a:link, a:visited {
	color: var(--nt-accent);
}
a:hover, a:focus {
	color: var(--nt-accent-2);
	text-decoration: underline;
}

/* Header title */
.header-title-group {
    align-items: start;
}

/* Header logo */
.header-logo {
    height: 1.0em;
    padding: 5px 0;
    width: auto;
}

/* Links and accents */
.entry-content a, .entry-content a:link, .entry-content a:visited {
	color: var(--nt-link);
}
.entry-content a:hover, .entry-content a:focus {
	color: var(--nt-link-2);
	text-decoration: underline;
}

/* Muted text (meta, captions) */
.entry-meta, .byline, .posted-on, .site-description, .caption, .wp-caption-text {
	color: var(--nt-muted);
}

/* Borders, separators */
* + * {
	border-color: var(--nt-bg-card-accent);
}
hr, .wp-block-separator, .divider {
	border-color: var(--nt-bg-card-accent);
}

/* Form controls */
input, textarea, select, button {
	background-color: rgba(255,255,255,0.03);
	color: var(--nt-text);
	border: 1px solid rgba(255,255,255,0.08);
}
input::placeholder, textarea::placeholder {
	color: rgba(246,246,251,0.6);
}

/* Code blocks and inline code */
pre, code, kbd, samp {
	background-color: rgba(255,255,255,0.03);
	color: var(--nt-text);
	border: 1px solid rgba(255,255,255,0.06);
}

/* Focus outlines for accessibility */
a:focus, button:focus, input:focus, textarea:focus {
	outline: 2px solid rgba(155,123,255,0.16);
	outline-offset: 2px;
}

/* Reduce brightness for images with light backgrounds */
img {
	background-color: transparent;
}

/* Specific Gutenberg/blocks tweaks */
.wp-block, .wp-block-group, .wp-block-cover, .wp-block-column {
	color: var(--nt-text);
}

/* Make sure widgets / menus use the light text */
.widget a, .menu a {
	color: var(--nt-accent);
}

/* Subtle card backgrounds where used */
.card, .widget, .menu, .site-header, .site-footer {
	background-color: rgba(11,0,31,0.25);
}

/* Small UI tweaks */
.site-title, .site-logo {
	color: var(--nt-text);
}

/* End child theme night-mode overrides */

/* Featured image: strong rounding */
.wp-block-post-featured-image,
.post-featured-image,
.post-thumbnail {
	border-radius: 10px;
    margin-top: 2.5em;
    margin-bottom: 2.5em;
	overflow: hidden;
	display: block;
}
.wp-block-post-featured-image img,
.post-featured-image img,
.post-thumbnail img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 0; /* container handles rounding to avoid double-radius */
	box-shadow: none; /* featured image sits flush */
}

/* Content images: subtler rounding + elegant shadow */
.entry-content img,
.wp-block-image img,
.wp-block-gallery img,
.post-content img,
.wp-block-cover img {
	border-radius: 10px;
    margin-top: 2.5em;
    margin-bottom: 2.5em;
	max-width: 100%;
	height: auto;
	display: block;
	box-shadow: 0 12px 30px rgba(0,0,0,0.65), 0 2px 6px rgba(255,255,255,0.02) inset;
	transition: transform .18s ease, box-shadow .18s ease;
}

/* Ensure captions follow the same rounding visually */
.wp-caption,
.wp-caption img,
.wp-block-image figcaption {
	border-radius: 10px;
    margin-top: 2.5em;
    margin-bottom: 2.5em;
}

/* End image styling changes */

/* Mobile / responsive navigation: use night-mode background and light text */
/* Cover a variety of theme/plugin selectors to ensure the drawer/overlay is dark */
.menu-modal,
.menu-modal .menu,
.navigation-modal,
.wp-block-navigation__responsive-container,
.wp-block-navigation__container,
.wp-block-navigation,
.wp-block-navigation nav,
.wp-block-navigation__responsive-container .wp-block-navigation__container,
.wp-block-navigation.is-open,
.has-mobile-menu .site-header {
	background-color: var(--nt-bg) !important;
	color: var(--nt-text) !important;
}

/* Links and buttons inside the mobile menu */
.menu-modal a,
.navigation-modal a,
.wp-block-navigation__responsive-container a,
.wp-block-navigation a,
.wp-block-navigation__container a {
	color: var(--nt-accent) !important;
}
.menu-modal a:hover,
.wp-block-navigation__responsive-container a:hover {
	color: var(--nt-accent-2) !important;
}

/* Close / toggle buttons */
.menu-modal .menu-toggle,
.menu-modal .menu-modal-close,
.wp-block-navigation__responsive-container .menu-toggle,
.wp-block-navigation .menu-toggle {
	color: var(--nt-text) !important;
}

/* Ensure the backdrop behind the panel is dark-ish */
.modal-backdrop,
.menu-modal-backdrop,
.wp-block-navigation__responsive-container::backdrop {
	background-color: rgba(11,0,31,0.6) !important;
}

/* Keep focus outlines visible on dark background */
.menu-modal a:focus,
.wp-block-navigation a:focus,
.menu-toggle:focus {
	outline: 2px solid rgba(155,123,255,0.18);
	outline-offset: 2px;
}

/* End mobile menu overrides */

/* Reduce paragraph spacing slightly, only for the encp_poema custom post type */
body[class*="encp_poema"] .entry-content p,
body[class*="encp-poema"] .entry-content p,
body[class*="single-encp_poema"] .entry-content p,
body[class*="single-encp-poema"] .entry-content p,
body[class*="encp_poema"] .wp-block-paragraph,
body[class*="encp-poema"] .wp-block-paragraph {
    margin-bottom: 0.5em;
    word-spacing: 0.1em;
}

/* Slightly tighter spacing for consecutive paragraphs in the CPT */
body[class*="encp_poema"] .entry-content p + p,
body[class*="encp-poema"] .entry-content p + p {
    margin-top: 0.5em;
}

/* ── Letra grid: card component ── */
.encp-card {
    position: relative;
    overflow: hidden;
    background: var(--nt-bg-card);
    border-radius: 8px;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
	text-decoration: none !important;
}
.encp-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.35);
    background: var(--nt-bg-card-accent);
}
/* Featured image: square-off bottom corners to blend into card body */
.encp-card .wp-block-post-featured-image {
    border-radius: 8px 8px 0 0;
    overflow: hidden;
    margin: 0;
}
.encp-card .wp-block-post-featured-image img {
    border-radius: 0;
    display: block;
    width: 100%;
}
/* Stretched link: title anchor covers the whole card */
.encp-card__title a {
    text-decoration: none;
}
.encp-card__title a::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
}
/* Keep inner image link from blocking the stretched link */
.encp-card .wp-block-post-featured-image a {
    position: static;
}

.encp-letra-grid {
	align-items: stretch;
}

.encp-card {
	height: 100%;
}

/* Letra grid: center items when the archive has only 1 or 2 entries */
.encp-letra-grid:has(> :last-child:nth-child(-n+2)) {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--wp--style--block-gap, 1.5rem);
}
.encp-letra-grid:has(> :last-child:nth-child(-n+2)) > * {
    flex: 0 1 calc(25% - var(--wp--style--block-gap, 1.5rem));
    min-width: 16rem;
}

/* Increase post-title slightly on small screens for the letra archive only */
@media (max-width: 600px) and (min-width: 320px) {
	.encp-letra-grid .encp-card .wp-block-post-title {
		font-size: 1.5rem !important;
		line-height: 1.2;
	}
}

/* alphabetic index component */
.encp-alpha-navigation {
    padding: 1rem 0;
    border-bottom: 1px solid var(--nt-border);
    width: 100%;
    background: var(--nt-bg-card);
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
    /* Ensure the nav itself doesn't grow, but allows internal scrolling */
    overflow: hidden;
}

.encp-alpha-list {
    list-style: none;
    margin: 0 auto;
    padding: 0 4rem; /* Padding prevents letters from hugging screen edges */
    display: flex;
    /* Changed from wrap to nowrap for the scroll effect */
    flex-wrap: nowrap; 
    gap: 0.5rem;
    /* Centers on desktop, but allows scrolling from left on mobile */
    justify-content: flex-start; 
    max-width: var(--wp--style--global--wide-size);
    
    /* Horizontal scroll logic */
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; /* Smooth momentum scrolling for iOS */
    scrollbar-width: none; /* Hides scrollbar on Firefox */
}

/* Hide scrollbar for Chrome/Safari/Edge */
.encp-alpha-list::-webkit-scrollbar {
    display: none;
}

.encp-alpha-item {
    flex: 0 0 auto; /* Prevents letters from shrinking */
    white-space: nowrap;
}

.encp-alpha-item a {
    text-decoration: none;
    font-weight: 600;
    font-size: 1.2rem;
    padding: 0.4rem 0.6rem;
    color: var(--nt-link);
    transition: opacity 0.2s;
    display: block;
}

.encp-alpha-item a:hover {
    color: var(--nt-link-2);
}

/* Active letter styling: larger and using the theme accent color */
.encp-alpha-item--active a {
    color: var(--nt-link-2);
    font-size: 1.6rem;
    padding: 0.35rem 0.75rem;
    line-height: 1;
}

@media (max-width: 600px) {
    .encp-alpha-item--active a {
        font-size: 1.4rem;
        line-height: 1.2;
    }
}

/* Desktop Adjustment: Center the list when space allows */
@media (min-width: 1024px) {
    .encp-alpha-list {
        justify-content: center;
        overflow-x: visible;
    }
}

.encp-alpha-list {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory; /* Enables snapping */
    -webkit-overflow-scrolling: touch;
}

.encp-alpha-item {
    scroll-snap-align: center; /* Snaps the letter to the center */
}

.encp-alpha-navigation {
    position: relative;
}

.encp-alpha-navigation::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 75px;
    height: 100%;
    background: linear-gradient(to left, rgba(255,255,255,0), var(--nt-bg-card));
    pointer-events: none; /* Allows clicking through the fade */
}

.encp-alpha-navigation::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 75px;
    height: 100%;
    background: linear-gradient(to right, rgba(255,255,255,0), var(--nt-bg-card));
    pointer-events: none; /* Allows clicking through the fade */
}

/* Hide the fade on desktop where everything is visible */
@media (min-width: 1200px) {
    .encp-alpha-navigation::before {
        display: none;
    }

	.encp-alpha-navigation::after {
        display: none;
    }
}

.wp-block-button .wp-block-button__link {
    padding: .9rem 1.6rem;
    border-radius: 8px;
    font-weight: 600;
}

.wp-block-button.is-style-filled .wp-block-button__link,
.wp-block-button .is-style-filled.wp-block-button__link {
    color: #111;
}

.btn-filled .wp-block-button__link {
    background-color: var(--nt-bg-btn);
    border: var(--nt-border) 1px solid;
}


/* 404 pattern: remove top margin for this specific image block */
.wp-block-image.no-top-margin,
.wp-block-image.no-top-margin img,
.wp-block-image.no-top-margin figure {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
}
.wp-block-image.no-top-margin img {
    object-fit: cover;
    width: 100%;
    height: auto;
    display: block;
}

/* ─── Tag Cloud ─────────────────────────────────────────── */
.encp-tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    justify-content: center;
    padding: 0.5rem 0;
}

.encp-tag {
    display: inline-block;
    padding: 0.4em 0.9em;
    border: 1px solid var(--nt-border);
    border-radius: 999px;          /* pill shape */
    background: var(--nt-bg-card);
    color: var(--nt-accent);
    text-decoration: none;
    line-height: 1.4;
    white-space: nowrap;
    transition:
        background-color 0.15s ease,
        color            0.15s ease,
        border-color     0.15s ease,
        transform        0.15s ease,
        box-shadow       0.15s ease;
}

.encp-tag:hover,
.encp-tag:focus-visible {
    background: var(--nt-bg-card-accent);
    color: var(--nt-accent);
    border-color: var(--nt-accent);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(153, 255, 0, 0.15);
    text-decoration: none;
}

/* Staggered reveal: tags start hidden, JS adds .is-visible */
.encp-tag-cloud .encp-tag {
    opacity: 0;
    transform: translateY(8px);
}

.encp-tag-cloud .encp-tag.is-visible {
    opacity: 1;
    transform: translateY(0);
    transition:
        opacity   0.4s ease calc(var(--_i, 0) * 40ms),
        transform 0.4s ease calc(var(--_i, 0) * 40ms),
        background-color 0.15s ease,
        color            0.15s ease,
        border-color     0.15s ease,
        box-shadow       0.15s ease;
}

/* ─── Navigation overlay search ─────────────────────────── */

/* Hide the mobile search & separator in the desktop horizontal nav bar */
.wp-block-navigation .encp-nav-search {
    display: none;
}
.wp-block-navigation .encp-nav-separator {
    display: none;
}

/* ─── Desktop header search (outside navigation) ────────── */
.encp-header-search-desktop {
    display: none;
}
@media (min-width: 600px) {
    .encp-header-search-desktop {
        display: block;
    }
    .encp-header-search-desktop .wp-block-search__inside-wrapper {
        background: rgba(255, 255, 255, 0.06);
        border: 1px solid rgba(255, 255, 255, 0.12);
        border-radius: 8px;
        overflow: hidden;
    }
    .encp-header-search-desktop .wp-block-search__input {
        background: transparent;
        color: var(--nt-text);
        border: none;
        padding: 0.5rem 0.75rem;
        font-size: 0.875rem;
        min-width: 120px;
        max-width: 140px;
    }
    .encp-header-search-desktop .wp-block-search__input::placeholder {
        color: var(--nt-muted);
    }
    .encp-header-search-desktop .wp-block-search__button {
        background: transparent;
        border: none;
        color: var(--nt-muted);
        padding: 0.5rem 0.65rem;
        cursor: pointer;
        display: flex;
        align-items: center;
    }
    .encp-header-search-desktop .wp-block-search__button:hover {
        color: var(--nt-accent-2);
    }
    .encp-header-search-desktop .wp-block-search__button svg {
        fill: currentColor;
        width: 18px;
        height: 18px;
    }
}

/* Show mobile search only inside the mobile overlay */
.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search {
    display: block;
    width: 100%;
    margin-top: 1.5rem;
}

/* Show separator in mobile overlay */
.wp-block-navigation__responsive-container.is-menu-open .encp-nav-separator {
    display: block;
    width: 100%;
    margin: 1.5rem 0 0.5rem;
    border: none;
    border-top: 1px solid var(--nt-bg-card-accent) !important;
    opacity: 1;
}

.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search .wp-block-search__inside-wrapper {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    overflow: hidden;
}

.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search .wp-block-search__input {
    background: transparent;
    color: var(--nt-text);
    border: none;
    padding: 0.75rem 1rem;
    font-size: 1rem;
}

.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search .wp-block-search__input::placeholder {
    color: var(--nt-muted);
}

.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search .wp-block-search__button {
    background: transparent;
    border: none;
    color: var(--nt-muted);
    padding: 0.75rem 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
}

.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search .wp-block-search__button:hover {
    color: var(--nt-accent-2);
}

.wp-block-navigation__responsive-container.is-menu-open .encp-nav-search .wp-block-search__button svg {
    fill: currentColor;
    width: 20px;
    height: 20px;
}

/* ─── Search results page search input ──────────────────── */

@media (max-width: 600px) {
    .encp-search-title {
        font-size: var(--wp--preset--font-size--large) !important;
    }
}

.encp-search-page .wp-block-search__inside-wrapper {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    overflow: hidden;
}

.encp-search-page .wp-block-search__input {
    background: transparent;
    color: var(--nt-text);
    border: none;
    padding: 0.75rem 1rem;
    font-size: 1.25rem;
}

.encp-search-page .wp-block-search__input::placeholder {
    color: var(--nt-muted);
}

.encp-search-page .wp-block-search__button {
    background: transparent;
    border: none;
    color: var(--nt-muted);
    padding: 0.75rem 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
}

.encp-search-page .wp-block-search__button:hover {
    color: var(--nt-accent-2);
}

.encp-search-page .wp-block-search__button svg {
    fill: currentColor;
    width: 20px;
    height: 20px;
}
