/**
 * Main Styles for Pet Match App
 */

* {
  /* box-sizing: border-box; */
  margin: 0;
  padding: 0;
}

html {
  font-size: var(--font-size-base);
  -webkit-font-smoothing: antialiased;
  /* -moz-osx-font-smoothing: grayscale; */
}

body {
  font-family: var(--font-family);
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  line-height: 1.6;
  /* overflow-x: hidden; */
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
  /* margin-bottom: var(--spacing-md); */
}

h1 {
  font-size: var(--font-size-2xl);
}
h2 {
  font-size: var(--font-size-xl);
}
h3 {
  font-size: var(--font-size-lg);
}
h4 {
  font-size: var(--font-size-base);
}

p {
  margin-bottom: var(--spacing-md);
}

a {
  color: var(--primary-color);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--primary-hover);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  border: none;
  border-radius: var(--border-radius-lg);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-primary {
  background-color: var(--primary-color);
  color: var(--text-light);
}

.btn-primary.disabled {
  display: none;
}

.btn-primary:hover:not(:disabled) {
  background-color: var(--primary-hover);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px var(--shadow-lg);
}

.btn-secondary {
  background-color: var(--secondary-color);
  color: var(--text-light);
}

.btn-secondary:hover:not(:disabled) {
  background-color: var(--secondary-hover);
}

/* Brand container with subscription indicator */
.brand-container {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.subscription-indicator {
  position: absolute;
  bottom: -8px;
  right: -12px;
  font-size: 0.75rem;
  padding: 4px;
  border-radius: 50%;
  background: var(--bg-primary);
  box-shadow: 0 2px 4px var(--shadow-sm);
}

.subscription-indicator.FREE i {
  color: var(--icon-free);
  filter: drop-shadow(0 0 2px rgba(65, 65, 65, 0.5));
}

.subscription-indicator.PLUS i {
  color: var(--icon-plus);
  filter: drop-shadow(0 0 2px rgba(47, 0, 0, 0.5));
}

.subscription-indicator.GOLD i {
  color: var(--icon-gold);
  filter: drop-shadow(0 0 2px rgba(96, 66, 5, 0.5));
}

.btn-danger {
  background-color: var(--danger-color);
  color: var(--text-light);
}

.btn-success {
  background-color: var(--success-color);
  color: var(--text-light);
}

.btn-icon {
  padding: var(--spacing-sm);
  /* background: rgba(0, 0, 0, 0.7); */
  border: none;
  font-size: var(--font-size-lg);
  color: var(--text-primary);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.btn-icon:hover {
  color: var(--primary-color);
  transform: scale(1.1);
}

.btn-sm {
  padding: var(--spacing-xs) var(--spacing-md);
  font-size: var(--font-size-sm);
}

.btn-lg {
  padding: var(--spacing-lg) var(--spacing-xl);
  font-size: var(--font-size-lg);
}

/* Forms */
.form-group {
  margin-bottom: var(--spacing-lg);
}

.form-group label {
  display: block;
  margin-bottom: var(--spacing-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
}

.form-group label .required {
  color: var(--danger-color);
  margin-left: 2px;
}

.form-control {
  width: 100%;
  padding: var(--spacing-md);
  font-size: var(--font-size-base);
  border: 2px solid var(--border-color);
  border-radius: var(--border-radius-md);
  background-color: var(--bg-primary);
  color: var(--text-primary);
  transition: border-color var(--transition-fast);
}

.form-control:focus {
  outline: none;
  border-color: var(--primary-color);
}
.form-range {
  width: 80%;
}
.input-with-icon {
  position: relative;
}

.input-with-icon i {
  position: absolute;
  left: var(--spacing-md);
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
}

.input-with-icon .form-control {
  padding-left: calc(var(--spacing-md) * 3);
}

.password-toggle {
  position: absolute;
  right: var(--spacing-md);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
}

.form-check {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.form-check-input {
  width: 18px;
  height: 18px;
  cursor: pointer;
}

/* Alerts */
.alert {
  padding: var(--spacing-md);
  border-radius: var(--border-radius-md);
  margin-bottom: var(--spacing-md);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.alert-success {
  background-color: rgba(76, 175, 80, 0.1);
  color: var(--success-color);
  border: 1px solid var(--success-color);
}

.alert-danger {
  background-color: rgba(244, 67, 54, 0.1);
  color: var(--danger-color);
  border: 1px solid var(--danger-color);
}

.alert-warning {
  background-color: rgba(255, 152, 0, 0.1);
  color: var(--warning-color);
  border: 1px solid var(--warning-color);
}

.alert-info {
  background-color: rgba(33, 150, 243, 0.1);
  color: var(--info-color);
  border: 1px solid var(--info-color);
}

/* Cards */
.card {
  background-color: var(--bg-primary);
  border-radius: var(--border-radius-xl);
  box-shadow: 0 2px 12px var(--shadow);
  overflow: hidden;
}

.card-body {
  padding: var(--spacing-lg);
}

.card-footer {
  padding: var(--spacing-lg);
  border-top: 1px solid var(--border-light);
  background-color: var(--bg-secondary);
}

/* Modals */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}

.modal-content {
  position: relative;
  background-color: var(--bg-primary);
  border-radius: var(--border-radius-xl);
  max-width: 500px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 8px 32px var(--shadow-lg);
  animation: modalSlideIn var(--transition-base);
}

@keyframes modalSlideIn {
  from {
    transform: translateY(-50px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-lg);
  border-bottom: 1px solid var(--border-light);
}

.modal-body {
  padding: var(--spacing-lg);
}

.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--spacing-md);
  padding: var(--spacing-lg);
  border-top: 1px solid var(--border-light);
}

.modal-close {
  background: none;
  border: none;
  font-size: var(--font-size-xl);
  cursor: pointer;
  color: var(--text-secondary);
}

/* Loading Spinner */
.spinner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
  padding: var(--spacing-2xl);
}

.fa-spin {
  animation: fa-spin 1s infinite linear;
}

@keyframes fa-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
    transform: scale(1.02);
  }
}

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--text-light);
  background-color: var(--danger-color);
  border-radius: var(--border-radius-full);
}

