/*
 Theme Name:   GeneratePress Child
 Theme URI:    https://generatepress.com
 Description:  GeneratePress Child Theme for NSWitchRoms - Design inspired by NSWPedia
 Author:       DevCreativos
 Author URI:   https://devcreativos.com/
 Template:     generatepress
 Version:      2.0.3
 Text Domain:  generatepress-child
*/

/* === GLOBAL STYLES === */
:root {
    /* Light Mode (Default) */
    --primary-color: #e30613;
    --secondary-color: #0066cc;
    --yellow-accent: #ffc107;
    --text-dark: #1a1a1a;
    --text-gray: #666;
    --text-light: #999;
    --border-color: #e0e0e0;
    --bg-body: #f8f9fa;
    --bg-card: #ffffff;
    --bg-header: #ffffff;
    --white: #ffffff;
    --shadow-subtle: 0 4px 20px rgba(0, 0, 0, 0.03);
    --shadow-deep: 0 10px 30px rgba(0, 0, 0, 0.1);
}

/* Dark Mode Overrides */
[data-theme="dark"] {
    --text-dark: #f0f0f0;
    --text-gray: #b0b0b0;
    --text-light: #888;
    --border-color: #333;
    --bg-body: #121212;
    --bg-card: #1e1e1e;
    --bg-header: #1a1a1a;
    --white: #1e1e1e;
    /* Re-map white to dark card bg */
    --shadow-subtle: 0 4px 20px rgba(0, 0, 0, 0.3);
    --shadow-deep: 0 10px 30px rgba(0, 0, 0, 0.5);
}

/* Force Dark Mode Card Backgrounds */
/* Force Dark Mode Card Backgrounds - High Specificity */
[data-theme="dark"] .inside-article,
[data-theme="dark"] .sidebar .widget,
[data-theme="dark"] .comments-area,
[data-theme="dark"] .paging-navigation,
[data-theme="dark"] .nsw-related-card,
[data-theme="dark"] #comments,
[data-theme="dark"] .site-content,
[data-theme="dark"] .container,
[data-theme="dark"] .entry-content {
    background-color: var(--bg-card) !important;
    color: var(--text-dark) !important;
}

[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6,
[data-theme="dark"] strong {
    color: #fff !important;
}

body {
    background-color: var(--bg-body);
    color: var(--text-dark);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    line-height: 1.6;
}

.inside-article,
.site-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* === HEADER & LOGO === */
.site-header {
    background: var(--bg-header);
    border-bottom: 1px solid var(--border-color);
    padding: 0;
}

.inside-header {
    padding: 0 !important;
    display: flex;
    align-items: center;
}

.site-logo {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-dark);
    line-height: 1;
    margin: 5px 0;
}

.site-logo .logo-highlight {
    color: var(--primary-color);
}

/* === NAVIGATION - Clean Horizontal === */
.main-navigation {
    background: var(--bg-header);
    border-bottom: 0;
    box-shadow: none;
    position: relative;
    z-index: 100;
}

/* Accessibility: visible keyboard focus ring without altering layout */
:where(
  a,
  button,
  input,
  select,
  textarea,
  [role="button"],
  [tabindex]:not([tabindex="-1"])
):focus-visible {
  outline: 2px solid var(--primary-color) !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 3px rgba(227, 6, 19, 0.22) !important;
}

.favorite-btn:focus-visible,
.nsw-react-btn:focus-visible,
.nsw-bridge-star:focus-visible,
.nsw-bridge-row:focus-visible {
  outline: 2px solid var(--primary-color) !important;
  outline-offset: 2px !important;
}

.inside-navigation {
    padding: 0 !important;
    max-width: 100% !important;
}

.main-navigation .main-nav {
    background: transparent;
}

.main-navigation .main-nav ul {
    display: flex;
    gap: 20px;
    align-items: center;
    margin: 0;
    padding: 0;
}

.main-navigation .main-nav ul li a {
    font-weight: 600;
    font-size: 14px;
    color: var(--text-dark);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 18px 0;
    line-height: 1;
    transition: all 0.2s ease;
    position: relative;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Hover and Active States */
.main-navigation .main-nav ul li a:hover {
    color: var(--primary-color);
}

.main-navigation .main-nav ul li {
    position: relative;
}

.main-navigation .main-nav ul li::after {
    content: '';
    position: absolute;
    bottom: -20px;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--primary-color);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.main-navigation .main-nav ul li:hover::after {
    transform: scaleX(1);
}

/* Hide parent red line when submenu is open */
.main-navigation .main-nav ul li:hover>ul~ ::after,
.main-navigation .main-nav ul li.menu-item-has-children:hover::after {
    display: none;
}

.main-navigation .main-nav ul li.current-menu-item,
.main-navigation .main-nav ul li.current-menu-ancestor {
    position: relative;
}

.main-navigation .main-nav ul li.current-menu-item>a,
.main-navigation .main-nav ul li.current-menu-ancestor>a {
    color: var(--primary-color);
    font-weight: 700;
    text-decoration: none !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
}

.main-navigation .menu-bar-item > a,
.main-navigation .search-item > a,
.main-navigation .menu-bar-item.search-item > a,
.main-navigation .menu-item-dark-toggle .theme-toggle-btn,
.main-navigation .main-nav > ul > li.nsw-login-item > a {
    padding-left: 12px !important;
    padding-right: 12px !important;
}

/* Remove "boxed" look from nav wrapper and icon area */
.site-header .inside-header,
.site-header .inside-navigation,
.site-header .main-navigation,
.site-header nav.main-navigation {
    background: var(--bg-header) !important;
    border: 0 !important;
    box-shadow: none !important;
}

.main-navigation .menu-bar-items {
    border-left: 0 !important;
    padding-left: 2px !important;
    margin-left: 4px !important;
}

.main-navigation .main-nav ul li.current-menu-item::after,
.main-navigation .main-nav ul li.current-menu-ancestor::after {
    transform: scaleX(1);
}

.main-navigation .main-nav ul li a::after {
    display: none;
}

.main-navigation .main-nav ul li a svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    /* Sincronizar color del icono con texto */
}

/* Right icons (search/menu-bar items) use separate underline logic */
.main-navigation .menu-bar-item {
    position: relative;
}

.main-navigation .menu-bar-item > a {
    position: relative;
    border-bottom: 0 !important;
    box-shadow: none !important;
    text-decoration: none !important;
}

.main-navigation .menu-bar-item > a::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 3px;
    background: var(--primary-color);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.main-navigation .menu-bar-item:hover > a::after,
.main-navigation .menu-bar-item:focus-within > a::after,
.main-navigation .menu-bar-item.active > a::after {
    transform: scaleX(1);
}

/* Align dark-mode toggle underline with main menu baseline */
.main-navigation .main-nav ul li.menu-item-dark-toggle::after {
    bottom: 0 !important;
}

/* === SUBMENUS (DROPDOWNS) - Modern Design === */
.main-navigation ul ul {
    background: #ffffff !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    border-radius: 0 !important;
    padding: 0 !important;
    min-width: 180px !important;
    max-width: 200px !important;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-5px);
    transition: all 0.2s ease;
    display: block !important;
    left: -9999px;
    top: calc(100% + 20px) !important;
    margin: 0 !important;
    border: none !important;
}

.main-navigation ul li:hover>ul {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    left: 0;
}

/* Hide red line on submenu items */
.main-navigation ul ul li {
    width: 100%;
}

.main-navigation ul ul li::after {
    display: none !important;
}

.main-navigation ul ul li a {
    font-weight: 500 !important;
    font-size: 14px !important;
    padding: 20px 20px !important;
    color: #333333 !important;
    border-bottom: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    transition: all 0.2s ease !important;
    display: block !important;
    white-space: nowrap !important;
}

.main-navigation ul ul li a:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
    padding-left: 28px;
}

.main-navigation ul ul li.current-menu-item>a {
    background: rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
}

.main-navigation ul ul li a::after {
    display: none;
}

/* Search Bar */
.navigation-search {
    margin-left: auto;
}

.navigation-search input {
    border-radius: 20px;
    padding: 8px 20px;
    border: 1px solid var(--border-color);
    background: var(--bg-light);
    font-size: 14px;
    width: 250px;
    transition: all 0.2s;
}

/* === BREADCRUMBS - Premium Modern Design === */
.nsw-breadcrumbs {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin: 0 0 30px 0;
    font-size: 13px;
    line-height: 1.4;
    clear: both;
    background: linear-gradient(135deg, rgba(227, 6, 19, 0.03) 0%, rgba(0, 102, 204, 0.03) 100%);
    border-left: 3px solid var(--primary-color);
    border-radius: 0 8px 8px 0;
    padding: 14px 20px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.nsw-breadcrumbs::after {
    content: '';
    display: table;
    clear: both;
}

.breadcrumb-link {
    display: inline;
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 600;
    transition: all 0.2s ease;
    position: relative;
    padding: 2px 4px;
    border-radius: 4px;
}

.breadcrumb-link:hover {
    color: #fff;
    background: var(--primary-color);
    padding: 2px 8px;
}

.breadcrumb-separator {
    display: inline;
    color: var(--text-light);
    font-size: 12px;
    user-select: none;
    margin: 0 8px;
    opacity: 0.5;
}

.breadcrumb-current {
    display: inline;
    color: var(--text-dark);
    font-weight: 600;
    background: rgba(0, 0, 0, 0.05);
    padding: 2px 10px;
    border-radius: 4px;
}

.navigation-search input:focus {
    outline: none;
    border-color: var(--secondary-color);
    background: var(--white);
}

/* === PAGE HEADER === */
.page-header {
    margin: 30px 0 20px;
}

.page-header h1 {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 20px;
}

/* === FILTER CONTROLS === */
.filter-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    flex-wrap: wrap;
    gap: 15px;
}

.game-filters {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.filter-btn {
    background-color: var(--yellow-accent);
    color: var(--text-dark);
    padding: 8px 16px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.filter-btn:hover {
    background-color: #ffb300;
    transform: translateY(-1px);
}

.filter-btn.active {
    background-color: var(--text-dark);
    color: var(--white);
}

/* View Toggle */
.view-toggle {
    display: flex;
    gap: 5px;
    background: var(--white);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 2px;
}

.view-toggle button {
    background: transparent;
    border: none;
    padding: 8px 12px;
    cursor: pointer;
    border-radius: 3px;
    transition: background 0.2s;
}

.view-toggle button:hover {
    background: var(--bg-light);
}

.view-toggle button.active {
    background: var(--text-dark);
    color: var(--white);
}

.view-toggle svg {
    width: 18px;
    height: 18px;
}

/* === ENTRY GRID === */
.entry-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 40px;
}

@media (min-width: 768px) {
    .entry-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* === ENTRY CARDS === */
.entry-card {
    background: var(--white);
    border-radius: 8px;
    border: 1px solid var(--border-color);
    overflow: hidden;
    position: relative;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    height: 100%;
}

.entry-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
}

/* Platform Badge */
.entry-card .platform-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--primary-color);
    color: var(--white);
    font-size: 9px;
    font-weight: 800;
    padding: 4px 8px;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    z-index: 2;
}

/* Exclusive Badge */
.entry-card .exclusive-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--yellow-accent);
    color: var(--text-dark);
    font-size: 9px;
    font-weight: 800;
    padding: 4px 8px;
    border-radius: 3px;
    text-transform: uppercase;
    z-index: 2;
}

/* Entry Cover Image */
.entry-cover {
    position: relative;
    width: 100%;
    padding-top: 150%;
    /* 2:3 aspect ratio */
    overflow: hidden;
    background: var(--bg-light);
}

.entry-cover img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
}

.entry-card:hover .entry-cover img {
    transform: scale(1.05);
}

/* Entry Info */
.entry-info {
    padding: 15px;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.entry-info h2,
.entry-info h3 {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.35;
    font-weight: 700;
    color: var(--text-dark);
    display: block;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    word-break: normal;
    overflow-wrap: anywhere;
    text-wrap: balance;
    text-align: left;
    letter-spacing: 0.1px;
}

.entry-card .game-meta {
    font-size: 12px;
    color: var(--text-gray);
    margin-bottom: 5px;
}

.entry-card .game-meta strong {
    font-weight: 600;
}

.entry-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: auto;
}

/* === PAGINATION === */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin: 40px 0;
}

.pagination a,
.pagination span {
    min-width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--white);
    border: 1px solid var(--border-color);
    color: var(--text-dark);
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    transition: all 0.2s;
}

.pagination a:hover {
    background: var(--bg-light);
    border-color: var(--text-dark);
}

.pagination .current {
    background: var(--text-dark);
    color: var(--white);
    border-color: var(--text-dark);
}

