/**
 * Kolirys — Navigation globale (site public)
 */

:root {
    --kl-nav-h: 72px;
    --kl-nav-h-scrolled: 60px;
    --kl-nav-link-py: 11px;
    --kl-nav-link-px: 15px;
}

@keyframes kl-nav-cta-pulse {
    0%, 100% { box-shadow: 0 2px 12px rgba(31, 165, 108, 0.25); }
    50% { box-shadow: 0 6px 22px rgba(31, 165, 108, 0.42); }
}

@keyframes kl-nav-dropdown-in {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ── Barre fixe ── */
.kl-site-nav.main-nav {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1050;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0 !important;
    background: rgba(255, 255, 255, 0.78) !important;
    background-image: none !important;
    filter: none !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.4);
    backdrop-filter: blur(18px) saturate(1.4);
    border-bottom: 1px solid transparent;
    box-shadow: none;
    transition:
        background 0.35s var(--k-ease-out),
        border-color 0.35s var(--k-ease-out),
        box-shadow 0.35s var(--k-ease-out);
}

.kl-site-nav.main-nav.kl-nav--scrolled {
    background: rgba(255, 255, 255, 0.94) !important;
    border-bottom-color: var(--k-border-subtle);
    box-shadow: 0 4px 24px rgba(15, 47, 75, 0.07);
}

.kl-site-nav > .container {
    max-width: var(--k-container-wide);
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: var(--kl-nav-h);
    padding: 14px 20px;
    transition: min-height 0.35s var(--k-ease-out), padding 0.35s var(--k-ease-out);
}

.kl-site-nav.kl-nav--scrolled > .container {
    min-height: var(--kl-nav-h-scrolled);
    padding-top: 10px;
    padding-bottom: 10px;
}

/* ── Logo ── */
.kl-site-nav .navbar-brand {
    display: flex;
    align-items: center;
    margin-right: 28px;
    padding: 0;
    flex-shrink: 0;
}

.kl-site-nav .kl-nav__brand img {
    display: block;
    height: 32px;
    width: auto;
    transition: height 0.35s var(--k-ease-out);
}

.kl-site-nav.kl-nav--scrolled .kl-nav__brand img {
    height: 26px;
}

/* ── Liens principaux ── */
@media (min-width: 992px) {
    .kl-site-nav .navbar-collapse {
        flex-grow: 1;
        display: flex !important;
        align-items: center;
        justify-content: flex-end;
        flex-wrap: nowrap;
    }
}

.kl-site-nav .kl-nav__menu {
    display: flex;
    align-items: center;
    gap: 2px;
    margin-left: auto !important;
}

.kl-site-nav .kl-nav__menu > .nav-item > .nav-link {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 4px;
    color: var(--k-text-secondary) !important;
    font-size: 0.875rem;
    font-weight: var(--k-font-weight-medium);
    letter-spacing: 0;
    line-height: 1 !important;
    text-transform: none;
    padding: var(--kl-nav-link-py) var(--kl-nav-link-px) !important;
    border-radius: var(--k-radius-pill);
    position: relative;
    white-space: nowrap;
    transition:
        color 0.2s var(--k-ease-out),
        background 0.2s var(--k-ease-out);
}

.kl-site-nav .kl-nav__home .fa-home {
    font-size: 0.875rem;
    line-height: 1;
}

.kl-site-nav .kl-nav__menu > .nav-item > .nav-link::before {
    display: none !important;
    content: none !important;
}

.kl-site-nav .kl-nav__menu > .nav-item > .nav-link:hover {
    color: var(--k-brand-primary) !important;
    background: rgba(29, 95, 146, 0.07);
}

.kl-site-nav .kl-nav__menu > .nav-item.active > .nav-link {
    color: var(--k-brand-primary) !important;
    background: rgba(29, 95, 146, 0.1);
    font-weight: var(--k-font-weight-semibold);
}

.kl-site-nav .kl-nav__chevron {
    font-size: 0.55rem;
    margin-left: 5px;
    opacity: 0.55;
    transition: transform 0.2s var(--k-ease-out);
}

