/* Notification styles */
@keyframes slideIn {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

/* S'assurer que .hidden fonctionne bien */
.hidden {
  display: none !important;
}

/* Shared user-menu controls dropdown placement and responsive behavior */
.edit-pseudo-btn {
  background: none;
  border: none;
  color: var(--primary-color);
  cursor: pointer;
  font-size: 1rem;
  margin-left: 8px;
  transition: color 0.2s;
}
.edit-pseudo-btn:hover {
  color: var(--secondary-color);
}
/* ------------------------------------------------------ */
/* Variables, Reset                                       */
/* ------------------------------------------------------ */

:root {
  --primary-color: #6366f1;
  --secondary-color: #8b5cf6;
  --success-color: #10b981;
  --danger-color: #ef4444;
  --warning-color: #f59e0b;
  --info-color: #3b82f6;
  --dark-bg: #0f172a;
  --card-bg: #1e293b;
  --card-border: #334155;
  --text-primary: #f1f5f9;
  --text-secondary: #94a3b8;
  --hover-color: #475569;
  --shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
  --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }

body {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background-color: var(--dark-bg);
  color: var(--text-primary);
  line-height: 1.6;
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

/* ------------------------------------------------------ */
/* Header                                                 */
/* ------------------------------------------------------ */

header {
  background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
  padding: 1rem 0;
  border-bottom: 1px solid var(--card-border);
  position: relative;

  z-index: 100;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

#header-content { gap: 1.5rem; }
#title-container { flex: 1; text-align: center; }
#page-meta { margin-top: 0.5rem; font-size: 0.9rem; color: var(--text-secondary); }

.dancing-script-title {
  font-family: "Dancing Script", cursive;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 2.5rem;
  background: linear-gradient(45deg, #6366f1, #8b5cf6);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: 0;
}

/* ------------------------------------------------------ */
/* Buttons                                                */
/* ------------------------------------------------------ */

.btn-primary, .btn-secondary, .btn-danger, .btn-success {
  padding: 0.75rem 1.5rem;
  border-radius: 0.75rem;
  border: none;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.95rem;
}

.btn-primary { background: linear-gradient(135deg, var(--primary-color), var(--secondary-color)); color: white; }
.btn-secondary { background: var(--card-bg); color: var(--text-primary); border: 1px solid var(--card-border); }
.btn-danger { background: linear-gradient(135deg, var(--danger-color), #dc2626); color: white; }
.btn-success { background: linear-gradient(135deg, var(--success-color), #059669); color: white; }

.btn-primary:hover, .btn-secondary:hover, .btn-danger:hover, .btn-success:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.survey-card button.btn-secondary { margin-top: 0.5rem; float: right; }

/* ------------------------------------------------------ */
/* Loading & states                                       */
/* ------------------------------------------------------ */

.loading-container {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 400px; gap: 1rem; flex: 1;
}

.spinner {
  width: 50px; height: 50px; border: 3px solid var(--card-border);
  border-top-color: var(--primary-color); border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }
.hidden { display: none !important; }

.empty-state {
  text-align: center; padding: 3rem; color: var(--text-secondary);
  background: var(--card-bg); border-radius: 1rem; border: 1px solid var(--card-border);
  margin: 1rem 0;
}

.empty-state i { font-size: 3rem; margin-bottom: 1rem; opacity: 0.5; }
.empty-state button { margin-top: 1rem; }

/* ------------------------------------------------------ */
/* Dashboard & grid                                       */
/* ------------------------------------------------------ */

.dashboard-container {
  max-width: 1400px;
  margin: 2rem auto;
  padding: 0 1rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  flex: 1;
}

.welcome-card {
  background: var(--card-bg);
  border-radius: 1rem;
  padding: 2rem;
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  text-align: center;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.1), rgba(139, 92, 246, 0.1));
}

.welcome-card h2 { display: flex; align-items: center; justify-content: center; gap: 0.75rem; margin-bottom: 0.5rem; }

.surveys-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

@media (max-width: 1024px) {
  .surveys-grid { grid-template-columns: 1fr; }
}

/* Colonne & header */
.surveys-column { display: flex; flex-direction: column; }

.column-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1.5rem; padding: 1rem 1.5rem;
  background: var(--card-bg); border-radius: 1rem; border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
}

.column-header h3 { display: flex; align-items: center; gap: 0.75rem; margin: 0; }

.badge {
  background: var(--primary-color); color: white;
  padding: 0.25rem 0.75rem; border-radius: 1rem; font-size: 0.9rem; font-weight: 600;
  min-width: 2rem; text-align: center;
}

.surveys-list { display: grid; gap: 1rem; flex: 1; }

/* ------------------------------------------------------ */
/* Cards                                                  */
/* ------------------------------------------------------ */

.survey-card {
  background: transparent;
  background-color: transparent;
  background-image: none;
  border-radius: 30px;
  padding: 1.5rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  transition: var(--transition);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(2, 6, 23, 0.28);
}

.survey-card:hover {
  transform: translateY(-4px);
  border-color: var(--primary-color);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.4);
}

.survey-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 4px; background: linear-gradient(90deg, #6366f1, #8b5cf6);
}
.survey-card.closed::before { background: linear-gradient(90deg, #ef4444, #dc2626); }

.survey-card-header {
  display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1rem;
}

.survey-theme { font-weight: 600; font-size: 1.2rem; color: var(--text-primary); line-height: 1.4; flex: 1; }

.survey-title-line {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  flex: 1 1 auto;
}

.survey-title-line .survey-theme {
  flex: 0 1 auto;
  min-width: 0;
  overflow-wrap: anywhere;
}

.survey-status {
  display: flex; align-items: center; gap: 0.5rem; padding: 0.25rem 0.75rem;
  border-radius: 1rem; font-size: 0.85rem; font-weight: 600;
}
.survey-status.open { background: rgba(16, 185, 129, 0.1); color: #10b981; }
.survey-status.closed { background: rgba(239, 68, 68, 0.1); color: #ef4444; }

.survey-details {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem;
  margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--card-border);
}

.detail-item { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; color: var(--text-secondary); }
.detail-item i { width: 16px; color: var(--primary-color); }

.survey-flash-indicator {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
  margin-left: 0;
  padding: 0.18rem 0.56rem 0.2rem 0.46rem;
  border-radius: 999px;
  border: 1px solid rgba(139, 92, 246, 0.58);
  background: transparent;
  color: #c4b5fd;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  line-height: 1;
  white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.survey-flash-indicator svg {
  width: 0.76rem;
  height: 0.76rem;
  flex: 0 0 auto;
  fill: #a78bfa;
  filter: none;
}

/* ------------------------------------------------------ */
/* Mobile segmented control                               */
/* ------------------------------------------------------ */

.mobile-toggle {
  display: none; /* hidden on desktop by default */
}

.toggle-group {
  display: inline-flex;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 999px;
  padding: 0.25rem;
  gap: 0.25rem;
  box-shadow: var(--shadow);
  align-items: center;
  justify-content: center;
}

.toggle-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.toggle-label {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.9rem;
  border-radius: 999px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: var(--transition);
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  outline: none;
}

.toggle-label .badge {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--card-border);
}

.toggle-input:focus + .toggle-label {
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.35);
}

.toggle-input:checked + .toggle-label {
  background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
  color: #fff;
}
.toggle-input:checked + .toggle-label .badge {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
  border-color: transparent;
}

/* Custom modal override (not using Bootstrap's modal JS) */
#confirm-modal.modal,
/* Modals are managed by shared/modal-sheet.css */
#confirm-modal .modal-content,
#edit-pseudo-modal .modal-content {
	width: min(100%, 520px);
}

/* ------------------------------------------------------ */
/* Options de type de sondage */
/* ------------------------------------------------------ */
.survey-type-options {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
}

.survey-type-btn {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--card-border);
  border-radius: 0.75rem;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  transition: var(--transition);
  text-align: center;
}

.survey-type-btn:hover {
  background: var(--hover-color);
  border-color: var(--primary-color);
  transform: translateY(-2px);
}

.survey-type-btn i {
  font-size: 2rem;
  color: var(--primary-color);
}

.survey-type-btn span {
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--text-primary);
}

.survey-type-btn small {
  font-size: 0.85rem;
  color: var(--text-secondary);
}

/* ------------------------------------------------------ */
/* Responsive                                             */
/* ------------------------------------------------------ */

@media (max-width: 768px) {
  .dancing-script-title { font-size: 2rem; }

  #header-content {
    display: flex; flex-direction: column; text-align: center; gap: 1rem;
  }

  #page-actions { width: 100%; justify-content: center; flex-wrap: wrap; }

  .dashboard-container { padding: 0 1rem; }
  .welcome-card { padding: 1.5rem; }

  .survey-details { grid-template-columns: 1fr; }

  .login-prompt { padding: 1rem; min-height: 60vh; }
  .login-card { padding: 2rem; margin: 1rem; }

  /* show segmented control, stack one column at a time */
  .mobile-toggle { display: flex; justify-content: center; }
  .surveys-grid { grid-template-columns: 1fr; }

  /* default: show open, hide closed (JS will toggle) */
  #open-column { display: block; }
  #closed-column { display: none; }
}

@media (max-width: 480px) {
  .dancing-script-title { font-size: 1.75rem; }

  .column-header { flex-direction: column; gap: 0.75rem; text-align: center; }
  .survey-card-header { flex-direction: column; gap: 0.75rem; }
  .survey-status { align-self: flex-start; }
}


/* ------------------------------------------------------ */
/* MENU UTILISATEUR & DÉCONNEXION RESPONSIVE             */
/* ------------------------------------------------------ */
.user-menu-container {
  display: block;
  position: relative;
  width: 100%;
}

@media (min-width: 768px) {
  .user-menu-container {
    width: auto;
  }
}

.user-menu-details {
  position: relative;
  width: 100%;
}

.user-menu-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  border-radius: 0.75rem;
  background: rgba(99, 102, 241, 0.1);
  border: 1px solid rgba(99, 102, 241, 0.3);
  color: var(--text-primary);
  font-weight: 600;
  transition: var(--transition);
  width: 100%;
  justify-content: center;
  font-size: clamp(0.9rem, 2.5vw, 0.95rem);
}

@media (min-width: 768px) {
  .user-menu-summary {
    width: auto;
    justify-content: flex-start;
  }
}

.user-menu-summary:hover {
  background: rgba(99, 102, 241, 0.2);
  border-color: var(--primary-color);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.user-menu-summary::-webkit-details-marker {
  display: none;
}

.user-icon {
  font-size: clamp(1.5rem, 4vw, 1.8rem);
  color: var(--primary-color);
  transition: var(--transition);
}

.user-name-short {
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chevron-icon {
  font-size: clamp(0.75rem, 2vw, 0.875rem);
  color: var(--text-secondary);
  transition: transform 0.3s ease;
}

.user-menu-details[open] .chevron-icon {
  transform: rotate(180deg);
}

.user-menu-summary:hover .user-icon {
  color: var(--secondary-color);
  transform: scale(1.1);
}

body:not([data-shared-user-menu='true']) .user-dropdown {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  min-width: 280px;
  background: var(--card-bg);
  border: 2px solid var(--primary-color);
  border-radius: 0.75rem;
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.5);
  z-index: 1000;
  animation: userMenuSlideDown 0.2s ease-out;
  overflow: hidden;
  width: 100%;
  max-width: 100vw;
}

@media (max-width: 767px) {
  body:not([data-shared-user-menu='true']) .user-dropdown {
    position: fixed;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    min-width: 100%;
    border-radius: 1rem 1rem 0 0;
    animation: slideUp 0.3s ease-out;
    max-height: 80vh;
    overflow-y: auto;
  }
}

@keyframes userMenuSlideDown {
  from {
    opacity: 0;
    transform: translateY(-15px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes slideUp {
  from {
    transform: translateY(100%) scale(0.95);
    opacity: 0;
  }
  to {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

.dropdown-header {
  padding: 1.25rem;
  background: rgba(99, 102, 241, 0.05);
  border-bottom: 1px solid var(--card-border);
}

.user-info {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.user-avatar {
  font-size: clamp(2rem, 5vw, 2.5rem);
  color: var(--primary-color);
  flex-shrink: 0;
  background: none !important;
  width: auto;
  height: auto;
}

.user-details {
  flex: 1;
  min-width: 0;
}

.user-name-full {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.user-name {
  font-weight: 700;
  color: var(--text-primary);
  font-size: clamp(0.95rem, 2.5vw, 1.1rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 150px;
}

.user-email {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin-top: 0.25rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dropdown-divider {
  height: 1px;
  background: var(--card-border);
  margin: 0.5rem 0;
  width: 100%;
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1.25rem;
  color: var(--text-primary);
  text-decoration: none;
  transition: var(--transition);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  font-size: clamp(0.9rem, 2.5vw, 0.95rem);
}

.dropdown-item:hover {
  background: rgba(51, 65, 85, 0.5);
  color: white;
}

.dropdown-item i {
  width: 20px;
  text-align: center;
  color: var(--text-secondary);
  font-size: 1rem;
  flex-shrink: 0;
}

.logout-item {
  color: var(--danger-color);
}

.logout-item:hover {
  background: rgba(239, 68, 68, 0.1);
  color: #ef4444;
}

/* ------------------------------------------------------ */
/* Login prompt container */
/* ------------------------------------------------------ */

.login-prompt {
  display: grid;
  place-items: center;
  min-height: calc(100vh - 160px);
  padding: 2rem 1rem;
}

/* Card: glassmorphism + accent */
.login-card {
  position: relative;
  width: 100%;
  max-width: 560px;
  padding: 2rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(51, 65, 85, 0.7);
  box-shadow: 0 25px 60px rgba(0,0,0,0.35);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  text-align: center;
}

/* Animated light sweep */
.login-card::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  filter: blur(16px);
  opacity: 0.35;
  pointer-events: none;
}

/* Header icon */
.login-card i.fas.fa-user-lock {
  display: inline-grid;
  place-items: center;
  width: 64px;
  height: 64px;
  margin: 0 auto 0.75rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
  color: #fff;
  font-size: 1.5rem;
}

/* Title + description */
.login-card h3 {
  margin: 0.5rem 0 0.25rem;
  font-weight: 700;
  letter-spacing: 0.3px;
  background: linear-gradient(45deg, #e5e7eb, #f1f5f9);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.login-card p {
  margin: 0.25rem auto 1.25rem;
  color: var(--text-secondary);
  max-width: 42ch;
}

/* CTA button */
#google-login-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 1.25rem;
  border-radius: 0.9rem;
  border: 1px solid rgba(99,102,241,0.3);
  background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.2px;
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

#google-login-btn i {
  font-size: 1.1rem;
}

#google-login-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.03);
}

/* Fine details: dividers + footer hint (optional) */
.login-card .divider {
  width: 100%;
  height: 1px;
  margin: 1.25rem 0;
  background: linear-gradient(90deg, transparent, rgba(51,65,85,0.6), transparent);
}

.login-card .hint {
  font-size: 0.9rem;
  color: var(--text-secondary);
}

/* Responsive polish */
@media (max-width: 480px) {
  .login-card { padding: 1.5rem; border-radius: 1rem; }
  #google-login-btn { width: 100%; justify-content: center; }
}

/* Prefer our layout over Bootstrap defaults inside login prompt */
.login-prompt .btn-primary {
  background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
  border: none;
}
#google-login-btn:focus-visible {
  outline: 3px solid rgba(99,102,241,0.4);
  outline-offset: 3px;
}

/* ------------------------------------------------------ */
/* FOOTER RESPONSIVE */
/* ------------------------------------------------------ */
.site-footer {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    border-top: 1px solid var(--card-border);
    margin-top: auto;
    padding: 2rem 1rem 1rem;
    width: 100%;
    position: relative;
    z-index: 10;
}

.footer-content {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 0 1rem;
}

@media (min-width: 768px) {
    .footer-content {
        grid-template-columns: repeat(2, 1fr);
        gap: 2.5rem;
    }
}

@media (min-width: 1024px) {
    .footer-content {
        grid-template-columns: 2fr 1fr 1.5fr 1.5fr;
        gap: 3rem;
    }
}

.footer-section {
    animation: fadeInUp 0.6s ease;
}

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

.footer-logo .dancing-script-title {
    font-size: clamp(1.5rem, 4vw, 2rem);
    margin-bottom: 0.5rem;
}

.footer-tagline {
    color: var(--text-secondary);
    font-size: clamp(0.9rem, 2.5vw, 1rem);
    margin-bottom: 1.5rem;
    font-style: italic;
}

.copyright {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.copyright p {
    color: var(--text-secondary);
    font-size: clamp(0.8rem, 2.5vw, 0.9rem);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.copyright i {
    color: var(--primary-color);
}

.footer-note {
    font-size: clamp(0.75rem, 2vw, 0.8rem) !important;
    opacity: 0.7;
    font-style: italic;
}

.footer-title {
    color: var(--text-primary);
    font-size: clamp(1rem, 2.5vw, 1.1rem);
    margin-bottom: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--primary-color);
    display: inline-block;
}

.footer-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.footer-links li {
    margin: 0;
}

.footer-link {
    color: var(--text-secondary);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0;
    transition: var(--transition);
    font-size: clamp(0.85rem, 2.5vw, 0.9rem);
    border-radius: 0.5rem;
    padding-left: 0.5rem;
}

.footer-link:hover {
    color: var(--primary-color);
    transform: translateX(5px);
    background: rgba(99, 102, 241, 0.1);
    padding-left: 1rem;
}

.footer-link i {
    width: 20px;
    text-align: center;
    font-size: 1rem;
    color: var(--primary-color);
    opacity: 0.8;
}

/* Social Links */
.social-links {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
    color: var(--text-secondary);
    font-size: 1.1rem;
    transition: var(--transition);
    border: 1px solid transparent;
}

.social-link:hover {
    background: var(--primary-color);
    color: white;
    transform: translateY(-3px);
    border-color: var(--primary-color);
    box-shadow: 0 5px 15px rgba(99, 102, 241, 0.3);
}

/* Newsletter */
.footer-newsletter {
    margin-top: 1.5rem;
}

.footer-newsletter p {
    color: var(--text-secondary);
    font-size: clamp(0.85rem, 2.5vw, 0.9rem);
    margin-bottom: 0.75rem;
}

.newsletter-form {
    display: flex;
    gap: 0.5rem;
    width: 100%;
}

.newsletter-input {
    flex: 1;
    padding: 0.75rem 1rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--card-border);
    border-radius: 0.75rem;
    color: var(--text-primary);
    font-size: clamp(0.85rem, 2.5vw, 0.9rem);
    transition: var(--transition);
    min-width: 0;
}

.newsletter-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.newsletter-btn {
    padding: 0.75rem 1.25rem;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    border: none;
    border-radius: 0.75rem;
    color: white;
    cursor: pointer;
    transition: var(--transition);
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
}

.newsletter-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(99, 102, 241, 0.3);
}

/* Footer Divider */
.footer-divider {
    height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        var(--card-border) 50%,
        transparent 100%);
    margin: 2rem auto;
    max-width: 1400px;
}

/* Footer Bottom */
.footer-bottom {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 1rem;
}

.footer-bottom-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 0;
}

@media (min-width: 768px) {
    .footer-bottom-content {
        flex-direction: row;
        gap: 2rem;
    }
}

.legal-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    font-size: clamp(0.75rem, 2vw, 0.8rem);
}

@media (min-width: 768px) {
    .legal-links {
        justify-content: flex-start;
    }
}

.legal-links a {
    color: var(--text-secondary);
    text-decoration: none;
    transition: var(--transition);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
}

.legal-links a:hover {
    color: var(--primary-color);
    background: rgba(99, 102, 241, 0.1);
}

.separator {
    color: var(--text-secondary);
    opacity: 0.5;
}

.language-selector {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: rgba(255, 255, 255, 0.05);
    padding: 0.5rem 1rem;
    border-radius: 0.75rem;
    border: 1px solid var(--card-border);
    min-width: 150px;
}

.language-selector i {
    color: var(--primary-color);
    font-size: 1rem;
}

.language-select {
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-size: clamp(0.85rem, 2.5vw, 0.9rem);
    width: 100%;
    cursor: pointer;
    outline: none;
}

.language-select option {
    background: var(--card-bg);
    color: var(--text-primary);
}

/* Animation pour le footer */
.site-footer {
    animation: slideUpFooter 0.8s ease-out;
}

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

/* Responsive adjustments */
@media (max-width: 767px) {
    .site-footer {
        padding: 1.5rem 0.75rem 0.75rem;
    }

    .footer-content {
        padding: 0 0.5rem;
        gap: 1.5rem;
    }

    .footer-section {
        text-align: center;
    }

    .footer-links {
        align-items: center;
    }

    .social-links {
        justify-content: center;
    }

    .newsletter-form {
        flex-direction: column;
    }

    .newsletter-btn {
        width: 100%;
    }
}

/* Dark mode adjustments */
@media (prefers-color-scheme: dark) {
    .site-footer {
        background: linear-gradient(135deg, #0a0f1d 0%, #1a2238 100%);
    }
}

/* Print styles */
@media print {
    .site-footer {
        display: none;
    }
}

/* Améliorations UX/Accessibilité */
button:focus-visible,
[tabindex]:focus-visible,
input:focus-visible,
select:focus-visible {
  outline: 3px solid rgba(99, 102, 241, 0.4);
  outline-offset: 2px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Animation pour notifications */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

.fade-in {
  animation: fadeIn 0.3s ease;
}

/* Styles pour le bouton d'édition de pseudo */
.edit-pseudo-btn {
  background: none;
  border: none;
  padding: 0;
  margin-left: 8px;
  cursor: pointer;
  color: var(--primary-color);
  font-size: 0.9rem;
  transition: color 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
}

.edit-pseudo-btn:hover {
  color: var(--secondary-color);
  background-color: rgba(99, 102, 241, 0.1);
}

.edit-pseudo-btn:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}

/* Ajustement pour l'affichage du pseudo */
.user-name {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

#pseudo-text {
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 768px) {
  #pseudo-text {
    max-width: 100px;
  }

  .edit-pseudo-btn {
    width: 22px;
    height: 22px;
    margin-left: 4px;
  }
}

/* Styles pour le modal d'édition de pseudo */
.pseudo-input {
  margin-bottom: 1rem !important;
}

.pseudo-error {
  color: #ef4444;
  font-size: 0.95rem;
  margin-top: 0.5rem;
  min-height: 1.2rem;
}

/* ------------------------------------------------------ */
/* Logo Header                                            */
/* ------------------------------------------------------ */

/* Lien cliquable */
/* Image du logo */
/* Hover élégant */
/* Accessibilité clavier */
/* ------------------------------------------------------ */
/* Responsive ajustements                                 */
/* ------------------------------------------------------ */
/* ------------------------------------------------------ */
/* Barre de recherche                                     */
/* ------------------------------------------------------ */

.search-container {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .search-container {
    width: 300px;
    margin: 0;
  }
}

.search-icon {
  position: absolute;
  left: 1rem;
  color: var(--text-secondary);
  z-index: 2;
  font-size: 1rem;
}

.search-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 3rem;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 0.75rem;
  color: var(--text-primary);
  font-size: 0.95rem;
  transition: var(--transition);
}

.search-input:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}

.search-input::placeholder {
  color: var(--text-secondary);
}

.clear-search-btn {
  position: absolute;
  right: 0.75rem;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.25rem;
  display: none;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  transition: var(--transition);
}

.clear-search-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
}

.clear-search-btn.visible {
  display: flex;
}

/* ------------------------------------------------------ */
/* Browse Header/Page-Actions Finalization                */
/* ------------------------------------------------------ */
body[data-page='browse-surveys'][data-shared-user-menu='true'] #page-actions {
	align-items: center;
}