/* Verified Badge */
.verified-badge {
  color: var(--info-color);
  font-size: var(--font-size-lg);
}

/* Utilities */
.text-center {
  text-align: center;
}
.text-left {
  text-align: left;
}
.text-right {
  text-align: right;
}

.text-muted {
  color: var(--text-muted);
}
.text-primary {
  color: var(--primary-color);
}
.text-danger {
  color: var(--danger-color);
}
.text-success {
  color: var(--success-color);
}

.d-none {
  display: none;
}
.d-block {
  display: block;
}
.d-flex {
  display: flex;
}

.flex-column {
  flex-direction: column;
}
.align-center {
  align-items: center;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}

.gap-sm {
  gap: var(--spacing-sm);
}
.gap-md {
  gap: var(--spacing-md);
}
.gap-lg {
  gap: var(--spacing-lg);
}

.mt-sm {
  margin-top: var(--spacing-sm);
}
.mt-md {
  margin-top: var(--spacing-md);
}
.mt-lg {
  margin-top: var(--spacing-lg);
}

.mb-sm {
  margin-bottom: var(--spacing-sm);
}
.mb-md {
  margin-bottom: var(--spacing-md);
}
.mb-lg {
  margin-bottom: var(--spacing-lg);
}

.p-sm {
  padding: var(--spacing-sm);
}
.p-md {
  padding: var(--spacing-md);
}
.p-lg {
  padding: var(--spacing-lg);
}

/* Photo Gallery for Pet Form */
.photo-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
  min-height: 100px;
}

.photo-card {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  background-color: var(--bg-secondary);
  cursor: pointer;
  transition: transform var(--transition-fast);
}

.photo-card:hover {
  transform: scale(1.02);
}