.kl-site-nav .nav-item-dropdown:hover .kl-nav__chevron {
    transform: rotate(180deg);
    opacity: 0.85;
}

/* Espace comptable */
.kl-site-nav .kl-nav__comptable .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8125rem !important;
}

.kl-site-nav .kl-nav__comptable .fa-star {
    color: var(--k-warning) !important;
    font-size: 0.72rem;
}

/* ── Zone actions (connexion + CTA) ── */
.kl-site-nav .kl-nav__actions {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: 10px;
    padding-left: 14px;
    border-left: 1px solid var(--k-border-subtle);
}

.kl-site-nav .kl-nav__login {
    color: var(--k-brand-primary) !important;
    font-size: 0.875rem;
    font-weight: var(--k-font-weight-semibold);
    padding: var(--kl-nav-link-py) 16px !important;
    border-radius: var(--k-radius-pill);
    white-space: nowrap;
    transition: background 0.2s var(--k-ease-out);
}

.kl-site-nav .kl-nav__login:hover {
    background: rgba(15, 47, 75, 0.06) !important;
    color: var(--k-brand-primary) !important;
}

.kl-site-nav .kl-nav__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--k-btn-cta-bg) !important;
    color: var(--k-text-on-brand) !important;
    font-size: 0.875rem;
    font-weight: var(--k-font-weight-semibold);
    padding: 9px 18px !important;
    border-radius: var(--k-radius-pill);
    white-space: nowrap;
    border: none;
    cursor: pointer;
    text-decoration: none;
    animation: kl-nav-cta-pulse 3.5s ease-in-out infinite;
    transition: background 0.2s var(--k-ease-out), transform 0.2s var(--k-ease-out);
}

.kl-site-nav .kl-nav__cta:hover {
    background: var(--k-btn-cta-hover) !important;
    color: var(--k-text-on-brand) !important;
    transform: translateY(-1px);
}

/* ── Dropdowns ── */
.kl-site-nav .nav-item-dropdown {
    position: relative;
}

/* Pont invisible lien → menu (évite la fermeture en diagonale) */
@media (min-width: 992px) {
    .kl-site-nav .nav-item-dropdown::before {
        content: '';
        position: absolute;
        left: -8px;
        right: -8px;
        top: 100%;
        height: 16px;
        z-index: 1099;
    }
}

.kl-site-nav .nav-link-dropdown-content {
    display: none !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: auto !important;
    width: auto !important;
    min-width: 260px;
    transform: none !important;
    z-index: 1100;
    background: var(--k-surface-card) !important;
    border: 1px solid var(--k-border-subtle);
    border-radius: var(--k-radius-md);
    box-shadow: var(--k-shadow-lg);
    padding: 10px 8px 8px;
    margin: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 0.15s var(--k-ease-out),
        visibility 0s linear 0.12s;
}

.kl-site-nav .nav-item-dropdown:hover > .nav-link-dropdown-content {
    display: block !important;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition-delay: 0s;
}

.kl-site-nav .kl-nav__dropdown--features > .nav-link-dropdown-content {
    min-width: 520px;
    display: none !important;
    grid-template-columns: 1fr 1fr;
    gap: 2px;
    padding: 10px;
}

.kl-site-nav .kl-nav__dropdown--features:hover > .nav-link-dropdown-content {
    display: grid !important;
}

.kl-site-nav .nav-link-dropdown-content a {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--k-text-primary);
    border: none;
    border-radius: var(--k-radius-sm);
    font-size: 0.8125rem;
    text-transform: none;
    font-weight: var(--k-font-weight-medium);
    padding: 9px 12px;
    transition: background 0.15s var(--k-ease-out), color 0.15s var(--k-ease-out);
}

.kl-site-nav .nav-link-dropdown-content a .fa,
.kl-site-nav .nav-link-dropdown-content a [class*="fa-"] {
    width: 18px;
    text-align: center;
    color: var(--k-brand-secondary);
    font-size: 0.8rem;
    flex-shrink: 0;
}

