/* =====================================================================
   sd-keypro-navbar — KeyPro.hu header navbar (v1.0.0)
   White pill bar + sliding grey highlight + product mega-menu + info/
   account dropdowns + mobile drawer. Brand-tokenized, pure CSS styling;
   the sliding pill geometry + hover-intent live in navbar.js.
   ===================================================================== */

.kpn-wrap { width: 100%; }

.kpn {
    --brand:        #127d3d;
    --brand-hover:  #157a42;
    --pill-bg:      rgba(20, 20, 20, .06);
    --ink:          #151515;
    --muted:        #5f6b64;
    --mut2:         #8a938c;
    --surf:         #ffffff;
    --bd:           #e3e6e3;
    --row-hover:    rgba(18, 125, 61, .06);
    --tile-bg:      rgba(18, 125, 61, .12);
    --slide-dur:    .3s;
    --easing:       cubic-bezier(.22, .61, .36, 1);

    position: relative;
    width: 100%;
    display: flex;
    justify-content: center;
    font-family: "Segoe UI", "Open Sans", system-ui, -apple-system, sans-serif;
}
.kpn *, .kpn *::before, .kpn *::after { box-sizing: border-box; }
.kpn-ico { flex: 0 0 auto; }

/* ---------- Desktop pill bar ---------- */
.kpn__bar {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px;
    background: var(--surf);
    border: 1px solid var(--bd);
    border-radius: 999px;
    box-shadow: 0 3px 8px rgba(130, 130, 130, .30);
}
.kpn__pill {
    position: absolute;
    left: 0; top: 0;
    z-index: 0;
    width: 0; height: 0;
    border-radius: 999px;
    background: var(--pill-bg);
    opacity: 0;
    pointer-events: none;
    transition: transform var(--slide-dur) var(--easing),
                width var(--slide-dur) var(--easing),
                height var(--slide-dur) var(--easing),
                opacity var(--slide-dur) var(--easing);
}
.kpn__item {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin: 0;
    padding: 10px 17px;
    border-radius: 999px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    color: var(--brand);
    text-decoration: none;
    /* !important beats the site-wide Customizer rule button{background:#127d3d!important}
       so the trigger buttons render as plain items, not green-filled pills. */
    background: transparent !important;
    border: 0;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    white-space: nowrap;
    transition: color var(--slide-dur) var(--easing);
}
/* The highlighted item (hover, open trigger, or current page) stays brand
   green — never flips to black when the pointer leaves. !important keeps it
   green over the theme's link colors. */
.kpn__item:hover,
.kpn__item.is-active,
.kpn__item.is-current { color: var(--brand) !important; }

/* The masthead is .navbar-dark, so its descendants inherit white text; the
   <button> triggers picked that up and vanished on the transparent bar. Force
   every bar item green with a strong, un-inherited selector. The theme also
   puts a border-radius + drop-shadow on <button>, framing the dropdown
   triggers (Termékek / Információk / Saját fiók) — strip that so they look
   identical to the plain <a> items. */
nav.kpn .kpn__bar .kpn__item,
nav.kpn .kpn__bar .kpn__item:hover,
nav.kpn .kpn__bar .kpn__item.is-active,
nav.kpn .kpn__bar .kpn__item.is-current {
    color: var(--brand) !important;
    box-shadow: none !important;
    border: 0 !important;
}
.kpn__item:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }
.kpn__trigger .kpn-ico { font-size: 16px; transition: transform var(--slide-dur) var(--easing); }
.kpn__trigger[aria-expanded="true"] .kpn-ico { transform: rotate(180deg); }

/* ---------- Panels: shared reveal ---------- */
.kpn__mega,
.kpn__drop {
    position: absolute;
    z-index: 50;
    left: 0; top: 100%;
    background: var(--surf);
    border: 1px solid var(--bd);
    border-radius: 16px;
    box-shadow: none;
    visibility: hidden;
    opacity: 0;
    transform: translateY(6px) scale(.98);
    transform-origin: top center;
    pointer-events: none;
    transition: opacity var(--slide-dur) var(--easing),
                transform var(--slide-dur) var(--easing),
                visibility var(--slide-dur);
}
.kpn__mega.open,
.kpn__drop.open {
    visibility: visible;
    opacity: 1;
    transform: none;
    pointer-events: auto;
}
/* Invisible hover bridge over the gap between the bar and the panel: extends
   the panel's hoverable area up across the ~10px gap so a slow cursor path
   from the trigger never crosses a dead zone that fires the close timer.
   Only live while the panel is open (closed panels are pointer-events:none). */
