/* ==========================================================================
   RESPONSIVE.CSS — All media queries consolidated from main.css
   Organized by breakpoint (largest → smallest)
   ========================================================================== */


/* ==========================================================================
   BREAKPOINT: 1400px
   ========================================================================== */
@media (max-width: 1400px) {

    /* --- Layout --- */
    .site-main {
        padding: 20px 30px 40px 30px;
    }

    /* --- Dashboard --- */
    .dashboard-bento-grid {
        gap: 20px;
    }

    .post-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .team-members-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }

    .masonry-style {
        column-count: 2;
    }

    /* --- Sidebar Compressions --- */
    .sidebar-header {
        padding: 20px 15px;
    }



    .main-navigation ul,
    .account-main-nav ul,
    .account-menu {
        gap: 10px;
    }

    .main-navigation li a,
    .account-main-nav li a {
        padding: 10px 14px;
        font-size: 14px;
    }

    .user-profile {
        gap: 10px;
    }

    .avatar-img {
        width: 38px;
        height: 38px;
    }

    .user-name {
        font-size: 14px;
    }

    /* --- Account Menu Compressions --- */
    .account-sidebar {
        width: 35%;
        padding: 30px 15px;
    }

    .account-nav {
        gap: 6px;
    }

    .account-nav .nav-item {
        font-size: 14px;
        gap: 12px;
    }

    .account-content {
        padding: 40px;
    }
}

@media (min-width: 768px) and (max-width: 1400px) {
    .kaia-avatar-wrapper {
        width: 70px !important;
        height: 70px !important;
    }

    .site-sidebar .custom-nav-menu li>a {
        padding-top: 7px !important;
        padding-bottom: 7px !important;
    }
}



/* ==========================================================================
   BREAKPOINT: 1200px
   ========================================================================== */
@media (max-width: 1200px) {
    .team-members-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* ==========================================================================
   BREAKPOINT: 1040px
   ========================================================================== */
@media (max-width: 1040px) {

    /* --- Dashboard --- */
    .dashboard-bento-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .span-2 {
        grid-column: span 1;
    }

    .post-grid {
        gap: 20px;
    }

    .tool-archive-grid {
        grid-template-columns: 1fr !important;
    }

    /* --- Account Page --- */
    .page-title {
        font-size: 32px;
    }

    .account-card {
        flex-direction: column;
        border-radius: 12px !important;
        overflow: hidden;
        /* Ensure contents don't bleed out */
    }

    .account-sidebar {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid #f1f5f9;
    }

    /* ======================================================
       ACCOUNT MENU - HORIZONTAL CAROUSEL MOBILE
    ====================================================== */
    .account-card {
        display: block !important;
    }

    .account-sidebar {
        width: 100% !important;
        border: none !important;
        padding: 0 !important;
        background: transparent !important;
        display: block !important;
        min-height: auto !important;
        margin-bottom: 25px !important;
    }

    .account-nav-container {
        position: relative !important;
        padding: 0 40px !important;
        /* Space for the arrows at 0 */
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        width: 100% !important;
        box-sizing: border-box !important;
        overflow: visible !important;
        height: auto !important;
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        margin-bottom: 20px !important;
    }

    .account-nav {
        display: block !important;
        width: 100% !important;
        height: auto !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        white-space: nowrap !important;
        flex: 1 !important;
        scrollbar-width: none !important;
        -ms-overflow-style: none !important;
        padding: 5px 0 !important;
        cursor: grab !important;
        scroll-behavior: smooth !important;
    }

    .account-nav::-webkit-scrollbar {
        display: none !important;
    }

    .account-nav ul.account-menu {
        display: flex !important;
        flex-direction: row !important;
        gap: 10px !important;
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        /* Managed by container now */
        width: max-content !important;
    }

    .account-menu .nav-item {
        flex: 0 0 auto !important;
        display: flex !important;
        align-items: center !important;
        width: auto !important;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
    }

    .account-menu .nav-item a {
        display: flex !important;
        padding: 8px 16px !important;
        /* Match filter pills more closely */
        border-radius: 40px !important;
        /* Pill shape like filters */
        background: #fff !important;
        /* Match filter pills */
        border: 1px solid #E2E8F0 !important;
        height: auto !important;
        /* Normal height */
        font-size: 13px !important;
        /* Match filters */
        font-weight: 600 !important;
        color: var(--text-muted) !important;
        transition: all 0.3s ease !important;
        text-decoration: none !important;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.03) !important;
    }

    .account-menu .nav-item.active a {
        background: #fff !important;
        color: #000 !important;
        border: 2px solid #000 !important;
        font-weight: 800 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
    }

    .account-menu .nav-item.logout-item a {
        color: #ef4444 !important;
        border: 1px solid #fca5a5 !important;
    }

    .account-menu .nav-item.logout-item a svg {
        color: #ef4444 !important;
        stroke: #ef4444 !important;
        display: block !important;
        opacity: 1 !important;
        width: 16px !important;
        height: 16px !important;
    }

    .account-menu .nav-item.logout-item a span {
        color: #ef4444 !important;
    }

    .account-nav .nav-item svg {
        width: 16px !important;
        height: 16px !important;
        margin: 0 !important;
    }

    .account-content {
        padding: 16px !important;
    }

    .user-posts-list .post-item-link {
        padding: 16px 16px 16px 10px !important;
    }

    .post-actions {
        padding-right: 10px !important;
    }

    /* Account Menu Arrows */
    .account-nav-container .account-nav-arrow {
        position: absolute !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        z-index: 10 !important;
        width: 34px !important;
        height: 34px !important;
        background: #000 !important;
        /* Bold black icons */
        border: none !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: #ECD812 !important;
        /* Yellow icons like Kaia */
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
        cursor: pointer !important;
        opacity: 1 !important;
        /* Always visible on mobile if needed */
        visibility: visible !important;
        pointer-events: auto !important;
    }

    .account-nav-container .account-nav-arrow.prev {
        left: 0 !important;
    }

    .account-nav-container .account-nav-arrow.next {
        right: 0 !important;
    }

    .account-nav-container .account-nav-arrow:hover {
        background: var(--text-main);
        color: #FFF;
        border-color: var(--text-main);
    }

    .agencia-form .form-row {
        grid-template-columns: 1fr;
    }

    .avatar-edit-container {
        flex-direction: column;
        text-align: center;
    }

    /* --- Favorites Touch Fix --- */
    .grid-card:hover .favorite-button-container,
    .prompt-glass-card:hover .favorite-button-container,
    .tool-archive-card:hover .favorite-button-container,
    .formacion-card:hover .favorite-button-container {
        opacity: 0;
        transform: scale(0.8);
        pointer-events: none;
    }

    .favorite-button-container.is-favorite {
        opacity: 1 !important;
        transform: scale(1) !important;
        pointer-events: auto !important;
    }

    .entry-top-bar .favorite-button-container {
        opacity: 1;
        transform: scale(1);
        pointer-events: auto;
    }
}