.pagination .further {
    border-radius: 20px;
    padding: 0 20px;
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
    .filter-controls {
        flex-direction: column;
        align-items: stretch;
    }

    .game-filters {
        justify-content: center;
    }

    .view-toggle {
        align-self: center;
    }

    .game-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }

    .navigation-search input {
        width: 100%;
    }

    /* === MOBILE MENU === */
    button.menu-toggle {
        font-weight: 700;
        font-size: 14px;
        color: var(--text-dark);
        padding: 0;
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        display: flex;
        align-items: center;
        gap: 8px;
    }

    button.menu-toggle:focus,
    button.menu-toggle:active {
        outline: none !important;
        background: transparent !important;
        color: var(--primary-color);
    }

    button.menu-toggle .gp-icon {
        font-size: 20px;
    }

}

/* === UTILITIES & EXTRAS (Moved from functions.php) === */

/* Premium Toast Notification */
#nsw-toast-container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.nsw-toast {
    background: #202020;
    color: #fff;
    padding: 12px 20px;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    font-weight: 500;
    border-left: 4px solid var(--primary-color);
    opacity: 0;
    transform: translateX(20px);
    transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    min-width: 250px;
}

.nsw-toast.show {
    opacity: 1;
    transform: translateX(0);
}

.nsw-toast-icon svg {
    display: block;
}

/* Star Pulse Animation */
@keyframes pulse-star {
    0% {
        transform: scale(1);
        text-shadow: 0 0 0 rgba(255, 179, 0, 0);
    }

    50% {
        transform: scale(1.15);
        text-shadow: 0 0 10px rgba(255, 179, 0, 0.6);
    }

    100% {
        transform: scale(1);
        text-shadow: 0 0 0 rgba(255, 179, 0, 0);
    }
}

.star-pulse {
    animation: pulse-star 2s infinite ease-in-out;
    display: inline-block;
}

/* Social Share Buttons */
.nsw-share-section {
    margin-top: 30px;
    margin-bottom: 30px;
}

.nsw-share-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
}

.nsw-share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 15px;
    border-radius: 8px;
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    font-size: 13px;
    transition: all 0.2s ease;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.nsw-share-btn:hover {
    transform: translateY(-3px);
    filter: brightness(1.1);
    color: #fff;
}

.nsw-share-btn svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

.share-whatsapp {
    background: #25D366;
}

.share-telegram {
    background: #0088cc;
}

.share-x {
    background: #000;
}

.share-facebook {
    background: #1877F2;
}

/* Related Posts Grid */
.nsw-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 20px;
    margin-top: 15px;
}

.nsw-related-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    transition: transform 0.3s ease;
    text-decoration: none;
    color: inherit;
    display: block;
}

.nsw-related-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}

.nsw-related-thumb {
    height: 100px;
    width: 100%;
    object-fit: cover;
    background: #eee;
}

.nsw-related-title {
    padding: 12px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.4;
    color: #333;
    text-align: center;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Premium Comments Section */
#comments {
    margin-top: 50px;
    background: #fff;
    padding: 30px;
    border-radius: 16px;
    border: 1px solid #eee;
}

.comment-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.comment-body {
    margin-bottom: 25px;
    border-bottom: 1px solid #f5f5f5;
    padding-bottom: 25px;
}

.comment-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    font-size: 12px;
    color: #999;
}

.fn {
    font-weight: 800;
    font-size: 14px;
    color: #444;
}

.comment-content p {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.6;
    color: #555;
}

.reply a {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--primary-color);
    text-decoration: none;
}

/* Comment Form */
#respond {
    margin-top: 30px;
}

.comment-form-comment label {
    display: none;
}

#comment {
    width: 100%;
    padding: 15px;
    border: 1px solid #eee;
    border-radius: 12px;
    font-family: inherit;
    font-size: 14px;
    background: #f9f9f9;
    transition: all 0.3s ease;
}

#comment:focus {
    border-color: var(--primary-color);
    background: #fff;
    outline: none;
}

.form-submit .submit {
    background: var(--primary-color);
    color: #fff;
    border: none;
    padding: 12px 25px;
    border-radius: 30px;
    font-weight: 700;
    cursor: pointer;
    margin-top: 15px;
    transition: transform 0.2s ease;
}

.form-submit .submit:hover {
    transform: scale(1.05);
}

/* === PREMIUM MENU REDESIGN V2 === */

/* Desktop Submenu Polish */
@media (min-width: 769px) {
    .main-navigation ul ul {
        width: 260px;
        /* Wider dropdown */
        padding: 15px 0;
        box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
        /* Deeper shadow */
        border: none;
        border-top: 4px solid var(--primary-color);
        border-radius: 0 0 12px 12px;
    }

    .main-navigation ul ul li a {
        font-size: 14px;
        /* Larger font */
        padding: 18px 25px;
        line-height: 1.45;
        color: #555;
        font-weight: 500;
        text-transform: none;
        /* Avoid uppercase if set */
    }

    .main-navigation ul ul li a:hover {
        background: #f8f9fa;
        color: var(--primary-color);
        padding-left: 32px;
        /* Smooth slide effect */
        box-shadow: inset 4px 0 0 var(--primary-color);
        /* Left accent line */
    }
}

/* === DARK MODE TOGGLE (SVG & ANIMATION) === */
.theme-toggle-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dark);
    transition: color 0.3s ease;
    height: 60px;
    /* Match menu height */
}

.theme-toggle-btn:hover {
    color: var(--primary-color);
    background: transparent !important;
}

/* Fix for Menu Item Container Hover */
.main-navigation .main-nav ul li.menu-item-dark-toggle:hover,
.main-navigation .main-nav ul li.menu-item-dark-toggle:focus-within {
    background: transparent !important;
    /* Remove grey background from li */
}

/* Force transparent states for the dark toggle wrapper/link/button */
.main-navigation .main-nav ul li.menu-item-dark-toggle > a,
.main-navigation .main-nav ul li.menu-item-dark-toggle > a:hover,
.main-navigation .main-nav ul li.menu-item-dark-toggle > a:focus,
.main-navigation .main-nav ul li.menu-item-dark-toggle > a:active,
.main-navigation .main-nav ul li.menu-item-dark-toggle .theme-toggle-btn,
.main-navigation .main-nav ul li.menu-item-dark-toggle .theme-toggle-btn:hover,
.main-navigation .main-nav ul li.menu-item-dark-toggle .theme-toggle-btn:focus,
.main-navigation .main-nav ul li.menu-item-dark-toggle .theme-toggle-btn:active {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Ensure Search Icon is Color Correct */
.main-navigation .search-item a {
    color: var(--text-dark);
}

[data-theme="dark"] .main-navigation .search-item a {
    color: #fff !important;
    /* Force white in dark mode */
}

/* Header icon animations (theme toggle + search) */
.main-navigation .menu-item-dark-toggle .theme-toggle-btn,
.main-navigation .search-item > a,
.main-navigation .menu-bar-item.search-item > a {
    transition: transform 0.25s ease, color 0.25s ease, opacity 0.25s ease;
    transform-origin: center;
}

.main-navigation .menu-item-dark-toggle .theme-toggle-btn:hover {
    transform: translateY(-1px) scale(1.08) rotate(10deg);
}

.main-navigation .menu-item-dark-toggle .theme-toggle-btn:active {
    transform: scale(0.95);
}

.main-navigation .search-item > a:hover,
.main-navigation .menu-bar-item.search-item > a:hover {
    transform: translateY(-1px) scale(1.08);
}

.main-navigation .search-item > a:active,
.main-navigation .menu-bar-item.search-item > a:active {
    transform: scale(0.95);
}

/* Back-to-top button: animation + light/dark aware colors */
.generate-back-to-top,
.generate-back-to-top:visited {
    background: #ffffff !important;
    color: #111827 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 10px !important;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18) !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease !important;
    animation: nswBackTopFloat 2.8s ease-in-out infinite;
}

.generate-back-to-top:hover,
.generate-back-to-top:focus {
    background: var(--primary-color) !important;
    color: #ffffff !important;
    border-color: var(--primary-color) !important;
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 12px 28px rgba(227, 6, 19, 0.35) !important;
}

.generate-back-to-top:active {
    transform: scale(0.96);
}

[data-theme="dark"] .generate-back-to-top,
[data-theme="dark"] .generate-back-to-top:visited {
    background: #1f2937 !important;
    color: #f9fafb !important;
    border-color: #374151 !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45) !important;
}

[data-theme="dark"] .generate-back-to-top:hover,
[data-theme="dark"] .generate-back-to-top:focus {
    background: var(--primary-color) !important;
    color: #ffffff !important;
    border-color: var(--primary-color) !important;
}

@keyframes nswBackTopFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-2px); }
}

.theme-toggle-icon {
    width: 20px;
    height: 20px;
    fill: currentColor;
    transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    display: block;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Rotate Animation on Toggle */
[data-theme="dark"] .theme-toggle-icon {
    transform: rotate(180deg);
}

/* Keep toggle icon visible when switching themes */
body:not([data-theme="dark"]) .main-navigation .menu-item-dark-toggle .theme-toggle-btn {
    color: #1a1a1a !important;
}

[data-theme="dark"] .main-navigation .menu-item-dark-toggle .theme-toggle-btn {
    color: #f0f0f0 !important;
}

/* Search modal icon color fix */
.navigation-search .search-submit,
.navigation-search button[type="submit"],
.navigation-search input[type="submit"] {
    color: #4b5563 !important;
}

.navigation-search .search-submit svg,
.navigation-search button[type="submit"] svg,
.navigation-search input[type="submit"] svg {
    fill: currentColor !important;
    stroke: currentColor !important;
}

.navigation-search .search-submit:before,
.navigation-search button[type="submit"]:before {
    color: #4b5563 !important;
}

/* Search modal (GeneratePress) submit icon */
.search-modal-form .search-submit,
.search-modal .search-form .search-submit,
.search-modal .search-submit {
    color: #374151 !important;
    opacity: 1 !important;
}

.search-modal-form .search-submit:before,
.search-modal .search-form .search-submit:before,
.search-modal .search-submit:before {
    color: #374151 !important;
    opacity: 1 !important;
}

.search-modal-form .search-submit .gp-icon,
.search-modal-form .search-submit .gp-icon svg,
.search-modal .search-submit .gp-icon,
.search-modal .search-submit .gp-icon svg {
    color: #374151 !important;
    fill: #374151 !important;
    stroke: #374151 !important;
    opacity: 1 !important;
}

/* Real selector used by GeneratePress search modal */
.gp-search-modal .search-modal-fields button,
.gp-search-modal .search-modal-fields button:hover,
.gp-search-modal .search-modal-fields button:focus,
.gp-search-modal .search-modal-fields button:active {
    color: #374151 !important;
}

.gp-search-modal .search-modal-fields button .gp-icon,
.gp-search-modal .search-modal-fields button .gp-icon svg,
.gp-search-modal .search-modal-fields button svg,
.gp-search-modal .search-modal-fields button svg path {
    color: #374151 !important;
    fill: #374151 !important;
    stroke: #374151 !important;
    opacity: 1 !important;
}

/* Dark mode card + badges contrast fixes */
[data-theme="dark"] .entry-grid .entry-card {
    background: #1f2329 !important;
    border: 1px solid #31363d !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35) !important;
    border-radius: 10px !important;
}

[data-theme="dark"] .entry-grid .entry-info h2,
[data-theme="dark"] .entry-grid .entry-info h3 {
    color: #f5f7fa !important;
}

[data-theme="dark"] .entry-grid .entry-card .entry-info {
    padding: 14px 14px 12px !important;
}

[data-theme="dark"] .entry-grid .platform-badge,
[data-theme="dark"] .entry-grid .entry-card .platform-badge {
    color: #ffffff !important;
}

[data-theme="dark"] .entry-grid .platform-badge svg,
[data-theme="dark"] .entry-grid .platform-badge svg path {
    fill: currentColor !important;
    stroke: currentColor !important;
}

/* Slider header badges follow theme color too */
.nsw-home-header-track .platform-badge {
    color: var(--text-dark) !important;
}

[data-theme="dark"] .nsw-home-header-track .platform-badge {
    color: #ffffff !important;
}

.nsw-home-header-track .platform-badge svg,
.nsw-home-header-track .platform-badge svg path {
    fill: currentColor !important;
    stroke: currentColor !important;
}

[data-theme="dark"] .entry-grid .tag-pill {
    background: #2a2f36 !important;
    border-color: #3a414a !important;
}

[data-theme="dark"] .entry-grid .tag-pill .part-format {
    color: #ffffff !important;
}

[data-theme="dark"] .entry-grid .tag-pill .part-weight {
    background: #2a2f36 !important;
    color: #e5e7eb !important;
}

[data-theme="dark"] .entry-grid .tag-pill .part-weight svg,
[data-theme="dark"] .entry-grid .tag-pill .part-weight path {
    fill: #e5e7eb !important;
    color: #e5e7eb !important;
}

/* Dark mode home: remove gray inner container block */
[data-theme="dark"].home .site-content,
[data-theme="dark"].home .site-main,
[data-theme="dark"].home .content-area,
[data-theme="dark"].home .inside-article,
[data-theme="dark"].home .hfeed,
[data-theme="dark"].home .separate-containers .inside-article,
[data-theme="dark"].home .separate-containers .site-main > * {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
}

/* Mobile Toggle Adjustment */
@media (max-width: 768px) {
    .theme-toggle-btn {
        height: auto;
        padding: 15px 20px;
        width: 100%;
        justify-content: flex-start;
    }

    .theme-toggle-text {
        margin-left: 10px;
        font-weight: 600;
        font-size: 14px;
    }
}

/* Mobile Specific Overrides */
@media (max-width: 768px) {

    /* Comments & Grid mobile tweaks */
    .nsw-related-grid {
        gap: 10px;
        grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    }

    #comments {
        margin-top: 30px;
        padding: 20px;
        border-radius: 12px;
    }

    .comment-body {
        padding-bottom: 15px;
        margin-bottom: 15px;
    }

    .nsw-share-grid {
        flex-wrap: wrap;
    }

    .nsw-share-btn {
        flex: 1 1 45%;
        font-size: 12px;
        padding: 8px 10px;
    }

}