.add-photo-card {
  border: 2px dashed var(--border-color);
  background-color: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.add-photo-card:hover {
  background-color: var(--bg-secondary);
  border-color: var(--primary-color);
  transform: scale(1.02);
}

.add-photo-card .upload-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  color: var(--text-secondary);
  text-align: center;
}

.add-photo-card:hover .upload-placeholder {
  color: var(--primary-color);
}

.add-photo-card .upload-placeholder i {
  font-size: var(--font-size-2xl);
}

.add-photo-card .upload-placeholder span {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.photo-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.5),
    transparent 30%,
    transparent 70%,
    transparent
  );
  opacity: 0;
  transition: opacity var(--transition-fast);
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: flex-start;
  padding: var(--spacing-sm);
}

.photo-card:hover .photo-overlay {
  opacity: 1;
}

/* On mobile/touch devices, always show photo overlay since there's no hover */
@media (max-width: 768px) {
  .photo-overlay {
    opacity: 1;
    background: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.6),
      transparent 40%,
      transparent
    );
  }
}

.primary-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  background-color: var(--warning-color);
  color: white;
  padding: 8px;
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  z-index: 2;
}

.photo-actions {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  gap: var(--spacing-sm);
  justify-content: flex-end;
  align-items: flex-start;
}

.photo-actions .btn-icon {
  background-color: rgba(0, 0, 0, 0.7);
  color: var(--text-primary);
  border-radius: var(--border-radius-md);
  padding: 8px;
  font-size: var(--font-size-sm);
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
}

.photo-actions .btn-icon:hover {
  background-color: rgba(0, 0, 0, 0.7);
  color: var(--primary-color);
  transform: scale(1.1);
}

.photo-actions .btn-danger:hover {
  background-color: rgba(0, 0, 0, 0.7);
  color: var(--danger-color);
  transform: scale(1.1);
}

.photo-upload-btn-container {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  align-items: flex-start;
}

.text-bold {
  font-weight: var(--font-weight-bold);
}

/* Image modal styles moved to image-modal.css */

/* ===============================================
   NOTIFICATIONS BELL
   =============================================== */

.notification-bell-container {
  position: relative;
}

.notification-bell-btn {
  position: relative;
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--text-primary);
  cursor: pointer;
  padding: var(--spacing-sm);
  transition: all var(--transition-fast);
}

.notification-bell-btn:hover {
  color: var(--primary-color);
  transform: scale(1.1);
}

.notification-badge {
  position: absolute;
  top: 0;
  right: 0;
  background: var(--danger-color);
  color: white;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
  display: none; /* Hidden by default, shown via JS when count > 0 */
}

.notification-badge:empty {
  display: none !important;
}

/* Notifications Dropdown */
.notifications-dropdown {
  position: absolute;
  width: 360px;
  max-height: 500px;
  background-color: var(--bg-secondary);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-lg);
  z-index: 10001; /* Above everything including modals */
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* Desktop positioning - top-right */
@media (min-width: 769px) {
  .notifications-dropdown {
    top: 70px;
    right: 20px;
  }
}

/* Mobile Responsiveness */
@media (max-width: 768px) {
  .notifications-dropdown {
    top: var(--navbar-height, 47px);
    /* left: 0; */
    right: 0;
    /* width: 100%; */
    max-height: calc(100vh - var(--navbar-height, 47px));
    border-radius: 0;
    z-index: 11000; /* Ensure it's above mobile menu (z-index: 10000) */
  }

  /* Ensure mobile notification badge is visible */
  .mobile-notification-bell .notification-badge {
    display: none; /* Hidden by default */
  }

  .mobile-notification-bell .notification-badge[style*="display: block"],
  .mobile-notification-bell
    .notification-badge[style*="display: inline-block"] {
    display: block !important;
  }
}

.notifications-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--border-light);
  background: var(--bg-primary);
}

.notifications-header h3 {
  margin: 0;
  font-size: var(--font-size-lg);
  color: var(--text-primary);
}

