/* ==================================================
   HEADER V2.1 · arquitectura limpia y editable
   Archivo único para diseño y comportamiento visual
   ================================================== */

.site-header.hs-site-header{
    position: sticky;
    top: 0;
    z-index: 999;
    background: rgba(7, 7, 7, 0.94);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(198, 168, 90, 0.14);
}

.site-header.hs-site-header .ast-primary-header-bar{
    background: transparent;
}

.site-header.hs-site-header .ast-container{
    width: min(100% - 28px, 1440px);
}

.hs-header-shell{
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 22px;
    min-height: 84px;
}

.hs-header-brand,
.hs-header-tools,
.hs-header-panel,
.hs-header-nav{
    min-width: 0;
}

.site-header .site-branding,
.site-header .site-branding .custom-logo-link{
    display: inline-flex;
    align-items: center;
}

.site-header .site-branding img,
.site-header .custom-logo{
    display: block;
    width: auto;
    max-height: 56px;
}

.site-header .site-title,
.site-header .site-description{
    margin: 0;
}

.hs-header-tools{
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
}

.hs-header-panel{
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    width: 100%;
}

.site-header .main-header-menu{
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: nowrap;
    gap: 10px;
    min-width: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.site-header .main-header-menu > .menu-item{
    position: relative;
    display: flex;
    align-items: center;
    margin: 0;
    list-style: none;
}

.site-header .main-header-menu > .menu-item > a,
.hs-header-account,
.hs-header-cart{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border: 1px solid rgba(198, 168, 90, 0.26);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255,255,255,0.018), rgba(255,255,255,0.01));
    color: #f6f0e3;
    font-size: 0.96rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.015);
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.site-header .main-header-menu > .menu-item.current-menu-item > a,
.site-header .main-header-menu > .menu-item.current_page_item > a,
.site-header .main-header-menu > .menu-item > a:hover,
.site-header .main-header-menu > .menu-item > a:focus-visible,
.hs-header-account:hover,
.hs-header-account:focus-visible,
.hs-header-cart:hover,
.hs-header-cart:focus-visible{
    color: var(--luxe-gold-soft);
    border-color: rgba(198, 168, 90, 0.52);
    background: linear-gradient(180deg, rgba(200,161,90,0.09), rgba(255,255,255,0.015));
    transform: translateY(-1px);
}

.site-header .main-header-menu > .menu-item.menu-item-has-children > a{
    padding-right: 18px;
}

.site-header .sub-menu{
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 220px;
    margin: 0;
    padding: 10px;
    list-style: none;
    border: 1px solid rgba(198,168,90,.16);
    border-radius: 16px;
    background: rgba(7,7,7,.98);
    box-shadow: 0 20px 44px rgba(0,0,0,.38);
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
    z-index: 30;
}