/* === DARK MODE FIXES FOR INLINE STYLES === */
[data-theme="dark"] .entry-technical-sheet,
[data-theme="dark"] #nsw-timer-container,
[data-theme="dark"] #nsw-download-links {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-dark) !important;
    box-shadow: none !important;
}

[data-theme="dark"] .tech-row {
    border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .tech-row span,
[data-theme="dark"] .tech-row div {
    color: var(--text-dark) !important;
}

/* Specific overrides for hardcoded colors in spans */
[data-theme="dark"] .tech-row span[style*="999"] {
    color: var(--text-gray) !important;
}

[data-theme="dark"] .tech-row span[style*="444"],
[data-theme="dark"] .tech-row span[style*="333"] {
    color: var(--text-dark) !important;
}

[data-theme="dark"] .entry-synopsis {
    color: var(--text-dark) !important;
}

[data-theme="dark"] .entry-cover-wrapper {
    border-color: var(--border-color) !important;
}

/* Fix "Información Técnica" Title */
[data-theme="dark"] .entry-column-tech h3 {
    color: #fff !important;
}

/* Fix Trailer Button in Dark Mode */
[data-theme="dark"] .trailer-btn {
    background: #333 !important;
    color: #fff !important;
}

[data-theme="dark"] .trailer-btn:hover {
    background: var(--primary-color) !important;
}

/* === DARK MODE FINAL POLISH (TROUBLESHOOTING) === */

/* 1. Footer Background & Text */
[data-theme="dark"] .site-footer,
[data-theme="dark"] .site-info {
    background-color: var(--bg-header) !important;
    color: var(--text-gray) !important;
}

[data-theme="dark"] .site-footer a {
    color: var(--text-light) !important;
}

/* 2. Search Icon Visibility */
[data-theme="dark"] .main-navigation .search-item a,
[data-theme="dark"] .main-navigation .search-item a:visited,
[data-theme="dark"] .main-navigation .search-item a:hover {
    color: #fff !important;
}

[data-theme="dark"] .main-navigation .search-item svg {
    fill: #fff !important;
}

/* 3. General Text Readability */
[data-theme="dark"] body,
[data-theme="dark"] p,
[data-theme="dark"] li,
[data-theme="dark"] span {
    color: #ddd !important;
}

/* 4. Headings & Titles (Force White) */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6,
[data-theme="dark"] .entry-title,
[data-theme="dark"] .widget-title,
[data-theme="dark"] .nsw-related-title {
    color: #fff !important;
}

/* 5. Inputs & Form Fields (Dark Background) */
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="url"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="search"],
[data-theme="dark"] textarea {
    background-color: var(--bg-body) !important;
    color: #fff !important;
    border-color: var(--border-color) !important;
}

/* 6. Specific Card Backgrounds check */
[data-theme="dark"] .inside-article,
[data-theme="dark"] .comments-area,
[data-theme="dark"] .sidebar .widget {
    background-color: var(--bg-card) !important;
}

/* 6. Specific Card Backgrounds check */
[data-theme="dark"] .inside-article,
[data-theme="dark"] .comments-area,
[data-theme="dark"] .sidebar .widget {
    background-color: var(--bg-card) !important;
}

/* === NAVIGATION - DARK/LIGHT MODE === */

/* Horizontal Navigation - Dark Mode */
[data-theme="dark"] .main-navigation {
    border-bottom-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .main-navigation .main-nav ul li a {
    color: var(--text-dark);
}

[data-theme="dark"] .main-navigation .main-nav ul li a:hover,
[data-theme="dark"] .main-navigation .main-nav ul li.current-menu-item>a {
    color: var(--primary-color);
}

/* Submenu - Light Mode (white dropdown) */
[data-theme="light"] .main-navigation ul ul {
    background: #ffffff !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

[data-theme="light"] .main-navigation ul ul li a {
    color: #333333 !important;
    padding: 20px 20px !important;
}

[data-theme="light"] .main-navigation ul ul li a:hover {
    background: rgba(227, 6, 19, 0.08) !important;
    color: var(--primary-color) !important;
}

[data-theme="light"] .main-navigation ul ul li.current-menu-item>a {
    background: rgba(227, 6, 19, 0.12) !important;
    color: var(--primary-color) !important;
}

/* Submenu - Dark Mode */
[data-theme="dark"] .main-navigation ul ul {
    background: #1a1a1a !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5) !important;
}

[data-theme="dark"] .main-navigation ul ul li a {
    color: #ffffff !important;
    padding: 20px 20px !important;
}

[data-theme="dark"] .main-navigation ul ul li a:hover {
    background: rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
}

/* === DARK MODE STYLES === */

/* === NUCLEAR DARK MODE FIXES === */
[data-theme="dark"] .main-title a,
[data-theme="dark"] .site-title a,
[data-theme="dark"] .site-branding a {
    color: #fff !important;
}

[data-theme="dark"] .site-description {
    color: #ccc !important;
}

[data-theme="dark"] .gallery-container,
[data-theme="dark"] .gallery-content-wrapper,
[data-theme="dark"] #download-section,
[data-theme="dark"] #nsw-download-links,
[data-theme="dark"] .entry-download-box,
[data-theme="dark"] .dl-links-wrapper a,
[data-theme="dark"] body.single .dl-links-wrapper a {
    background: rgba(255, 255, 255, 0.03) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
}

[data-theme="dark"] body.single .dl-links-wrapper a:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    color: #ffffff !important;
}

[data-theme="dark"] .dl-links-wrapper a .srv-icon {
    background: rgba(255, 255, 255, 0.1) !important;
}

[data-theme="dark"] .main-navigation .search-item a,
[data-theme="dark"] .main-navigation .search-item a svg,
[data-theme="dark"] .menu-bar-item.search-item a {
    color: #fff !important;
    fill: #fff !important;
    opacity: 1 !important;
}

/* Dark header/nav aligned with footer color */
[data-theme="dark"] .site-header,
[data-theme="dark"] .inside-header,
[data-theme="dark"] .inside-navigation,
[data-theme="dark"] .main-navigation,
[data-theme="dark"] .navigation-branding,
[data-theme="dark"] nav.main-navigation,
[data-theme="dark"] .main-navigation .main-nav {
    background: #0f1218 !important;
    background-color: #0f1218 !important;
    box-shadow: none !important;
    border: none !important;
}

/* Premium Breadcrumbs - Dark Mode */
[data-theme="dark"] .nsw-breadcrumbs {
    background: linear-gradient(135deg, rgba(227, 6, 19, 0.1) 0%, rgba(0, 102, 204, 0.1) 100%);
    border-left-color: var(--primary-color);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .breadcrumb-link {
    color: var(--primary-color);
}

[data-theme="dark"] .breadcrumb-link:hover {
    color: #fff;
    background: var(--primary-color);
}

[data-theme="dark"] .breadcrumb-separator {
    color: #555;
}

[data-theme="dark"] .breadcrumb-current {
    color: #fff;
    background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .site-footer,
[data-theme="dark"] .site-info,
[data-theme="dark"] .footer-widgets {
    background: #0f1218 !important;
    background-color: #0f1218 !important;
    color: var(--text-gray) !important;
}

[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
    color: #fff !important;
}

/* Titulos Específicos (Override de .entry-main-body) */
[data-theme="dark"] .entry-column-left h2,
[data-theme="dark"] .entry-column-left h3,
[data-theme="dark"] .entry-column-tech h2,
[data-theme="dark"] .entry-column-tech h3,
[data-theme="dark"] .entry-main-body h2,
[data-theme="dark"] .entry-main-body h3 {
    color: #fff !important;
    border-left-color: #fff !important;
}

/* Iconos de Plataforma Badges */
.platform-badge {
    position: absolute;
    top: 5px;
    left: 5px;
    background: var(--primary-color);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    z-index: 10;
    padding: 5px !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    line-height: 1;
}

.platform-badge svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    display: block;
}

.platform-badge.has-text {
    padding: 4px 8px !important;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

/* Titulos Secciones Unificados */
.entry-column-left h2,
.entry-column-left h3,
.entry-column-tech h2,
.entry-column-tech h3,
.entry-main-body h2,
.entry-main-body h3 {
    font-size: 20px !important;
    border-left: 4px solid var(--primary-color) !important;
    padding-left: 15px !important;
    margin-bottom: 25px !important;
    margin-top: 40px !important;
    font-weight: 700 !important;
    color: #555 !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.entry-main-body h2:first-child,
.entry-main-body h3:first-child {
    margin-top: 0 !important;
}

/* Colores Categorias y Badges Premium */
.entry-tags {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    flex-wrap: wrap;
}

.tag-pill {
    display: inline-flex;
    align-items: stretch;
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    font-size: 11px;
    font-weight: 800;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border: 1px solid #eee;
    line-height: 1;
}

.tag-pill .part-format {
    background: var(--primary-color);
    color: #fff;
    padding: 0 10px;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    min-height: 24px;
}

.tag-pill .part-weight {
    color: #444;
    padding: 0 10px;
    background: #fff;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 24px;
}

.tag-pill svg {
    width: 14px;
    height: 14px;
    display: block;
}

/* Gallery Grid Premium */
.gallery-container {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 40px;
}

.gallery-content-wrapper {
    padding: 20px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
}

.gallery-content-wrapper .separator {
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    background: #fff;
    overflow: hidden;
    display: block;
    position: relative;
    aspect-ratio: 16 / 9;
}

.gallery-content-wrapper a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    margin: 0 !important;
    padding: 0 !important;
}

.gallery-content-wrapper img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    display: block;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: transform 0.3s ease;
}

.gallery-content-wrapper a:hover img {
    transform: scale(1.05);
}

/* === FINAL NAV OVERRIDES (Fix submenu spacing + arrow gap) === */
@media (min-width: 769px) {
    .main-navigation:not(.toggled) .main-nav ul ul {
        top: 100% !important;
        padding: 8px 0 !important;
        box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12) !important;
        border-radius: 0 !important;
    }

    .main-navigation:not(.toggled) .main-nav ul ul li > a,
    .main-navigation:not(.toggled) .main-nav ul ul li > a:visited {
        padding: 12px 20px !important;
        line-height: 1.5 !important;
        min-height: 44px !important;
        display: flex !important;
        align-items: center !important;
    }

    .main-navigation:not(.toggled) .main-nav > ul > li.menu-item-has-children > a {
        padding-right: 4px !important;
    }

    .main-navigation:not(.toggled) .main-nav > ul > li.menu-item-has-children > a .dropdown-menu-toggle {
        padding-left: 4px !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
    }

    .main-navigation:not(.toggled) .main-nav ul ul li > a:hover,
    .main-navigation:not(.toggled) .main-nav ul ul li:hover > a,
    .main-navigation:not(.toggled) .main-nav ul ul li.sfHover > a {
        color: #1f2937 !important;
        background: #f3f4f6 !important;
    }
}

/* FINAL OVERRIDE: match dark header and footer colors */
body[data-theme="dark"] .site-header,
body[data-theme="dark"] .inside-header,
body[data-theme="dark"] .inside-navigation,
body[data-theme="dark"] .main-navigation,
body[data-theme="dark"] .navigation-branding,
body[data-theme="dark"] nav.main-navigation,
body[data-theme="dark"] .main-navigation .main-nav,
body[data-theme="dark"] .site-footer,
body[data-theme="dark"] .site-info,
body[data-theme="dark"] .footer-widgets,
body[data-theme="dark"] .inside-footer-widgets,
body[data-theme="dark"] .footer-widgets-container,
body[data-theme="dark"] .inside-site-info,
body[data-theme="dark"] .copyright-bar,
body[data-theme="dark"] .footer-bar {
    background: #1b1f26 !important;
    background-color: #1b1f26 !important;
    background-image: none !important;
    border-color: #1b1f26 !important;
}

/* GLOBAL submenu style (same visual language as account dropdown) */
@media (min-width: 769px) {
    .main-navigation:not(.toggled) .main-nav > ul > li.menu-item-has-children {
        position: relative;
    }

    /* Hover bridge: keeps submenu open while crossing visual gap */
    .main-navigation:not(.toggled) .main-nav > ul > li.menu-item-has-children::before {
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        height: 26px;
        background: transparent;
        pointer-events: auto;
        z-index: 9998;
    }

    .main-navigation:not(.toggled) .main-nav ul ul {
        left: 0 !important;
        right: auto !important;
        top: calc(100% + 24px) !important;
        min-width: 190px !important;
        width: auto !important;
        padding: 6px 0 !important;
        margin: 0 !important;
        border: 1px solid #e5e7eb !important;
        border-radius: 10px !important;
        box-shadow: 0 12px 24px rgba(0, 0, 0, 0.14) !important;
        background: #ffffff !important;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-6px);
        transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease !important;
    }

    .main-navigation:not(.toggled) .main-nav ul li:hover > ul,
    .main-navigation:not(.toggled) .main-nav ul li.sfHover > ul {
        opacity: 1 !important;
        visibility: visible !important;
        transform: translateY(0) !important;
    }

    .main-navigation:not(.toggled) .main-nav ul ul li > a,
    .main-navigation:not(.toggled) .main-nav ul ul li > a:visited {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        min-height: 40px !important;
        padding: 10px 14px !important;
        color: #111827 !important;
        text-align: left !important;
        line-height: 1.2 !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        border: 0 !important;
        box-shadow: none !important;
        background: transparent !important;
    }

    .main-navigation:not(.toggled) .main-nav ul ul li > a:hover,
    .main-navigation:not(.toggled) .main-nav ul ul li:hover > a {
        background: #f3f4f6 !important;
        color: var(--primary-color) !important;
        padding-left: 14px !important;
    }

    [data-theme="dark"] .main-navigation:not(.toggled) .main-nav ul ul {
        background: #1a202c !important;
        border-color: #2d3748 !important;
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.45) !important;
    }

    [data-theme="dark"] .main-navigation:not(.toggled) .main-nav ul ul li > a,
    [data-theme="dark"] .main-navigation:not(.toggled) .main-nav ul ul li > a:visited {
        color: #e5e7eb !important;
    }

    [data-theme="dark"] .main-navigation:not(.toggled) .main-nav ul ul li > a:hover,
    [data-theme="dark"] .main-navigation:not(.toggled) .main-nav ul ul li:hover > a {
        background: #2a3342 !important;
        color: #ffffff !important;
    }
}

