/* ============================================================
 * EDUTECH MEGA MENU (emm-)
 * Ізольований компонент — не впливає на існуючий хедер.
 * Всі класи з префіксом emm- щоб уникнути конфліктів.
 * ============================================================ */

/* ── CSS Custom Properties ── */
:root {
    /* 1. Dimensions */
    --emm-header-h: 80px;
    --emm-header-h-mob: 60px;
    --emm-sidebar-w: 250px;
    --emm-max-w: 1440px;
    --emm-radius: 8px;
    --emm-radius-sm: 6px;
    --emm-radius-lg: 10px;
    --emm-trigger-size: 40px;
    --emm-icon-size: 18px;
    --emm-thumb-size: 36px;
    --emm-hero-h: 180px;

    /* 2. Spacing */
    --emm-gap-xs: 4px;
    --emm-gap-sm: 8px;
    --emm-gap-md: 12px;
    --emm-gap-lg: 20px;
    --emm-gap-xl: 32px;
    --emm-pad-btn: 9px 18px;
    --emm-pad-item: 12px 20px;
    --emm-pad-content: 28px 36px;

    /* 3. Colors - Neutrals */
    --emm-clr-white: #ffffff;
    --emm-clr-black: #000000;
    --emm-clr-dark: #1a1a1a;
    --emm-clr-gray-dark: #333333;
    --emm-clr-gray: #444444;
    --emm-clr-gray-light: #666666;
    --emm-clr-gray-mute: #999999;
    --emm-clr-gray-line: #dddddd;
    
    /* 4. Backgrounds & Borders */
    --emm-bg-panel: #ffffff;
    --emm-bg-sidebar: #f8f8f8;
    --emm-bg-hover: #f0f0f0;
    --emm-bg-scrolled: #f0f0f0;
    --emm-bg-scrolled-hover: #e4e4e4;
    --emm-bg-active: #1a1a1a;
    --emm-border-light: #ebebeb;
    --emm-border-faint: #f5f5f5;
    --emm-overlay-bg: rgba(0, 0, 0, 0.35);

    /* 5. Glassmorphism (Transparent Header) */
    --emm-glass-bg: rgba(255, 255, 255, 0.1);
    --emm-glass-bg-hover: rgba(255, 255, 255, 0.2);
    --emm-glass-border: rgba(255, 255, 255, 0.4);
    --emm-glass-border-hover: rgba(255, 255, 255, 0.65);
    --emm-glass-blur: blur(4px);

    /* 6. Accents */
    --emm-clr-accent: #05ad40;
    --emm-clr-accent-text: #ffffff;

    /* 7. Typography & Motion */
    --emm-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --emm-fs-base: 14px;
    --emm-fs-sm: 13px;
    --emm-fs-xs: 10px;
    --emm-fs-title: 16px;
    --emm-lh-base: 1.5;
    --emm-lh-btn: 1;
    --emm-transition: 0.25s ease;
    --emm-panel-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
    
    /* 8. Structural Helpers */
    --emm-border-w: 1px;
    --emm-border-w-md: 1.5px;
    --emm-border-w-lg: 2px;
    --emm-border-w-active: 3px;
    --emm-offset-y: -8px;
    --emm-sidebar-icon-container: 24px;
    --emm-view-all-mt: 18px;
}

/* ============================================================
 * 1. КНОПКА «КАТАЛОГ»
 * ============================================================ */
.emm-trigger-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--emm-gap-sm);
    padding: var(--emm-pad-btn);
    border-radius: var(--emm-radius);
    border: var(--emm-border-w-md) solid var(--emm-glass-border);
    background: var(--emm-glass-bg);
    backdrop-filter: var(--emm-glass-blur);
    -webkit-backdrop-filter: var(--emm-glass-blur);
    color: var(--emm-clr-white);
    font-family: var(--emm-font);
    font-weight: 600;
    font-size: var(--emm-fs-base);
    line-height: var(--emm-lh-btn);
    cursor: pointer;
    transition: all var(--emm-transition);
    white-space: nowrap;
    outline: none;
    margin-left: var(--emm-gap-lg);
    margin-right: var(--emm-gap-md);
    flex-shrink: 0;
}

.emm-trigger-btn:hover {
    background: var(--emm-glass-bg-hover);
    border-color: var(--emm-glass-border-hover);
}

