/* Tailwind CSS Custom Configuration */
@import 'tailwindcss/base';
@import 'tailwindcss/components';
@import 'tailwindcss/utilities';

/* Custom CSS Variables for Brand Colors */
:root {
    --dark-green: #0B3D2E;
    --dark-brown: #3E2C23;
    --golden: #D4AF37;
    --pale-cream: #F5F3EE;
    --pure-white: #FFFFFF;
}

/* Custom Tailwind Color Classes */
.text-dark-green { color: var(--dark-green); }
.text-dark-brown { color: var(--dark-brown); }
.text-golden { color: var(--golden); }
.text-pale-cream { color: var(--pale-cream); }
.text-pure-white { color: var(--pure-white); }

.bg-dark-green { background-color: var(--dark-green); }
.bg-dark-brown { background-color: var(--dark-brown); }
.bg-golden { background-color: var(--golden); }
.bg-pale-cream { background-color: var(--pale-cream); }
.bg-pure-white { background-color: var(--pure-white); }

.border-dark-green { border-color: var(--dark-green); }
.border-dark-brown { border-color: var(--dark-brown); }
.border-golden { border-color: var(--golden); }
.border-pale-cream { border-color: var(--pale-cream); }

.hover\:text-golden:hover { color: var(--golden); }
.hover\:text-dark-brown:hover { color: var(--dark-brown); }
.hover\:text-pure-white:hover { color: var(--pure-white); }

.hover\:bg-golden:hover { background-color: var(--golden); }
.hover\:bg-dark-green:hover { background-color: var(--dark-green); }
.hover\:bg-pale-cream:hover { background-color: var(--pale-cream); }

.focus\:ring-golden:focus { 
    --tw-ring-color: var(--golden);
    --tw-ring-opacity: 0.5;
}

/* New Hero Section Styles */
        .hero-background-image {
            background-image: url('/img/chandehero.jpg');
            background-size: cover;
            background-position: center;
        }
        
        .roast-hero-background-image {
            background-image: url('/img/k2.jpg');
            background-size: cover;
            background-position: center;
        }
        .shop-hero-background-image {
            background-image: url('/img/shop22.jpg');
            background-size: cover;
            background-position: center;
        }
        .news-hero-background-image {
            background-image: url('/img/newabout.jpg');
            background-size: cover;
            background-position: center;
        }
        .contact-hero-background-image {
            background-image: url('/img/contact2.jpg');
            background-size: cover;
            background-position: center;
        }
        .about2-hero-background-image {
            background-image: url('/img/shop2.jpg');
            background-size: cover;
            background-position: center;
        }
/* Coffee Pattern Background */
.coffee-pattern {
    background-image: 
        radial-gradient(circle at 25% 25%, #fff 2px, transparent 2px), 
        radial-gradient(circle at 75% 75%, #fff 1px, transparent 1px);
    background-size: 50px 50px, 30px 30px;
}

/* Custom Font Families */
.font-serif {
    font-family: 'Playfair Display', serif;
}

.font-sans {
    font-family: 'Lato', sans-serif;
}

/* Smooth Scrolling */
html {
    scroll-behavior: smooth;
}

/* Custom Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in-up {
    animation: fadeInUp 0.6s ease-out;
}

/* Custom Hover Effects */
.group:hover .group-hover\:scale-110 {
    transform: scale(1.1);
}

.group:hover .group-hover\:text-golden {
    color: var(--golden);
}

.group:hover .group-hover\:text-dark-brown {
    color: var(--dark-brown);
}

.group:hover .group-hover\:bg-golden {
    background-color: var(--golden);
}

/* Navigation Enhancements */
nav {
    transition: all 0.3s ease;
}

nav.shadow-lg {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

/* Button Hover Effects */
button:hover {
    transform: translateY(-1px);
}

/* Card Hover Effects */
.hover\:-translate-y-2:hover {
    transform: translateY(-0.5rem);
}

/* Backdrop Blur Support */
.backdrop-blur-sm {
    backdrop-filter: blur(4px);
}

/* Custom Gradient Backgrounds */
.bg-gradient-to-br {
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}

.bg-gradient-to-r {
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

/* Responsive Typography */
@media (max-width: 768px) {
    .text-5xl { font-size: 2.25rem; }
    .text-6xl { font-size: 2.5rem; }
    .text-7xl { font-size: 3rem; }
    .text-4xl { font-size: 1.875rem; }
    .text-xl { font-size: 1rem; }
}

/* Custom Spacing */
.space-y-8 > * + * {
    margin-top: 2rem;
}

.space-y-6 > * + * {
    margin-top: 1.5rem;
}

.space-y-4 > * + * {
    margin-top: 1rem;
}

/* Loading States */
.loading {
    opacity: 0.7;
    pointer-events: none;
}

/* Accessibility Improvements */
button:focus,
a:focus,
input:focus {
    outline: 2px solid var(--golden);
    outline-offset: 2px;
}

/* Print Styles */
@media print {
    .fixed,
    .sticky {
        position: static;
    }
    
    .shadow-lg,
    .shadow-2xl {
        box-shadow: none;
    }
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    .opacity-70 {
        opacity: 1;
    }
    
    .text-pale-cream {
        color: var(--pure-white);
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

@keyframes landscape-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.animate-landscape-scroll {
  display: flex;
  width: 200%;
  animation: landscape-scroll 30s linear infinite;
}

.animate-landscape-scroll:hover {
  animation-play-state: paused; /* Pause when hovered */
}

.bg-dark-brown {
  background-color: #3b2f2f;
}