.mark-all-read-btn {
  background: none;
  border: none;
  color: var(--primary-color);
  font-size: var(--font-size-sm);
  cursor: pointer;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-sm);
  transition: all var(--transition-fast);
}

.mark-all-read-btn:hover {
  background: var(--bg-primary);
}

.notifications-list {
  flex: 1;
  overflow-y: auto;
  max-height: 400px;
}

.notification-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-md);
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--border-light);
  cursor: pointer;
  transition: all var(--transition-fast);
  background: var(--bg-primary);
}

.notification-item:hover {
  background: var(--bg-primary);
}

.notification-item.unread {
  background: var(--bg-primary);
}

.notification-icon {
  font-size: 1.5rem;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
}

.notification-icon.match {
  background: #ffe5e5;
  color: #ff6b6b;
}

.notification-icon.message {
  background: #e5f3ff;
  color: #4a90e2;
}

.notification-icon.super-like {
  background: #fff3e5;
  color: #ff9f40;
}

.notification-icon.profile-view {
  background: #f0e5ff;
  color: #9b59b6;
}

.notification-content {
  flex: 1;
  min-width: 0;
}

.notification-title {
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 var(--spacing-xs) 0;
  font-size: var(--font-size-base);
}

.notification-body {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  margin: 0 0 var(--spacing-xs) 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* Actor link styling for premium users */
.notification-actor-link {
  color: var(--primary-color);
  font-weight: 600;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.notification-actor-link:hover {
  color: var(--primary-hover);
  text-decoration: underline;
}

.notification-time {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.notifications-loading,
.notifications-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xl);
  color: var(--text-secondary);
  gap: var(--spacing-md);
}

.notifications-empty i {
  color: var(--text-muted);
}

.icon {
  display: inline-block;
  width: 33px;
  height: 32px;
  overflow: hidden;
}
.icon-small {
  display: inline-block;
  width: 20px;
  height: 20px;
  overflow: hidden;
}
.icon-small svg {
  color: #4a90e2;
}

.container {
  /* min-height: calc(100vh - var(--navbar-height)); */
  padding: calc(var(--spacing-md)) var(--spacing-lg) var(--spacing-lg);
  max-width: 1200px;
  margin: 0 auto;
  overflow: visible;
}
.container-header {
  /* justify-content: space-between; */
  align-items: center;
  margin-bottom: var(--spacing-sm);
  display: flex;
  flex-wrap: wrap; /* Wrap to second line if needed */

  /* Align with stats bar height */
  min-height: 38px;
  gap: var(--spacing-md);

  /* Dynamic max-width to prevent button obstruction by stats bar */
  max-width: calc(100% - var(--stats-bar-width, 0px) - var(--spacing-md));
}
.container-greeting {
  font-size: var(--font-size-2xl);
  /* font-weight: var(--font-weight-bold); */
  color: var(--text-primary);
  margin: 0;
  /* flex: 1; */
  min-width: 0;
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  color: var(--text-primary);
  margin: 0;
  /* flex: 1; */
  min-width: 0;
}

/* ==================== GAMIFICATION STATS BAR ==================== */

.gamification-stats-bar {
  display: flex;
  align-items: center;
  max-height: 38px;
  height: 38px;
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-lg);
  padding: 0 var(--spacing-md);
  gap: var(--spacing-md);
  box-shadow: 0 2px 8px var(--shadow);
  overflow: visible;
  /* Re-enable pointer events for the stats bar itself */
  pointer-events: auto;
}

/* Sections */
.stats-section {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  height: 100%;
}

/* Divider */
.stats-divider {
  width: 1px;
  height: 24px;
  background-color: var(--border-color);
  flex-shrink: 0;
}

/* Left Section: Level Info */
.stats-level {
  gap: var(--spacing-md);
}

.level-badge {
  border: 2px solid transparent;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  /* background: linear-gradient(
    135deg,
    var(--primary-color),
    var(--secondary-color)
  ); */
  /* color: white; */
  padding: 2px 10px;
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  min-width: 35px;
  /* max-width: 50px; */
}

