/**
 * Kasvuhoonekeskus Header — Styles
 *
 * Extracted from inline <style> for proper browser caching,
 * minification support, and separation of concerns.
 *
 * Color scheme:
 *  - Primary Green: #2d5f3f
 *  - Dark Green (hover): #1f4a2e
 *  - Dark: #1A1A1A
 *  - White: #FFFFFF
 *
 * @package Kasvuhoonekeskus
 * @since   2.0.0
 */

/* ============================================
   HEADER — BASE
   ============================================ */

.kkhk-header {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    box-sizing: border-box !important;
    min-height: 82px !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
}

.kkhk-header *,
.kkhk-header *::before,
.kkhk-header *::after {
    box-sizing: border-box !important;
}

.kkhk-header-bg {
    background-color: transparent !important;
    width: 100% !important;
    padding: 0 30px !important;
    margin-top: 8px !important;
    border-radius: 8px !important;
    position: relative !important;
    z-index: 99 !important;
    box-shadow: none !important;
}

.kkhk-header-container {
    max-width: 1300px !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 12px 20px !important;
    gap: 1.5rem !important;
}

/* Group action buttons (search, login, cart) together - push to right */
.kkhk-header-actions {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-left: auto !important;
}

/* Action buttons */
.kkhk-search,
.kkhk-login,
.kkhk-cart {
    display: flex !important;
    align-items: center !important;
}


/* ============================================
   LOGO
   ============================================ */

.kkhk-logo {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
    flex-shrink: 0 !important;
}

.kkhk-logo img {
    height: 50px !important;
    width: auto !important;
}

.kkhk-logo-text {
    display: flex !important;
    flex-direction: column !important;
    line-height: 1.1 !important;
}

.kkhk-logo-title {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    color: #1A1A1A !important;
    letter-spacing: 0.5px !important;
}

.kkhk-logo-subtitle {
    font-size: 1rem !important;
    font-weight: 400 !important;
    color: #666 !important;
    margin-left: 2px !important;
}

/* ============================================
   NAVIGATION
   ============================================ */

.kkhk-nav {
    flex: 1 !important;
    display: flex !important;
    justify-content: center !important;
}

.kkhk-menu {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.kkhk-menu-item > a {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 10px 18px !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    border-radius: 6px !important;
    transition: all 0.2s ease !important;
    white-space: nowrap !important;
    text-transform: capitalize !important;
}

.kkhk-menu-item > a:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #FFFFFF !important;
}

.kkhk-dropdown-arrow {
    transition: transform 0.2s ease !important;
}

.kkhk-has-dropdown:hover .kkhk-dropdown-arrow {
    transform: rotate(180deg) !important;
}

/* Highlight (Kampaaniad) */
.kkhk-highlight > a {
    color: #FFC107 !important;
    font-weight: 600 !important;
}

.kkhk-highlight > a:hover {
    color: #FFD54F !important;
}

/* Active menu item */
.kkhk-menu-item.kkhk-active > a {
    position: relative !important;
}

.kkhk-menu-item.kkhk-active > a::after {
    content: '' !important;
    position: absolute !important;
    bottom: 6px !important;
    left: 18px !important;
    right: 18px !important;
    height: 2px !important;
    background: #CFDDD4 !important;
    border-radius: 1px !important;
}

.kkhk-highlight.kkhk-active > a::after {
    background: #FFC107 !important;
}

/* ============================================
   SIMPLE DROPDOWN
   ============================================ */

.kkhk-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    background: #FFFFFF !important;
    border-radius: 10px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15) !important;
    padding: 8px 0 !important;
    min-width: 180px !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) !important;
    transition: all 0.2s ease !important;
    z-index: 1000 !important;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.kkhk-has-dropdown {
    position: relative !important;
}

