/*
Theme Name: Twenty Twenty-Five Child
Theme URI: https://wordpress.org/themes/twentytwentyfive/
Author: Neural Inc.
Author URI: https://neural.co.jp/
Description: A premium, modern child theme for the WordPress Twenty Twenty-Five block theme, optimized for extensibility, custom styles, and Japanese character-based excerpts.
Template: twentytwentyfive
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: twentytwentyfive-child
*/

/* Custom Layout Styles for Contact Form 7 */
.cf7-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
}
.cf7-col {
    flex: 1;
}
.cf7-col-full {
    width: 100%;
}
.cf7-row input,
.cf7-row textarea,
.cf7-row select {
    width: 100%;
    padding: 12px;
    border: 1px solid #ccc;
    box-sizing: border-box;
}
.cf7-row select {
    padding-right: 40px;
    padding-left: 16px;
}
.cf7-row textarea {
    min-height: 200px;
    resize: vertical;
}
@media (max-width: 768px) {
    .cf7-row {
        flex-direction: column;
    }
}

/* Premium Select Dropdown Styling */
select {
    display: inline-block;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 12px 16px;
    font-family: inherit;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.25;
    color: currentColor;
    background-color: transparent;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 16px;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 8px !important;
    box-sizing: border-box;
    cursor: pointer;
    transition:
        border-color 0.2s ease-in-out,
        box-shadow 0.2s ease-in-out;
    max-width: 100%;
}

/* Hover and Focus States */
select:hover {
    border-color: rgba(0, 0, 0, 0.3);
}

select:focus {
    outline: none;
    border-color: var(--wp--preset--color--contrast, #000);
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.05);
}

/* Dark mode / dark background compatibility */
.is-dark-theme select,
[class*="dark"] select,
body.has-dark-background select {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    border-color: rgba(255, 255, 255, 0.2);
}

.is-dark-theme select:hover,
[class*="dark"] select:hover,
body.has-dark-background select:hover {
    border-color: rgba(255, 255, 255, 0.4);
}

.is-dark-theme select:focus,
[class*="dark"] select:focus,
body.has-dark-background select:focus {
    border-color: var(--wp--preset--color--base, #fff);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
}

/* Unified Global Border-Radius for Inputs, Textareas, Selects, and Buttons */
input[type="text"],
input[type="email"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="password"],
textarea,
select,
.wp-block-search__input,
.wp-block-search__button,
.custom-dropdown-trigger,
button,
input[type="submit"],
.wp-block-button__link {
    border-radius: 8px !important;
}

/* Premium Dynamic Hover Effects for Buttons with FSE Custom Colors */
.wp-block-button__link,
button:not(.custom-dropdown-trigger),
input[type="submit"],
.wp-block-search__button {
    transition: 
        filter 0.2s cubic-bezier(0.16, 1, 0.3, 1), 
        transform 0.2s cubic-bezier(0.16, 1, 0.3, 1), 
        box-shadow 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.wp-block-button__link:hover,
.wp-block-button__link:focus,
button:not(.custom-dropdown-trigger):hover,
button:not(.custom-dropdown-trigger):focus,
input[type="submit"]:hover,
input[type="submit"]:focus,
.wp-block-search__button:hover,
.wp-block-search__button:focus {
    filter: brightness(0.85) saturate(1.1) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12) !important;
    outline: none !important;
}

/* Active states (click response) */
.wp-block-button__link:active,
button:not(.custom-dropdown-trigger):active,
input[type="submit"]:active,
.wp-block-search__button:active {
    filter: brightness(0.75) saturate(1.15) !important;
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06) !important;
}

/* Contact Form 7 specific compatibility */
.wpcf7 select {
    margin-bottom: 0;
}

/* CF7 Submit Button — match global button styles */
.wpcf7 .wpcf7-submit-wrap,
.wpcf7 p:has(input[type="submit"]) {
    text-align: center;
}

.wpcf7 input[type="submit"] {
    background-color: #007cba;
    color: #ffffff;
    border: none;
    padding: 12px 2.25rem;
    font-size: var(--wp--preset--font-size--medium);
    font-family: inherit;
    font-weight: inherit;
    border-radius: 8px;
    cursor: pointer;
    display: inline-block;
    width: auto;
    height: auto;
    line-height: 1.5;
}