.level-badge i {
  font-size: 12px;
}

.level-card.level-1 {
  border-color: rgb(76, 175, 80);
  background: linear-gradient(135deg, rgba(76, 175, 80, 0.5), transparent);
  color: rgb(76, 175, 80);
}
.level-card.level-2 {
  border-color: #2196f3;
  background: linear-gradient(135deg, rgba(33, 150, 243, 0.5), transparent);
  color: #2196f3;
}
.level-card.level-3 {
  border-color: #9c27b0;
  background: linear-gradient(135deg, rgba(156, 39, 176, 0.5), transparent);
  color: #9c27b0;
}
.level-card.level-4 {
  border-color: #ff9800;
  background: linear-gradient(135deg, rgba(255, 152, 0, 0.5), transparent);
  color: #ff9800;
}
.level-card.level-5 {
  border-color: #ffc107;
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.5), transparent);
  color: #ffc107;
}

.level-card.level-1 .level-icon::before {
  color: #4caf50;
  font-family: "Font Awesome 5 Free";
  content: "\f4d8";
}
.level-card.level-2 .level-icon::before {
  color: #2196f3;
  font-family: "Font Awesome 5 Free";
  content: "\f500";
}
.level-card.level-3 .level-icon::before {
  color: #9c27b0;
  font-family: "Font Awesome 5 Free";
  content: "\f1b0";
}
.level-card.level-4 .level-icon::before {
  color: #ff9800;
  font-family: "Font Awesome 5 Free";
  content: "\f521";
}
.level-card.level-5 .level-icon::before {
  color: #ffc107;
  font-family: "Font Awesome 5 Free";
  content: "\f091";
}

.level-number {
  font-size: var(--font-size-base);
}

.level-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  /* min-width: 120px; */
}

.level-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  line-height: 1;
}

.level-progress-wrapper {
  display: flex;
  align-items: center;
  gap: 6px;
}

.level-progress-bar {
  flex: 1;
  height: 4px;
  background-color: var(--bg-secondary);
  border-radius: 2px;
  overflow: hidden;
  min-width: 60px;
}

.level-progress-fill {
  height: 100%;
  background: linear-gradient(
    90deg,
    var(--success-color),
    var(--primary-color)
  );
  border-radius: 2px;
  transition: width var(--transition-base);
}

.level-progress-text {
  font-size: 10px;
  color: var(--text-muted);
  white-space: nowrap;
  font-weight: var(--font-weight-medium);
}

/* Center Section: Stats Metrics */
.stats-metrics {
  flex: 1;
  justify-content: space-around;
  gap: var(--spacing-lg);
}

