/**
 * Glassmorphism Styles
 * Effets de verre modernes pour projets Excel
 * Basé sur verify-elaoumrani
 */

/* ========================================
   BASE GLASS STYLES
   ======================================== */

/**
 * Glass Card
 * Effet de verre principal avec blur et bordure
 */
.glass-card {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-base));
  -webkit-backdrop-filter: blur(var(--blur-base));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.glass-card:hover {
  background: var(--glass-bg-hover);
  border-color: var(--glass-border-hover);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}

/**
 * Glass Card Variants
 */
.glass-card-sm {
  padding: var(--spacing-sm);
  border-radius: var(--radius-md);
}

.glass-card-md {
  padding: var(--spacing-md);
  border-radius: var(--radius-lg);
}

.glass-card-lg {
  padding: var(--spacing-lg);
  border-radius: var(--radius-lg);
}

.glass-card-xl {
  padding: var(--spacing-xl);
  border-radius: var(--radius-xl);
}

/* Glass card avec blur fort */
.glass-card-strong {
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(var(--blur-lg));
  -webkit-backdrop-filter: blur(var(--blur-lg));
}

/* Glass card avec effet subtil */
.glass-card-subtle {
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(var(--blur-sm));
  -webkit-backdrop-filter: blur(var(--blur-sm));
}

/* ========================================
   GLASS BUTTONS
   ======================================== */

/**
 * Glass Button
 * Bouton interactif avec effet de verre
 */
.glass-button {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-md));
  -webkit-backdrop-filter: blur(var(--blur-md));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm) var(--spacing-md);
  color: var(--text-primary);
  font-weight: var(--font-medium);
  font-size: var(--text-base);
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.glass-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.2),
    transparent
  );
  transition: left var(--transition-slow);
}

.glass-button:hover::before {
  left: 100%;
}

.glass-button:hover {
  background: var(--glass-bg-hover);
  border-color: var(--glass-border-hover);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.glass-button:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

/* Glass button variants */
.glass-button-primary {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--accent-info);
  color: var(--accent-info-light);
}

.glass-button-primary:hover {
  background: rgba(59, 130, 246, 0.25);
  box-shadow: var(--shadow-glow-info);
}

.glass-button-success {
  background: rgba(16, 185, 129, 0.15);
  border-color: var(--accent-success);
  color: var(--accent-success-light);
}

.glass-button-success:hover {
  background: rgba(16, 185, 129, 0.25);
  box-shadow: var(--shadow-glow-success);
}

.glass-button-warning {
  background: rgba(245, 158, 11, 0.15);
  border-color: var(--accent-warning);
  color: var(--accent-warning-light);
}

.glass-button-warning:hover {
  background: rgba(245, 158, 11, 0.25);
  box-shadow: var(--shadow-glow-warning);
}

.glass-button-error {
  background: rgba(239, 68, 68, 0.15);
  border-color: var(--accent-error);
  color: var(--accent-error-light);
}

.glass-button-error:hover {
  background: rgba(239, 68, 68, 0.25);
  box-shadow: var(--shadow-glow-error);
}

/* ========================================
   GLASS PANELS & CONTAINERS
   ======================================== */

/**
 * Glass Panel
 * Container large pour sections de contenu
 */
.glass-panel {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-base));
  -webkit-backdrop-filter: blur(var(--blur-base));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  box-shadow: var(--shadow-md);
}

/**
 * Glass Header
 * Section header avec effet de verre
 */
.glass-header {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-xl));
  -webkit-backdrop-filter: blur(var(--blur-xl));
  border-bottom: 1px solid var(--glass-border);
  padding: var(--spacing-md);
  position: sticky;
  top: 0;
  z-index: var(--z-header);
}

/**
 * Glass Badge
 * Petit élément en forme de pilule
 */
.glass-badge {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-md));
  -webkit-backdrop-filter: blur(var(--blur-md));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-full);
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

/* ========================================
   GLASS STATUS INDICATORS
   ======================================== */

.glass-status {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-base));
  -webkit-backdrop-filter: blur(var(--blur-base));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.glass-status-success {
  background: rgba(16, 185, 129, 0.1);
  border-color: var(--accent-success);
}

.glass-status-warning {
  background: rgba(245, 158, 11, 0.1);
  border-color: var(--accent-warning);
}

.glass-status-error {
  background: rgba(239, 68, 68, 0.1);
  border-color: var(--accent-error);
}

.glass-status-info {
  background: rgba(59, 130, 246, 0.1);
  border-color: var(--accent-info);
}

/* ========================================
   GLASS INPUT ELEMENTS
   ======================================== */

.glass-input {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-base));
  -webkit-backdrop-filter: blur(var(--blur-base));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm) var(--spacing-md);
  color: var(--text-primary);
  font-size: var(--text-base);
  transition: all var(--transition-base);
}

.glass-input:focus {
  outline: none;
  border-color: var(--accent-info);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: var(--shadow-glow-info);
}

.glass-input::placeholder {
  color: var(--text-muted);
}

/* ========================================
   GLASS OVERLAY
   ======================================== */

.glass-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 10, 0.8);
  backdrop-filter: blur(var(--blur-lg));
  -webkit-backdrop-filter: blur(var(--blur-lg));
  z-index: var(--z-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ========================================
   GLASS DIVIDER
   ======================================== */

.glass-divider {
  height: 1px;
  background: var(--glass-border);
  margin: var(--spacing-md) 0;
}

/* ========================================
   NO BACKDROP FILTER FALLBACK
   ======================================== */

@supports not (backdrop-filter: blur(10px)) {
  .glass-card,
  .glass-button,
  .glass-panel,
  .glass-header,
  .glass-badge,
  .glass-status,
  .glass-input,
  .glass-overlay {
    background: rgba(255, 255, 255, 0.15);
  }
}
