/* i18n Language Switcher Styles - Enhanced Design */

/* Language switcher container */
.language-switcher {
  position: relative;
  display: inline-block;
  margin-left: 12px;
}

/* Language button - Enhanced visibility */
.language-btn {
  background: rgba(0, 0, 0, 0.3); /* Darker background for better contrast */
  border: 1px solid rgba(255, 255, 255, 0.4); /* Stronger border */
  color: #fff;
  padding: 8px 16px;
  border-radius: 50px; /* Pill shape for modern look */
  cursor: pointer;
  font-size: 14px; /* Slightly larger text */
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s ease;
  backdrop-filter: blur(8px);
  white-space: nowrap;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5); /* Text shadow for legibility */
}

.language-btn:hover {
  background: rgba(0, 0, 0, 0.5);
  border-color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2);
}

.language-btn:active {
  transform: translateY(0);
}

.language-btn i:first-child {
  font-size: 18px; /* Larger icon */
  color: #4facfe; /* Blue accent for icon */
}

.language-btn i:last-child {
  font-size: 12px;
  opacity: 1; /* Full opacity */
  margin-left: 2px;
}

.language-btn span {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
}

/* Dropdown menu - Enhanced design */
.language-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 160px;
  background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
  border: 2px solid rgba(0, 123, 255, 0.2);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px) scale(0.95);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1000;
  overflow: hidden;
  backdrop-filter: blur(10px);
}

.language-switcher:hover .language-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

/* Dropdown items - Modern style */
.language-item {
  display: block;
  padding: 12px 18px;
  color: #2c3e50;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.2s ease;
  cursor: pointer;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  position: relative;
  overflow: hidden;
}

.language-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(0, 123, 255, 0.1), transparent);
  transition: left 0.5s ease;
}

.language-item:hover::before {
  left: 100%;
}

.language-item:last-child {
  border-bottom: none;
}

.language-item:hover {
  background: linear-gradient(135deg, rgba(0, 123, 255, 0.1) 0%, rgba(0, 86, 179, 0.05) 100%);
  color: #007bff;
  padding-left: 24px;
  font-weight: 700;
}

.language-item.active {
  background: linear-gradient(135deg, #007bff 0%, #0056b3 100%);
  color: #fff;
  font-weight: 700;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.language-item.active::after {
  content: "✓";
  float: right;
  margin-left: 12px;
  font-size: 16px;
  font-weight: bold;
  animation: checkmark 0.3s ease;
}

@keyframes checkmark {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

/* Font support for Sinhala and Tamil */
body {
  font-family: 'Roboto', 'Poppins', 'Noto Sans Sinhala', 'Noto Sans Tamil', sans-serif;
}

/* Ensure proper rendering for Sinhala script */
[lang="si"],
[lang="si"] * {
  font-family: 'Noto Sans Sinhala', 'Iskoola Pota', Arial, sans-serif;
}

/* Improve Sinhala text visibility */
[lang="si"] .language-btn span,
[lang="si"] .navmenu a {
  font-weight: 700 !important; /* Bold font for Sinhala header text */
  letter-spacing: 0; /* Remove letter spacing as it can break Sinhala ligatures */
}

/* Ensure proper rendering for Tamil script */
[lang="ta"],
[lang="ta"] * {
  font-family: 'Noto Sans Tamil', 'Latha', Arial, sans-serif;
}

/* Strong overflow prevention for Tamil language */
[lang="ta"] body,
[lang="ta"] html {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}

[lang="ta"] .header .container-fluid {
  padding-left: 5px !important;
  padding-right: 5px !important;
  max-width: 100vw !important;
}

[lang="ta"] .navmenu ul {
  gap: 4px;
  flex-wrap: nowrap;
}

[lang="ta"] .navmenu ul li a,
[lang="ta"] .navmenu ul li span {
  font-size: 11px;
  padding: 8px 6px;
  white-space: nowrap;
}

[lang="ta"] .flag-img {
  height: 42px !important;
  margin-left: 8px !important;
}

[lang="ta"] .language-switcher {
  margin-left: 5px;
}

/* Similar adjustments for Sinhala */
[lang="si"] body,
[lang="si"] html {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}

[lang="si"] .navmenu ul li a,
[lang="si"] .navmenu ul li span {
  font-size: 11px;
  padding: 8px 6px;
}

[lang="si"] .navmenu ul {
  gap: 6px;
}

[lang="si"] .flag-img {
  height: 42px !important;
  margin-left: 10px !important;
}

/* Responsive design */
@media (max-width: 992px) {
  .language-switcher {
    margin-left: 6px;
  }
  
  .language-btn {
    padding: 5px 10px;
    font-size: 11px;
  }
  
  .language-btn span {
    font-size: 10px;
  }
  
  /* Tamil responsive adjustments */
  [lang="ta"] .navmenu ul li a,
  [lang="ta"] .navmenu ul li span {
    font-size: 11px;
  }
  
  [lang="ta"] .flag-img {
    margin-left: 8px !important;
  }
}

@media (max-width: 768px) {
  .language-switcher {
    margin-left: 4px;
  }
  
  .language-btn {
    padding: 5px 8px;
    gap: 4px;
  }
  
  .language-btn i:first-child {
    font-size: 12px;
  }
  
  .language-dropdown {
    min-width: 120px;
  }
  
  .language-item {
    padding: 9px 14px;
    font-size: 12px;
  }
  
  /* Aggressive Tamil mobile adjustments */
  [lang="ta"] .navmenu ul li a,
  [lang="ta"] .navmenu ul li span {
    font-size: 9px !important;
    padding: 6px 4px !important;
  }
  
  [lang="ta"] .logo-img.main-logo {
    height: 50px !important;
  }
  
  [lang="ta"] .flag-img {
    height: 38px !important;
    margin-left: 4px !important;
  }
  
  [lang="ta"] .language-btn {
    padding: 4px 6px !important;
  }
  
  /* Sinhala mobile adjustments */
  [lang="si"] .navmenu ul li a,
  [lang="si"] .navmenu ul li span {
    font-size: 10px;
    padding: 6px 5px;
  }
  
  [lang="si"] .flag-img {
    height: 38px !important;
    margin-left: 5px !important;
  }
}

/* Extra small screens */
@media (max-width: 576px) {
  .language-btn span {
    display: none; /* Hide language code on very small screens */
  }
  
  .language-btn {
    padding: 5px;
    min-width: 32px;
    justify-content: center;
  }
  
  .language-btn i:last-child {
    display: none; /* Hide chevron on mobile */
  }
  
  /* Very small screen Tamil fixes */
  [lang="ta"] .navmenu ul li a,
  [lang="ta"] .navmenu ul li span {
    font-size: 8px !important;
    padding: 5px 3px !important;
  }
  
  [lang="ta"] .logo-img.main-logo {
    height: 42px !important;
  }
  
  [lang="ta"] .flag-img {
    display: none !important; /* Hide flag on very small screens with Tamil */
  }
  
  [lang="si"] .navmenu ul li a,
  [lang="si"] .navmenu ul li span {
    font-size: 9px !important;
  }
}

/* Smooth transitions for language changes */
[data-i18n] {
  transition: opacity 0.2s ease;
}

/* Loading state */
.i18n-loading [data-i18n] {
  opacity: 0.6;
}