/* Native Discord menu item colors */
.main-navigation .main-nav ul li.menu-item-discord-native > a {
    color: #3643c7 !important;
    font-weight: 700 !important;
    text-shadow: none;
    transition: color 0.2s ease, text-shadow 0.2s ease;
}

/* Pull Discord closer to the theme toggle icon */
@media (min-width: 769px) {
    .main-navigation .main-nav ul li.menu-item-discord-native {
        margin-right: -14px;
    }
}

.main-navigation .main-nav ul li.menu-item-discord-native > a:hover {
    color: #2f3ab1 !important;
    text-shadow: none;
}

[data-theme="dark"] .main-navigation .main-nav ul li.menu-item-discord-native > a {
    color: #8ea1ff !important;
    text-shadow: 0 0 8px rgba(142, 161, 255, 0.35);
}

[data-theme="dark"] .main-navigation .main-nav ul li.menu-item-discord-native > a:hover {
    color: #a8b6ff !important;
    text-shadow: 0 0 12px rgba(168, 182, 255, 0.55), 0 0 20px rgba(168, 182, 255, 0.3);
}

/* Auth icon button */
.nsw-login-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: 60px;
    padding: 0 15px;
    border-radius: 0;
    background: transparent !important;
    color: var(--text-dark) !important;
    text-decoration: none !important;
    margin-left: 0;
    line-height: 60px !important;
    border: 0 !important;
    transition: transform 0.2s ease, color 0.2s ease;
}

.main-navigation .menu-bar-items .nsw-login-item > a {
    padding-left: 15px !important;
    padding-right: 15px !important;
    line-height: 60px !important;
}

.nsw-login-icon-btn svg {
    width: 19px;
    height: 19px;
    display: block;
    stroke-width: 2.1;
    position: relative;
    top: 20px;
}

.nsw-login-icon-btn:hover {
    background: transparent !important;
    color: var(--primary-color) !important;
    transform: translateY(-1px);
}

[data-theme="dark"] .nsw-login-icon-btn {
    background: transparent !important;
    color: #ffffff !important;
}

.nsw-login-icon-btn.is-logged {
    color: #22c55e !important;
}

[data-theme="dark"] .nsw-login-icon-btn.is-logged {
    color: #4ade80 !important;
}

/* Logged user submenu */
.nsw-login-item-logged {
    position: relative;
}

.nsw-login-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    left: auto;
    transform: translateY(-6px);
    min-width: 170px;
    margin: 0;
    padding: 6px 0;
    list-style: none;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.14);
    opacity: 0;
    visibility: hidden;
    /* initial offset included in combined transform above */
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
    z-index: 9999;
}

.nsw-login-item-logged:hover .nsw-login-dropdown,
.nsw-login-item-logged:focus-within .nsw-login-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Respect GP dropdown direction setting */
.main-navigation.sub-menu-left .nsw-login-dropdown {
    left: 0;
    right: auto;
}

.nsw-login-dropdown li {
    margin: 0;
}

.nsw-login-dropdown li a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    padding: 10px 14px;
    color: #111827 !important;
    text-decoration: none;
    font-size: 13px;
    line-height: 1.2;
    text-align: left;
}

.nsw-login-dropdown li a:hover {
    background: #f3f4f6;
    color: var(--primary-color) !important;
}

[data-theme="dark"] .nsw-login-dropdown {
    background: #1a202c;
    border-color: #2d3748;
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.45);
}

[data-theme="dark"] .nsw-login-dropdown li a {
    color: #e5e7eb !important;
}

[data-theme="dark"] .nsw-login-dropdown li a:hover {
    background: #2a3342;
    color: #ffffff !important;
}

.nsw-login-dropdown .nsw-dd-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    flex: 0 0 14px;
}

.nsw-login-dropdown .nsw-dd-icon svg {
    width: 14px;
    height: 14px;
    display: block;
}

/* Auth modal */
.nsw-auth-modal {
    position: fixed;
    inset: 0;
    display: none;
    z-index: 999999;
    backdrop-filter: blur(2px);
}

.nsw-auth-modal.is-open {
    display: block;
}

.nsw-auth-backdrop {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(1200px 500px at 20% -10%, rgba(227, 6, 19, 0.16), transparent 45%),
        radial-gradient(900px 420px at 100% 0%, rgba(37, 99, 235, 0.15), transparent 40%),
        rgba(3, 6, 12, 0.62);
}

.nsw-auth-dialog {
    position: relative;
    width: min(92vw, 440px);
    margin: 7vh auto 0;
    background:
        linear-gradient(165deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 251, 255, 0.96) 100%);
    color: #0f172a;
    border-radius: 22px;
    padding: 20px 20px 18px;
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(8px);
    animation: nswAuthIn 0.28s ease both;
    overflow: hidden;
}

/* Related cards: remove global heading decoration only in this block */
.nsw-related-grid .entry-info h2,
.nsw-related-grid .entry-info h3,
.entry-related-section .entry-grid .entry-info h2,
.entry-related-section .entry-grid .entry-info h3 {
    border-left: 0 !important;
    padding-left: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 10px !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
    font-weight: 700 !important;
}

[data-theme="dark"] .nsw-auth-dialog {
    background:
        linear-gradient(160deg, rgba(16, 23, 34, 0.96) 0%, rgba(13, 19, 30, 0.96) 100%);
    color: #e5e7eb;
    border: 1px solid rgba(80, 98, 129, 0.45);
    box-shadow: 0 26px 64px rgba(0, 0, 0, 0.55);
}

.nsw-auth-dialog::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 6px;
    background: linear-gradient(90deg, #ff2a2a 0%, #ff6b6b 42%, #5f7bff 100%);
}

.nsw-auth-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 6px 44px 14px 0;
}

.nsw-auth-badge {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #ff2a2a, #e30613);
    color: #fff;
    box-shadow: 0 10px 22px rgba(227, 6, 19, 0.32);
    flex: 0 0 36px;
}

.nsw-auth-title {
    margin: 0;
    font-size: 18px;
    line-height: 1.2;
    font-weight: 800;
    letter-spacing: 0.2px;
}

.nsw-auth-subtitle {
    margin: 3px 0 0;
    font-size: 12px;
    opacity: 0.78;
}

.nsw-auth-open {
    overflow: hidden;
}

.nsw-auth-close {
    position: absolute;
    top: 12px;
    right: 12px;
    border: 1px solid #d5dbe6;
    background: #ffffff;
    font-size: 22px;
    line-height: 1;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    cursor: pointer;
    color: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.nsw-auth-close:hover {
    transform: translateY(-1px);
    background: #f8fafc;
    border-color: #c8d0dd;
}

.nsw-auth-tabs {
    display: flex;
    gap: 8px;
    margin: 0 0 16px;
    padding: 5px;
    background: rgba(148, 163, 184, 0.18);
    border-radius: 13px;
    border: 1px solid rgba(203, 213, 225, 0.55);
}

.nsw-auth-tab {
    flex: 1;
    border: 1px solid transparent;
    background: transparent;
    color: #334155;
    border-radius: 9px;
    padding: 8px 10px;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: 0.2px;
    transition: all 0.2s ease;
}

.nsw-auth-tab.active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
}

[data-theme="dark"] .nsw-auth-tab {
    color: #cbd5e1;
}

[data-theme="dark"] .nsw-auth-tabs {
    background: rgba(71, 85, 105, 0.26);
}

[data-theme="dark"] .nsw-auth-close {
    background: #202633;
    border-color: #3b4456;
    color: #e5e7eb;
}

.nsw-auth-panel {
    display: none;
}

.nsw-auth-panel.active {
    display: block;
    background: rgba(255, 255, 255, 0.54);
    border: 1px solid rgba(203, 213, 225, 0.52);
    border-radius: 14px;
    padding: 14px;
}

[data-theme="dark"] .nsw-auth-panel.active {
    background: rgba(27, 37, 55, 0.55);
    border-color: rgba(71, 85, 105, 0.55);
}

.nsw-auth-panel label {
    display: block;
    margin: 10px 0 6px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.25px;
    text-transform: uppercase;
    opacity: 0.92;
}

.nsw-auth-panel input {
    width: 100%;
    border: 1px solid #c7d0df;
    border-radius: 12px;
    padding: 11px 12px;
    margin-bottom: 8px;
    background: #ffffff;
    color: #111827;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.nsw-auth-panel input:focus {
    outline: none;
    border-color: #f87171;
    box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.2);
}

[data-theme="dark"] .nsw-auth-panel input {
    background: #0f1218;
    color: #e5e7eb;
    border-color: #334155;
}

.nsw-auth-forgot {
    display: inline-block;
    margin: 2px 0 8px;
    font-size: 12px;
    font-weight: 600;
    color: #2563eb;
    text-decoration: none;
}

.nsw-auth-forgot:hover {
    color: #1d4ed8;
    text-decoration: underline;
}

.nsw-auth-legal {
    margin-top: 8px;
    padding: 10px 12px;
    border: 1px solid rgba(148, 163, 184, 0.35);
    border-radius: 12px;
    background: rgba(248, 250, 252, 0.8);
}

.nsw-auth-check {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 0 0 8px !important;
    font-size: 12px;
    font-weight: 500;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1.35;
    opacity: 1 !important;
}