.kkhk-has-dropdown:hover .kkhk-dropdown {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.kkhk-dropdown ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.kkhk-dropdown li a {
    display: block !important;
    padding: 10px 20px !important;
    color: #1A1A1A !important;
    text-decoration: none !important;
    font-size: 0.95rem !important;
    transition: all 0.15s ease !important;
    text-transform: capitalize !important;
}

.kkhk-dropdown li a:hover {
    background: rgba(45, 95, 63, 0.06) !important;
    color: #2d5f3f !important;
    padding-left: 24px !important;
}

/* ============================================
   MEGA DROPDOWN
   ============================================ */

.kkhk-mega-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 50% !important;
    transform: translateX(-50%) translateY(10px) !important;
    background: #FFFFFF !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2) !important;
    padding: 24px !important;
    width: 700px !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.25s ease !important;
    z-index: 1000 !important;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.kkhk-has-dropdown:hover .kkhk-mega-dropdown {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateX(-50%) translateY(0) !important;
}

.kkhk-mega-container {
    width: 100% !important;
}

.kkhk-mega-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 16px !important;
}

.kkhk-mega-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding: 16px 12px !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    background: #f8f9fa !important;
    border: 1px solid transparent !important;
}

.kkhk-mega-item:hover {
    background: #2d5f3f !important;
    transform: translateY(-4px) !important;
    border-color: rgba(45, 95, 63, 0.3) !important;
    box-shadow: 0 8px 24px rgba(45, 95, 63, 0.25) !important;
}

.kkhk-mega-item:hover .kkhk-mega-title {
    color: #FFFFFF !important;
}

.kkhk-mega-item:hover .kkhk-mega-count {
    color: rgba(255, 255, 255, 0.85) !important;
}

.kkhk-mega-image {
    width: 70px !important;
    height: 70px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    margin-bottom: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #FFFFFF !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
}

.kkhk-mega-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.kkhk-mega-no-image {
    background: #e9ecef !important;
    color: #adb5bd !important;
}

.kkhk-mega-item:hover .kkhk-mega-no-image {
    background: rgba(255, 255, 255, 0.25) !important;
    color: rgba(255, 255, 255, 0.85) !important;
}

.kkhk-mega-title {
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    color: #1A1A1A !important;
    margin-bottom: 4px !important;
    line-height: 1.3 !important;
    transition: color 0.2s ease !important;
    text-transform: capitalize !important;
}

.kkhk-mega-count {
    font-size: 0.75rem !important;
    color: #888 !important;
    transition: color 0.2s ease !important;
}

.kkhk-mega-footer {
    margin-top: 20px !important;
    padding-top: 16px !important;
    border-top: 1px solid #eee !important;
    text-align: center !important;
}

.kkhk-mega-all {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 24px !important;
    background: #1A1A1A !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
    border-radius: 8px !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    transition: all 0.2s ease !important;
}

.kkhk-mega-all:hover {
    background: #2d5f3f !important;
    color: #FFFFFF !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(45, 95, 63, 0.3) !important;
}

/* ============================================
   CART BUTTON
   ============================================ */

.kkhk-cart {
    flex-shrink: 0 !important;
}

.kkhk-cart-btn {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px 18px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 50px !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
}

.kkhk-cart-btn:hover {
    background: rgba(255, 255, 255, 0.15) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

.kkhk-cart-btn.kkhk-cart-empty {
    opacity: 0.6 !important;
    cursor: default !important;
}

.kkhk-cart-btn.kkhk-cart-empty:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
}

.kkhk-cart-total {
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    color: #FFFFFF !important;
}

.kkhk-cart-icon {
    position: relative !important;
    color: #FFFFFF !important;
    display: flex !important;
    align-items: center !important;
}

.kkhk-cart-count {
    position: absolute !important;
    top: -8px !important;
    right: -8px !important;
    width: 18px !important;
    height: 18px !important;
    background: #FFFFFF !important;
    color: #2d5f3f !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ============================================
   LOGIN BUTTON
   ============================================ */

.kkhk-login {
    flex-shrink: 0 !important;
}

.kkhk-login-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 10px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 50px !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    width: 42px !important;
    height: 42px !important;
}