.kl-site-nav .nav-link-dropdown-content a:hover {
    background: var(--k-surface-muted) !important;
    color: var(--k-brand-secondary) !important;
    padding-left: 12px !important;
    border-bottom: none !important;
}

/* ── Bannière app mobile ── */
.kl-site-nav #downloadMobileApp {
    position: fixed;
    top: var(--kl-nav-h);
    left: 0;
    right: 0;
    z-index: 1049;
    background: var(--k-brand-primary) !important;
    border-radius: 0 !important;
    margin-bottom: 0 !important;
    font-size: 0.8125rem;
    padding: 8px 16px !important;
}

/* ── Toggle mobile ── */
.kl-site-nav .navbar-toggler {
    border: 1px solid var(--k-border-subtle);
    border-radius: var(--k-radius-sm);
    color: var(--k-brand-primary);
    padding: 6px 10px;
    font-size: 1.15rem;
    background: var(--k-surface-card);
    transition: background 0.2s var(--k-ease-out);
}

.kl-site-nav .navbar-toggler:hover {
    background: var(--k-surface-muted);
}

.kl-site-nav .navbar-toggler:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(29, 95, 146, 0.15);
}

/* ── Homepage : décalage hero ── */
.page-home .kl-hero {
    padding-top: calc(var(--kl-nav-h) + 52px);
}

body.kl-mobile-app-banner .page-home .kl-hero {
    padding-top: calc(var(--kl-nav-h) + 104px);
}

/* Fallback : décaler le hero sous la nav fixe (pages sans règle dédiée) */
body:not(.page-home):not(.page-agency-partner) .kl-wrap > .kl-hero:first-child {
    padding-top: calc(var(--kl-nav-h) + 48px);
}

/* ── Overrides legacy (custom_index.css) ── */
.kl-site-nav.navbar {
    box-shadow: none !important;
}

.kl-site-nav .nav-item-dropdown .nav-link-dropdown-content {
    top: auto !important;
    width: auto !important;
    box-shadow: var(--k-shadow-lg) !important;
}