.emm-trigger-btn.emm-icon-only {
    padding: var(--emm-pad-btn);
    width: var(--emm-trigger-size);
    height: var(--emm-trigger-size);
    justify-content: center;
}

.emm-trigger-btn.emm-icon-only .emm-trigger-text {
    display: none;
}

.emm-trigger-btn:focus-visible {
    box-shadow: 0 0 0 2px var(--emm-glass-border);
}

.emm-trigger-icon {
    width: var(--emm-icon-size);
    height: var(--emm-icon-size);
    flex-shrink: 0;
    transition: transform var(--emm-transition);
}

.custom-header-wrapper.scrolled .emm-trigger-btn,
body:not(.home) .custom-header-wrapper .emm-trigger-btn {
    background: var(--emm-bg-scrolled);
    border-color: rgba(0, 0, 0, 0.12);
    color: var(--emm-clr-dark);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.custom-header-wrapper.scrolled .emm-trigger-btn:hover,
body:not(.home) .custom-header-wrapper .emm-trigger-btn:hover {
    background: var(--emm-bg-scrolled-hover);
    border-color: rgba(0, 0, 0, 0.25);
}

.emm-trigger-btn.emm-active {
    background: var(--emm-bg-active);
    color: var(--emm-clr-white);
    border-color: var(--emm-bg-active);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.emm-trigger-btn.emm-active:hover {
    background: var(--emm-clr-gray-dark);
    border-color: var(--emm-clr-gray-dark);
}

.custom-header-wrapper.scrolled .emm-trigger-btn.emm-active,
body:not(.home) .custom-header-wrapper .emm-trigger-btn.emm-active {
    background: var(--emm-bg-active);
    color: var(--emm-clr-white);
    border-color: var(--emm-bg-active);
}

.emm-trigger-btn.emm-active .emm-trigger-icon {
    transform: rotate(45deg);
}

/* ============================================================
 * 2. ОВЕРЛЕЙ
 * ============================================================ */
.emm-overlay {
    position: fixed;
    inset: 0;
    background: var(--emm-overlay-bg);
    z-index: 190;
    opacity: 0;
    visibility: hidden;
}

.emm-overlay.emm-visible {
    opacity: 1;
    visibility: visible;
}

/* ============================================================
 * 3. ПАНЕЛЬ МЕГА-МЕНЮ
 * ============================================================ */
.emm-panel {
    position: fixed;
    top: var(--emm-header-h);
    left: 0;
    width: 100%;
    z-index: 200;
    background: var(--emm-bg-panel);
    box-shadow: var(--emm-panel-shadow);
    border-top: var(--emm-border-w) solid var(--emm-border-light);
    opacity: 0;
    visibility: hidden;
    transform: translateY(var(--emm-offset-y));
    max-height: calc(100vh - var(--emm-header-h));
    overflow-y: auto;
    font-family: var(--emm-font);
    font-size: var(--emm-fs-base);
    line-height: var(--emm-lh-base);
    color: var(--emm-clr-dark);
    box-sizing: border-box;
}

.emm-panel *,
.emm-panel *::before,
.emm-panel *::after {
    box-sizing: border-box;
}

.emm-panel.emm-open {
    visibility: visible;
}

.emm-inner {
    max-width: var(--emm-max-w);
    margin: 0 auto;
    display: flex;
    min-height: 480px;
}

/* ============================================================
 * 4. САЙДБАР (ліва колонка)
 * ============================================================ */
.emm-sidebar {
    width: var(--emm-sidebar-w);
    flex-shrink: 0;
    background: var(--emm-bg-sidebar);
    border-right: 1px solid var(--emm-border-light);
    padding: var(--emm-gap-md) 0;
    overflow-y: auto;
}

.emm-sidebar-item {
    display: flex;
    align-items: center;
    gap: var(--emm-gap-md);
    padding: var(--emm-pad-item);
    cursor: pointer;
    transition: background var(--emm-transition), border-color var(--emm-transition);
    position: relative;
    border-left: var(--emm-border-w-active) solid transparent;
}

.emm-sidebar-item:hover {
    background: var(--emm-bg-hover);
}

.emm-sidebar-item.emm-active {
    background: var(--emm-clr-white);
    border-left-color: var(--emm-bg-active);
}

.emm-item-icon {
    font-size: var(--emm-icon-size);
    line-height: var(--emm-lh-btn);
    flex-shrink: 0;
    width: var(--emm-sidebar-icon-container);
    text-align: center;
}

.emm-item-title {
    flex: 1;
    color: var(--emm-clr-dark);
    font-weight: 600;
    font-size: var(--emm-fs-base);
    text-decoration: none !important;
    transition: color var(--emm-transition);
}

.emm-sidebar-item:hover .emm-item-title,
.emm-sidebar-item.emm-active .emm-item-title {
    color: var(--emm-clr-black);
}

.emm-chevron {
    color: var(--emm-clr-gray-line);
    font-size: var(--emm-icon-size);
    line-height: 1;
    transition: color var(--emm-transition), transform var(--emm-transition);
    flex-shrink: 0;
}

.emm-sidebar-item:hover .emm-chevron,
.emm-sidebar-item.emm-active .emm-chevron {
    color: var(--emm-clr-gray-light);
    transform: translateX(2px);
}

/* ============================================================
 * 5. КОНТЕНТ (права колонка)
 * ============================================================ */
.emm-content {
    flex: 1;
    padding: var(--emm-pad-content);
    min-width: 0;
}

.emm-subcategory-group {
    display: none;
    animation: emm-fadeIn 0.2s ease;
}

.emm-subcategory-group.emm-active {
    display: block;
}

@keyframes emm-fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

.emm-group-title {
    font-size: var(--emm-fs-title);
    font-weight: 700;
    color: var(--emm-clr-dark);
    margin: 0 0 var(--emm-gap-lg) 0;
    padding: 0 0 var(--emm-gap-sm) 0;
    border-bottom: var(--emm-border-w-lg) solid var(--emm-border-faint);
}

/* ============================================================
 * СЕТКИ И КАРТОЧКИ (3D принтеры и комплектующие)
 * ============================================================ */
.emm-grid-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--emm-gap-lg);
    margin-top: var(--emm-gap-md);
}