.kkhk-login-btn:hover {
    background: rgba(255, 255, 255, 0.15) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

.kkhk-user-icon {
    color: #FFFFFF !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ============================================
   MINI-CART
   ============================================ */

.kkhk-cart-wrapper {
    position: relative !important;
}

.kkhk-mini-cart {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    width: 360px !important;
    background: #FFFFFF !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) !important;
    transition: all 0.25s ease !important;
    z-index: 10001 !important;
    margin-top: 10px !important;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.kkhk-cart-wrapper:hover .kkhk-mini-cart {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.kkhk-mini-cart-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid #eee !important;
    font-weight: 600 !important;
    color: #1A1A1A !important;
    background: linear-gradient(to right, #f8f9fa, #FFFFFF) !important;
}

.kkhk-mini-cart-count {
    font-size: 0.85rem !important;
    color: #888 !important;
    font-weight: 500 !important;
}

.kkhk-mini-cart-items {
    max-height: 320px !important;
    overflow-y: auto !important;
    padding: 12px 20px !important;
}

.kkhk-mini-cart-empty {
    text-align: center !important;
    padding: 30px 20px !important;
    color: #888 !important;
}

.kkhk-mini-cart-empty svg {
    margin-bottom: 12px !important;
    color: #ddd !important;
}

.kkhk-mini-cart-empty p {
    margin: 0 !important;
    font-size: 0.95rem !important;
}

.kkhk-mini-cart-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid #f5f5f5 !important;
}

.kkhk-mini-cart-item:last-child {
    border-bottom: none !important;
}

.kkhk-mini-cart-item-image {
    flex-shrink: 0 !important;
    width: 60px !important;
    height: 60px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: #f8f9fa !important;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.kkhk-mini-cart-item-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.kkhk-mini-cart-item-info {
    flex: 1 !important;
    min-width: 0 !important;
}

.kkhk-mini-cart-item-name {
    display: block !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: #1A1A1A !important;
    text-decoration: none !important;
    margin-bottom: 4px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.kkhk-mini-cart-item-name:hover {
    color: #2d5f3f !important;
}

.kkhk-mini-cart-item-meta {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 0.85rem !important;
}

.kkhk-mini-cart-item-qty {
    color: #888 !important;
}

.kkhk-mini-cart-item-price {
    color: #2d5f3f !important;
    font-weight: 600 !important;
}

.kkhk-mini-cart-item-remove {
    flex-shrink: 0 !important;
    width: 28px !important;
    height: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #ccc !important;
    border-radius: 50% !important;
    transition: all 0.2s ease !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    padding: 0 !important;
}

.kkhk-mini-cart-item-remove:hover {
    background: #fff5f5 !important;
    color: #2d5f3f !important;
}

.kkhk-mini-cart-item-remove.kkhk-loading {
    pointer-events: none !important;
    opacity: 0.5 !important;
}

.kkhk-mini-cart-item-remove.kkhk-loading svg {
    animation: kkhk-spin 1s linear infinite !important;
}

@keyframes kkhk-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.kkhk-mini-cart-item.kkhk-removing {
    opacity: 0.5 !important;
    pointer-events: none !important;
}

.kkhk-mini-cart-more {
    text-align: center !important;
    padding: 12px 0 !important;
    font-size: 0.85rem !important;
    color: #888 !important;
}

.kkhk-mini-cart-footer {
    padding: 16px 20px !important;
    border-top: 1px solid #eee !important;
    background: linear-gradient(to right, #f8f9fa, #FFFFFF) !important;
    border-radius: 0 0 16px 16px !important;
}

.kkhk-mini-cart-subtotal {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 12px !important;
    font-size: 0.95rem !important;
}

.kkhk-mini-cart-subtotal > span:first-child {
    color: #1A1A1A !important;
    font-weight: 600 !important;
}

.kkhk-mini-cart-subtotal-amount {
    font-weight: 700 !important;
    font-size: 1.1rem !important;
    color: #2d5f3f !important;
}

.kkhk-mini-cart-checkout {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 12px 20px !important;
    background: #2d5f3f !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    font-size: 0.95rem !important;
    transition: all 0.2s ease !important;
}

.kkhk-mini-cart-checkout:hover {
    background: #1f4a2e !important;
    color: #FFFFFF !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(45, 95, 63, 0.35) !important;
}

.kkhk-checkout-disabled {
    background: #ccc !important;
    color: #888 !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
}

.kkhk-checkout-disabled:hover {
    background: #ccc !important;
    color: #888 !important;
}

/* ============================================
   MOBILE TOGGLE
   ============================================ */

.kkhk-mobile-toggle {
    display: none !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 5px !important;
    width: 40px !important;
    height: 40px !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    padding: 8px !important;
}

.kkhk-mobile-toggle span {
    display: block !important;
    width: 100% !important;
    height: 2px !important;
    background: #FFFFFF !important;
    border-radius: 2px !important;
    transition: all 0.3s ease !important;
}

.kkhk-mobile-toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px) !important;
}

.kkhk-mobile-toggle.active span:nth-child(2) {
    opacity: 0 !important;
}

.kkhk-mobile-toggle.active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px) !important;
}

/* ============================================
   MOBILE NAVIGATION
   ============================================ */

.kkhk-mobile-nav {
    position: fixed !important;
    top: 0 !important;
    right: -100% !important;
    width: 100% !important;
    max-width: 320px !important;
    height: 100vh !important;
    height: 100dvh !important;
    background: #FFFFFF !important;
    z-index: 99999 !important;
    transition: right 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: -5px 0 20px rgba(0, 0, 0, 0.15) !important;
}

.kkhk-mobile-nav.active {
    right: 0 !important;
}

.kkhk-mobile-nav-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid rgba(45, 95, 63, 0.15) !important;
    background: linear-gradient(to right, #f8f9fa, #FFFFFF) !important;
}

.kkhk-mobile-nav-title {
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    color: #1A1A1A !important;
}

.kkhk-mobile-nav-close {
    width: 44px !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(45, 95, 63, 0.1) !important;
    border: none !important;
    color: #2d5f3f !important;
    cursor: pointer !important;
    border-radius: 50% !important;
    transition: all 0.2s ease !important;
    padding: 0 !important;
    -webkit-tap-highlight-color: transparent !important;
}

.kkhk-mobile-nav-close:hover,
.kkhk-mobile-nav-close:active {
    background: rgba(45, 95, 63, 0.2) !important;
    color: #1f4a2e !important;
}

.kkhk-mobile-nav-content {
    padding: 20px 24px 24px !important;
    overflow-y: auto !important;
    flex: 1 !important;
}

.kkhk-mobile-menu {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.kkhk-mobile-menu > li {
    border-bottom: 1px solid rgba(26, 26, 26, 0.08) !important;
}

.kkhk-mobile-menu > li > a {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 16px 0 !important;
    color: #1A1A1A !important;
    text-decoration: none !important;
    font-size: 1.1rem !important;
    font-weight: 500 !important;
    text-transform: capitalize !important;
}

.kkhk-mobile-highlight > a,
.kkhk-mobile-highlight > a[href],
.kkhk-mobile-menu .kkhk-mobile-highlight a {
    color: #2d5f3f !important;
    font-weight: 600 !important;
}

.kkhk-mobile-submenu {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 0 12px 16px !important;
    display: none !important;
}

.kkhk-mobile-has-sub.active .kkhk-mobile-submenu {
    display: block !important;
}

.kkhk-mobile-has-sub.active > a svg {
    transform: rotate(180deg) !important;
}

.kkhk-mobile-submenu li a {
    display: block !important;
    padding: 10px 0 !important;
    color: #666 !important;
    text-decoration: none !important;
    font-size: 0.95rem !important;
    text-transform: capitalize !important;
}

.kkhk-mobile-submenu li a:hover {
    color: #2d5f3f !important;
}

.kkhk-mobile-all a {
    color: #2d5f3f !important;
    font-weight: 600 !important;
}

.kkhk-mobile-cart {
    margin-top: 24px !important;
    padding-top: 24px !important;
    border-top: 1px solid rgba(45, 95, 63, 0.2) !important;
}

.kkhk-mobile-cart-btn {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 14px 20px !important;
    background: #2d5f3f !important;
    border-radius: 10px !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    border: none !important;
    cursor: pointer !important;
    width: 100% !important;
    position: relative !important;
    -webkit-tap-highlight-color: transparent !important;
    touch-action: manipulation !important;
    transition: all 0.2s ease !important;
}

.kkhk-mobile-cart-btn:hover {
    background: #1f4a2e !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(45, 95, 63, 0.35) !important;
}

.kkhk-mobile-cart-btn.kkhk-mobile-cart-empty {
    background: #ccc !important;
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
}

.kkhk-mobile-cart-btn.kkhk-mobile-cart-empty:hover {
    background: #ccc !important;
    transform: none !important;
    box-shadow: none !important;
}

.kkhk-mobile-cart-total {
    margin-left: auto !important;
}

.kkhk-mobile-cart-count-badge {
    position: absolute !important;
    top: 8px !important;
    right: 12px !important;
    width: 20px !important;
    height: 20px !important;
    background: #1A1A1A !important;
    color: #FFFFFF !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 2px solid #2d5f3f !important;
}

/* ============================================
   MOBILE MINI-CART (standalone panel)
   ============================================ */

.kkhk-mobile-mini-cart {
    position: fixed !important;
    top: 0 !important;
    right: -100% !important;
    width: 100% !important;
    max-width: 400px !important;
    height: 100% !important;
    height: 100dvh !important;
    background: #FFFFFF !important;
    z-index: 1000001 !important;
    transition: right 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.3) !important;
    will-change: right !important;
}

.kkhk-mobile-mini-cart.active {
    right: 0 !important;
}

.kkhk-mobile-mini-cart-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 20px !important;
    border-bottom: 1px solid #eee !important;
    font-weight: 600 !important;
    font-size: 1.1rem !important;
    color: #1A1A1A !important;
    background: linear-gradient(to right, #f8f9fa, #FFFFFF) !important;
}

.kkhk-mobile-mini-cart-close {
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(45, 95, 63, 0.1) !important;
    border: none !important;
    color: #2d5f3f !important;
    cursor: pointer !important;
    border-radius: 50% !important;
    transition: all 0.2s ease !important;
    padding: 0 !important;
    -webkit-tap-highlight-color: transparent !important;
}

.kkhk-mobile-mini-cart-close:hover,
.kkhk-mobile-mini-cart-close:active {
    background: rgba(45, 95, 63, 0.2) !important;
    color: #1f4a2e !important;
}

.kkhk-mobile-mini-cart-content {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

.kkhk-mobile-mini-cart-items {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 16px 20px !important;
}

.kkhk-mobile-mini-cart-footer {
    padding: 20px !important;
    border-top: 1px solid #eee !important;
    background: linear-gradient(to right, #f8f9fa, #FFFFFF) !important;
}

.kkhk-mobile-mini-cart-subtotal {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 16px !important;
    font-size: 1rem !important;
}

.kkhk-mobile-mini-cart-subtotal > span:first-child {
    color: #1A1A1A !important;
    font-weight: 600 !important;
}

.kkhk-mobile-cart-subtotal-amount {
    color: #2d5f3f !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
}

.kkhk-mobile-cart-checkout {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 12px 20px !important;
    background: #2d5f3f !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    font-size: 0.95rem !important;
    transition: all 0.2s ease !important;
}

.kkhk-mobile-cart-checkout:hover {
    background: #1f4a2e !important;
    color: #FFFFFF !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(45, 95, 63, 0.35) !important;
}

.kkhk-mobile-cart-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    height: 100dvh !important;
    background: rgba(0, 0, 0, 0.6) !important;
    z-index: 1000000 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity 0.3s ease, visibility 0.3s ease !important;
}

.kkhk-mobile-cart-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

.kkhk-mobile-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.5) !important;
    z-index: 99998 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.3s ease !important;
}