.wpcf7 input[type="submit"]:hover {
    background-color: color-mix(in srgb, #007cba 85%, transparent);
    color: #ffffff;
}

.wpcf7 input[type="submit"]:focus {
    outline: 2px solid #007cba;
    outline-offset: 2px;
}

/* CF7 inputs — consistent height with button */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 input[type="number"],
.wpcf7 input[type="search"] {
    padding: 12px;
    line-height: 1.5;
    height: auto;
    box-sizing: border-box;
}

/* Premium Globe Language Selector Styling (.custom-dropdown & .gt_selector) */

/* Hide original select elements but keep them for accessibility and screen readers */
.custom-dropdown-hidden-select {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Custom Dropdown Wrapper */
.custom-dropdown.gt-custom-dropdown {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    min-width: 140px;
    font-family: inherit;
    box-sizing: border-box;
}

/* Trigger Button */
.custom-dropdown-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 12px 16px 12px 14px;
    font-family: inherit;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.25;
    color: currentColor;
    background-color: transparent;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 8px !important;
    cursor: pointer;
    box-sizing: border-box;
    transition: 
        border-color 0.2s ease-in-out,
        box-shadow 0.2s ease-in-out,
        background-color 0.2s ease-in-out;
}

.custom-dropdown-trigger:hover {
    border-color: rgba(0, 0, 0, 0.3);
}

.custom-dropdown-trigger:focus {
    outline: none;
    border-color: var(--wp--preset--color--contrast, #000);
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.05);
}

/* Trigger elements */
.custom-dropdown-trigger-icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px;
    opacity: 0.8;
    color: currentColor;
}

.custom-dropdown-trigger-label {
    flex: 1;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: 12px;
    line-height: 1.25;
}

.custom-dropdown-trigger-arrow-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0.7;
    transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Open states */
.custom-dropdown.open {
    z-index: 999999 !important; /* Elevate the active dropdown wrapper context */
}

.custom-dropdown.open .custom-dropdown-trigger {
    border-color: var(--wp--preset--color--contrast, #000);
    background-color: transparent;
}

.custom-dropdown.open .custom-dropdown-trigger-arrow-wrap {
    transform: rotate(180deg);
    opacity: 1;
}

/* Dropdown Menu Panel (Glassmorphism & Shadows) */
.custom-dropdown-menu {
    position: absolute;
    top: calc(100% + 10px) !important;
    left: 0;
    min-width: 180px;
    width: 100%;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 8px !important;
    box-shadow: 
        0 10px 25px -5px rgba(0, 0, 0, 0.08), 
        0 8px 16px -6px rgba(0, 0, 0, 0.04), 
        0 0 1px 0 rgba(0, 0, 0, 0.04);
    z-index: 999999 !important; /* Consistent ultra-high z-index for dropdown panels */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px) scale(0.96);
    pointer-events: none;
    transition: 
        opacity 0.22s cubic-bezier(0.16, 1, 0.3, 1), 
        transform 0.22s cubic-bezier(0.16, 1, 0.3, 1), 
        visibility 0.22s;
}

.custom-dropdown.open .custom-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

/* Custom Options List */
.custom-dropdown-options {
    list-style: none;
    padding: 6px;
    margin: 0;
    max-height: 260px;
    overflow-y: auto;
    box-sizing: border-box;
}

/* Custom Scrollbar for Options List */
.custom-dropdown-options::-webkit-scrollbar {
    width: 5px;
}

.custom-dropdown-options::-webkit-scrollbar-track {
    background: transparent;
}

.custom-dropdown-options::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.1);
    border-radius: 10px;
}

.custom-dropdown-options::-webkit-scrollbar-thumb:hover {
    background-color: rgba(0, 0, 0, 0.2);
}

/* Invidual Dropdown Option Item */
.custom-dropdown-option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
    color: rgba(0, 0, 0, 0.8);
    border-radius: 6px !important;
    cursor: pointer;
    box-sizing: border-box;
    transition: 
        background-color 0.15s cubic-bezier(0.16, 1, 0.3, 1),
        color 0.15s cubic-bezier(0.16, 1, 0.3, 1);
}

.custom-dropdown-option:not(:first-child) {
    margin-top: 2px;
}

.custom-dropdown-option:hover {
    background-color: rgba(0, 0, 0, 0.04);
    color: #000000;
}

