/* Packages Page Styles */

/* Smooth scroll behavior */
html {
    scroll-behavior: smooth;
}

/* Floating animation for suitcase icon */
@keyframes float {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-20px);
    }
}

.animate-float {
    animation: float 6s ease-in-out infinite;
}

/* Card hover effects */
.tool-card {
    transition: all 0.3s ease;
}

.tool-card:hover {
    transform: translateY(-4px);
}

/* Smooth transitions for all interactive elements */
button, a {
    transition: all 0.2s ease;
}

/* Footer links hover effect */
footer a {
    transition: color 0.2s ease;
}

/* Custom scrollbar for webkit browsers */
::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-track {
    background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
    background: #555;
}

/* Mobile responsiveness */
@media (max-width: 768px) {
    .tool-card {
        margin-bottom: 1rem;
    }
}

@media (max-width: 650px) {
    .grid-cols-4 { 
        grid-template-columns: repeat(2, minmax(0, 1fr)); 
    }
}

@media (max-width: 500px) {
    .relative.z-10.max-w-7xl.mx-auto.px-4.py-16 { 
        padding-top: 3rem; 
        padding-bottom: 3rem; 
    }
    
    .flex.flex-wrap.justify-center.gap-8 { 
        gap: 1rem; 
    }
    
    .flex.flex-wrap.justify-center.gap-8 .flex.items-center.gap-2 { 
        width: 100%; 
        justify-content: center; 
    }
    
    .bg-gradient-to-r.from-gray-50.via-white.to-gray-50.py-20 { 
        padding-top: 3rem; 
        padding-bottom: 3rem; 
    }
    
    .bg-white.py-20 { 
        padding-top: 3rem; 
        padding-bottom: 3rem; 
    }
    
    .bg-gradient-to-br.py-20 { 
        padding-top: 3rem; 
        padding-bottom: 3rem; 
    }
    
    .max-w-7xl.mx-auto.px-4.py-16 { 
        padding-top: 3rem; 
        padding-bottom: 3rem; 
    }
    
    .gap-6 { 
        gap: 1rem; 
    }
    
    .flex.flex-wrap.justify-center.gap-4.mb-8 {
        gap: 0.5rem;
    }
    
    .bg-gradient-to-br.rounded-2xl.border-2.p-8 {
        padding: 1.25rem;
    }
    
    /* Package cards - side by side layout on mobile */
    button.outbound-link.text-center {
        display: grid;
        grid-template-columns: auto 1fr auto;
        grid-template-rows: auto auto auto;
        align-items: center;
        text-align: left;
        gap: 0 0.75rem;
        padding: 1rem;
    }
    
    button.outbound-link.text-center .w-16.h-16 {
        grid-row: 1 / 4;
        grid-column: 1;
        margin: 0;
        width: 3rem;
        height: 3rem;
    }
    
    button.outbound-link.text-center .w-16.h-16 span {
        font-size: 1rem;
    }
    
    button.outbound-link.text-center h4 {
        grid-column: 2;
        grid-row: 1;
        margin: 0;
    }
    
    button.outbound-link.text-center p {
        grid-column: 2;
        grid-row: 2;
        margin: 0;
    }
    
    button.outbound-link.text-center > span.inline-block {
        grid-column: 2;
        grid-row: 3;
        margin-top: 0.25rem;
        justify-self: start;
    }
    
    button.outbound-link.text-center::after {
        content: '›';
        grid-column: 3;
        grid-row: 1 / 4;
        font-size: 1.5rem;
        font-weight: 300;
        color: #9ca3af;
        align-self: center;
    }
}

@media (max-width: 350px) {
    .grid-cols-4 { 
        grid-template-columns: repeat(1, minmax(0, 1fr)); 
    }
}

/* Card hover states */
.bg-gray-50.rounded-xl.p-6.text-center.border-2:hover {
    transform: translateY(-2px);
}

/* Category card animations */
.bg-white.rounded-2xl.border-2.border-gray-200 {
    transition: all 0.3s ease;
}

.bg-white.rounded-2xl.border-2.border-gray-200:hover {
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
}

/* Feature icon hover effect */
.bg-white.rounded-xl.p-4.border-2.border-gray-200.text-center:hover .w-12.h-12 {
    transform: scale(1.1);
    transition: transform 0.2s ease;
}

.w-12.h-12 {
    transition: transform 0.2s ease;
}

/* Link arrow animation */
.group:hover svg.group-hover\:translate-x-1 {
    transform: translateX(4px);
}

/* Quick nav buttons */
.flex.flex-wrap.justify-center.gap-4.mb-8 a {
    position: relative;
    overflow: hidden;
}

.flex.flex-wrap.justify-center.gap-4.mb-8 a::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s ease;
}

.flex.flex-wrap.justify-center.gap-4.mb-8 a:hover::after {
    left: 100%;
}

/* Outbound link button hover */
.outbound-link:hover {
    transform: translateY(-2px);
}

/* Responsive image handling */
img {
    max-width: 100%;
    height: auto;
}

/* Print styles */
@media print {
    .bg-gradient-to-br,
    .bg-gradient-to-r {
        background: #f9fafb !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }
    
    a[href]::after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
        color: #6b7280;
    }
}