.kkhk-mobile-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 1100px) {
    .kkhk-menu-item > a {
        padding: 10px 12px !important;
        font-size: 0.9rem !important;
    }

    .kkhk-mega-dropdown {
        width: 600px !important;
    }

    .kkhk-mega-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (max-width: 900px) {
    .kkhk-header {
        min-height: 68px !important;
    }

    .kkhk-nav,
    .kkhk-cart,
    .kkhk-login {
        display: none !important;
    }

    .kkhk-mobile-toggle {
        display: flex !important;
    }

    .kkhk-header-container {
        padding: 10px 0 !important;
    }

    .kkhk-logo img {
        height: 40px !important;
    }

    .kkhk-logo-title {
        font-size: 1.2rem !important;
    }

    .kkhk-logo-subtitle {
        font-size: 0.85rem !important;
    }
}

@media (max-width: 480px) {
    .kkhk-header-bg {
        padding: 0 16px !important;
    }

    .kkhk-logo-text {
        display: none !important;
    }

    .kkhk-mobile-nav {
        max-width: 100% !important;
    }
}

/* ============================================
   HEADER SEARCH
   ============================================ */

.kkhk-search {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    z-index: 10003 !important;
}

.kkhk-search-toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 10px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 50px !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    width: 42px !important;
    height: 42px !important;
}