.nsw-auth-check:last-child {
    margin-bottom: 0 !important;
}

.nsw-auth-check input[type="checkbox"] {
    width: 15px;
    height: 15px;
    margin: 1px 0 0 !important;
    accent-color: #e30613;
    flex: 0 0 15px;
}

.nsw-auth-check a {
    color: #e30613;
    font-weight: 700;
    text-decoration: none;
}

.nsw-auth-check a:hover {
    text-decoration: underline;
}

[data-theme="dark"] .nsw-auth-forgot {
    color: #7aa2ff;
}

[data-theme="dark"] .nsw-auth-forgot:hover {
    color: #9db8ff;
}

[data-theme="dark"] .nsw-auth-legal {
    border-color: rgba(71, 85, 105, 0.7);
    background: rgba(15, 23, 35, 0.7);
}

[data-theme="dark"] .nsw-auth-check {
    color: #d6dbe5;
}

[data-theme="dark"] .nsw-auth-check a {
    color: #ff6168;
}

.nsw-auth-panel button[type="submit"] {
    width: 100%;
    border: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%);
    color: #fff;
    font-weight: 700;
    padding: 12px 12px;
    cursor: pointer;
    margin-top: 8px;
    box-shadow: 0 10px 24px rgba(227, 6, 19, 0.28);
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.nsw-auth-panel button[type="submit"]:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(227, 6, 19, 0.36);
    filter: saturate(1.05);
}

.nsw-auth-message {
    margin-top: 12px;
    min-height: 20px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.2px;
    padding-left: 2px;
}

.nsw-auth-message.is-error {
    color: #ef4444;
}

.nsw-auth-message.is-success {
    color: #16a34a;
}

@media (max-width: 480px) {
    .nsw-auth-dialog {
        margin-top: 6vh;
        width: min(94vw, 420px);
        padding: 16px 14px 14px;
    }

    .nsw-auth-tabs {
        margin-top: 30px;
        margin-right: 0;
    }
}

@keyframes nswAuthIn {
    from {
        opacity: 0;
        transform: translateY(12px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Frontend pages: Mi cuenta / Favoritos */
.nsw-account-box {
    position: relative;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.95) 0%, rgba(246, 249, 255, 0.95) 100%);
    border: 1px solid rgba(203, 213, 225, 0.75);
    border-radius: 20px;
    padding: 22px;
    margin: 14px 0 24px;
    box-shadow: 0 24px 58px rgba(15, 23, 42, 0.14);
    overflow: hidden;
    backdrop-filter: blur(6px);
}

.nsw-account-box::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, #ff2a2a 0%, #ff6b6b 45%, #5f7bff 100%);
    z-index: 1;
}

.nsw-account-box h2 {
    position: relative;
    z-index: 2;
    margin: 0 0 12px;
    font-size: 24px;
    line-height: 1.2;
    letter-spacing: 0.2px;
}

.nsw-account-notice {
    border-radius: 8px;
    padding: 10px 12px;
    font-weight: 600;
    margin-bottom: 12px;
}

.nsw-account-notice.is-success {
    background: rgba(34, 197, 94, 0.12);
    color: #15803d;
    border: 1px solid rgba(34, 197, 94, 0.35);
}

.nsw-account-notice.is-error {
    background: rgba(239, 68, 68, 0.12);
    color: #b91c1c;
    border: 1px solid rgba(239, 68, 68, 0.35);
}

.nsw-account-form label {
    display: block;
    margin: 10px 0 6px;
    font-size: 13px;
    font-weight: 700;
    color: #334155;
}

.nsw-account-form input[type="text"],
.nsw-account-form input[type="email"],
.nsw-account-form input[type="password"],
.nsw-account-form input[type="file"] {
    width: 100%;
    border: 1px solid #c7d0df;
    background: #fff;
    border-radius: 12px;
    padding: 10px 12px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.nsw-account-form input[type="text"]:focus,
.nsw-account-form input[type="email"]:focus,
.nsw-account-form input[type="password"]:focus,
.nsw-account-form input[type="file"]:focus {
    outline: none;
    border-color: #f87171;
    box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.18);
}

.nsw-account-form button[type="submit"] {
    margin-top: 12px;
    border: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%);
    color: #fff;
    padding: 12px 14px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 12px 26px rgba(227, 6, 19, 0.28);
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.nsw-account-form button[type="submit"]:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 30px rgba(227, 6, 19, 0.34);
    filter: saturate(1.05);
}

.nsw-account-avatar-row {
    display: flex;
    gap: 14px;
    align-items: center;
    margin-bottom: 4px;
}

.nsw-account-avatar-preview img,
.nsw-account-avatar-preview .avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(203, 213, 225, 0.95);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.16);
}

.nsw-account-avatar-fields {
    flex: 1;
}

.nsw-account-check-inline {
    display: flex !important;
    align-items: center;
    gap: 8px;
    margin: 8px 0 0 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}

[data-theme="dark"] .nsw-account-form input[type="text"],
[data-theme="dark"] .nsw-account-form input[type="email"],
[data-theme="dark"] .nsw-account-form input[type="password"],
[data-theme="dark"] .nsw-account-form input[type="file"] {
    background: #0f1218;
    color: #e5e7eb;
    border-color: #334155;
}

.nsw-account-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 14px;
}

.nsw-account-actions .button {
    background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%);
    color: #fff;
    border: 0;
    border-radius: 10px;
    padding: 9px 13px;
    text-decoration: none;
    font-weight: 700;
    box-shadow: 0 10px 22px rgba(227, 6, 19, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.nsw-account-actions .button:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(227, 6, 19, 0.3);
}

.nsw-favorites-list {
    margin: 8px 0 0;
    padding-left: 18px;
}

.nsw-favorites-list li {
    margin: 0 0 8px;
}

.nsw-favorites-page .nsw-favorites-list {
    list-style: none;
    margin: 12px 0 0;
    padding: 0;
    display: grid;
    gap: 12px;
}

.nsw-favorites-page .nsw-favorite-row {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid #cbd5e1;
    border-radius: 14px;
    background: #f8fafc;
}

.nsw-favorites-page .nsw-favorite-console {
    color: #0ea5a4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.nsw-favorites-page .nsw-favorite-title {
    font-size: 18px;
    line-height: 1.15;
    font-weight: 500;
    color: #262626;
    text-decoration: none;
    text-align: left;
}

.nsw-favorites-page .nsw-favorite-title:hover {
    color: var(--primary-color);
}

.nsw-favorites-page .nsw-favorite-meta {
    display: inline-flex;
    gap: 8px;
    align-items: center;
}

.nsw-favorites-page .nsw-favorite-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

.nsw-favorites-page .nsw-favorite-pill.is-size {
    background: #dbeafe;
    color: #1d4ed8;
}

.nsw-favorites-page .nsw-favorite-pill.is-format {
    background: #dcfce7;
    color: #15803d;
}

.nsw-favorites-page .nsw-favorite-remove {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    line-height: 1;
    border: 1px solid #fecaca;
    border-radius: 10px;
    background: #fff1f2;
    color: #b91c1c;
    padding: 7px 10px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
}

.nsw-favorites-page .nsw-favorite-remove:hover {
    background: #ffe4e6;
    border-color: #fda4af;
}

.nsw-favorites-page .nsw-favorites-empty {
    margin: 12px 0 0;
    color: #64748b;
}

@media (max-width: 900px) {
    .nsw-favorites-page .nsw-favorite-row {
        grid-template-columns: 28px minmax(0, 1fr) auto;
        grid-template-areas:
            "icon title remove"
            ". meta meta";
    }

    .nsw-favorites-page .nsw-favorite-console {
        grid-area: icon;
    }

    .nsw-favorites-page .nsw-favorite-title {
        grid-area: title;
        font-size: 16px;
    }

    .nsw-favorites-page .nsw-favorite-meta {
        grid-area: meta;
        justify-self: start;
    }

    .nsw-favorites-page .nsw-favorite-remove {
        grid-area: remove;
    }
}

.favorite-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

.favorite-btn .favorite-icon {
    display: block;
    transition: transform 0.2s ease, filter 0.2s ease;
}

.favorite-btn:hover .favorite-icon {
    transform: scale(1.08);
    filter: drop-shadow(0 0 6px rgba(255, 179, 0, 0.45));
}

/* Comments - Modern UI */
#comments,
#nsw-comments-area .comments-area {
    position: relative;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.95) 0%, rgba(246, 249, 255, 0.95) 100%);
    border: 1px solid rgba(203, 213, 225, 0.75);
    border-radius: 20px;
    padding: 24px;
    box-shadow: 0 24px 58px rgba(15, 23, 42, 0.1);
    overflow: hidden;
}

#comments::before,
#nsw-comments-area .comments-area::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, #ff2a2a 0%, #ff6b6b 45%, #5f7bff 100%);
}

#comments .comments-title,
#comments .comment-reply-title {
    font-size: 30px;
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 16px;
}

#comments .comment-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 6px;
}

#comments .comment-list .comment {
    margin: 0;
    padding: 0;
}

#comments .comment-body {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(203, 213, 225, 0.7);
    border-radius: 12px;
    padding: 8px 9px;
}

#comments .comment-meta {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    margin-bottom: 4px;
}

#comments .comment-author {
    display: flex;
    align-items: center;
    gap: 6px;
}

#comments .comment-author .avatar {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 2px solid rgba(203, 213, 225, 0.9);
}

#comments .comment-author .fn {
    font-weight: 800;
    color: #111827;
    font-size: 14px;
}

#comments .comment-metadata {
    font-size: 11px;
    font-weight: 600;
    opacity: 0.75;
}

#comments .comment-content {
    color: #1f2937;
    line-height: 1.35;
    margin: 2px 0 1px;
    font-size: 14px;
}

#comments .reply a,
#comments .comment-reply-link {
    display: inline-flex;
    align-items: center;
    margin-top: 2px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    text-decoration: none;
    color: #e30613;
}

#comments .reply a:hover,
#comments .comment-reply-link:hover {
    color: #b80410;
}

#comments .comment-respond {
    margin-top: 16px;
    padding: 16px;
    border: 1px solid rgba(203, 213, 225, 0.7);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.8);
}

#comments .comment-form label {
    display: block;
    margin: 8px 0 5px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    color: #334155;
}

#comments .comment-form input[type="text"],
#comments .comment-form input[type="email"],
#comments .comment-form input[type="url"],
#comments .comment-form textarea {
    width: 100%;
    border: 1px solid #c7d0df;
    border-radius: 12px;
    background: #fff;
    color: #111827;
    padding: 10px 12px;
}

#comments .comment-form textarea {
    min-height: 130px;
    resize: vertical;
}

#comments .comment-form input:focus,
#comments .comment-form textarea:focus {
    outline: none;
    border-color: #f87171;
    box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.2);
}

#comments .form-submit input[type="submit"] {
    border: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%);
    color: #fff;
    padding: 11px 16px;
    font-weight: 800;
    box-shadow: 0 10px 22px rgba(227, 6, 19, 0.25);
}

#comments .form-submit input[type="submit"]:hover {
    filter: saturate(1.06);
    transform: translateY(-1px);
}

.nsw-comments-login-note {
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.9) 0%, rgba(246, 249, 255, 0.9) 100%) !important;
    border-color: rgba(203, 213, 225, 0.75) !important;
    border-radius: 12px !important;
}

[data-theme="dark"] #comments,
[data-theme="dark"] #nsw-comments-area .comments-area,
[data-theme="dark"] .comments-area {
    background: linear-gradient(160deg, rgba(16, 23, 34, 0.95) 0%, rgba(13, 19, 30, 0.95) 100%);
    border-color: rgba(80, 98, 129, 0.45);
    box-shadow: 0 28px 64px rgba(0, 0, 0, 0.55);
}

[data-theme="dark"] #comments .comment-body,
[data-theme="dark"] #comments .comment-respond {
    background: rgba(17, 24, 39, 0.72);
    border-color: rgba(71, 85, 105, 0.65);
}

[data-theme="dark"] #comments .comment-author .fn,
[data-theme="dark"] #comments .comment-content,
[data-theme="dark"] #comments .comments-title,
[data-theme="dark"] #comments .comment-reply-title {
    color: #e5e7eb;
}

[data-theme="dark"] #comments .comment-metadata {
    color: #9ca3af;
}

[data-theme="dark"] #comments .comment-form label {
    color: #cbd5e1;
}

[data-theme="dark"] #comments .comment-form input[type="text"],
[data-theme="dark"] #comments .comment-form input[type="email"],
[data-theme="dark"] #comments .comment-form input[type="url"],
[data-theme="dark"] #comments .comment-form textarea {
    background: #0f1218;
    color: #e5e7eb;
    border-color: #334155;
}