.kpn__mega::before,
.kpn__drop::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -18px;      /* spans the full trigger→panel gap (bar padding + 10px) */
    height: 18px;
}

/* ---------- Mega-menu (products): drill-down stage + 2-col rows ---------- */
.kpn__mega {
    width: min(560px, 94vw);
    padding: 10px;
}
/* Drill stage: root view + one view per family. JS adds .is-ready, which
   absolutely-stacks the views and drives the height so they cross-slide.
   Without JS the views simply stack (still usable). */
.kpn__stage { position: relative; }
.kpn__stage.is-ready { overflow: hidden; transition: height .3s var(--easing); }
.kpn__stage.is-ready > .kpn__view {
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    opacity: 0;
    transform: translateX(28px);
    pointer-events: none;
    transition: opacity .28s var(--easing), transform .28s var(--easing);
}
.kpn__stage.is-ready > .kpn__view.is-active {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}
/* minmax(0, 1fr): a bare 1fr is minmax(auto, 1fr), whose auto min = content
   size — a long nowrap description then widens the column past the panel and
   overflows. Clamping the min to 0 lets the row shrink so the desc ellipsizes. */
.kpn__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 4px; }

/* Sub-view header: back / family name / view-all */
.kpn__subhead {
    display: flex;
    align-items: center;
    justify-content: flex-start;   /* back + name sit left, "Összes" pushed right */
    gap: 8px;
    padding: 0 6px 8px;
    margin-bottom: 6px;
    border-bottom: 1px solid var(--bd);
}
.kpn__back,
.kpn__suball {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 6px 8px;
    border-radius: 8px;
    font-family: inherit;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    transition: background var(--slide-dur) var(--easing), color var(--slide-dur) var(--easing);
}
.kpn__back { background: none; border: 0; color: var(--muted); }
.kpn__back:hover { color: var(--ink); background: var(--row-hover); }
.kpn__back .kpn-ico { font-size: 16px; }
.kpn__subtitle { font-size: 14px; font-weight: 500; color: var(--ink); }
.kpn__suball { color: var(--brand); margin-left: auto; }
.kpn__suball:hover { background: var(--row-hover); }
.kpn__suball .kpn-ico { font-size: 15px; }
.kpn__back:focus-visible,
.kpn__suball:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }

/* Sub-category rows: no icon tile, just title + chevron */
.kpn__row--sub { padding: 11px 12px; }
.kpn__row--sub .kpn__rowtitle { font-size: 13.5px; font-weight: 500; }