.kkhk-search-toggle:hover {
    background: rgba(255, 255, 255, 0.15) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
    color: #FFFFFF !important;
}

.kkhk-search-toggle.active {
    background: #FFFFFF !important;
    border-color: #FFFFFF !important;
    color: #1A1A1A !important;
}

.kkhk-search-toggle-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #FFFFFF !important;
    transition: color 0.2s ease !important;
}

.kkhk-search-toggle-icon svg {
    width: 20px !important;
    height: 20px !important;
}

.kkhk-search-toggle:hover .kkhk-search-toggle-icon {
    color: #2d5f3f !important;
}

.kkhk-search-toggle.active .kkhk-search-toggle-icon {
    color: #FFFFFF !important;
}

.kkhk-search-dropdown {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    right: 0 !important;
    width: 420px !important;
    background: #FFFFFF !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) scale(0.98) !important;
    transition: all 0.25s ease !important;
    z-index: 10002 !important;
    overflow: visible !important;
    pointer-events: none !important;
    border: 1px solid rgba(26, 26, 26, 0.1) !important;
}

.kkhk-search.active .kkhk-search-dropdown {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) scale(1) !important;
    pointer-events: auto !important;
}

.kkhk-search-input-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.08) !important;
    background: #fafafa !important;
    pointer-events: auto !important;
}