/* Selected state */
.custom-dropdown-option.selected {
    background-color: rgba(0, 0, 0, 0.03);
    color: #000000;
    font-weight: 600;
}

/* Option Checkmark SVG Wrapper */
.custom-dropdown-option-check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--wp--preset--color--contrast, #000);
    opacity: 0;
    transform: scale(0.6);
    transition: 
        opacity 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.custom-dropdown-option.selected .custom-dropdown-option-check {
    opacity: 1;
    transform: scale(1);
}

/* ==========================================
   Dark Mode / Dark Background Compatibility
   ========================================== */

.is-dark-theme .custom-dropdown-trigger,
[class*="dark"] .custom-dropdown-trigger,
body.has-dark-background .custom-dropdown-trigger {
    border-color: rgba(255, 255, 255, 0.2);
}

.is-dark-theme .custom-dropdown-trigger:hover,
[class*="dark"] .custom-dropdown-trigger:hover,
body.has-dark-background .custom-dropdown-trigger:hover {
    border-color: rgba(255, 255, 255, 0.4);
    background-color: rgba(255, 255, 255, 0.05);
}

.is-dark-theme .custom-dropdown-trigger:focus,
[class*="dark"] .custom-dropdown-trigger:focus,
body.has-dark-background .custom-dropdown-trigger:focus {
    border-color: var(--wp--preset--color--base, #fff);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
}

.is-dark-theme .custom-dropdown.open .custom-dropdown-trigger,
[class*="dark"] .custom-dropdown.open .custom-dropdown-trigger,
body.has-dark-background .custom-dropdown.open .custom-dropdown-trigger {
    border-color: var(--wp--preset--color--base, #fff);
    background-color: transparent;
}

/* Dark Menu Box Overlay */
.is-dark-theme .custom-dropdown-menu,
[class*="dark"] .custom-dropdown-menu,
body.has-dark-background .custom-dropdown-menu {
    background: rgba(25, 25, 25, 0.85);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 
        0 10px 25px -5px rgba(0, 0, 0, 0.3), 
        0 8px 16px -6px rgba(0, 0, 0, 0.2), 
        0 0 1px 0 rgba(255, 255, 255, 0.1);
}

/* Dark Option Item */
.is-dark-theme .custom-dropdown-option,
[class*="dark"] .custom-dropdown-option,
body.has-dark-background .custom-dropdown-option {
    color: rgba(255, 255, 255, 0.8);
}

.is-dark-theme .custom-dropdown-option:hover,
[class*="dark"] .custom-dropdown-option:hover,
body.has-dark-background .custom-dropdown-option:hover {
    background-color: rgba(255, 255, 255, 0.06);
    color: #ffffff;
}

.is-dark-theme .custom-dropdown-option.selected,
[class*="dark"] .custom-dropdown-option.selected,
body.has-dark-background .custom-dropdown-option.selected {
    background-color: rgba(255, 255, 255, 0.04);
    color: #ffffff;
}

.is-dark-theme .custom-dropdown-option-check,
[class*="dark"] .custom-dropdown-option-check,
body.has-dark-background .custom-dropdown-option-check {
    color: var(--wp--preset--color--base, #fff);
}


/* Dark Scrollbar */
.is-dark-theme .custom-dropdown-options::-webkit-scrollbar-thumb,
[class*="dark"] .custom-dropdown-options::-webkit-scrollbar-thumb,
body.has-dark-background .custom-dropdown-options::-webkit-scrollbar-thumb {
    background-color: rgba(255, 255, 255, 0.15);
}

.is-dark-theme .custom-dropdown-options::-webkit-scrollbar-thumb:hover,
[class*="dark"] .custom-dropdown-options::-webkit-scrollbar-thumb:hover,
body.has-dark-background .custom-dropdown-options::-webkit-scrollbar-thumb:hover {
    background-color: rgba(255, 255, 255, 0.25);
}

/* ==========================================================================
   Premium Navigation Submenu (Child Menu) Styling
   Unifies header submenus with the custom select box aesthetics (Glassmorphism)
   ========================================================================== */

/* Elevate parent list items when active/hovered to ensure dropdown floats on top */
.wp-block-navigation-item.has-child:hover,
.wp-block-navigation-item.has-child:focus-within,
.wp-block-navigation-submenu:hover,
.wp-block-navigation-submenu:focus-within {
    z-index: 999999 !important;
}

/* Submenu Container Override (Child dropdowns only, high z-index to stay on top) */
.wp-block-navigation__submenu-container,
ul.sub-menu {
    background-color: rgba(255, 255, 255, 0.85) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 8px !important;
    box-shadow: 
        0 10px 25px -5px rgba(0, 0, 0, 0.08), 
        0 8px 16px -6px rgba(0, 0, 0, 0.04), 
        0 0 1px 0 rgba(0, 0, 0, 0.04) !important;
    padding: 6px !important;
    box-sizing: border-box !important;
    z-index: 999999 !important; /* Ensure child dropdown menu stays on top of page content */
    margin-top: 10px !important;
}

/* Protective hover bridge to prevent menu from closing when moving cursor across the 10px gap */
.wp-block-navigation__submenu-container::before,
ul.sub-menu::before {
    content: "" !important;
    position: absolute !important;
    top: -12px !important;
    left: 0 !important;
    right: 0 !important;
    height: 12px !important;
    background: transparent !important;
    pointer-events: auto !important;
}

/* Reset list items inside the submenu container to avoid any default theme borders, solid backgrounds, or weird margins */
.wp-block-navigation__submenu-container .wp-block-navigation-item,
ul.sub-menu li {
    background-color: transparent !important;
    background: transparent !important;
    border: none !important;
    border-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    list-style: none !important;
    float: none !important;
    width: 100% !important;
    min-width: 100% !important;
}

/* Add a 2px top margin between items just like in our custom select dropdown options */
.wp-block-navigation__submenu-container .wp-block-navigation-item:not(:first-child),
ul.sub-menu li:not(:first-child) {
    margin-top: 2px !important;
}

/* Submenu Item Links (Strictly inside the child dropdown submenu container) */
.wp-block-navigation__submenu-container .wp-block-navigation-item .wp-block-navigation-item__content,
.wp-block-navigation__submenu-container .wp-block-navigation-item a,
ul.sub-menu li a {
    display: block !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    color: rgba(0, 0, 0, 0.8) !important;
    border-radius: 6px !important;
    border: none !important;
    border-width: 0 !important;
    box-shadow: none !important;
    transition: 
        background-color 0.15s cubic-bezier(0.16, 1, 0.3, 1),
        color 0.15s cubic-bezier(0.16, 1, 0.3, 1) !important;
    text-decoration: none !important;
}

/* Hover State (Strictly inside child dropdown submenu container) */
.wp-block-navigation__submenu-container .wp-block-navigation-item:hover > a,
.wp-block-navigation__submenu-container .wp-block-navigation-item:hover > .wp-block-navigation-item__content,
ul.sub-menu li:hover > a {
    background-color: rgba(0, 0, 0, 0.04) !important;
    color: #000000 !important;
}

/* Active/Current Page State (Strictly inside child dropdown submenu container) */
.wp-block-navigation__submenu-container .wp-block-navigation-item[aria-current="page"] > a,
ul.sub-menu li.current-menu-item > a {
    background-color: rgba(0, 0, 0, 0.03) !important;
    color: #000000 !important;
    font-weight: 600 !important;
}

/* ----------------------------------------------------
   Dark Mode / Dark Background for Navigation Submenus
   ---------------------------------------------------- */
.is-dark-theme .wp-block-navigation__submenu-container,
.is-dark-theme ul.sub-menu,
[class*="dark"] .wp-block-navigation__submenu-container,
[class*="dark"] ul.sub-menu,
body.has-dark-background .wp-block-navigation__submenu-container,
body.has-dark-background ul.sub-menu {
    background-color: rgba(25, 25, 25, 0.85) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
    box-shadow: 
        0 10px 25px -5px rgba(0, 0, 0, 0.3), 
        0 8px 16px -6px rgba(0, 0, 0, 0.2), 
        0 0 1px 0 rgba(255, 255, 255, 0.1) !important;
}

/* Dark Mode Text Colors (Strictly inside child dropdown submenu container) */
.is-dark-theme .wp-block-navigation__submenu-container .wp-block-navigation-item a,
.is-dark-theme ul.sub-menu li a,
[class*="dark"] .wp-block-navigation__submenu-container .wp-block-navigation-item a,
[class*="dark"] ul.sub-menu li a,
body.has-dark-background .wp-block-navigation__submenu-container .wp-block-navigation-item a,
body.has-dark-background ul.sub-menu li a {
    color: rgba(255, 255, 255, 0.8) !important;
}

/* Dark Mode Hover Colors (Strictly inside child dropdown submenu container) */
.is-dark-theme .wp-block-navigation__submenu-container .wp-block-navigation-item:hover > a,
.is-dark-theme ul.sub-menu li:hover > a,
[class*="dark"] .wp-block-navigation__submenu-container .wp-block-navigation-item:hover > a,
[class*="dark"] ul.sub-menu li:hover > a,
body.has-dark-background .wp-block-navigation__submenu-container .wp-block-navigation-item:hover > a,
body.has-dark-background ul.sub-menu li:hover > a {
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: #ffffff !important;
}

/* Dark Mode Active Page (Strictly inside child dropdown submenu container) */
.is-dark-theme .wp-block-navigation__submenu-container .wp-block-navigation-item[aria-current="page"] > a,
.is-dark-theme ul.sub-menu li.current-menu-item > a,
[class*="dark"] .wp-block-navigation__submenu-container .wp-block-navigation-item[aria-current="page"] > a,
[class*="dark"] ul.sub-menu li.current-menu-item > a,
body.has-dark-background .wp-block-navigation__submenu-container .wp-block-navigation-item[aria-current="page"] > a,
body.has-dark-background ul.sub-menu li.current-menu-item > a {
    background-color: rgba(255, 255, 255, 0.04) !important;
    color: #ffffff !important;
}

/* ==========================================================================
   Premium Modern Pagination & Navigation Styles
   Unifies query loops and index navigation with the child theme's premium aesthetics
   ========================================================================== */

/* Main pagination container */
.wp-block-query-pagination,
.pagination,
.nav-links {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    margin: 50px auto !important;
    padding: 0 !important;
    flex-wrap: wrap !important;
    width: 100% !important;
    border: none !important;
    background: none !important;
    box-shadow: none !important;
}

/* Pagination numbers wrapper */
.wp-block-query-pagination-numbers {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    border: none !important;
    background: none !important;
    box-shadow: none !important;
}

/* Individual page number links & spans */
.wp-block-query-pagination-numbers a,
.wp-block-query-pagination-numbers span,
.page-numbers,
.pagination .nav-links a,
.pagination .nav-links span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 42px !important;
    height: 42px !important;
    padding: 0 6px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    color: currentColor !important;
    text-decoration: none !important;
    background-color: rgba(0, 0, 0, 0.02) !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 8px !important;
    transition: 
        background-color 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        border-color 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        color 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
}

/* Ellipsis / Dots style */
.wp-block-query-pagination-numbers span.dots,
.page-numbers.dots,
.pagination .nav-links span.dots {
    background-color: transparent !important;
    border-color: transparent !important;
    cursor: default !important;
    opacity: 0.5 !important;
    pointer-events: none !important;
}

/* Active / Current Page page number */
.wp-block-query-pagination-numbers span.current,
.wp-block-query-pagination-numbers span[aria-current="page"],
.page-numbers.current,
.pagination .nav-links span.current {
    background-color: var(--wp--preset--color--contrast, #000) !important;
    border-color: var(--wp--preset--color--contrast, #000) !important;
    color: var(--wp--preset--color--base, #fff) !important;
    font-weight: 600 !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08) !important;
    cursor: default !important;
}

/* Hover style for page links (excluding current and dots) */
.wp-block-query-pagination-numbers a:hover,
.wp-block-query-pagination-numbers a:focus,
a.page-numbers:not(.current):not(.dots):hover,
a.page-numbers:not(.current):not(.dots):focus,
.pagination .nav-links a:not(.current):not(.dots):hover {
    background-color: rgba(0, 0, 0, 0.06) !important;
    border-color: rgba(0, 0, 0, 0.2) !important;
    color: #000000 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05) !important;
}

/* Active state (click response) for page links */
.wp-block-query-pagination-numbers a:active,
a.page-numbers:not(.current):not(.dots):active {
    background-color: rgba(0, 0, 0, 0.1) !important;
    transform: translateY(0) !important;
}

/* Previous / Next Button overrides */
.wp-block-query-pagination-previous,
.wp-block-query-pagination-next,
.page-numbers.prev,
.page-numbers.next,
.pagination .prev,
.pagination .next {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 42px !important;
    padding: 0 20px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: currentColor !important;
    text-decoration: none !important;
    background-color: rgba(0, 0, 0, 0.03) !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 8px !important;
    transition: 
        background-color 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        border-color 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.2s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
}

/* Hover style for Previous / Next buttons */
.wp-block-query-pagination-previous:hover,
.wp-block-query-pagination-previous:focus,
.wp-block-query-pagination-next:hover,
.wp-block-query-pagination-next:focus,
.page-numbers.prev:hover,
.page-numbers.next:hover,
.pagination .prev:hover,
.pagination .next:hover {
    background-color: rgba(0, 0, 0, 0.06) !important;
    border-color: rgba(0, 0, 0, 0.2) !important;
    color: #000000 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05) !important;
}

/* Active click state for Previous / Next buttons */
.wp-block-query-pagination-previous:active,
.wp-block-query-pagination-next:active,
.page-numbers.prev:active,
.page-numbers.next:active {
    background-color: rgba(0, 0, 0, 0.1) !important;
    transform: translateY(0) !important;
}

/* ==========================================================
   Dark Mode / Dark Background Compatibility for Pagination
   ========================================================== */
.is-dark-theme .wp-block-query-pagination-numbers a,
.is-dark-theme .page-numbers,
.is-dark-theme .pagination .nav-links a,
[class*="dark"] .wp-block-query-pagination-numbers a,
[class*="dark"] .page-numbers,
[class*="dark"] .pagination .nav-links a,
body.has-dark-background .wp-block-query-pagination-numbers a,
body.has-dark-background .page-numbers,
body.has-dark-background .pagination .nav-links a {
    background-color: rgba(255, 255, 255, 0.04) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Dark mode active page */
.is-dark-theme .wp-block-query-pagination-numbers span.current,
.is-dark-theme .wp-block-query-pagination-numbers span[aria-current="page"],
.is-dark-theme .page-numbers.current,
[class*="dark"] .wp-block-query-pagination-numbers span.current,
[class*="dark"] .wp-block-query-pagination-numbers span[aria-current="page"],
[class*="dark"] .page-numbers.current,
body.has-dark-background .wp-block-query-pagination-numbers span.current,
body.has-dark-background .wp-block-query-pagination-numbers span[aria-current="page"],
body.has-dark-background .page-numbers.current {
    background-color: var(--wp--preset--color--base, #fff) !important;
    border-color: var(--wp--preset--color--base, #fff) !important;
    color: var(--wp--preset--color--contrast, #000) !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3) !important;
}

/* Dark mode hover page numbers */
.is-dark-theme .wp-block-query-pagination-numbers a:hover,
.is-dark-theme a.page-numbers:not(.current):hover,
[class*="dark"] .wp-block-query-pagination-numbers a:hover,
[class*="dark"] a.page-numbers:not(.current):hover,
body.has-dark-background .wp-block-query-pagination-numbers a:hover,
body.has-dark-background a.page-numbers:not(.current):hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.25) !important;
    color: #ffffff !important;
}

/* Dark mode previous/next buttons */
.is-dark-theme .wp-block-query-pagination-previous,
.is-dark-theme .wp-block-query-pagination-next,
.is-dark-theme .page-numbers.prev,
.is-dark-theme .page-numbers.next,
[class*="dark"] .wp-block-query-pagination-previous,
[class*="dark"] .wp-block-query-pagination-next,
[class*="dark"] .page-numbers.prev,
[class*="dark"] .page-numbers.next,
body.has-dark-background .wp-block-query-pagination-previous,
body.has-dark-background .wp-block-query-pagination-next,
body.has-dark-background .page-numbers.prev,
body.has-dark-background .page-numbers.next {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Dark mode previous/next hover */
.is-dark-theme .wp-block-query-pagination-previous:hover,
.is-dark-theme .wp-block-query-pagination-next:hover,
[class*="dark"] .wp-block-query-pagination-previous:hover,
[class*="dark"] .wp-block-query-pagination-next:hover,
body.has-dark-background .wp-block-query-pagination-previous:hover,
body.has-dark-background .wp-block-query-pagination-next:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.25) !important;
    color: #ffffff !important;
}