.emm-card {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border: var(--emm-border-w) solid var(--emm-border-light);
    border-radius: var(--emm-radius);
    padding: var(--emm-gap-md);
    text-decoration: none !important;
    transition: transform var(--emm-transition), box-shadow var(--emm-transition), border-color var(--emm-transition);
    min-height: 170px;
}

.emm-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    border-color: var(--emm-clr-gray-line);
}

.emm-card-img-wrap {
    width: 100%;
    height: 100px;
    border-radius: var(--emm-radius-sm);
    overflow: hidden;
    margin-bottom: var(--emm-gap-sm);
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.emm-card-img-wrap img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform 0.5s ease;
}

.emm-card:hover .emm-card-img-wrap img {
    transform: scale(1.06);
}

.emm-card-title {
    font-size: var(--emm-fs-sm);
    font-weight: 600;
    color: var(--emm-clr-dark);
    text-align: center;
    margin-top: auto;
}

.emm-card-view-all {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--emm-bg-sidebar);
    border: var(--emm-border-w-lg) dashed var(--emm-clr-gray-line);
    border-radius: var(--emm-radius);
    padding: var(--emm-gap-md);
    text-decoration: none !important;
    min-height: 170px;
    transition: all var(--emm-transition);
}

.emm-card-view-all:hover {
    background: #ffffff;
    border-color: var(--emm-clr-accent);
}

.emm-card-view-all .emm-card-title {
    color: var(--emm-clr-accent);
    font-weight: 700;
    font-size: var(--emm-fs-base);
}

/* ============================================================
 * ФИЛАМЕНТ (Бренды, сетки, палитры)
 * ============================================================ */
.emm-brands-bar {
    display: flex;
    align-items: center;
    gap: var(--emm-gap-md);
    background: var(--emm-bg-sidebar);
    border-radius: var(--emm-radius);
    padding: 8px 16px;
    margin-bottom: var(--emm-gap-lg);
    border: var(--emm-border-w) solid var(--emm-border-light);
}

.emm-brands-label {
    font-size: var(--emm-fs-sm);
    font-weight: 700;
    color: var(--emm-clr-gray-dark);
}

.emm-brands-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--emm-gap-sm);
}