body[data-page='browse-surveys'][data-shared-user-menu='true'] #page-actions > button {
	min-height: var(--header-action-height-desktop);
}

/* Keep shared dropdown centering rules */
body[data-page='browse-surveys'][data-shared-user-menu='true'] .user-dropdown {
	position: absolute !important;
	left: 50% !important;
	right: auto !important;
	bottom: auto !important;
	width: max-content !important;
	min-width: 260px !important;
	max-width: min(92vw, 360px) !important;
	transform: translateX(-50%) !important;
	animation: none !important;
}

body[data-page='browse-surveys'][data-shared-user-menu='true'] .dropdown-header,
body[data-page='browse-surveys'][data-shared-user-menu='true'] .user-info,
body[data-page='browse-surveys'][data-shared-user-menu='true'] .user-details,
body[data-page='browse-surveys'][data-shared-user-menu='true'] .user-name-full {
	text-align: center !important;
	justify-content: center !important;
}

body[data-page='browse-surveys'][data-shared-user-menu='true'] .search-toolbar {
	width: min(1400px, calc(100% - 2rem));
	margin: 0 auto 0.75rem;
	display: flex;
	justify-content: center;
}

body[data-page='browse-surveys'][data-shared-user-menu='true'] .search-toolbar .search-container {
	width: min(780px, 100%);
	max-width: 100%;
	margin: 0;
}

