@font-face {
    font-family: 'Romelio Sans';
    src: url('/assets/fonts/romelio_sans/Romelio.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

:root{
    --nav-font-size: 27px;
    --nav-letter-spacing: 0.02em;
    --nav-word-spacing: 0.12em;
    --nav-gap: 22px;
    --nav-padding-y: 8px;
    --nav-padding-x: 18px;
    --accent: #000;
}

/* ============================
    HEADER
============================ */
.header {
    position: relative;
    width: 100%;
    background: #fff;
    border-bottom: 1px solid #eee;
    z-index: 2000;
}

.header .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 12px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* ============================
    NAV ITEM
============================ */
.nav {
    display: flex;
    gap: 25px;
    
}

.nav-item {
    text-decoration: none;
    color: var(--accent);
    font-size: var(--nav-font-size);
    letter-spacing: var(--nav-letter-spacing);
    word-spacing: var(--nav-word-spacing);
    padding: var(--nav-padding-y) var(--nav-padding-x);
    border-radius: 999px;    
    border: 2px solid transparent;
    /* cambioooo */
    transition: background .25s ease, 
                border-color .25s ease,
                box-shadow .28s ease;
}

/* Hover y active SUAVES */
.nav-item:hover,
.nav-item.active {
    background: #fff;
    border-color: var(--accent);
    box-shadow:
        0 0 0 2px rgba(0,0,0,0.05),
        0 0 0 4px rgba(0,0,0,0.03) inset;
}

/* ============================
    MOBILE MENU
============================ */
.menu-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

.menu-icon {
    width: 30px;
    transition: transform .25s ease;
}

/* Cuando se abre → girar 45° para indicar cierre (X) */
.menu-btn.active .menu-icon {
    transform: rotate(90deg) scale(0.9);
}
/* LOGO */
.logo img {
    height: 120px;
     transition: transform .25s ease;
}
@media (min-width: 769px) {


    .menu-btn {
        display: none;
    }

    .nav {
        position: static;
        background: none;
        box-shadow: none;
    }

    .nav-item {
        font-size: 27px;
        padding: 8px 12px;
        border-radius: 999px;
    }

    .nav-item:hover,
    .nav-item.active {
        background: #fff;
        border: 2px solid #8f0303;
    }
}
@media (max-width: 1040px) and (min-width: 769px) {

    :root {
        --nav-font-size: 24px;
        --nav-letter-spacing: 0.015em;
        --nav-word-spacing: 0.08em;
        --nav-gap: 14px;
        --nav-padding-y: 6px;
        --nav-padding-x: 12px;
    }

    .nav {
        gap: var(--nav-gap);
    }

    .nav-item {
        font-size: var(--nav-font-size);
        padding: var(--nav-padding-y) var(--nav-padding-x);
    }

}

@media (max-width: 768px) {

    .header .container {
        flex-direction: row-reverse;
padding: 10px 16px;
    }
.nav {
        position: absolute;
        top: 100%;
        right:auto ;            /* 🔥 clave */
        left: 0.2px;
        width: auto;            /* 🔥 clave */
        min-width: 220px;
        max-width: 280px;

        background: #fff;
        border: 1px solid #eee;
        border-radius: 14px;
        box-shadow: 0 12px 30px rgba(0,0,0,.08);

        overflow: hidden;
        max-height: 0;
        opacity: 0;
        pointer-events: none;

        display: flex;
        flex-direction: column;
        gap: 6px;

        padding: 0;
        transition: max-height .35s ease, opacity .25s ease;
        z-index: 1500;
    }

.nav-item {
        width: 100%;
        text-align: left;
        font-size: 19px;
        padding: 12px 16px;
        position: relative;
        padding-left: 44px; /* espacio para icono */
         border: none;
        box-shadow: none;
        background: transparent;
    }
.nav-item::before {
        content: "";
        position: absolute;
        left: 16px;
        top: 50%;
        transform: translateY(-50%);
        width: 15px;
        height: 14px;
        background: url("/linea_grafica/public/assets/img/header/drop.png") no-repeat center;
        background-size: contain;
        opacity: 0.5;
        transition: opacity .25s ease, transform .25s ease;
    }

    /* Estado activo → icono distinto */
    .nav-item.active::before {
        background-image: url("/linea_grafica/public/assets/img/header/drop_active.png");
        opacity: 1;
        transform: translateY(-50%) scale(1.15);
    }
    .nav-item:hover,
    .nav-item.active {
        border: none;
        box-shadow: none;
        background: rgba(0,0,0,0.03);
    }
   .nav.open {
        max-height: 400px;
        opacity: 1;
        pointer-events: auto;
        padding: 10px;
    }


    .logo img {
        height: 80px;
    }
}