.kpn__row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 12px;
    text-decoration: none;
    /* <button> rows default to text-align:center (UA), which centered the
       title/description; force left so they match the <a> rows. */
    text-align: left;
    color: var(--ink);
    transition: background var(--slide-dur) var(--easing);
}
.kpn__row:hover { background: var(--row-hover); }
.kpn__row:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.kpn__tile {
    flex: 0 0 auto;
    width: 40px; height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--tile-bg);
    color: var(--brand);
    font-size: 21px;
}
.kpn__rowtext { display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; }
.kpn__rowtitle { font-size: 13.5px; font-weight: 500; line-height: 1.3; color: var(--ink); }
.kpn__rowdesc  { font-size: 12px; font-weight: 400; line-height: 1.35; color: var(--mut2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kpn__rowchev {
    margin-left: auto;
    color: var(--mut2);
    font-size: 16px;
    opacity: 0;
    transform: translateX(-4px);
    transition: opacity var(--slide-dur) var(--easing), transform var(--slide-dur) var(--easing);
}
.kpn__row:hover .kpn__rowchev,
.kpn__row:focus-visible .kpn__rowchev { opacity: 1; transform: none; }

/* ---------- List dropdowns (info / account) ---------- */
.kpn__drop {
    width: max(220px, 15rem);
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.kpn__link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border-radius: 10px;
    font-size: 13.5px;
    font-weight: 500;
    line-height: 1.3;
    color: var(--ink);
    text-decoration: none;
    transition: background var(--slide-dur) var(--easing);
}
.kpn__link:hover { background: var(--row-hover); }
.kpn__link:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.kpn__link .kpn-ico { font-size: 16px; color: var(--mut2); }
.kpn__link--sep { margin-top: 6px; padding-top: 12px; border-top: 1px solid var(--bd); }

/* ---------- Mobile burger + drawer ---------- */
.kpn__burger {
    display: none;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 999px;
    background: var(--surf);
    border: 1px solid var(--bd);
    box-shadow: 0 3px 8px rgba(130, 130, 130, .30);
    font-family: inherit;
    font-size: 15px;
    font-weight: 500;
    color: var(--ink);
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
}
.kpn__burger .kpn-ico { font-size: 20px; }
.kpn__drawer { display: none; }

@media (max-width: 991px) {
    .kpn__bar { display: none; }
    .kpn__mega, .kpn__drop { display: none !important; }
    .kpn__burger { display: inline-flex; }
    .kpn__drawer {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 100000;
        background: var(--surf);
        transform: translateX(100%);
        transition: transform .3s var(--easing);
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }
    .kpn__drawer.open { transform: translateX(0); }
}
.kpn__drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 20px;
    border-bottom: 1px solid var(--bd);
    position: sticky;
    top: 0;
    background: var(--surf);
}
.kpn__drawer-title { font-size: 17px; font-weight: 500; color: var(--ink); }
.kpn__drawer-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px; height: 40px;
    border-radius: 10px;
    background: none;
    border: 1px solid var(--bd);
    color: var(--ink);
    font-size: 22px;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
}
.kpn__m-link {
    display: block;
    padding: 15px 20px;
    border-bottom: 1px solid var(--bd);
    font-size: 16px;
    font-weight: 500;
    color: var(--ink);
    text-decoration: none;
}
.kpn__acc { border-bottom: 1px solid var(--bd); }
.kpn__acc-sum {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 20px;
    font-size: 16px;
    font-weight: 500;
    color: var(--ink);
    cursor: pointer;
    list-style: none;
}
.kpn__acc-sum::-webkit-details-marker { display: none; }
.kpn__acc-sum .kpn-ico { font-size: 20px; color: var(--mut2); transition: transform .25s var(--easing); }
.kpn__acc[open] .kpn-ico { transform: rotate(180deg); }
.kpn__acc-body { padding: 4px 0 12px; background: #f7f9f8; }
.kpn__m-sub {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px 12px 28px;
    font-size: 15px;
    font-weight: 400;
    color: var(--muted);
    text-decoration: none;
}
.kpn__m-sub:hover { color: var(--ink); }
.kpn__m-ico { display: inline-flex; color: var(--brand); font-size: 18px; }
body.kpn-drawer-lock { overflow: hidden; }

/* ---------- Theme-bleed guards ----------
   The masthead is .navbar-dark (descendants inherit white text) and the
   Customizer forces button{background:#127d3d!important} + a drop-shadow, so
   the <button> drill rows rendered as green pills with white text. Re-assert
   the panels' own colors/background with strong selectors. */
nav.kpn .kpn__mega .kpn__row,
nav.kpn .kpn__mega .kpn__back {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}
nav.kpn .kpn__mega .kpn__row:hover,
nav.kpn .kpn__mega .kpn__back:hover { background: var(--row-hover) !important; }
nav.kpn .kpn__mega .kpn__rowtitle,
nav.kpn .kpn__mega .kpn__subtitle { color: var(--ink) !important; }
nav.kpn .kpn__mega .kpn__rowdesc,
nav.kpn .kpn__mega .kpn__rowchev { color: var(--mut2) !important; }
nav.kpn .kpn__mega .kpn__back { color: var(--muted) !important; }
nav.kpn .kpn__mega .kpn__back:hover { color: var(--ink) !important; }
nav.kpn .kpn__mega .kpn__tile { color: var(--brand) !important; background: var(--tile-bg) !important; }
nav.kpn .kpn__mega .kpn__suball { color: var(--brand) !important; }
nav.kpn .kpn__drop .kpn__link { color: var(--ink) !important; background: transparent !important; }
nav.kpn .kpn__drop .kpn__link:hover { background: var(--row-hover) !important; }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
    .kpn__pill, .kpn__item, .kpn__trigger .kpn-ico,
    .kpn__mega, .kpn__drop, .kpn__row, .kpn__rowchev, .kpn__link,
    .kpn__stage, .kpn__view, .kpn__back, .kpn__suball,
    .kpn__drawer, .kpn__acc-sum .kpn-ico { transition: none !important; }
}