body[data-page='browse-surveys'][data-shared-user-menu='true'] #page-actions .search-container {
	display: none !important;
}

@media (max-width: 768px) {
	body[data-page='browse-surveys'][data-shared-user-menu='true'] .search-toolbar {
		width: calc(100% - 1rem);
		margin-bottom: 0.6rem;
	}
}


/* Shared modal authority for pseudo edit */
body[data-page='browse-surveys'][data-shared-user-menu='true'] #edit-pseudo-modal.modal,
body[data-page='browse-surveys'][data-shared-user-menu='true'] #confirm-modal.modal {
	inset: 0 !important;
}

body[data-page='browse-surveys'][data-shared-user-menu='true'] #edit-pseudo-modal .close-modal,
body[data-page='browse-surveys'][data-shared-user-menu='true'] #confirm-modal .close-modal {
	opacity: 1 !important;
	visibility: visible !important;
}

/* Align browse welcome surface with the binary creation welcome card. */
body[data-page='browse-surveys'] .welcome-card {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: 1px solid rgba(255, 255, 255, 0.14) !important;
	border-radius: 30px !important;
	box-shadow: 0 20px 40px rgba(2, 6, 23, 0.28) !important;
	color: #e2e8f0 !important;
	text-align: center !important;
	padding: 2rem !important;
	animation: browseWelcomeSlideDown 0.5s ease;
}

body[data-page='browse-surveys'] .welcome-card h2 {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	margin-bottom: 0.5rem;
}

@keyframes browseWelcomeSlideDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
