/* Glass Component Architecture */

/* Primary Glass Card */
.glass-card {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur-md));
  -webkit-backdrop-filter: blur(var(--blur-md));
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-light);
  border-left-color: var(--glass-border-light);
  box-shadow:
    inset 0 1px 0 0 var(--glass-border-glow),
    0 8px 32px rgba(0, 0, 0, 0.4),
    0 2px 8px rgba(0, 0, 0, 0.2);
  border-radius: 16px;
  transform: translateZ(0);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.glass-card:hover {
  transform: translateY(-2px) translateZ(0);
  box-shadow:
    inset 0 1px 0 0 var(--glass-border-glow),
    0 16px 48px rgba(0, 0, 0, 0.5),
    0 4px 12px rgba(0, 0, 0, 0.3);
}

/* Elevated Glass Panel */
.glass-elevated {
  background: var(--glass-bg-elevated);
  backdrop-filter: blur(var(--blur-lg));
  border: 1px solid var(--glass-border-light);
  box-shadow:
    inset 0 1px 0 0 rgba(232, 232, 232, 0.08),
    0 24px 64px rgba(0, 0, 0, 0.6),
    0 8px 24px rgba(0, 0, 0, 0.4);
  border-radius: 20px;
}

/* Subtle Glass */
.glass-subtle {
  background: var(--glass-bg-subtle);
  backdrop-filter: blur(var(--blur-sm));
  border: 1px solid rgba(58, 58, 58, 0.2);
  border-radius: 8px;
}

/* Float Classes */
.float-subtle {
  transform: translateY(0);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.float-subtle:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
}

.float-medium {
  transform: translateY(0) scale(1);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
  transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.float-medium:hover {
  transform: translateY(-8px) scale(1.01);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.5);
}

.float-heavy {
  transform: translateY(0) scale(1);
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.4),
    0 0 0 1px var(--glass-border);
  transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.float-heavy:hover {
  transform: translateY(-12px) scale(1.02);
  box-shadow:
    0 32px 64px rgba(0, 0, 0, 0.6),
    0 0 0 1px var(--glass-border-light);
}

/* Dithered Texture */
.dither-texture {
  position: relative;
}

.dither-texture::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity: 0.03;
  pointer-events: none;
  mix-blend-mode: overlay;
}