.stat-item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.stat-item i {
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.stat-points i {
  color: var(--warning-color);
}

.stat-streak i {
  color: var(--danger-color);
}

.stat-matches i {
  color: var(--primary-color);
}

.stat-content {
  display: flex;
  flex-direction: column;
  gap: 0;
  line-height: 1;
}

.stat-value {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.stat-label {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* Right Section: Recent Achievements */
.stats-achievements {
  gap: var(--spacing-sm);
  /* min-width: 120px; */
}

.achievements-header {
  display: flex;
  align-items: center;
  gap: 4px;
}

.achievements-header i {
  color: var(--warning-color);
  font-size: 14px;
}

.achievements-title {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.achievements-list {
  display: flex;
  align-items: center;
  gap: 4px;
}

.achievement-badge {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--warning-color), #f59e0b);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: transform var(--transition-fast);
  cursor: pointer;
}

.achievement-badge:hover {
  transform: scale(1.15);
}

.achievement-count {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: var(--font-weight-semibold);
  margin-left: 2px;
}

.no-achievements {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 12px;
}

/* Quick Action Button */
.stats-action {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--border-radius-md);
  background-color: var(--bg-secondary);
  color: var(--primary-color);
  transition: all var(--transition-fast);
  flex-shrink: 0;
  border: 1px solid var(--border-color);
}

.stats-action:hover {
  background-color: var(--primary-light);
  transform: scale(1.05);
  border-color: var(--primary-color);
}

.stats-action i {
  font-size: 14px;
}

.stats-toggle i {
  transition: transform var(--transition-fast);
}

.stats-toggle.active i {
  transform: rotate(180deg);
  /* background-color: var(--primary-light); */
  border-color: var(--primary-color);
}

/* ==================== STATS EXTENSION ==================== */
.gamification-stats-bar-wrapper {
  position: sticky;
  top: var(--navbar-height);
  z-index: 1020; /* Below navbar (1030) but above other content */
  background: transparent;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--spacing-lg);
  padding-right: var(--spacing-lg);
  /* Match container width constraints */
  max-width: 1200px;
  display: flex;
  justify-content: flex-end;
  /* Consistent height with container-header */
  min-height: 38px;
  align-items: center;
  /* Allow clicks to pass through wrapper to elements beneath */
  pointer-events: none;
}

.stats-extension {
  position: absolute;
  top: 100%;

  /* right: 0; */
  background: var(--bg-primary);
  border: 1px solid var(--border-color);

  border-radius: var(--border-radius-lg);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  z-index: 100;
  overflow: hidden;
  transition: all var(--transition-normal);
  /* Prevent full width expansion */
  width: auto;
  max-width: min(500px, calc(100vw - var(--spacing-lg) * 2));
  /* min-width: 300px; */
  /* Re-enable pointer events for extension dropdown */
  pointer-events: auto;
}

.stats-extension.show {
  animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.extension-content {
  display: flex;
  flex-direction: column;
}

/* Extension Rows - Match Status Bar Height */
.extension-row {
  display: flex;
  align-items: center;
  height: 38px;
  padding: 0 var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
  gap: var(--spacing-md);
}

.extension-row:last-child {
  border-bottom: none;
}

.extension-row .stat-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  /* flex: 1; */
  /* min-width: 0; */
}

.extension-row .stat-item i {
  font-size: 16px;
  flex-shrink: 0;
}

.extension-row .stat-content {
  display: flex;
  align-items: baseline;
  gap: 4px;
  min-width: 0;
}

.extension-row .stat-value {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.extension-row .stat-label {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.3px;
}

/* Icon Colors */
.extension-row .stat-streak i {
  color: #ef4444; /* Red for streak */
}

.extension-row .stat-rating i {
  color: #f97316; /* Orange for ratings */
}
.extension-row-achievements i {
  color: var(--warning-color); /* Orange for acheivement icon */
}
/* Achievements Row - Compact */
.extension-row-achievements {
  height: auto;
  min-height: 38px;
  padding: var(--spacing-xs) var(--spacing-md);
  /* flex-flow: row-reverse; */
}

.achievements-compact {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

.achievement-badge-compact {
  width: 32px;
  height: 32px;
  border-radius: var(--border-radius-circle);
  background: linear-gradient(135deg, #f97316, #ea580c); /* Orange gradient */
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 16px;
  cursor: pointer;
  transition: all var(--transition-fast);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.achievement-badge-compact:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.achievement-count-compact {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  font-weight: var(--font-weight-semibold);
  margin-left: var(--spacing-xs);
}

/* Rewards Row - Compact */
.extension-row-rewards {
  height: auto;
  min-height: 38px;
  padding: var(--spacing-xs) var(--spacing-md);
}
.extension-row-rewards i {
  color: var(--secondary-color); /* Awards icon */
}
.rewards-compact {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
  /* width: 100%; */
}

.rewards-compact .stat-item {
  flex: 0 0 auto;
  min-width: 0;
}

.reward-badge-compact {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  transition: all var(--transition-fast);
}

.reward-badge-compact:hover {
  border-color: var(--primary-light);
  transform: translateY(-1px);
}

.reward-badge-compact i {
  font-size: 14px;
  color: var(--primary-color);
}

.reward-badge-compact .reward-name {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.reward-badge-compact .reward-claim-btn-compact {
  padding: 2px 8px;
  font-size: var(--font-size-xs);
  background: linear-gradient(
    135deg,
    var(--primary-color),
    var(--primary-dark)
  );
  color: white;
  border: none;
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast);
}

.reward-badge-compact .reward-claim-btn-compact:hover {
  transform: scale(1.05);
}

.reward-badge-compact .reward-claim-btn-compact:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.reward-claimed-compact {
  opacity: 0.6;
  border-color: var(--success-color);
}

.reward-claimed-compact i {
  color: var(--success-color);
}

/* Scalable Container 
     Using 'em' means the box size is relative to the font-size.
     If you set font-size: 50px on this div, the width becomes ~90px automatically.
  */
.paw-container {
  position: relative;
  display: inline-block;
  width: 1.3em; /* Width relative to font size */
  height: 1em; /* Height relative to font size */
  vertical-align: middle; /* Aligns nicely with text */
}

/* Shared styles */
.paw-icon {
  position: absolute;
  width: 100%; /* Fills the container width context */
  line-height: 1; /* Prevents line-height issues */
}

/* The Paw Behind */
.paw-back {
  left: 10%; /* Start at the far left */
  top: -5%; /* Push down by 20% of container height */
  opacity: 0.7; /* 50% transparent to look like a shadow/background */
  transform: rotate(30deg);
  z-index: 1;
}

/* The Paw in Front */
.paw-front {
  left: -10%; /* Push right by 40% of container width */
  top: -20%; /* Align to top */
  transform: rotate(-30deg);
  z-index: 2;
}

/* Scalable Container */
.paws-like-container {
  /* position: relative;
  display: inline-block;
  /* Adjusted width/height for the new symmetrical layout */

  /*  vertical-align: middle; */
}

/* The Paw on the Left (Tilted Right) */
.paw-left {
  left: -20%; /* Start at the far left */
  top: 50%; /* Slight lift */
  opacity: 0.8; /* Nearly full opacity */
  transform: rotate(30deg); /* Highly tilted inwards */
  z-index: 1;
}

/* The Paw on the Right (Tilted Left) */
.paw-right {
  left: 20%; /* Pushed right to create space/overlap */
  top: 50%; /* Same lift as the left paw */
  opacity: 1; /* Full opacity on the front paw */
  transform: rotate(-30deg); /* Highly tilted inwards (symmetrical) */
  z-index: 2;
}
/* ==================== MOBILE RESPONSIVE ==================== */
@media (max-width: 1200px) {
  .gamification-stats-bar {
    padding: 0 var(--spacing-sm);
    gap: var(--spacing-sm);
    /* height: auto; */
  }
  .level-progress-text {
    display: none;
  }
  .stat-label {
    display: none;
  }
  .achievements-title {
    display: none;
  }

  .level-progress-wrapper {
    max-width: 90px;
  }
}

@media (max-width: 768px) {
  .gamification-stats-bar {
    padding: 0 var(--spacing-sm);
    gap: var(--spacing-sm);
    /* height: auto; */
    /* width: 100%; */
  }
  .level-badge {
    padding: 1px 2px;
    min-width: 40px;
    gap: 1px;
  }
  .stats-level {
    gap: var(--spacing-xs);
  }

  /* {
    padding: calc(var(--navbar-height)) var(--spacing-md) var(--spacing-lg);
  } */
  .container-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .container-greeting {
    /* flex-direction: column; */
  }

  .level-name {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
  }
  .stats-metrics {
    gap: var(--spacing-xs);
    /* flex: 1 1 100%;
    justify-content: space-between; */
  }

  .stat-item {
    gap: 2px;
  }

  .stat-item i {
    font-size: 14px;
    width: auto;
  }

  .stat-value {
    font-size: var(--font-size-sm);
  }

  .stats-achievements {
    min-width: auto;
  }

  .stats-divider {
    display: none;
  }

  .stats-action {
    width: 28px;
    height: 28px;
  }
}