[data-theme="dark"] .nsw-comments-login-note {
    background: rgba(17, 24, 39, 0.7) !important;
    border-color: rgba(71, 85, 105, 0.65) !important;
}

/* Comments style v2 (forum-like) */
#comments .comments-title {
    font-size: 24px;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(148, 163, 184, 0.4);
    padding-bottom: 12px;
    margin-top: 10px;
    margin-bottom: 14px;
    position: relative;
}

#comments .comments-title::after {
    content: none;
}

#comments .comment-body {
    border-radius: 10px;
}

#comments .comment-author .avatar {
    border-radius: 6px;
    width: 34px;
    height: 34px;
}

#comments .comment-author .fn {
    color: #12212f;
    font-size: 18px;
    line-height: 1.1;
}

#comments .comment-metadata {
    margin-left: 4px;
    white-space: nowrap;
}

#comments .comment-content p {
    margin-bottom: 10px;
}

#comments .comment-list .children {
    list-style: none;
    margin: 4px 0 0 10px;
    padding: 0 0 0 8px;
    border-left: 2px solid var(--primary-color);
}

#comments .comment-list .children .comment-body {
    background: rgba(227, 6, 19, 0.03);
}

#comments .reply a,
#comments .comment-reply-link {
    color: #6b7280;
    font-weight: 700;
    text-transform: none;
}

#comments .reply a:hover,
#comments .comment-reply-link:hover {
    color: var(--primary-color);
}

#comments .comment-form-comment textarea {
    min-height: 120px;
}

#comments .logged-in-as,
#comments .comment-notes {
    font-size: 13px;
    color: #64748b;
}

#comments .comment-form-comment label {
    display: none;
}

/* Formulario arriba del listado */
#comments {
    display: flex;
    flex-direction: column;
}

#comments .comment-reply-title {
    order: 1;
}

#comments .comment-respond {
    order: 2;
}

#comments .comments-title {
    order: 3;
}

#comments .comment-list,
#comments ol.comment-list {
    order: 4;
}

[data-theme="dark"] #comments .comments-title {
    border-bottom-color: rgba(71, 85, 105, 0.7);
}

[data-theme="dark"] #comments .comment-author .fn {
    color: #e5e7eb;
}

[data-theme="dark"] #comments .comment-list .children .comment-body {
    background: rgba(227, 6, 19, 0.07);
}

[data-theme="dark"] #comments .reply a,
[data-theme="dark"] #comments .comment-reply-link {
    color: #cbd5e1;
}

#comments .reply {
    display: flex;
    align-items: center;
    gap: 6px;
}

.nsw-comment-reactions {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #9ca3af;
    font-size: 11px;
    line-height: 1;
}

.nsw-comment-reactions .nsw-react-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
    opacity: 0.85;
    transition: transform 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.nsw-comment-reactions .nsw-react-btn svg {
    display: block;
}

.nsw-comment-reactions .nsw-react-btn:hover {
    opacity: 1;
    transform: translateY(-1px);
}

.nsw-comment-reactions .nsw-react-btn.is-active {
    color: var(--primary-color);
    opacity: 1;
}

.nsw-comment-reactions .nsw-react-btn.is-pop {
    animation: nswReactPop 0.25s ease;
}

.nsw-comment-reactions .nsw-react-count {
    font-weight: 700;
    min-width: 8px;
    text-align: center;
}

.nsw-comment-reactions .nsw-react-sep {
    opacity: 0.6;
}

[data-theme="dark"] .nsw-comment-reactions {
    color: #94a3b8;
}

#comments .comment-reply-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

#comments .comment-reply-link svg {
    transition: transform 0.2s ease;
}

#comments .comment-reply-link:hover svg {
    transform: translateX(2px);
}

@keyframes nswReactPop {
    0% { transform: scale(1); }
    50% { transform: scale(1.18); }
    100% { transform: scale(1); }
}

/* Single post: separar contenedor del header/footer */
body.single .site-content {
    margin-top: 16px !important;
    margin-bottom: 22px !important;
    border-radius: 14px;
}

/* Ads: centrado global por defecto */
.nsw-ad-top,
.nsw-ad-bottom,
.nsw-ad-cover,
.nsw-ad-synopsis,
.nsw-ad-gallery,
.nsw-ad-downloads,
.nsw-ad-related,
.nsw-ad-footer-global {
    text-align: center !important;
}

.nsw-ad-top > *,
.nsw-ad-bottom > *,
.nsw-ad-cover > *,
.nsw-ad-synopsis > *,
.nsw-ad-gallery > *,
.nsw-ad-downloads > *,
.nsw-ad-related > *,
.nsw-ad-footer-global > * {
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Report page */
.nsw-report-form select,
.nsw-report-form textarea {
    width: 100%;
    border: 1px solid #c7d0df;
    background: #fff;
    color: #111827;
    border-radius: 12px;
    padding: 10px 12px;
}

.nsw-report-form textarea {
    resize: vertical;
    min-height: 140px;
}

.nsw-report-form select:focus,
.nsw-report-form textarea:focus {
    outline: none;
    border-color: #f87171;
    box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.18);
}

[data-theme="dark"] .nsw-report-form select,
[data-theme="dark"] .nsw-report-form textarea {
    background: #0f1218;
    color: #e5e7eb;
    border-color: #334155;
}

/* Rating cleanup */
.nsw-rating-system,
.nsw-rating-system .stars-outer {
    border: none !important;
    box-shadow: none !important;
}

.nsw-rating-system .star svg {
    fill: currentColor;
}

[data-theme="dark"] .nsw-rating-system .star {
    color: #ffb300 !important;
}

/* Bridge rating stars: keep visible before voting */
.nsw-bridge-star {
    color: #9ca3af !important;
    opacity: 1 !important;
}

.nsw-bridge-star svg,
.nsw-bridge-star svg path {
    fill: currentColor !important;
}

.nsw-bridge-star.is-on {
    color: #ffb300 !important;
}

[data-theme="dark"] .nsw-bridge-star {
    color: #64748b !important;
}

.nsw-comments-login-note .nsw-login-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 10px;
    padding: 8px 12px;
    border-radius: 10px;
    background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%);
    color: #fff !important;
    font-weight: 800;
    text-decoration: none !important;
    box-shadow: 0 8px 18px rgba(227, 6, 19, 0.24);
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.nsw-comments-login-note .nsw-login-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(227, 6, 19, 0.3);
    filter: saturate(1.05);
}

[data-theme="dark"] .nsw-comments-login-note .nsw-login-cta {
    box-shadow: 0 10px 22px rgba(227, 6, 19, 0.35);
}

[data-theme="dark"] .nsw-account-box {
    background: linear-gradient(160deg, rgba(16, 23, 34, 0.95) 0%, rgba(13, 19, 30, 0.95) 100%);
    border-color: rgba(80, 98, 129, 0.45);
    box-shadow: 0 28px 64px rgba(0, 0, 0, 0.55);
}

[data-theme="dark"] .nsw-account-form label {
    color: #d6dbe5;
}

[data-theme="dark"] .nsw-account-avatar-preview img,
[data-theme="dark"] .nsw-account-avatar-preview .avatar {
    border-color: rgba(71, 85, 105, 0.9);
}

[data-theme="dark"] .nsw-account-notice.is-success {
    color: #4ade80;
}

[data-theme="dark"] .nsw-account-notice.is-error {
    color: #fca5a5;
}
/* Home builder: carrusel horizontal */
.nsw-home-carousel {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 8px;
  scrollbar-width: thin;
}

.nsw-home-carousel .entry-card {
  flex: 0 0 220px;
  min-width: 220px;
  max-width: 220px;
}

.nsw-home-header-track .entry-card {
  flex: 0 0 220px;
  min-width: 220px;
  max-width: 220px;
}

.nsw-view-all-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid #e30613;
  background: linear-gradient(135deg, #ff2a36, #e30613);
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.2px;
  text-decoration: none;
  line-height: 1;
  box-shadow: 0 10px 20px rgba(227, 6, 19, 0.28);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}

.nsw-view-all-btn svg {
  fill: currentColor;
  width: 15px;
  height: 15px;
  flex: 0 0 15px;
  transform: translateY(0.5px);
  transition: transform .2s ease, opacity .2s ease;
  opacity: .95;
}

.nsw-view-all-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.03);
  box-shadow: 0 14px 28px rgba(227, 6, 19, 0.34);
}

.nsw-view-all-btn:hover svg {
  transform: translateX(-3px);
}

.nsw-view-all-btn:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(227, 6, 19, 0.28), 0 12px 26px rgba(227, 6, 19, 0.32);
}

[data-theme="dark"] .nsw-view-all-btn {
  border-color: #ff4d57;
  background: linear-gradient(135deg, #ff3b47, #cf0611);
  color: #fff;
  box-shadow: 0 12px 24px rgba(227, 6, 19, 0.4);
}

@media (max-width: 768px) {
  .nsw-view-all-btn {
    padding: 9px 14px;
    font-size: 12px;
    gap: 8px;
  }
}

.nsw-tax-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.nsw-tax-card {
  display: block;
  padding: 12px;
  border: 1px solid var(--border-color);
  border-radius: 10px;
  background: var(--bg-card);
  text-decoration: none;
  color: var(--text-dark);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.nsw-tax-card strong {
  display: block;
  font-size: 14px;
  margin-bottom: 6px;
}

.nsw-tax-card span {
  font-size: 12px;
  color: var(--text-gray);
}

.nsw-tax-card:hover {
  transform: translateY(-2px);
  border-color: var(--primary-color);
  box-shadow: 0 8px 20px rgba(0, 0, 0, .12);
}

.nsw-faq-box {
  max-width: 980px;
  margin: 0 auto;
}

.nsw-faq-page-wrap {
  margin-top: 0;
  margin-bottom: 0;
}

/* FAQ page: same separation pattern as single.php */
body.nsw-faq-page .site-content {
  margin-top: 16px !important;
  margin-bottom: 22px !important;
  border-radius: 14px;
}

body.nsw-dmca-page .site-content {
  margin-top: 16px !important;
  margin-bottom: 22px !important;
  border-radius: 14px;
}

.nsw-faq-intro {
  margin-bottom: 14px;
  color: var(--text-gray);
}

.nsw-faq-list {
  display: grid;
  gap: 10px;
}

.nsw-faq-item {
  border: 1px solid var(--border-color);
  border-radius: 12px;
  background: var(--bg-card);
  overflow: hidden;
}

.nsw-faq-item summary {
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 700;
  list-style: none;
}

.nsw-faq-item summary::-webkit-details-marker {
  display: none;
}

.nsw-faq-item[open] summary {
  background: rgba(227, 6, 19, 0.08);
  color: var(--primary-color);
}

.nsw-faq-answer {
  padding: 0 14px 14px;
  color: var(--text-dark);
}

.nsw-dmca-box {
  max-width: 980px;
  margin: 0 auto;
}

.nsw-dmca-box h3 {
  margin: 20px 0 8px;
  font-size: 18px;
}

.nsw-dmca-box ul {
  margin: 0 0 8px 18px;
}

.nsw-dmca-box li {
  margin-bottom: 6px;
  color: var(--text-dark);
}

.nsw-dmca-note {
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid rgba(227, 6, 19, 0.25);
  background: rgba(227, 6, 19, 0.08);
  color: var(--text-dark);
}

.nsw-updates-box {
  max-width: 980px;
  margin: 0 auto;
}

.nsw-updates-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.nsw-updates-head h2 {
  margin: 0;
}

.nsw-updates-refresh {
  font-size: 13px;
  color: var(--text-gray);
  background: rgba(0, 0, 0, 0.04);
  border: 1px solid var(--border-color);
  border-radius: 999px;
  padding: 6px 10px;
}

.nsw-updates-intro {
  margin: 0 0 12px;
  color: var(--text-gray);
}

.nsw-updates-list {
  margin: 0;
  padding-left: 0;
  list-style: none;
  counter-reset: nsw-updates-counter;
}

.nsw-updates-list li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  padding: 8px 0 8px 30px;
  border-bottom: 1px dashed var(--border-color);
  position: relative;
  counter-increment: nsw-updates-counter;
}

.nsw-updates-list li::before {
  content: counter(nsw-updates-counter) ".";
  position: absolute;
  left: 0;
  top: 8px;
  font-weight: 800;
  color: var(--text-gray);
}

.nsw-updates-list li a {
  color: var(--text-dark);
  text-decoration: none;
  font-weight: 600;
}

.nsw-updates-list li a:hover {
  color: var(--primary-color);
}

.nsw-updates-list li span {
  color: var(--text-gray);
  font-size: 12px;
  white-space: nowrap;
}

@media (max-width: 768px) {
  body.nsw-updates-page .nsw-updates-box,
  body.nsw-updates-page .inside-article {
    max-width: 100% !important;
    width: 100% !important;
  }

  body.nsw-updates-page .nsw-updates-box {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  .nsw-updates-box {
    max-width: 100%;
  }

  .nsw-updates-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .nsw-updates-head h2 {
    font-size: 30px;
    line-height: 1.2;
  }

  .nsw-updates-refresh {
    font-size: 12px;
    padding: 5px 9px;
  }

  .nsw-updates-intro {
    font-size: 16px;
    line-height: 1.55;
    margin-bottom: 14px;
  }

  body.nsw-updates-page .nsw-updates-list li,
  .nsw-updates-list li {
    display: block;
    padding: 12px 0 14px 24px !important;
    gap: 0;
  }

  .nsw-updates-list li::before {
    top: 10px;
    font-size: 16px;
  }

  body.nsw-updates-page .nsw-updates-list li a,
  .nsw-updates-list li a {
    display: block;
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin-bottom: 8px !important;
    font-weight: 700 !important;
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  body.nsw-updates-page .nsw-updates-list li span,
  .nsw-updates-list li span {
    display: block;
    font-size: 11px !important;
    line-height: 1.45 !important;
    white-space: normal;
    opacity: 0.9;
  }

  body.nsw-updates-page .nsw-updates-list li::before {
    left: 0 !important;
    top: 12px !important;
    font-size: 14px !important;
  }
}

.nsw-top-games-box {
  max-width: 980px;
  margin: 0 auto;
}

.nsw-top-games-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.nsw-top-games-item {
  display: block;
  align-items: start;
}

.nsw-top-games-item .entry-card {
  width: 100%;
  max-width: none;
  min-width: 0;
}

.nsw-top-games-item .entry-cover img {
  height: 250px;
  object-fit: cover;
}

.nsw-top-games-item .entry-info {
  padding: 10px 10px 8px;
}

.nsw-top-games-item .entry-info h2 {
  font-size: 15px;
}

.nsw-top-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  min-width: 46px;
  border-radius: 10px;
  font-weight: 900;
  font-size: 12px;
  color: #fff;
  background: linear-gradient(135deg, #e30613, #ff4d4d);
  box-shadow: 0 8px 20px rgba(227, 6, 19, 0.25);
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 9;
}

.nsw-top-games-item .platform-badge {
  left: auto;
  right: 10px;
}

@media (max-width: 1200px) {
  .nsw-top-games-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 992px) {
  .nsw-top-games-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .nsw-top-games-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

body.nsw-updates-page .entry-header .entry-title {
  display: none !important;
}

body.nsw-games-list-page .site-content {
  margin-top: 16px !important;
  margin-bottom: 22px !important;
  border-radius: 14px;
}

body.nsw-games-list-page .entry-header .entry-title {
  text-align: left !important;
}

.nsw-games-list-box {
  max-width: 1120px;
  margin: 0 auto;
}

.nsw-gl-search-wrap {
  position: relative;
  max-width: 600px;
  margin: 0 auto 20px;
}

.nsw-gl-search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #9aa8b8;
}

.nsw-gl-search-wrap input[type="text"] {
  width: 100%;
  height: 52px;
  border-radius: 999px;
  border: 1px solid var(--border-color);
  background: var(--bg-card);
  color: var(--text-dark);
  padding: 0 18px 0 46px;
}

.nsw-gl-letter-title {
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-gray);
  margin: 6px 0 12px;
}

.nsw-gl-letters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 18px;
}

.nsw-gl-letter {
  min-width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid var(--border-color);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--text-dark);
  font-weight: 700;
  font-size: 14px;
  background: var(--bg-card);
}

