/* =====================================================================
   GRUPO ENFOQUE PERÚ — PORTADA estilo Conexa
   - Header transparente sobre el hero, que se vuelve sólido al hacer scroll
   - Hero = slider full-bleed (cityscape + mapa Perú) con flechas y autoplay
   Carga DESPUÉS de styles.css (gana por orden).
   ===================================================================== */

/* ---------------- HEADER OVERLAY (transparente → sólido) ---------------- */
.header {
    position: fixed; top: 0; left: 0; right: 0;
    background: transparent; box-shadow: none;
    transition: background .35s ease, box-shadow .35s ease, padding .35s ease;
}
.header .container { transition: padding .35s ease; }

/* Estado SÓLIDO (al hacer scroll o con el menú móvil abierto) */
.header.hdr-scrolled,
.header.menu-open { background: #fff; box-shadow: 0 2px 20px rgba(0,0,0,.08); }

/* En desktop, sobre el hero, los textos del menú van en blanco */
@media (min-width: 1181px) {
    .header:not(.hdr-scrolled) .nav-menu > li > a { color: #fff; }
    .header:not(.hdr-scrolled) .nav-menu > li > a:hover { color: var(--dorado); background: rgba(255,255,255,.12); }
    .header:not(.hdr-scrolled) .logo .brand { color: #fff; }
    .header:not(.hdr-scrolled) .logo .tagline { color: var(--dorado); }
}
/* El hamburguesa (móvil/tablet) blanco sobre el hero, navy al scrollear o con menú abierto */
.header:not(.hdr-scrolled):not(.menu-open) .menu-toggle { color: #fff; }
.header.hdr-scrolled .menu-toggle,
.header.menu-open .menu-toggle { color: var(--azul-navy); }
/* En móvil el logo blanco arriba; navy si scrollea o abre el menú */
@media (max-width: 1180px) {
    .header:not(.hdr-scrolled):not(.menu-open) .logo .brand { color: #fff; }
}

/* Compensar el header fijo en páginas internas (servicio.php) */
.svc-hero { padding-top: 120px !important; }

/* ---------------- SLIDER DE PORTADA ---------------- */
.portada {
    position: relative; height: 100vh; min-height: 620px; max-height: 920px;
    overflow: hidden; background: var(--azul-navy-oscuro);
}
.portada-slides { position: absolute; inset: 0; }
.portada-slide {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    opacity: 0; transform: scale(1.06);
    transition: opacity 1.1s ease, transform 6s ease;
    will-change: opacity, transform;
}
.portada-slide::before {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(100deg, rgba(8,42,69,.92) 0%, rgba(8,42,69,.62) 42%, rgba(8,42,69,.22) 78%, rgba(8,42,69,.30) 100%);
}
.portada-slide.is-active { opacity: 1; transform: scale(1); z-index: 1; }

.portada .container { position: relative; z-index: 3; height: 100%; display: flex; align-items: center; }
.portada-content { max-width: 700px; color: #fff; }
.portada-content .pre {
    display: inline-flex; align-items: center; gap: 9px;
    font-size: .82rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
    color: var(--dorado); margin-bottom: 18px;
}
.portada-content .pre::before { content: ""; width: 34px; height: 2px; background: var(--dorado); }
.portada-content h1 {
    font-size: clamp(2.1rem, 4.6vw, 4rem); line-height: 1.08; color: #fff; margin-bottom: 18px;
    text-shadow: 0 2px 30px rgba(0,0,0,.25);
}
.portada-content h1 span { color: var(--cian); }
.portada-content p {
    font-size: clamp(1rem, 1.5vw, 1.2rem); color: rgba(255,255,255,.9); margin-bottom: 30px; max-width: 560px;
}
.portada-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.portada-btn {
    display: inline-flex; align-items: center; gap: 11px;
    padding: 16px 34px; border-radius: 60px; font-weight: 700; font-size: .98rem;
    background: var(--naranja); color: #fff; border: 2px solid var(--naranja);
    transition: all .3s ease;
}
.portada-btn i { transition: transform .3s ease; }
.portada-btn:hover { background: var(--naranja-hover); border-color: var(--naranja-hover); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(232,101,42,.45); }
.portada-btn:hover i { transform: translateX(5px); }
.portada-btn.ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.7); }
.portada-btn.ghost:hover { background: #fff; color: var(--azul-navy); border-color: #fff; box-shadow: 0 12px 30px rgba(0,0,0,.25); }

/* Flechas (apiladas a la derecha, estilo conexa) */
.portada-arrow {
    position: absolute; right: 34px; z-index: 4;
    width: 54px; height: 54px; border-radius: 50%;
    background: rgba(255,255,255,.08); border: 1.5px solid rgba(255,255,255,.6);
    color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center;
    font-size: 1rem; transition: all .3s ease; backdrop-filter: blur(3px);
}
.portada-arrow:hover { background: #fff; color: var(--azul-navy); border-color: #fff; }
.portada-prev { top: calc(50% - 36px); }
.portada-next { top: calc(50% + 36px); }

/* Dots (abajo a la izquierda, alineados al contenido) */
.portada-dots { position: absolute; bottom: 38px; left: 0; right: 0; z-index: 4; }
.portada-dots .container { display: flex; gap: 10px; height: auto; }
.portada-dot {
    width: 36px; height: 4px; border-radius: 3px; border: none; padding: 0; cursor: pointer;
    background: rgba(255,255,255,.35); transition: all .3s ease;
}
.portada-dot.is-active { background: var(--dorado); width: 54px; }

/* ---------------- RESPONSIVE ---------------- */
@media (max-width: 768px) {
    .portada { height: auto; min-height: 82vh; }
    .portada .container { padding-top: 96px; padding-bottom: 84px; align-items: center; }
    .portada-content { text-align: left; }
    /* Menos texto en móvil: se oculta el párrafo largo y se compacta el título */
    .portada-content p { display: none; }
    .portada-content h1 { font-size: clamp(1.85rem, 7.4vw, 2.5rem); margin-bottom: 24px; }
    .portada-content .pre { margin-bottom: 14px; font-size: .72rem; letter-spacing: 1.5px; }
    .portada-arrow { width: 44px; height: 44px; right: 16px; font-size: .85rem; }
    .portada-prev { top: auto; bottom: 96px; }
    .portada-next { top: auto; bottom: 44px; }
    .portada-dots { bottom: 22px; }
    .portada-slide::before { background: linear-gradient(180deg, rgba(8,42,69,.78) 0%, rgba(8,42,69,.55) 50%, rgba(8,42,69,.8) 100%); }
}
@media (max-width: 480px) {
    .portada-btn { padding: 14px 26px; font-size: .92rem; }
    .portada-arrow { bottom: 90px; }
    .portada-next { bottom: 40px; }
}
