/**
 * ============================================
 * OASIISBOX - Application Styles
 * ============================================
 *
 * RÈGLE: Aucune couleur hardcodée ici.
 * Toutes les couleurs viennent de tokens.css
 */

/* Import des tokens */
@import "./tokens.css";

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

body {
  background-color: rgb(var(--color-background));
  color: rgb(var(--color-text));
  min-height: 100vh;
}

/* Subtle gradient overlay for light mode */
body:not(.dark) {
  background-image: linear-gradient(
    135deg,
    rgba(var(--action-primary-rgb), 0.03) 0%,
    rgba(var(--brand-primary-rgb), 0.03) 100%
  );
}

/* ============================================
   THEME UTILITIES
   ============================================ */

.bg-theme-surface { background-color: rgb(var(--color-surface)); }
.bg-theme-background { background-color: rgb(var(--color-background)); }
.text-theme-primary { color: rgb(var(--color-text)); }
.text-theme-secondary { color: rgb(var(--color-text-secondary)); }
.border-theme { border-color: rgb(var(--color-border)); }

/* ============================================
   GLASSMORPHISM
   ============================================ */

.glass {
  background: var(--glass-light-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glass-light-border);
}

.dark .glass {
  background: var(--glass-dark-bg);
  border-color: var(--glass-dark-border);
}

.glass-card {
  background: var(--glass-light-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--glass-light-border);
  border-radius: 1.5rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px var(--shadow-color-light);
}

.glass-card:hover {
  background: var(--glass-light-bg-hover);
  border-color: var(--glass-light-border-hover);
  transform: translateY(-4px);
  box-shadow: 0 20px 40px var(--shadow-color-light-strong);
}

.dark .glass-card {
  background: var(--glass-dark-bg);
  border-color: var(--glass-dark-border);
  box-shadow: 0 4px 6px var(--shadow-color-dark);
}

.dark .glass-card:hover {
  background: var(--glass-dark-bg-hover);
  border-color: var(--glass-dark-border-hover);
  box-shadow:
    0 20px 40px var(--shadow-color-dark-strong),
    0 0 30px var(--shadow-glow);
}

/* Navbar Glass */
.navbar-glass {
  background: var(--glass-light-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--glass-light-border);
  box-shadow: 0 2px 10px var(--shadow-color-light);
}

.dark .navbar-glass {
  background: rgba(var(--surface-dark-rgb), 0.95);
  border-bottom-color: var(--glass-dark-border);
  box-shadow: 0 4px 20px var(--shadow-color-dark);
}

/* ============================================
   BENTO GRID
   ============================================ */

.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  grid-auto-rows: minmax(180px, auto);
}

@media (max-width: 1024px) {
  .bento-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

.bento-item {
  border-radius: 1.5rem;
  padding: 1.5rem;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.bento-span-2 { grid-column: span 2; }
.bento-span-3 { grid-column: span 3; }
.bento-row-2 { grid-row: span 2; }

@media (max-width: 1024px) {
  .bento-span-3 { grid-column: span 2; }
}

@media (max-width: 640px) {
  .bento-span-2,
  .bento-span-3 { grid-column: span 1; }
  .bento-row-2 { grid-row: span 1; }
  .bento-grid { gap: 1rem; }
  .bento-item {
    padding: 1.25rem;
    border-radius: 1.25rem;
  }
  .glass-card { border-radius: 1.25rem; }
}

/* Mobile typography */
@media (max-width: 640px) {
  .gradient-text { font-size: 2rem !important; }
}

/* Touch-friendly improvements */
@media (max-width: 768px) {
  button, a.inline-flex, input[type="submit"] { min-height: 44px; }
  .bento-grid { overflow-x: hidden; }
  .status-dot { width: 8px; height: 8px; }
}

/* Very small screens */
@media (max-width: 380px) {
  .bento-item { padding: 1rem; }
  .navbar-glass { padding-left: 0.5rem; padding-right: 0.5rem; }
}

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

.status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
  animation: pulse-status 2s ease-in-out infinite;
}

.status-up {
  background-color: var(--state-success);
  box-shadow: 0 0 10px rgba(var(--state-success-rgb), 0.5);
}

.status-down {
  background-color: var(--state-error);
  box-shadow: 0 0 10px rgba(var(--state-error-rgb), 0.5);
}

.status-degraded {
  background-color: var(--state-warning);
  box-shadow: 0 0 10px rgba(var(--state-warning-rgb), 0.5);
}

.status-unknown {
  background-color: var(--text-muted);
  box-shadow: 0 0 10px rgba(var(--text-muted-rgb), 0.5);
}

@keyframes pulse-status {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.1); }
}

/* ============================================
   GRADIENT TEXT & EFFECTS
   ============================================ */

