/* Accommodation Page Styles */

/* Smooth scroll behavior */
html {
    scroll-behavior: smooth;
}

/* Hero section animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.main-title {
    animation: fadeInUp 0.8s ease-out;
}

/* Floating animation for house 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-10 { 
        gap: 1rem; 
        margin-top: 40px; 
    }
    
    .flex.flex-wrap.justify-center.gap-10 .flex.items-center.gap-2 { 
        width: 100%; 
        justify-content: center; 
    }
    
    .bg-gradient-to-r.from-gray-50.via-white.to-gray-50.py-16 { 
        padding-top: 2rem; 
        padding-bottom: 2rem; 
    }
    
    .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.items-center.gap-3.backdrop-blur-sm.px-6.py-4.rounded-xl.border { 
        padding: 0.5rem; 
    }
    
    .flex.items-center.gap-3.backdrop-blur-sm.px-6.py-4.rounded-xl.border .flex.items-center.gap-3 { 
        gap: 0.5rem; 
    }
}

@media (max-width: 350px) {
    .grid-cols-4 { 
        grid-template-columns: repeat(1, minmax(0, 1fr)); 
    }
}

/* Anchor link offset for fixed header - removed */

/* Hotel/booking card hover states */
.bg-white.rounded-xl.p-4.border-2:hover {
    transform: translateY(-2px);
}

/* Category card animations */
.bg-white.rounded-2xl.border-2.border-gray-200.p-6 {
    transition: all 0.3s ease;
}

.bg-white.rounded-2xl.border-2.border-gray-200.p-6: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);
}

/* Badge styling */
.bg-green-600.text-white.text-xs.font-bold.px-3.py-1.rounded-full,
.bg-blue-600.text-white.text-xs.font-bold.px-3.py-1.rounded-full,
.bg-purple-600.text-white.text-xs.font-bold.px-3.py-1.rounded-full,
.bg-yellow-500.text-white.text-xs.font-bold.px-3.py-1.rounded-full,
.bg-green-500.text-white.text-xs.font-bold.px-3.py-1.rounded-full {
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Info box styling */
.bg-blue-50.rounded-xl,
.bg-purple-100.rounded-xl,
.bg-green-50.rounded-xl,
.bg-amber-100.rounded-xl {
    position: relative;
}

/* Gradient overlays for section backgrounds */
.bg-gradient-to-br.from-purple-50.to-indigo-50::before,
.bg-gradient-to-br.from-amber-50.to-orange-50::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 2px 2px, rgba(99, 102, 241, 0.03) 1px, transparent 0);
    background-size: 40px 40px;
    pointer-events: none;
}

/* Quick nav buttons */
.flex.flex-wrap.justify-center.gap-4.mb-12 a {
    position: relative;
    overflow: hidden;
}

.flex.flex-wrap.justify-center.gap-4.mb-12 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-12 a:hover::after {
    left: 100%;
}

/* Villa features grid icons */
.grid.grid-cols-2.sm\:grid-cols-3.md\:grid-cols-4.lg\:grid-cols-6 .bg-white {
    cursor: default;
}

/* CTA section button effects */
.bg-gradient-to-br.from-indigo-600.to-purple-700 a {
    position: relative;
    overflow: hidden;
}

/* 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;
    }
}