.kkhk-search-input-wrapper svg {
    flex-shrink: 0 !important;
    color: #1A1A1A !important;
    opacity: 0.5 !important;
}

.kkhk-search-input {
    flex: 1 !important;
    border: none !important;
    background: transparent !important;
    font-size: 1rem !important;
    color: #1A1A1A !important;
    outline: none !important;
    font-family: inherit !important;
}

.kkhk-search-input::placeholder {
    color: #999 !important;
}

.kkhk-search-clear {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border: none !important;
    background: rgba(45, 95, 63, 0.15) !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    color: #2d5f3f !important;
    transition: all 0.2s ease !important;
    flex-shrink: 0 !important;
    font-size: 20px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
}

.kkhk-search-clear.visible {
    display: flex !important;
}

.kkhk-search-clear:hover {
    background: rgba(45, 95, 63, 0.25) !important;
    color: #1f4a2e !important;
}

.kkhk-search-results {
    max-height: 400px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    pointer-events: auto !important;
}

.kkhk-search-loading {
    display: none !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 40px 20px !important;
    gap: 12px !important;
    color: #666 !important;
}

.kkhk-search-loading.visible {
    display: flex !important;
}

.kkhk-search-spinner {
    width: 32px !important;
    height: 32px !important;
    border: 3px solid #eee !important;
    border-top-color: #2d5f3f !important;
    border-radius: 50% !important;
    animation: ppSearchSpin 0.8s linear infinite !important;
}

@keyframes ppSearchSpin {
    to { transform: rotate(360deg); }
}

.kkhk-search-empty {
    display: none !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 40px 20px !important;
    gap: 12px !important;
    color: #999 !important;
}

.kkhk-search-empty.visible {
    display: flex !important;
}

.kkhk-search-empty img {
    opacity: 0.5 !important;
    margin-bottom: 12px !important;
    color: #1A1A1A !important;
}

.kkhk-search-items {
    padding: 8px 0 !important;
    pointer-events: auto !important;
}

.kkhk-search-item {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 12px 20px !important;
    text-decoration: none !important;
    transition: background 0.15s ease !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}

.kkhk-search-item:hover {
    background: rgba(45, 95, 63, 0.06) !important;
}

.kkhk-search-item-image {
    width: 56px !important;
    height: 56px !important;
    border-radius: 10px !important;
    object-fit: cover !important;
    background: #f0f0f0 !important;
    flex-shrink: 0 !important;
    border: 1px solid rgba(26, 26, 26, 0.08) !important;
}

.kkhk-search-item-info {
    flex: 1 !important;
    min-width: 0 !important;
}