.nsw-gl-letter.is-active {
  background: #0ea5a0;
  color: #fff;
  border-color: #0ea5a0;
}

.nsw-gl-toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  margin: 6px 0 18px;
}

.nsw-gl-view-toggle {
  display: inline-flex;
  gap: 6px;
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  padding: 4px;
}

.nsw-gl-view-btn {
  width: 40px;
  height: 34px;
  border-radius: 8px;
  color: #8ea1b2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.nsw-gl-view-btn.is-active {
  color: #0ea5a0;
  background: rgba(14, 165, 160, 0.14);
}

.nsw-gl-results.is-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.nsw-gl-card {
  display: block;
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: var(--text-dark);
  height: 100%;
}

.nsw-gl-cover {
  position: relative;
  aspect-ratio: 2/3;
  overflow: hidden;
  background: #d9dde3;
}

.nsw-gl-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.nsw-gl-cover .platform-badge {
  left: 8px;
  top: 8px;
}

.nsw-gl-year {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(0, 0, 0, .7);
  color: #fff;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  padding: 2px 7px;
}

.nsw-gl-body {
  padding: 10px 10px 12px;
}

.nsw-gl-body h3 {
  margin: 0 0 8px;
  font-size: 17px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.nsw-gl-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.nsw-gl-console-icon {
  width: 24px;
  height: 24px;
  min-width: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(14, 165, 160, 0.12);
  color: #0ea5a0;
}

.nsw-gl-console-icon svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

.nsw-gl-size,
.nsw-gl-cat {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 10px;
}

.nsw-gl-size {
  background: #dbeafe;
  color: #1560c8;
}

.nsw-gl-cat {
  background: #dcfce7;
  color: #1f7a33;
}

/* Games list dark mode: improve chips contrast (size/category) */
[data-theme="dark"] .nsw-gl-card {
  background: #1b1f27 !important;
  border-color: #2a3240 !important;
}

[data-theme="dark"] .nsw-gl-body h3 {
  color: #f3f4f6 !important;
}

[data-theme="dark"] .nsw-gl-size {
  background: #1e3554 !important;
  color: #d7e9ff !important;
  border: 1px solid #2f4f77 !important;
}

[data-theme="dark"] .nsw-gl-cat {
  background: #1f3b2a !important;
  color: #d9fbe4 !important;
  border: 1px solid #2f5a3f !important;
}

[data-theme="dark"] .nsw-gl-results.is-list .nsw-gl-size,
[data-theme="dark"] .nsw-gl-results.is-list .nsw-gl-cat,
[data-theme="dark"] .nsw-gl-results.is-grid .nsw-gl-size,
[data-theme="dark"] .nsw-gl-results.is-grid .nsw-gl-cat {
  opacity: 1 !important;
  filter: none !important;
}

.nsw-gl-results.is-list {
  display: grid;
  gap: 12px;
}

.nsw-gl-results.is-list .nsw-gl-card {
  display: block;
}

.nsw-gl-results.is-list .nsw-gl-cover .platform-badge {
  display: none !important;
}

.nsw-gl-results.is-list .nsw-gl-cover {
  display: none !important;
}

.nsw-gl-results.is-list .nsw-gl-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.nsw-gl-results.is-list .nsw-gl-body h3 {
  margin: 0;
  -webkit-line-clamp: 2;
  font-size: 20px;
  text-align: left;
  flex: 1;
  width: 100%;
}

.nsw-gl-results.is-grid .nsw-gl-console-icon {
  display: none;
}

.nsw-gl-results.is-list .nsw-gl-meta {
  flex-wrap: nowrap;
  white-space: nowrap;
}

.nsw-gl-pagination .page-numbers {
  list-style: none;
  padding: 0;
  margin: 20px 0 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.nsw-gl-pagination .page-numbers li > * {
  min-width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--border-color);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--text-dark);
  font-weight: 800;
  background: var(--bg-card);
}

.nsw-gl-pagination .page-numbers .current {
  color: #fff;
  border-color: #0ea5a0;
  background: linear-gradient(180deg, #10c7be, #0ea5a0);
}

@media (max-width: 1100px) {
  .nsw-gl-results.is-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .nsw-gl-results.is-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .nsw-gl-results.is-list .nsw-gl-card {
    grid-template-columns: 1fr;
  }

  .nsw-gl-results.is-list .nsw-gl-body h3 {
    font-size: 19px;
  }
}

@media (max-width: 560px) {
  .nsw-gl-results.is-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .nsw-gl-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
}

.nsw-404-wrap {
  padding: 34px 28px;
  border: 1px solid var(--border-color);
  border-radius: 16px;
  background: linear-gradient(180deg, var(--bg-card), rgba(0, 0, 0, .01));
  text-align: center;
}

.nsw-404-badge {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(227, 6, 19, .12);
  border: 1px solid rgba(227, 6, 19, .24);
  color: var(--primary-color);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 10px;
}

.nsw-404-wrap h1 {
  margin: 0 0 8px;
  font-size: 34px;
}

.nsw-404-wrap p {
  margin: 0 auto 18px;
  max-width: 540px;
  color: var(--text-gray);
}

.nsw-404-redirect-note {
  margin-top: -6px;
  margin-bottom: 16px;
  font-size: 13px;
  color: var(--text-gray);
}

/* Footer refinement */
.site-footer .site-info {
  padding: 16px 20px !important;
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: .2px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.site-footer .site-info,
.site-footer .site-info span,
.site-footer .site-info p {
  color: rgba(255, 255, 255, 0.9) !important;
}

.site-footer .site-info a {
  color: #9fb9ff !important;
  text-decoration: none;
  border-bottom: 1px dotted rgba(159, 185, 255, 0.45);
  transition: color .2s ease, border-color .2s ease;
}

.site-footer .site-info a:hover {
  color: #dbe7ff !important;
  border-bottom-color: rgba(219, 231, 255, 0.8);
}

/* Footer colors by theme mode */
body:not([data-theme="dark"]) .site-footer .site-info,
body:not([data-theme="dark"]) .site-footer .site-info span,
body:not([data-theme="dark"]) .site-footer .site-info p {
  color: var(--text-dark) !important;
}

body:not([data-theme="dark"]) .site-footer .site-info a {
  color: #2b5fcc !important;
  border-bottom-color: rgba(43, 95, 204, 0.45);
}

body:not([data-theme="dark"]) .site-footer .site-info a:hover {
  color: #1f4fb3 !important;
  border-bottom-color: rgba(31, 79, 179, 0.8);
}

[data-theme="dark"] .site-footer .site-info,
[data-theme="dark"] .site-footer .site-info span,
[data-theme="dark"] .site-footer .site-info p {
  color: rgba(255, 255, 255, 0.9) !important;
}

/* Archive/search/404: same header/footer separation pattern as single */
body.category .site-content,
body.tag .site-content,
body.search .site-content,
body.error404 .site-content {
  margin-top: 16px !important;
  margin-bottom: 22px !important;
  border-radius: 14px;
}

.nsw-404-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.nsw-404-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
}

.nsw-404-btn.is-primary {
  background: var(--primary-color);
  color: #fff;
  border: 1px solid var(--primary-color);
}

.nsw-404-btn.is-ghost {
  background: transparent;
  color: var(--text-dark);
  border: 1px solid var(--border-color);
}

.nsw-404-search {
  max-width: 520px;
  margin: 0 auto;
}

.nsw-download-bridge-entry-wrap {
  padding: 4px 0;
}

.nsw-download-bridge-entry-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 22px;
  border-radius: 12px;
  background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%);
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 800;
  font-size: 15px;
  letter-spacing: 0.2px;
  border: 1px solid rgba(227, 6, 19, 0.7);
  box-shadow: 0 12px 26px rgba(227, 6, 19, 0.24);
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease, background 0.2s ease;
}

.nsw-download-bridge-entry-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(227, 6, 19, 0.3);
  filter: saturate(1.06);
  background: linear-gradient(135deg, #ff3d3d 0%, #e30613 100%);
}

.nsw-download-bridge-entry-btn:active {
  transform: translateY(0);
}

[data-theme="dark"] .nsw-download-bridge-entry-btn {
  box-shadow: 0 16px 32px rgba(227, 6, 19, 0.34);
  border-color: rgba(255, 80, 80, 0.65);
}