.gradient-text {
  background: linear-gradient(
    135deg,
    var(--action-primary) 0%,
    var(--brand-primary) 50%,
    var(--action-hover) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.gradient-border {
  position: relative;
  background: linear-gradient(
    135deg,
    rgba(var(--action-primary-rgb), 0.05),
    rgba(var(--brand-primary-rgb), 0.05)
  );
  border-radius: 1.5rem;
}

.gradient-border::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 1.5rem;
  padding: 1px;
  background: linear-gradient(135deg, var(--action-primary), var(--brand-primary), var(--action-hover));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

/* ============================================
   HOVER EFFECTS
   ============================================ */

.hover-lift {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.hover-lift:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px var(--shadow-color-light);
}

.dark .hover-lift:hover {
  box-shadow:
    0 20px 40px var(--shadow-color-dark-strong),
    0 0 20px var(--shadow-glow);
}

/* ============================================
   ANIMATIONS
   ============================================ */

.animate-float {
  animation: float 6s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* ============================================
   BADGES
   ============================================ */

.badge-opensource {
  background: linear-gradient(135deg, var(--state-warning), var(--state-warning-dark));
  color: white;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 0.2rem 0.6rem;
  border-radius: 9999px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  animation: badge-pulse 2s ease-in-out infinite;
  box-shadow: 0 2px 8px rgba(var(--state-warning-rgb), 0.4);
}

@keyframes badge-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.8; }
}

.badge-live {
  background: linear-gradient(135deg, var(--state-success), var(--state-success-dark));
  color: white;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 0.2rem 0.6rem;
  border-radius: 9999px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ============================================
   ICON CONTAINERS
   ============================================ */

.icon-gradient {
  background: linear-gradient(135deg, var(--tw-gradient-from), var(--tw-gradient-to));
}

/* ============================================
   REVEAL ANIMATIONS (Scroll)
   ============================================ */

.reveal-hidden {
  opacity: 0;
  transform: translateY(30px);
}

.reveal-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* Staggered delays for grid items */
.bento-grid > .reveal-visible:nth-child(1) { transition-delay: 0ms; }
.bento-grid > .reveal-visible:nth-child(2) { transition-delay: 100ms; }
.bento-grid > .reveal-visible:nth-child(3) { transition-delay: 200ms; }
.bento-grid > .reveal-visible:nth-child(4) { transition-delay: 300ms; }
.bento-grid > .reveal-visible:nth-child(5) { transition-delay: 400ms; }
.bento-grid > .reveal-visible:nth-child(6) { transition-delay: 500ms; }
.bento-grid > .reveal-visible:nth-child(7) { transition-delay: 600ms; }
.bento-grid > .reveal-visible:nth-child(8) { transition-delay: 700ms; }

/* Alternative reveal from left */
.reveal-left.reveal-hidden {
  opacity: 0;
  transform: translateX(-30px);
}

.reveal-left.reveal-visible {
  opacity: 1;
  transform: translateX(0);
}

/* Alternative reveal scale */
.reveal-scale.reveal-hidden {
  opacity: 0;
  transform: scale(0.95);
}

.reveal-scale.reveal-visible {
  opacity: 1;
  transform: scale(1);
}

/* ============================================
   ICON GLOW EFFECTS
   ============================================ */

.icon-glow {
  transition: all 0.3s ease;
}

.icon-glow:hover {
  filter: drop-shadow(0 0 8px currentColor);
}

/* ============================================
   LINK ANIMATIONS
   ============================================ */

.link-arrow {
  transition: transform 0.2s ease;
}

.link-arrow:hover .fa-arrow-right {
  transform: translateX(4px);
}

/* ============================================
   SHIMMER EFFECT
   ============================================ */

.shimmer {
  position: relative;
  overflow: hidden;
}

.shimmer::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(var(--surface-light-elevated-rgb), 0.1),
    transparent
  );
  animation: shimmer 3s infinite;
}

@keyframes shimmer {
  0% { left: -100%; }
  100% { left: 100%; }
}

/* ============================================
   FOCUS STYLES
   ============================================ */

input:focus, button:focus, a:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(var(--action-primary-rgb), 0.3);
}

.dark input:focus, .dark button:focus, .dark a:focus {
  box-shadow: 0 0 0 3px rgba(var(--brand-primary-rgb), 0.3);
}

/* ============================================
   SCROLLBAR STYLING
   ============================================ */

::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(var(--text-muted-rgb), 0.4);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(var(--text-muted-rgb), 0.6);
}

.dark ::-webkit-scrollbar-thumb {
  background: rgba(var(--text-muted-rgb), 0.3);
}

.dark ::-webkit-scrollbar-thumb:hover {
  background: rgba(var(--text-muted-rgb), 0.5);
}

/* ============================================
   SELECTION STYLING
   ============================================ */

::selection {
  background: rgba(var(--action-primary-rgb), 0.3);
  color: inherit;
}

.dark ::selection {
  background: rgba(var(--brand-primary-rgb), 0.3);
}

/* ============================================
   FLASH MESSAGES
   ============================================ */

.flash-enter {
  opacity: 0;
  transform: translateY(-20px);
}

.flash-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.flash-exit {
  opacity: 0;
  transform: translateY(-20px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

/* ============================================
   STATUS PAGE COMPACT
   ============================================ */

.status-card-compact {
  min-height: 90px;
}

.status-card-compact:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(var(--action-primary-rgb), 0.3);
}

.status-card-compact:hover {
  transform: scale(1.05);
}

/* Disable hover lift effect for status cards (they use scale instead) */
.status-card-compact.glass-card:hover {
  transform: scale(1.05);
}

/* Line clamp for open source descriptions */
.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