.emm-brand-pill {
    font-size: var(--emm-fs-sm);
    font-weight: 600;
    color: var(--emm-clr-gray-light);
    background: #ffffff;
    border: var(--emm-border-w) solid var(--emm-border-light);
    padding: 4px 12px;
    border-radius: 100px;
    text-decoration: none !important;
    transition: all var(--emm-transition);
}

.emm-brand-pill:hover {
    color: var(--emm-clr-white);
    background: var(--emm-clr-accent);
    border-color: var(--emm-clr-accent);
    transform: translateY(-1px);
}

.emm-filament-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    max-width: 680px;
    gap: var(--emm-gap-lg);
    margin-top: var(--emm-gap-md);
}

.emm-filament-card {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border: var(--emm-border-w) solid var(--emm-border-light);
    border-radius: var(--emm-radius);
    padding: var(--emm-gap-md);
    transition: transform var(--emm-transition), box-shadow var(--emm-transition), border-color var(--emm-transition);
    min-height: 170px;
}

.emm-filament-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    border-color: var(--emm-clr-gray-line);
}

.emm-filament-main-link {
    text-decoration: none !important;
}

.emm-filament-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--emm-gap-sm);
    margin-bottom: var(--emm-gap-sm);
}

.emm-filament-img-wrap {
    width: 100%;
    height: 100px;
    border-radius: var(--emm-radius-sm);
    overflow: hidden;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.emm-filament-img-wrap img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform 0.5s ease;
}

.emm-filament-card:hover .emm-filament-img-wrap img {
    transform: scale(1.06);
}

.emm-filament-title {
    font-size: var(--emm-fs-sm);
    font-weight: 600;
    color: var(--emm-clr-dark);
    text-align: center;
}

.emm-color-palette {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    margin: var(--emm-gap-sm) auto;
    padding-bottom: var(--emm-gap-sm);
    border-bottom: var(--emm-border-w) solid var(--emm-border-faint);
    max-width: 150px;
}

.emm-color-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    display: inline-block;
    border: var(--emm-border-w) solid rgba(0, 0, 0, 0.12);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
    transition: transform var(--emm-transition), box-shadow var(--emm-transition);
    cursor: pointer;
}

.emm-color-dot:hover {
    transform: scale(1.3);
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);
    z-index: 2;
}

.emm-color-more {
    font-size: 9px;
    font-weight: 700;
    color: var(--emm-clr-gray-light);
    display: inline-flex;
    align-items: center;
    padding-left: 2px;
}

/* Кнопка вызова подтипов PLA */
.emm-subtypes-trigger {
    display: flex;
    align-items: center;
    width: 100%;
    margin-top: auto;
    border: none;
    background: none;
    padding: 0;
    padding-top: var(--emm-gap-sm);
    border-top: var(--emm-border-w) solid var(--emm-border-faint);
    cursor: pointer;
    outline: none;
    font-family: var(--emm-font);
}

.emm-subtypes-trigger span {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 12px;
    background: var(--emm-bg-sidebar);
    border: var(--emm-border-w) solid var(--emm-border-light);
    border-radius: var(--emm-radius-sm);
    font-size: 12px;
    font-weight: 700;
    color: var(--emm-clr-gray-dark);
    width: 100%;
    transition: all var(--emm-transition);
}

.emm-subtypes-trigger:hover span {
    background: var(--emm-bg-hover);
    color: var(--emm-clr-black);
    border-color: var(--emm-clr-gray-line);
}

.emm-subtypes-trigger .emm-details-chevron {
    width: 10px;
    height: 6px;
    color: var(--emm-clr-gray-light);
    transition: transform var(--emm-transition), color var(--emm-transition);
    transform: rotate(-90deg); /* Поворот направо */
}

.emm-subtypes-trigger:hover .emm-details-chevron {
    color: var(--emm-clr-accent);
}

.emm-view-hidden {
    display: none !important;
}

/* Стили подраздела видов PLA */
.emm-filament-subview {
    animation: emm-fadeIn 0.25s ease;
}

.emm-subview-header {
    display: flex;
    align-items: center;
    gap: var(--emm-gap-lg);
    margin-bottom: var(--emm-gap-lg);
    border-bottom: var(--emm-border-w-lg) solid var(--emm-border-faint);
    padding-bottom: var(--emm-gap-sm);
}