body[data-theme="dark"] .entry-download-box .nsw-download-bridge-entry-wrap .nsw-download-bridge-entry-btn,
body[data-theme="dark"] .entry-download-box .dl-links-wrapper .nsw-download-bridge-entry-btn {
  background: linear-gradient(135deg, #ff2a2a 0%, #e30613 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 80, 80, 0.65) !important;
  box-shadow: 0 16px 32px rgba(227, 6, 19, 0.34) !important;
}

body[data-theme="dark"] .entry-download-box .nsw-download-bridge-entry-wrap .nsw-download-bridge-entry-btn:hover,
body[data-theme="dark"] .entry-download-box .dl-links-wrapper .nsw-download-bridge-entry-btn:hover {
  background: linear-gradient(135deg, #ff3d3d 0%, #e30613 100%) !important;
  color: #fff !important;
}

@media (max-width: 768px) {
  .nsw-download-bridge-entry-btn {
    width: 100%;
    max-width: 360px;
    font-size: 14px;
  }
}

.main-navigation .main-nav .nsw-mobile-login-static {
  display: none !important;
}

/* === MOBILE RESCUE PATCH (final override) === */
@media (max-width: 768px) {
  html,
  body {
    overflow-x: hidden;
  }

  .inside-article,
  .site-content,
  .separate-containers .inside-article,
  .separate-containers .site-main > * {
    padding-left: 14px !important;
    padding-right: 14px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  .entry-grid,
  .nsw-gl-results.is-grid,
  .nsw-top-games-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .entry-info h2,
  .entry-info h3,
  .nsw-gl-body h3 {
    font-size: 13px !important;
    line-height: 1.35 !important;
    word-break: break-word;
  }

  .nsw-home-carousel .entry-card,
  .nsw-home-header-track .entry-card {
    flex: 0 0 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
  }

  .nsw-top-games-item .entry-cover img {
    height: 200px !important;
  }

  .nsw-gl-results.is-list .nsw-gl-body {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  .nsw-gl-results.is-list .nsw-gl-body h3 {
    font-size: 16px !important;
    line-height: 1.3 !important;
    text-align: left !important;
  }

  .nsw-gl-results.is-list .nsw-gl-meta {
    flex-wrap: wrap !important;
    white-space: normal !important;
    gap: 6px !important;
  }

  img,
  iframe,
  table {
    max-width: 100% !important;
  }

  table {
    display: block;
    overflow-x: auto;
  }
}

@media (max-width: 560px) {
  .entry-grid,
  .nsw-gl-results.is-grid,
  .nsw-top-games-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .entry-info,
  .nsw-gl-body {
    padding: 8px !important;
  }

  .nsw-home-carousel .entry-card,
  .nsw-home-header-track .entry-card {
    flex: 0 0 146px !important;
    min-width: 146px !important;
    max-width: 146px !important;
  }
}

/* === MENU MOBILE FIX ONLY === */
@media (max-width: 768px) {
  .main-navigation .menu-bar-items .search-item > a,
  .main-navigation .menu-bar-items .menu-bar-item.search-item > a {
    position: relative !important;
    top: 0 !important;
  }

  .main-navigation .inside-navigation > .menu-toggle:not(:first-of-type) {
    display: none !important;
  }

  .main-navigation .inside-navigation .menu-toggle + .menu-toggle {
    display: none !important;
  }

  .main-navigation .main-nav .menu-toggle {
    display: none !important;
  }

  .main-navigation .menu-bar-items .nsw-login-item > a,
  .nsw-login-icon-btn {
    height: 40px !important;
    line-height: 40px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .nsw-login-icon-btn svg {
    position: static !important;
    top: auto !important;
    margin: 0 !important;
    width: 18px !important;
    height: 18px !important;
  }

  .main-navigation .menu-bar-items .nsw-login-item > a,
  .main-navigation .menu-bar-items .search-item > a,
  .main-navigation .menu-bar-items .menu-bar-item.search-item > a {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .main-navigation .menu-toggle {
    margin-right: 10px !important;
    padding-right: 6px !important;
    height: 40px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    vertical-align: middle !important;
    position: relative !important;
    top: -2px !important;
  }

  .main-navigation .menu-toggle,
  .main-navigation .menu-toggle:hover,
  .main-navigation .menu-toggle:focus {
    background: transparent !important;
    color: var(--text-dark) !important;
    border: 0 !important;
    box-shadow: none !important;
    position: relative !important;
    z-index: 10002 !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  .main-navigation .menu-toggle .gp-icon {
    font-size: 24px !important;
    line-height: 1 !important;
  }

  .main-navigation .menu-toggle .gp-icon svg,
  .main-navigation .menu-toggle .gp-icon i {
    transition: transform 0.24s ease, opacity 0.24s ease, filter 0.24s ease !important;
    transform-origin: center;
  }

  .main-navigation .menu-toggle .menu-toggle-text,
  .main-navigation .menu-toggle .mobile-menu,
  .main-navigation .menu-toggle .menu-bar-item {
    display: none !important;
  }

  .main-navigation .menu-bar-items .search-item,
  .main-navigation .menu-bar-items .menu-bar-item.search-item {
    display: none !important;
  }

  .main-navigation .menu-bar-items .nsw-login-item,
  .main-navigation .menu-bar-items .nsw-login-item-logged {
    display: none !important;
  }

  .main-navigation.toggled .main-nav > ul {
    position: fixed !important;
    top: var(--nsw-mobile-drawer-top, 0px) !important;
    left: 0 !important;
    width: min(86vw, 348px) !important;
    max-width: 348px !important;
    height: calc(100dvh - var(--nsw-mobile-drawer-top, 0px)) !important;
    margin: 0 !important;
    padding: 68px 12px 16px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    transform: none !important;
    animation: none !important;
    border-right: 1px solid #d9e1ec !important;
    border-radius: 0 !important;
    box-shadow: 10px 0 34px rgba(15, 23, 42, 0.28) !important;
    z-index: 10000 !important;
    background: linear-gradient(180deg, #ffffff 0%, #f7f9fc 100%) !important;
    -webkit-overflow-scrolling: touch;
  }

  [data-theme="dark"] .main-navigation.toggled .main-nav > ul {
    background: linear-gradient(180deg, #111827 0%, #0b1220 100%) !important;
    border-right-color: #273244 !important;
  }

  .main-navigation.toggled .main-nav > ul::after,
  .main-navigation .main-nav ul::after {
    content: none !important;
    display: none !important;
  }

  .main-navigation.toggled .main-nav > ul {
    display: block !important;
    gap: 0 !important;
  }

  .main-navigation.toggled .main-nav > ul > li {
    margin: 0 0 6px !important;
    border-radius: 12px !important;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid #e3e9f2;
    box-shadow: 0 5px 14px rgba(15, 23, 42, 0.06);
  }

  [data-theme="dark"] .main-navigation.toggled .main-nav > ul > li {
    background: rgba(17, 24, 39, 0.92);
    border-color: #233045;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28);
  }

  .main-navigation.toggled .main-nav > ul > li::after {
    display: none !important;
  }

  .main-navigation.toggled .main-nav ul li a {
    padding: 14px 16px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.4px !important;
    line-height: 1.25 !important;
    border-bottom: 1px solid #edf1f7 !important;
    white-space: normal !important;
    color: #0f172a !important;
    background: transparent !important;
    transition: background-color 0.2s ease, color 0.2s ease, padding-left 0.2s ease !important;
  }

  [data-theme="dark"] .main-navigation.toggled .main-nav ul li a {
    color: #e5e7eb !important;
    border-bottom-color: #1f2937 !important;
  }

  .main-navigation.toggled .main-nav > ul > li:last-child > a {
    border-bottom: 0 !important;
  }

  .main-navigation.toggled .main-nav > ul > li > a:hover,
  .main-navigation.toggled .main-nav > ul > li > a:focus {
    background: rgba(227, 6, 19, 0.08) !important;
    color: var(--primary-color) !important;
    padding-left: 20px !important;
  }

  .main-navigation.toggled .main-nav > ul > li.current-menu-item > a,
  .main-navigation.toggled .main-nav > ul > li.current-menu-ancestor > a {
    color: var(--primary-color) !important;
    background: linear-gradient(90deg, rgba(227, 6, 19, 0.14), rgba(227, 6, 19, 0.03)) !important;
    border-left: 3px solid var(--primary-color) !important;
    padding-left: 17px !important;
  }

  .main-navigation.toggled .main-nav ul ul {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    border: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: #f8fafc !important;
    border-top: 1px solid #e4eaf3 !important;
  }

  [data-theme="dark"] .main-navigation.toggled .main-nav ul ul {
    background: #0f172a !important;
    border-top-color: #1f2a3d !important;
  }

  .main-navigation.toggled .main-nav ul ul li a {
    padding: 11px 16px 11px 30px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    border-bottom: 1px solid #e9eef6 !important;
  }

  [data-theme="dark"] .main-navigation.toggled .main-nav ul ul li a {
    border-bottom-color: #1a2538 !important;
  }

  .main-navigation.toggled .main-nav ul ul li:last-child > a {
    border-bottom: 0 !important;
  }

  .main-navigation.toggled .main-nav ul ul li a:hover,
  .main-navigation.toggled .main-nav ul ul li.current-menu-item > a {
    background: rgba(227, 6, 19, 0.1) !important;
    color: var(--primary-color) !important;
  }

  .main-navigation.toggled .dropdown-menu-toggle {
    margin-left: auto !important;
    opacity: 0.9;
  }

  .main-navigation.toggled .menu-toggle {
    position: fixed !important;
    top: calc(var(--nsw-mobile-drawer-top, 0px) + 10px) !important;
    left: calc(min(86vw, 348px) - 50px) !important;
    right: auto !important;
    z-index: 10003 !important;
    width: 28px !important;
    height: 28px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    color: #111827 !important;
    box-shadow: none !important;
    transition: transform 0.2s ease, color 0.2s ease !important;
  }

  .main-navigation.toggled .menu-toggle::before {
    content: "×";
    display: block;
    font-size: 28px;
    line-height: 1;
    font-weight: 400;
    color: currentColor;
  }

  .main-navigation.toggled .menu-toggle:hover {
    transform: scale(1.06) !important;
    color: #ffffff !important;
  }

  .main-navigation.toggled .menu-toggle:active {
    transform: scale(0.95) !important;
  }

  .main-navigation.toggled .menu-toggle .gp-icon svg,
  .main-navigation.toggled .menu-toggle .gp-icon i {
    transform: rotate(90deg) scale(1.06);
    filter: drop-shadow(0 1px 1px rgba(15, 23, 42, 0.2));
  }

  .main-navigation.toggled .menu-toggle .gp-icon {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    transform: none !important;
    line-height: 1 !important;
  }

  .main-navigation.toggled .menu-toggle .gp-icon svg,
  .main-navigation.toggled .menu-toggle .gp-icon i {
    width: 18px !important;
    height: 18px !important;
    display: block !important;
    margin: 0 !important;
  }

  [data-theme="dark"] .main-navigation.toggled .menu-toggle {
    background: transparent !important;
    border: 0 !important;
    color: #f8fafc !important;
  }

  .off-canvas-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 9998 !important;
    background: rgba(9, 15, 26, 0.5) !important;
    backdrop-filter: blur(2px);
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity 0.22s ease, visibility 0.22s ease !important;
  }

  .main-navigation.toggled + .off-canvas-overlay {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  .main-navigation.toggled .main-nav .nsw-mobile-search-item > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px;
  }

  .main-navigation.toggled .main-nav .nsw-mobile-login-item > a,
  .main-navigation.toggled .main-nav .nsw-mobile-login-static > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
  }

  .main-navigation.toggled .main-nav .nsw-mobile-login-item > a svg,
  .main-navigation.toggled .main-nav .nsw-mobile-login-static > a svg {
    width: 16px !important;
    height: 16px !important;
    position: static !important;
    top: auto !important;
  }

  .main-navigation.toggled .main-nav .nsw-mobile-login-item .nsw-mobile-login-label,
  .main-navigation.toggled .main-nav .nsw-mobile-login-static .nsw-mobile-login-label {
    display: inline-block;
    line-height: 1.2;
  }

  .main-navigation.toggled .main-nav .nsw-mobile-login-static {
    display: block !important;
  }

  .main-navigation.toggled .menu-item-dark-toggle .theme-toggle-btn {
    width: 100% !important;
    min-height: 48px !important;
    padding: 10px 14px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    line-height: 1.2 !important;
    transform: none !important;
    animation: none !important;
  }

  .main-navigation.toggled .menu-item-dark-toggle .theme-toggle-btn:hover,
  .main-navigation.toggled .menu-item-dark-toggle .theme-toggle-btn:focus,
  .main-navigation.toggled .menu-item-dark-toggle .theme-toggle-btn:active {
    transform: none !important;
  }

  .main-navigation.toggled .menu-item-dark-toggle .theme-toggle-icon {
    position: static !important;
    transform: none !important;
    margin: 0 !important;
    width: 18px !important;
    height: 18px !important;
    flex: 0 0 18px;
  }

  .main-navigation.toggled .menu-item-dark-toggle .theme-toggle-text {
    margin: 0 !important;
    font-size: 14px !important;
    font-style: normal !important;
    transform: none !important;
    text-decoration: none !important;
  }
}