.site-header .menu-item:hover > .sub-menu,
.site-header .menu-item:focus-within > .sub-menu{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

.site-header .sub-menu a{
    display: flex;
    align-items: center;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 10px;
    color: #f4eedf;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
}

.site-header .sub-menu a:hover,
.site-header .sub-menu a:focus-visible{
    background: rgba(200,161,90,0.08);
    color: var(--luxe-gold-soft);
}

.hs-header-actions{
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.hs-header-cart{
    gap: 10px;
}

.hs-cart-count{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(198,168,90,0.16);
    color: var(--luxe-gold);
    font-size: 0.78rem;
    font-weight: 800;
}

.hs-header-toggle{
    display: none;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    padding: 0;
    border: 1px solid rgba(198, 168, 90, 0.32);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(200,161,90,0.10), rgba(255,255,255,0.02));
    color: var(--luxe-gold);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.hs-header-toggle:hover,
.hs-header-toggle:focus-visible{
    border-color: rgba(198, 168, 90, 0.52);
    background: linear-gradient(180deg, rgba(200,161,90,0.16), rgba(255,255,255,0.03));
    transform: translateY(-1px);
}

.hs-header-toggle span{
    position: absolute;
    width: 20px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.hs-header-toggle span:nth-child(1){ transform: translateY(-6px); }
.hs-header-toggle span:nth-child(2){ transform: translateY(0); }
.hs-header-toggle span:nth-child(3){ transform: translateY(6px); }

.hs-header-toggle[aria-expanded="true"] span:nth-child(1){ transform: rotate(45deg); }
.hs-header-toggle[aria-expanded="true"] span:nth-child(2){ opacity: 0; }
.hs-header-toggle[aria-expanded="true"] span:nth-child(3){ transform: rotate(-45deg); }

@media (max-width: 1220px){
    .site-header .main-header-menu{
        gap: 8px;
    }

    .site-header .main-header-menu > .menu-item > a,
    .hs-header-account,
    .hs-header-cart{
        min-height: 46px;
        padding: 0 16px;
        font-size: 0.90rem;
    }
}

@media (max-width: 1080px){
    .site-header .main-header-menu > .menu-item > a,
    .hs-header-account,
    .hs-header-cart{
        padding: 0 14px;
        font-size: 0.84rem;
    }

    .hs-header-actions{
        gap: 8px;
    }
}

@media (max-width: 921px){
    .site-header.hs-site-header .ast-container{
        width: min(100% - 20px, 1440px);
    }

    .hs-header-shell{
        grid-template-columns: minmax(0, 1fr) auto;
        min-height: 74px;
        gap: 12px;
    }

    .site-header .site-branding img,
    .site-header .custom-logo{
        max-height: 44px;
    }

    .hs-header-toggle{
        position: relative;
        display: inline-flex;
    }

    .hs-header-panel{
        position: absolute;
        top: calc(100% + 10px);
        left: 0;
        right: 0;
        display: none;
        grid-template-columns: 1fr;
        gap: 16px;
        padding: 16px;
        border: 1px solid rgba(198,168,90,.18);
        border-radius: 18px;
        background: rgba(7,7,7,.98);
        box-shadow: 0 24px 56px rgba(0,0,0,.42);
        z-index: 40;
        overflow: hidden;
    }

    .hs-header-panel.is-open{
        display: grid;
    }

    .hs-header-nav,
    .hs-header-actions{
        width: 100%;
    }

    .site-header .main-header-menu{
        display: grid;
        justify-content: stretch;
        gap: 10px;
    }

    .site-header .main-header-menu > .menu-item{
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: stretch;
    }

    .site-header .main-header-menu > .menu-item > a{
        justify-content: flex-start;
        width: 100%;
        min-height: 48px;
        padding: 0 14px;
        border-radius: 12px;
    }

    .site-header .sub-menu{
        position: static;
        min-width: 0;
        margin-top: 8px;
        padding: 8px;
        border-radius: 12px;
        opacity: 1;
        visibility: visible;
        transform: none;
        pointer-events: auto;
        display: none;
        box-shadow: none;
    }

    .site-header .menu-item:hover > .sub-menu,
    .site-header .menu-item:focus-within > .sub-menu{
        display: none;
    }

    .site-header .menu-item.is-open > .sub-menu{
        display: block;
        grid-column: 1 / -1;
    }

    .hs-header-actions{
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .hs-header-account,
    .hs-header-cart{
        width: 100%;
        min-height: 48px;
        border-radius: 12px;
    }

    body.hs-mobile-menu-open{
        overflow: hidden;
    }
}

@media (max-width: 520px){
    .site-header.hs-site-header .ast-container{
        width: min(100% - 16px, 1440px);
    }

    .hs-header-shell{
        min-height: 70px;
    }

    .site-header .site-branding img,
    .site-header .custom-logo{
        max-height: 38px;
    }

    .hs-header-panel{
        left: 0;
        right: 0;
        top: calc(100% + 8px);
        padding: 14px;
        border-radius: 16px;
    }

    .hs-header-toggle{
        width: 46px;
        height: 46px;
        border-radius: 12px;
    }
}


/* ==================================================
   HEADER V2.2 · contención, botones y logo
   ================================================== */

.hs-header-shell{
    grid-template-columns: minmax(200px, 250px) minmax(0, 1fr);
}

.hs-header-brand{
    min-width: 0;
    max-width: 250px;
}

.site-header .site-branding,
.site-header .site-branding .custom-logo-link{
    width: 100%;
    max-width: 100%;
}

.site-header .site-branding img,
.site-header .custom-logo{
    max-width: 100%;
    height: auto;
    object-fit: contain;
}

.site-header .main-header-menu > .menu-item > a,
.hs-header-account,
.hs-header-cart{
    min-height: 50px;
    border-radius: 10px;
}

.hs-header-toggle{
    border-radius: 10px;
    color: #c6a85a;
}

.hs-header-toggle:hover,
.hs-header-toggle:focus-visible{
    color: #d3b369;
}

@media (max-width: 1320px){
    .hs-header-shell{
        grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
        gap: 16px;
    }

    .hs-header-brand{
        max-width: 220px;
    }

    .site-header .main-header-menu{
        gap: 8px;
    }

    .site-header .main-header-menu > .menu-item > a,
    .hs-header-account,
    .hs-header-cart{
        min-height: 48px;
        padding: 0 14px;
        font-size: 0.9rem;
        border-radius: 10px;
    }
}

@media (max-width: 1080px){
    .hs-header-shell{
        grid-template-columns: minmax(170px, 200px) minmax(0, 1fr);
    }

    .hs-header-brand{
        max-width: 200px;
    }

    .site-header .main-header-menu > .menu-item > a,
    .hs-header-account,
    .hs-header-cart{
        padding: 0 12px;
        font-size: 0.84rem;
    }
}

@media (max-width: 921px){
    .hs-header-shell{
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .hs-header-brand{
        max-width: 180px;
    }

    .hs-header-panel{
        border-radius: 16px;
    }

    .site-header .main-header-menu > .menu-item > a,
    .hs-header-account,
    .hs-header-cart,
    .hs-header-toggle{
        border-radius: 10px;
    }
}

@media (max-width: 520px){
    .hs-header-brand{
        max-width: 156px;
    }
}



/* === Final 1.1.1 header search ====================================== */
.hs-header-panel{
    grid-template-columns:minmax(220px, 340px) minmax(0, 1fr) auto;
}
.hs-header-search{
    min-width:0;
}
.hs-header-search form,
.hs-header-search .woocommerce-product-search,
.hs-header-search .search-form{
    position:relative;
    display:block;
    margin:0;
}
.hs-header-search input[type="search"],
.hs-header-search .search-field{
    width:100%;
    min-height:48px;
    padding:0 18px;
    border:1px solid rgba(198,168,90,0.22);
    border-radius:12px;
    background:rgba(255,255,255,0.02);
    color:#f6f0e3;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.015);
}
.hs-header-search input[type="search"]::placeholder,
.hs-header-search .search-field::placeholder{
    color:rgba(246,240,227,0.56);
}
.hs-header-search input[type="search"]:focus,
.hs-header-search .search-field:focus{
    outline:none;
    border-color:rgba(198,168,90,0.44);
    box-shadow:0 0 0 3px rgba(198,168,90,0.10);
}
.hs-header-search button,
.hs-header-search .search-submit{
    display:none !important;
}
@media (max-width: 1220px){
    .hs-header-panel{
        grid-template-columns:minmax(180px, 280px) minmax(0,1fr) auto;
    }
}
@media (max-width: 980px){
    .hs-header-search{
        display:none;
    }
    .hs-header-panel{
        grid-template-columns:minmax(0,1fr) auto;
    }
}