.kkhk-search-item-title {
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    color: #1A1A1A !important;
    margin: 0 0 4px 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.kkhk-search-item-category {
    font-size: 0.8rem !important;
    color: #999 !important;
    margin: 0 !important;
}

.kkhk-search-item-price {
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    color: #1A1A1A !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

.kkhk-search-item-price del {
    color: #999 !important;
    font-weight: 400 !important;
    font-size: 0.85rem !important;
}

.kkhk-search-item-price ins {
    text-decoration: none !important;
    color: #2d5f3f !important;
    font-weight: 700 !important;
}

.kkhk-search-item.on-sale .kkhk-search-item-price {
    color: #2d5f3f !important;
}

.kkhk-search-all {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 14px 20px !important;
    background: #fafafa !important;
    border-top: 1px solid rgba(26, 26, 26, 0.08) !important;
    color: #1A1A1A !important;
    font-weight: 500 !important;
    font-size: 0.95rem !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}

.kkhk-search-all.visible {
    display: flex !important;
}

.kkhk-search-all:hover {
    background: #2d5f3f !important;
    color: #FFFFFF !important;
}

/* Search overlay */
.kkhk-search-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 10001 !important;
    display: none !important;
    pointer-events: none !important;
}

.kkhk-search-overlay.active {
    display: block !important;
    pointer-events: none !important;
}

/* Mobile search */
@media (max-width: 900px) {
    .kkhk-search {
        display: none !important;
    }
}

/* Mobile search (inside menu) */
.kkhk-mobile-search {
    padding: 16px 20px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.08) !important;
}

.kkhk-mobile-search-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    background: #f5f5f5 !important;
    border-radius: 12px !important;
}

.kkhk-mobile-search-wrapper img {
    flex-shrink: 0 !important;
    opacity: 0.6 !important;
}

.kkhk-mobile-search-input {
    flex: 1 !important;
    border: none !important;
    background: transparent !important;
    font-size: 1rem !important;
    color: #1A1A1A !important;
    outline: none !important;
    font-family: inherit !important;
}

.kkhk-mobile-search-input::placeholder {
    color: #999 !important;
}

.kkhk-mobile-search-clear {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    width: 30px !important;
    height: 30px !important;
    border: none !important;
    background: rgba(45, 95, 63, 0.15) !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    color: #2d5f3f !important;
    flex-shrink: 0 !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
}

.kkhk-mobile-search-clear.visible {
    display: flex !important;
}

.kkhk-mobile-search-clear:hover {
    background: rgba(45, 95, 63, 0.25) !important;
    color: #1f4a2e !important;
}

.kkhk-mobile-search-results {
    display: none !important;
    margin-top: 12px !important;
}

.kkhk-mobile-search-results.visible {
    display: block !important;
}

.kkhk-mobile-search-loading {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 20px !important;
    color: #666 !important;
    font-size: 0.9rem !important;
}

.kkhk-mobile-search-loading.visible {
    display: flex !important;
}

.kkhk-mobile-search-loading .kkhk-search-spinner {
    width: 24px !important;
    height: 24px !important;
}

.kkhk-mobile-search-empty {
    display: none !important;
    padding: 20px !important;
    text-align: center !important;
    color: #999 !important;
    font-size: 0.9rem !important;
}

.kkhk-mobile-search-empty.visible {
    display: block !important;
}

.kkhk-mobile-search-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 10px 0 !important;
    text-decoration: none !important;
    border-bottom: 1px solid #f0f0f0 !important;
}

.kkhk-mobile-search-item:last-child {
    border-bottom: none !important;
}

.kkhk-mobile-search-item img {
    width: 48px !important;
    height: 48px !important;
    border-radius: 8px !important;
    object-fit: cover !important;
    background: #f0f0f0 !important;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.kkhk-mobile-search-item-info {
    flex: 1 !important;
    min-width: 0 !important;
}

.kkhk-mobile-search-item-title {
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: #1A1A1A !important;
    margin: 0 0 2px 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.kkhk-mobile-search-item-price {
    font-size: 0.85rem !important;
    color: #2d5f3f !important;
    font-weight: 600 !important;
}

.kkhk-mobile-search-all {
    display: none !important;
    padding: 12px !important;
    margin-top: 8px !important;
    background: #2d5f3f !important;
    color: #FFFFFF !important;
    text-align: center !important;
    border-radius: 10px !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    font-size: 0.9rem !important;
    transition: all 0.2s ease !important;
}

.kkhk-mobile-search-all:hover {
    background: #1f4a2e !important;
}

.kkhk-mobile-search-all.visible {
    display: block !important;
}