/* ── Responsive ── */
@media (max-width: 991px) {
    :root {
        --kl-nav-h: 60px;
        --kl-nav-link-py: 12px;
        --kl-nav-link-px: 14px;
    }

  /* Bootstrap .navbar-expand-lg > .container force padding: 0 sur mobile */
    .kl-site-nav.navbar-expand-lg > .container {
        flex-wrap: nowrap;
        min-height: var(--kl-nav-h);
        padding-top: 10px !important;
        padding-bottom: 10px !important;
        padding-left: 24px !important;
        padding-right: 28px !important;
        position: relative;
    }

    .kl-site-nav .navbar-brand {
        margin-right: auto;
        margin-left: 0;
        max-width: calc(100% - 60px);
    }

    .kl-site-nav .kl-nav__brand img {
        height: 28px;
    }

    .kl-site-nav .navbar-toggler {
        flex-shrink: 0;
        margin-left: 8px;
        margin-right: 0;
    }

    /* Bannière « Téléchargez l'app » : masquée sur mobile */
    .kl-site-nav #downloadMobileApp {
        display: none !important;
    }

    .kl-site-nav .navbar-collapse {
        flex: none !important;
        width: 100%;
        display: none !important;
        height: auto !important;
        overflow: visible !important;
        transition: none !important;
    }

  /* Menu mobile : toggle JS (sans animation Bootstrap collapse) */
    .kl-site-nav .navbar-collapse.kl-nav-mobile--open {
        display: flex !important;
        flex-direction: column;
        position: fixed;
        top: var(--kl-nav-h);
        left: 0;
        right: 0;
        width: 100%;
        height: calc(100vh - var(--kl-nav-h));
        height: calc(100dvh - var(--kl-nav-h));
        max-height: none !important;
        min-height: 0 !important;
        z-index: 1045;
        background: rgba(255, 255, 255, 0.98);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        border-top: 1px solid var(--k-border-subtle);
        box-shadow: var(--k-shadow-md);
        padding: 12px 16px 24px;
        overflow-x: hidden;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    body.kl-mobile-app-banner .kl-site-nav .navbar-collapse.kl-nav-mobile--open {
        top: calc(var(--kl-nav-h) + 52px);
    }

    .kl-site-nav .kl-nav__menu {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: 4px;
        margin-left: 0 !important;
    }

    .kl-site-nav .kl-nav__menu > .nav-item {
        width: 100%;
    }

    .kl-site-nav .kl-nav__menu > .nav-item > .nav-link {
        width: 100%;
        justify-content: flex-start;
        padding: var(--kl-nav-link-py) var(--kl-nav-link-px) !important;
        border-radius: var(--k-radius-sm);
        font-size: 0.9375rem;
        text-transform: none !important;
    }

    .kl-site-nav .kl-nav__home {
        justify-content: flex-start;
        gap: 10px;
    }

    .kl-site-nav .kl-nav__home::after {
        content: 'Accueil';
        font-size: 0.9375rem;
        font-weight: var(--k-font-weight-medium);
    }

    .kl-site-nav .kl-nav__actions {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        margin-left: 0;
        padding-left: 0;
        border-left: none;
        border-top: 1px solid var(--k-border-subtle);
        margin-top: 12px;
        padding-top: 16px;
        gap: 8px;
    }

    .kl-site-nav .kl-nav__cta {
        width: 100%;
        text-align: center;
        padding: 13px 18px !important;
        animation: none;
    }

    .kl-site-nav .kl-nav__login {
        width: 100%;
        text-align: center;
        padding: var(--kl-nav-link-py) 16px !important;
    }

    /* Sous-menus : masqués sauf accordéon ouvert */
    .kl-site-nav .nav-link-dropdown-content {
        display: none !important;
        position: static !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: none !important;
        min-width: 0 !important;
        width: 100% !important;
        margin: 0 0 6px !important;
        padding: 6px !important;
        border-radius: var(--k-radius-sm) !important;
        border: 1px solid var(--k-border-subtle) !important;
        background: var(--k-surface-muted) !important;
        box-shadow: none !important;
    }

    .kl-site-nav .nav-item-dropdown:hover > .nav-link-dropdown-content,
    .kl-site-nav .kl-nav__dropdown--features:hover > .nav-link-dropdown-content {
        display: none !important;
    }

    .kl-site-nav .nav-item-dropdown.kl-nav__dropdown--open > .nav-link-dropdown-content {
        display: block !important;
    }

    .kl-site-nav .nav-item-dropdown.kl-nav__dropdown--open.kl-nav__dropdown--features > .nav-link-dropdown-content {
        display: grid !important;
        grid-template-columns: 1fr;
        gap: 2px;
    }

    .kl-site-nav .nav-link-dropdown-content a {
        color: var(--k-text-primary) !important;
        border-bottom: none !important;
        border-radius: var(--k-radius-sm);
        padding: 10px 12px !important;
        font-size: 0.875rem !important;
        text-transform: none !important;
        font-weight: var(--k-font-weight-medium) !important;
    }

    .kl-site-nav .nav-link-dropdown-content a:hover {
        background: var(--k-surface-card) !important;
        padding-left: 12px !important;
    }

    .kl-site-nav .nav-item-dropdown > .nav-link .kl-nav__chevron {
        margin-left: auto;
    }

    .kl-site-nav .nav-item-dropdown.kl-nav__dropdown--open > .nav-link .kl-nav__chevron {
        transform: rotate(180deg);
        opacity: 0.85;
    }
}

body.kl-nav-mobile-open {
    overflow: hidden;
}

body.kl-nav-mobile-open::before {
    content: '';
    position: fixed;
    inset: 0;
    top: var(--kl-nav-h);
    z-index: 1040;
    background: rgba(15, 47, 75, 0.4);
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .kl-site-nav .kl-nav__cta {
        animation: none;
    }
}

@media (max-width: 640px) {
    body:not(.page-home):not(.page-agency-partner) .kl-wrap > .kl-hero:first-child {
        padding-top: calc(var(--kl-nav-h) + 28px);
    }
}
