/**
 * Modern Components Stylesheet
 * Header & Footer - Based on Figma Design System
 */

/* =============================================
   MODERN HEADER ENHANCEMENTS
   ============================================= */

/* Scrolled Header State */
.header.scrolled {
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-md);
}

/* Mobile Menu Styles */
@media (max-width: 768px) {
  .nav-menu {
    position: fixed;
    left: -100%;
    top: 76px;
    flex-direction: column;
    background-color: white;
    width: 100%;
    text-align: center;
    transition: var(--transition-medium);
    box-shadow: var(--shadow-lg);
    padding: var(--spacing-8) 0;
    max-height: calc(100vh - 76px);
    overflow-y: auto;
    z-index: var(--z-dropdown);
  }

  .nav-menu.active {
    left: 0;
  }

  .nav-menu li {
    width: 100%;
    padding: var(--spacing-2) 0;
  }

  .nav-link {
    padding: var(--spacing-3) var(--spacing-6);
    display: block;
    font-size: var(--font-size-lg);
  }

  .hamburger.active span:nth-child(2) {
    opacity: 0;
  }

  .hamburger.active span:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
  }

  .hamburger.active span:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
  }
}

/* =============================================
   MODERN FOOTER STYLES
   ============================================= */

.modern-footer {
  position: relative;
  background: linear-gradient(to bottom, var(--gray-900), #000000);
  color: white;
  padding: var(--spacing-20) 0 var(--spacing-8);
  overflow: hidden;
}

.footer-gradient {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--accent-amber-500),
    transparent
  );
}

.footer-content {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--spacing-12);
  margin-bottom: var(--spacing-12);
}

@media (max-width: 1024px) {
  .footer-content {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-8);
  }
}

@media (max-width: 640px) {
  .footer-content {
    grid-template-columns: 1fr;
    gap: var(--spacing-8);
    text-align: center;
  }
}

/* Footer Brand Section */
.footer-brand {
  padding-right: var(--spacing-8);
}

.footer-logo {
  font-family: var(--font-display);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--accent-amber-500);
  margin-bottom: var(--spacing-4);
}

.footer-description {
  color: var(--gray-400);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-6);
  font-size: var(--font-size-sm);
}

/* Social Links */
.social-links-modern {
  display: flex;
  gap: var(--spacing-4);
}

@media (max-width: 640px) {
  .social-links-modern {
    justify-content: center;
  }
}

.social-link-modern {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-800);
  color: white;
  transition: var(--transition-base);
  font-size: var(--font-size-lg);
}

.social-link-modern:hover {
  background: var(--accent-amber-600);
  transform: translateY(-3px) rotate(5deg);
  box-shadow: var(--shadow-amber);
}

.social-link-modern.facebook:hover {
  background: #1877f2;
}

.social-link-modern.instagram:hover {
  background: linear-gradient(
    45deg,
    #f09433,
    #e6683c,
    #dc2743,
    #cc2366,
    #bc1888
  );
}

.social-link-modern.twitter:hover {
  background: #1da1f2;
}

/* Footer Heading */
.footer-heading {
  color: white;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-4);
}

/* Footer Links */
.footer-links {
  list-style: none;
  padding: 0;
  display: block !important;
}

.footer-links li {
  margin-bottom: var(--spacing-2);
  display: block !important;
}

.footer-links a {
  color: var(--gray-400);
  transition: var(--transition-base);
  font-size: var(--font-size-sm);
  display: block !important;
  width: 100%;
}

.footer-links a:hover {
  color: var(--accent-amber-500);
  transform: translateX(5px);
}

/* Hours List */
.hours-list {
  list-style: none;
  padding: 0;
}

.hours-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-2) 0;
  color: var(--gray-400);
  font-size: var(--font-size-sm);
  border-bottom: 1px solid var(--gray-800);
}

.hours-list li:last-child {
  border-bottom: none;
}

.hours-list li span:first-child {
  font-weight: var(--font-weight-medium);
  color: var(--gray-300);
}

@media (max-width: 640px) {
  .hours-list li {
    flex-direction: column;
    text-align: center;
    gap: var(--spacing-1);
  }
}

/* Contact Info List */
.contact-info-list {
  list-style: none;
  padding: 0;
}

.contact-info-list li {
  display: flex;
  gap: var(--spacing-3);
  align-items: flex-start;
  margin-bottom: var(--spacing-4);
  color: var(--gray-400);
  font-size: var(--font-size-sm);
}

.contact-info-list li i {
  color: var(--accent-amber-500);
  font-size: var(--font-size-lg);
  width: 20px;
  flex-shrink: 0;
  margin-top: var(--spacing-1);
}

@media (max-width: 640px) {
  .contact-info-list li {
    justify-content: center;
  }
}

/* Footer Bottom */
.footer-bottom {
  padding-top: var(--spacing-8);
  border-top: 1px solid var(--gray-800);
  text-align: center;
}

.copyright {
  color: var(--gray-400);
  font-size: var(--font-size-sm);
  margin-bottom: var(--spacing-4);
}

.footer-bottom-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-2);
  margin-bottom: var(--spacing-4);
  flex-wrap: wrap;
}

.footer-bottom-links a {
  color: var(--gray-400);
  transition: var(--transition-base);
  font-size: var(--font-size-sm);
}

.footer-bottom-links a:hover {
  color: var(--accent-amber-500);
}

.footer-bottom-links .separator {
  color: var(--gray-600);
  font-size: var(--font-size-sm);
}

.admin-link {
  color: var(--gray-500);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
}

.admin-link:hover {
  color: var(--accent-amber-500);
}

.developer-credit {
  color: var(--gray-500);
  font-size: var(--font-size-xs);
  margin-top: var(--spacing-2);
}

.developer-name {
  color: var(--accent-amber-500);
  font-weight: var(--font-weight-semibold);
}

/* =============================================
   ANIMATIONS
   ============================================= */

@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* =============================================
   UTILITY CLASSES
   ============================================= */

.fade-in-up {
  animation: fadeInUp 0.6s ease-out;
}

.slide-in-right {
  animation: slideInRight 0.5s ease-out;
}

.slide-in-left {
  animation: slideInLeft 0.5s ease-out;
}