/* ==========================================================================
   BREAKPOINT: 900px
   ========================================================================== */
@media (max-width: 900px) {

    /* --- Toggle: hamburger on mobile, positioned top-right --- */
    .universal-toggle {
        left: auto !important;
        right: 16px;
        top: 16px;
        z-index: 1100;
    }

    /* On mobile: default = sidebar hidden → show hamburger, hide X */
    .universal-toggle .icon-menu {
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    .universal-toggle .icon-close {
        opacity: 0 !important;
        pointer-events: none !important;
    }

    body.menu-open {
        overflow: hidden !important;
        position: fixed !important;
        width: 100% !important;
        height: 100% !important;
    }

    /* When menu is open → show X, hide hamburger */
    body.menu-open .universal-toggle .icon-menu {
        opacity: 0 !important;
        pointer-events: none !important;
    }

    body.menu-open .universal-toggle .icon-close {
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    /* --- Sidebar Mobile Optimizations --- */
    body:not(.sidebar-collapsed) .site-sidebar,
    .site-sidebar {
        transform: translateX(-100%);
        width: 100%;
        z-index: 1050;
        display: flex;
        flex-direction: column;
        height: 100vh;
        height: 100dvh;
        overflow-y: auto !important;
        /* Allow internal scroll if menu is long */
        overscroll-behavior: contain !important;
        /* Prevent scroll chaining to background */
        -webkit-overflow-scrolling: touch;
    }

    body.menu-open .site-sidebar {
        transform: translateX(0);
    }

    /* Main content: full width, no margin */
    body:not(.sidebar-collapsed) .site-main,
    .site-main {
        margin-left: 0 !important;
        padding: 20px 16px 30px 16px;
        width: 100% !important;
        max-width: 100% !important;
    }

    .global-container {
        max-width: 100%;
        padding: 0;
    }

    /* --- Archive Filter Navigation Arrows Mobile --- */
    .filter-pills-container {
        padding: 0 !important;
        position: relative !important;
        box-sizing: border-box !important;
    }

    .filter-pills-container .filter-nav {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        background: #000 !important;
        color: #ECD812 !important;
        border: none !important;
        width: 34px !important;
        height: 34px !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
        display: none;
        /* Hidden by default, script will show if needed */
    }

    .filter-pills-container .filter-nav.visible {
        display: flex !important;
    }

    .filter-pills-container .filter-nav.prev {
        left: -16px !important;
    }

    .filter-pills-container .filter-nav.next {
        right: -16px !important;
    }

    /* Overlay behind sidebar */
    .mobile-sidebar-overlay {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        height: 100dvh;
        background: rgba(0, 0, 0, 0.5);
        z-index: 1040;
        opacity: 0;
        pointer-events: none;
        transition: 0.4s ease;
    }

    body.menu-open .mobile-sidebar-overlay {
        opacity: 1;
        pointer-events: auto;
    }

    .sidebar-header {
        padding: 30px 60px 30px 20px;
        /* Specific top/right padding requested */
        flex-shrink: 0;
    }

    .custom-logo-link {
        display: block;
        max-width: 180px;
        margin-bottom: 10px;
    }

    .custom-logo-link img {
        width: 100%;
        height: auto;
    }

    .user-info .user-status {
        display: flex !important;
    }

    .status-dot {
        width: 8px !important;
        height: 8px !important;
        flex-shrink: 0 !important;
    }

    .site-sidebar .main-navigation {
        padding: 10px 20px !important;
        display: flex;
        flex-direction: column;
        flex: 1;
        overflow: hidden;
        /* Menu container doesn't scroll, its children will */
    }

    .site-sidebar .custom-nav-menu {
        gap: 5px !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow-y: auto;
        /* Only the list scrolls */
        flex: 1;
        scrollbar-width: none;
    }

    .site-sidebar .custom-nav-menu::-webkit-scrollbar {
        display: none;
    }

    .site-sidebar .main-navigation li a {
        padding: 8px 16px !important;
        font-size: 17px !important;
        border-radius: 10px !important;
    }

    .sidebar-bottom-promo {
        margin-top: 10px;
        /* Reduced margin to keep menu visible */
        padding: 0 !important;
        background: none !important;
        border: none !important;
        flex-shrink: 0;
    }

    /* Kaia CTA Mobile - Matching Desktop exactly but with tighter spacing */
    .kaia-sidebar-cta {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0;
        text-decoration: none;
    }

    .kaia-avatar-wrapper {
        width: 90px;
        /* Slightly smaller for mobile if needed, or 100px for exact match */
        height: 90px;
        border-radius: 50%;
        overflow: hidden;
        background: #000;
        border: 3px solid #000;
        box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1);
        position: relative;
        z-index: 1;
        flex-shrink: 0;
    }

    .kaia-avatar-wrapper video {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .kaia-pill {
        background: #000 !important;
        color: #ECD812 !important;
        font-weight: 800;
        font-size: 13px;
        padding: 2px 16px;
        border-radius: 50px;
        text-align: center;
        white-space: nowrap;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
        margin-top: -5px;
        /* Subtle overlap like desktop */
        position: relative;
        z-index: 2;
        border: 3px solid #000 !important;
    }

    /* --- Content Typography --- */
    .main-text-content {
        padding: 0 !important;
        font-size: 16px;
    }

    /* Alignment adjustments for Cultura Sirope and other Singles */
    .single-cultura_sirope .tool-title-meta,
    .single-cultura_sirope .cpt-pill-wrap {
        text-align: left !important;
        justify-content: flex-start !important;
    }

    .single-cultura_sirope h1.entry-title {
        text-align: left !important;
    }

    .single-layout {
        padding: 40px 20px !important;
    }

    .main-text-content h2 {
        font-size: 28px;
    }

    .main-text-content h3 {
        font-size: 24px;
    }

    .main-text-content figure {
        margin: 2.5em 0;
    }

    .main-text-content blockquote {
        padding: 16px !important;
    }

    .main-text-content blockquote p {
        font-size: 18px !important;
        line-height: 1.6 !important;
        margin: 0 !important;
        /* Optional: reset margin to ensure padding looks correct */
    }
}


/* ==========================================================================
   BREAKPOINT: 782px (WP Admin Bar)
   ========================================================================== */
@media screen and (max-width: 782px) {
    .admin-bar .site-sidebar {
        top: 46px;
        height: calc(100vh - 46px);
    }

    .admin-bar .universal-toggle {
        top: 66px !important;
    }

    .admin-bar .mobile-sidebar-overlay {
        top: 46px;
    }
}


/* ==========================================================================
   BREAKPOINT: 768px
   ========================================================================== */
@media (max-width: 768px) {

    /* --- Tool Single --- */
    .tool-header-flex {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }

    .custom-logo-link {
        display: flex;
    }

    .entry-header-actions {
        width: 100%;
        justify-content: flex-start;
        border-top: 1px solid #E5E9F0;
        padding-top: 20px;
        flex-direction: column;
    }

    .entry-header-actions>div,
    .entry-header-actions .favorite-button-container {
        width: 100%;
    }

    /* --- Single Favorite Button --- */
    .single-layout article>.favorite-button-container {
        top: 15px;
        right: 15px;
    }

    .single-layout article>.favorite-button-container .favorite-label {
        width: 38px;
        height: 38px;
    }

    .entry-header-actions .author-actions {
        flex-direction: column;
    }

    .entry-header-actions .btn-action-ghost {
        width: 100%;
        justify-content: center;
    }

    .tool-logo-wrap {
        width: 80px;
        height: 80px;
        min-width: 80px;
    }

    .archive-layout,
    .single-layout {
        padding: 24px 16px;
        border-radius: 12px;
    }

    .bento-card {
        padding: 15px;
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .dashboard-topbar {
        margin-bottom: 24px;
    }

    .topbar-welcome h1 {
        font-size: 1.5rem;
        margin-bottom: 15px;
    }

    .topbar-actions {
        width: 100%;
    }

    .topbar-actions .btn {
        flex: 1;
        text-align: center;
        padding: 10px 16px;
        font-size: 13px;
    }

    .tool-specs-bar {
        flex-direction: column;
    }

    .spec-tile {
        min-width: 100%;
    }

    .tool-primary-btn {
        min-width: 100%;
    }

    .dark-glass-code {
        padding: 40px 16px 16px 16px;
    }

    .dark-glass-code pre {
        font-size: 13px;
    }

    .caso-details-wrapper {
        padding: 20px 16px;
    }

    .bottom-cta-wrap {
        padding: 20px 16px;
        margin-top: 40px;
    }

    .tutorial-section iframe {
        border-radius: 12px;
    }

    .filter-group.filter-dropdown-group {
        gap: 16px;
        flex-direction: column;
        align-items: flex-start;
    }

    .archive-results-bar {
        flex-direction: column;
        gap: 10px;
        align-items: flex-start;
    }

    .btn-add-frontend {
        margin-bottom: 20px;
    }

    .posts-pagination {
        margin-top: 30px;
    }

    .posts-pagination .nav-links {
        flex-wrap: wrap;
        justify-content: center;
    }

    .card-body {
        padding: 16px;
    }

    .card-body h3 {
        font-size: 16px;
    }

    .moodboard-preview-box {
        flex-direction: column;
        gap: 12px;
        align-items: flex-start;
    }

    .list-header,
    .list-item {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .list-header {
        display: none;
    }

    .kpi-item {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .icon-grid-style {
        grid-template-columns: 1fr;
    }

    .prompt-list-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .prompt-list-item .item-tag {
        align-self: flex-start;
    }

    .tool-card-title {
        font-size: 18px;
    }

    .tool-archive-card {
        padding: 20px;
    }

    .sidebar-bottom-promo {
        padding: 16px;
    }

    /* --- Post Grid --- */
    .post-grid {
        grid-template-columns: 1fr;
    }

    .tool-archive-grid {
        grid-template-columns: 1fr !important;
    }

    /* --- Submission Form --- */
    .submission-card .card-content {
        padding: 30px 20px;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    /* --- Entry Top Bar --- */
    .entry-top-bar {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
    }

    /* --- Profiles Grid & Page Title --- */
    .profiles-grid {
        grid-template-columns: 1fr;
    }

    .page-title {
        font-size: 36px !important;
    }
}


/* ==========================================================================
   BREAKPOINT: 768px (min-width — Desktop Up)
   ========================================================================== */
@media (min-width: 768px) {
    .caso-full-grid {
        grid-template-columns: 1fr 1fr;
    }
}


/* ==========================================================================
   BREAKPOINT: 640px
   ========================================================================== */
@media (max-width: 768px) {

    .masonry-style,
    .card-cases .masonry-style {
        column-count: 1;
    }

    .team-members-grid {
        grid-template-columns: 1fr;
    }

    /* --- Favorites Account Mobile --- */
    .favorite-item {
        padding: 10px 12px;
    }

    .favorite-item-link {
        display: grid;
        grid-template-columns: 32px 1fr;
        grid-template-areas:
            "fav-icon fav-label"
            "fav-icon fav-title";
        gap: 4px 12px;
        align-items: center;
    }

    .favorite-item .cpt-icon-box {
        grid-area: fav-icon;
        width: 32px;
        height: 32px;
        align-self: start;
        margin-top: 2px;
    }

    .favorite-item .cpt-icon-box svg {
        width: 16px;
        height: 16px;
    }

    .favorite-item .cpt-label {
        grid-area: fav-label;
        font-size: 9px;
        padding: 4px 8px;
        justify-self: start;
        align-self: end;
    }

    .favorite-item .post-title {
        grid-area: fav-title;
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        line-clamp: 2;
        font-size: 14px;
        line-height: 1.3;
        align-self: start;
    }
}


/* ==========================================================================
   BREAKPOINT: 600px
   ========================================================================== */
@media (max-width: 600px) {
    .icon-grid-style {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}


/* ==========================================================================
   BREAKPOINT: 480px
   ========================================================================== */
@media (max-width: 480px) {
    .login-wall-card {
        padding: 40px 25px;
    }
}