.emm-subview-back {
    display: inline-flex;
    align-items: center;
    gap: var(--emm-gap-sm);
    background: var(--emm-bg-sidebar);
    border: var(--emm-border-w) solid var(--emm-border-light);
    padding: 6px 14px;
    border-radius: var(--emm-radius-sm);
    font-family: var(--emm-font);
    font-size: 12px;
    font-weight: 700;
    color: var(--emm-clr-gray-dark);
    cursor: pointer;
    transition: all var(--emm-transition);
    outline: none;
}

.emm-subview-back:hover {
    background: var(--emm-bg-hover);
    color: var(--emm-clr-black);
    border-color: var(--emm-clr-gray-line);
}

.emm-subview-back svg {
    width: 6px;
    height: 10px;
    color: var(--emm-clr-gray-light);
    transition: transform var(--emm-transition);
}

.emm-subview-back:hover svg {
    transform: translateX(-2px);
    color: var(--emm-clr-accent);
}

.emm-subview-title {
    font-size: var(--emm-fs-title);
    font-weight: 700;
    color: var(--emm-clr-dark);
    margin: 0;
}

/* Сетка в 5 колонок для подраздела */
.emm-subview-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--emm-gap-lg);
}

.emm-subview-card {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border: var(--emm-border-w) solid var(--emm-border-light);
    border-radius: var(--emm-radius);
    padding: var(--emm-gap-md);
    transition: transform var(--emm-transition), box-shadow var(--emm-transition), border-color var(--emm-transition);
    min-height: 170px;
}

.emm-subview-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    border-color: var(--emm-clr-gray-line);
}

.emm-subview-card .emm-color-palette {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.emm-subview-img-wrap {
    width: 100%;
    height: 100px;
    border-radius: var(--emm-radius-sm);
    overflow: hidden;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.emm-subview-img-wrap img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform 0.5s ease;
}

.emm-subview-card:hover .emm-subview-img-wrap img {
    transform: scale(1.06);
}

.emm-subview-card-title {
    font-size: var(--emm-fs-sm);
    font-weight: 600;
    color: var(--emm-clr-dark);
    text-align: center;
}

/* ============================================================
 * ОДНОСТРАНИЧНЫЕ МАКЕТЫ (Сканеры, Распродажа)
 * ============================================================ */
.emm-single-cat-layout {
    display: flex;
    align-items: center;
    gap: var(--emm-gap-xl);
    background: #ffffff;
    border: var(--emm-border-w) solid var(--emm-border-light);
    border-radius: var(--emm-radius-lg);
    padding: var(--emm-pad-content);
    margin-top: var(--emm-gap-md);
}

.emm-single-cat-img {
    width: 280px;
    height: 180px;
    border-radius: var(--emm-radius);
    overflow: hidden;
    flex-shrink: 0;
    border: var(--emm-border-w) solid var(--emm-border-light);
}

.emm-single-cat-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.emm-single-cat-info {
    display: flex;
    flex-direction: column;
    gap: var(--emm-gap-lg);
}

.emm-single-cat-info p {
    font-size: var(--emm-fs-title);
    color: var(--emm-clr-gray-light);
    margin: 0;
}

.emm-view-all-btn {
    align-self: flex-start;
    font-size: var(--emm-fs-base);
    font-weight: 700;
    color: var(--emm-clr-white);
    background: var(--emm-clr-accent);
    padding: 10px 24px;
    border-radius: var(--emm-radius);
    text-decoration: none !important;
    transition: all var(--emm-transition);
}

.emm-view-all-btn:hover {
    background: #048f34;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(5, 173, 64, 0.25);
}

/* ============================================================
 * БЕЙДЖІ
 * ============================================================ */
.emm-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px var(--emm-gap-sm);
    border-radius: 100px;
    font-size: var(--emm-fs-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: var(--emm-clr-accent);
    color: var(--emm-clr-accent-text);
    flex-shrink: 0;
    line-height: 1.4;
}

/* ============================================================
 * АДАПТИВНІСТЬ
 * ============================================================ */
@media (max-width: 768px) {
    .emm-trigger-btn {
        display: none !important;
    }

    .emm-panel,
    .emm-overlay {
        display: none !important;
    }
}
