/* ============================================================
   ZED — Premium Design System
   Colors: Neon Violet (#a855f7, #d946ef, #e879f9)
   Background: Deep Purple gradient (#0a0118 → #12051f → #1a0730)
   ============================================================ */

/* === Google Fonts — Premium Typography === */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: linear-gradient(168deg, #0a0118 0%, #12051f 40%, #1a0730 100%);
  background-attachment: fixed;
  overflow-x: hidden;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Apply Inter to all text */
*, *::before, *::after {
  font-family: inherit;
}

/* La page se termine exactement au dernier texte (pas d'espace vide en bas) */
#root > div > section:last-of-type > div.relative.z-10 {
  padding-bottom: 1rem !important;
}

/* ============================================================
   1. PREMIUM NEON BUTTONS
   ============================================================ */

/* All action buttons — Neon mauve flash */
@keyframes zed-btn-pulse {
  0%, 100% { box-shadow: 0 0 18px rgba(217, 70, 239, 0.7), 0 0 40px rgba(217, 70, 239, 0.45), 0 0 80px rgba(168, 85, 247, 0.3), inset 0 1px 0 rgba(255,255,255,0.25); }
  50%      { box-shadow: 0 0 32px rgba(232, 121, 249, 0.95), 0 0 65px rgba(217, 70, 239, 0.7), 0 0 110px rgba(168, 85, 247, 0.5), inset 0 1px 0 rgba(255,255,255,0.4); }
}

button[class*="bg-fuchsia-300"],
a[class*="bg-fuchsia-300"],
button[class*="border-fuchsia-300"]:not([class*="bg-fuchsia-300"]),
a[class*="border-fuchsia-300"]:not([class*="bg-fuchsia-300"]) {
  background: linear-gradient(135deg, #e879f9 0%, #d946ef 50%, #c026d3 100%) !important;
  color: #0a0118 !important;
  box-shadow:
    0 0 18px rgba(217, 70, 239, 0.7),
    0 0 40px rgba(217, 70, 239, 0.45),
    0 0 80px rgba(168, 85, 247, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.25) !important;
  border: 1px solid rgba(232, 121, 249, 0.55) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
  animation: zed-btn-pulse 1.6s ease-in-out infinite;
  position: relative;
  overflow: hidden;
  letter-spacing: 0.02em;
  font-weight: 600;
}

button[class*="bg-fuchsia-300"]:hover,
a[class*="bg-fuchsia-300"]:hover,
button[class*="border-fuchsia-300"]:not([class*="bg-fuchsia-300"]):hover,
a[class*="border-fuchsia-300"]:not([class*="bg-fuchsia-300"]):hover {
  background: linear-gradient(135deg, #f0abfc 0%, #e879f9 50%, #d946ef 100%) !important;
  color: #0a0118 !important;
  box-shadow:
    0 0 28px rgba(232, 121, 249, 0.95),
    0 0 60px rgba(217, 70, 239, 0.6),
    0 0 110px rgba(168, 85, 247, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.4) !important;
  border-color: rgba(240, 171, 252, 0.7) !important;
  transform: translateY(-1px) scale(1.02) !important;
  animation: none;
}

button[class*="bg-fuchsia-300"]:active,
a[class*="bg-fuchsia-300"]:active,
button[class*="border-fuchsia-300"]:not([class*="bg-fuchsia-300"]):active,
a[class*="border-fuchsia-300"]:not([class*="bg-fuchsia-300"]):active {
  transform: translateY(0) scale(0.99) !important;
  box-shadow:
    0 0 12px rgba(217, 70, 239, 0.7),
    0 0 30px rgba(217, 70, 239, 0.4),
    inset 0 1px 3px rgba(0, 0, 0, 0.2) !important;
  animation: none;
}

/* "Ouvrir la fiche" pill buttons inside cards */
.inline-flex[class*="border-fuchsia-300"] {
  transition: all 0.25s ease !important;
}

.inline-flex[class*="border-fuchsia-300"]:hover {
  box-shadow: 0 0 12px rgba(168, 85, 247, 0.3) !important;
}

/* ============================================================
   2. PREMIUM CONTAINER / CARD GLOW
   ============================================================ */

/* Cards de contenu — fond opaque pour bloquer l'animation derrière */
section .bg-white\/5:not(.zed-keep),
section .bg-\[\#190b2a\]\/75:not(.zed-keep),
section .bg-\[\#1b0c2e\]\/80:not(.zed-keep),
section .bg-black\/20:not(.zed-keep),
section .bg-black\/10:not(.zed-keep) {
  background-color: rgba(18, 5, 31, 0.95) !important;
  backdrop-filter: blur(12px) !important;
}

/* Premium neon halo around all containers/cards */
section .rounded-2xl.bg-white\/5:not(.zed-keep),
section [class*="rounded-[1.5rem]"].bg-white\/5:not(.zed-keep),
section [class*="rounded-[1.75rem]"].bg-white\/5:not(.zed-keep),
section [class*="rounded-[2rem]"].bg-white\/5:not(.zed-keep),
section .rounded-2xl.bg-\[\#190b2a\]\/75:not(.zed-keep),
section .rounded-2xl.bg-\[\#1b0c2e\]\/80:not(.zed-keep),
.rounded-2xl.bg-white\/5,
[class*="rounded-[2rem]"].bg-white\/5,
[class*="rounded-[1.5rem]"].bg-white\/5 {
  box-shadow:
    0 0 0 1px rgba(168, 85, 247, 0.2),
    0 0 15px rgba(168, 85, 247, 0.12),
    0 0 40px rgba(168, 85, 247, 0.06),
    0 0 80px rgba(139, 92, 246, 0.03) !important;
  border-color: rgba(168, 85, 247, 0.22) !important;
  transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease !important;
}

/* Card hover — enhanced glow */
section .rounded-2xl.bg-white\/5:not(.zed-keep):hover,
section [class*="rounded-[1.5rem]"].bg-white\/5:not(.zed-keep):hover,
section [class*="rounded-[1.75rem]"].bg-white\/5:not(.zed-keep):hover,
section [class*="rounded-[2rem]"].bg-white\/5:not(.zed-keep):hover {
  box-shadow:
    0 0 0 1px rgba(232, 121, 249, 0.3),
    0 0 20px rgba(217, 70, 239, 0.2),
    0 0 50px rgba(168, 85, 247, 0.1),
    0 0 90px rgba(139, 92, 246, 0.05) !important;
  border-color: rgba(232, 121, 249, 0.35) !important;
}

/* Inner sub-cards (bg-[#1b0c2e]/80, bg-[#190b2a]/75) */
div[class*="bg-[#1b0c2e]"],
div[class*="bg-[#190b2a]"] {
  border-color: rgba(168, 85, 247, 0.18) !important;
  box-shadow:
    0 0 0 1px rgba(168, 85, 247, 0.1),
    0 0 12px rgba(168, 85, 247, 0.06) !important;
  transition: box-shadow 0.3s ease, border-color 0.3s ease !important;
}

div[class*="bg-[#1b0c2e]"]:hover,
div[class*="bg-[#190b2a]"]:hover {
  border-color: rgba(232, 121, 249, 0.25) !important;
  box-shadow:
    0 0 0 1px rgba(168, 85, 247, 0.15),
    0 0 18px rgba(168, 85, 247, 0.1) !important;
}

/* bg-black/20 sub-items (feature list items) */
.bg-black\/20 {
  border: 1px solid rgba(168, 85, 247, 0.08) !important;
  box-shadow: 0 0 8px rgba(168, 85, 247, 0.04) !important;
  transition: all 0.25s ease !important;
}

.bg-black\/20:hover {
  border-color: rgba(168, 85, 247, 0.15) !important;
  box-shadow: 0 0 12px rgba(168, 85, 247, 0.08) !important;
  background-color: rgba(0, 0, 0, 0.25) !important;
}

/* Modal containers — premium backdrop */
.fixed.inset-0.z-50 > div {
  box-shadow:
    0 0 0 1px rgba(168, 85, 247, 0.25),
    0 0 30px rgba(217, 70, 239, 0.2),
    0 0 60px rgba(168, 85, 247, 0.1),
    0 25px 50px rgba(0, 0, 0, 0.6) !important;
}

/* ============================================================
   3. NAVIGATION — Premium glassmorphism
   ============================================================ */

.sticky.top-0.z-40 {
  background: rgba(10, 1, 24, 0.8) !important;
  backdrop-filter: blur(20px) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.2) !important;
  border-bottom: 1px solid rgba(168, 85, 247, 0.12) !important;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.3), 0 0 40px rgba(168, 85, 247, 0.04) !important;
}

/* Active nav pill */
nav button.rounded-full[class*="bg-fuchsia-300"],
.sticky button.rounded-full[class*="bg-fuchsia-300"] {
  animation: none !important;
  box-shadow:
    0 0 10px rgba(217, 70, 239, 0.4),
    0 0 20px rgba(217, 70, 239, 0.15) !important;
}

/* ============================================================
   4. FOOTER — Premium treatment
   ============================================================ */

footer {
  background: linear-gradient(180deg, #0d0318 0%, #08010f 100%) !important;
  border-top: 1px solid rgba(168, 85, 247, 0.12) !important;
}

/* ============================================================
   5. FORM INPUTS — Neon focus states
   ============================================================ */

input, textarea {
  font: inherit;
  transition: all 0.25s ease !important;
  border: 1px solid rgba(168, 85, 247, 0.15) !important;
}

input:focus, textarea:focus {
  border-color: rgba(232, 121, 249, 0.45) !important;
  box-shadow:
    0 0 0 3px rgba(168, 85, 247, 0.1),
    0 0 15px rgba(168, 85, 247, 0.12),
    0 0 30px rgba(168, 85, 247, 0.06) !important;
  outline: none !important;
}

button {
  font: inherit;
}

/* ============================================================
   6. BADGE / PILL — Premium glow
   ============================================================ */

/* "ZED · Agents IA" top badge */
.inline-flex.rounded-full[class*="border-fuchsia-400"] {
  box-shadow:
    0 0 10px rgba(168, 85, 247, 0.15),
    0 0 25px rgba(168, 85, 247, 0.08) !important;
  border-color: rgba(168, 85, 247, 0.35) !important;
  backdrop-filter: blur(8px);
}

/* ============================================================
   7. TYPOGRAPHY — Enhanced gradient text
   ============================================================ */

h1, h2, h3 {
  letter-spacing: -0.01em;
}

/* Section labels ("Agents IA", "Automatisation", etc.) */
.text-fuchsia-300 {
  text-shadow: 0 0 20px rgba(217, 70, 239, 0.3);
}

/* ============================================================
   SCROLLBAR — Premium style
   ============================================================ */

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(168, 85, 247, 0.25); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(168, 85, 247, 0.45); }

/* Focus visible — accessibility */
*:focus-visible {
  outline: 2px solid rgba(168, 85, 247, 0.6);
  outline-offset: 2px;
}

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

.zed-anim {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.zed-anim.zed-visible {
  opacity: 1;
  transform: translateY(0);
}
.zed-anim-delay-1 { transition-delay: 0.1s; }
.zed-anim-delay-2 { transition-delay: 0.2s; }
.zed-anim-delay-3 { transition-delay: 0.3s; }
.zed-anim-delay-4 { transition-delay: 0.4s; }
.zed-anim-delay-5 { transition-delay: 0.5s; }

/* Honeypot — anti-bot */
.zed-hp {
  position: absolute;
  left: -9999px;
  opacity: 0;
  height: 0;
  overflow: hidden;
  pointer-events: none;
}

/* ============================================================
   TECH BACKGROUND — Floating orbs
   ============================================================ */

.zed-tech-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   PARTICLE CANVAS
   ============================================================ */

.zed-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

.zed-canvas-fixed {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  pointer-events: none !important;
  z-index: -1 !important;
}

/* Galaxy section (Création web page) */
.zed-galaxy-section {
  isolation: isolate;
  background: #04010c;
}
.zed-galaxy-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 0;
  pointer-events: auto;
  cursor: crosshair;
}

.zed-galaxy-canvas.zed-galaxy-fixed {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  pointer-events: none !important;
  cursor: default !important;
  z-index: -1 !important;
}

.zed-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.55;
  will-change: transform;
}
.zed-orb-1 {
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(168, 85, 247, 0.5), rgba(168, 85, 247, 0) 70%);
  top: -80px; left: -60px;
  animation: zed-float-1 18s ease-in-out infinite;
}
.zed-orb-2 {
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(139, 92, 246, 0.5), rgba(139, 92, 246, 0) 70%);
  bottom: -80px; right: -40px;
  animation: zed-float-2 22s ease-in-out infinite;
}
.zed-orb-3 {
  width: 260px; height: 260px;
  background: radial-gradient(circle, rgba(168, 85, 247, 0.4), rgba(168, 85, 247, 0) 70%);
  top: 30%; right: 20%;
  animation: zed-float-3 26s ease-in-out infinite;
}

@keyframes zed-float-1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(80px, 60px) scale(1.1); }
  66%      { transform: translate(-40px, 100px) scale(0.95); }
}
@keyframes zed-float-2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(-90px, -50px) scale(1.05); }
  66%      { transform: translate(60px, -90px) scale(1.12); }
}
@keyframes zed-float-3 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.45; }
  50%      { transform: translate(-60px, 40px) scale(1.15); opacity: 0.6; }
}

/* ============================================================
   CIRCUIT GRID
   ============================================================ */

.zed-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(168, 85, 247, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(168, 85, 247, 0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 0%, transparent 80%);
  pointer-events: none;
  animation: zed-grid-shift 30s linear infinite;
}

@keyframes zed-grid-shift {
  0%   { background-position: 0 0, 0 0; }
  100% { background-position: 60px 60px, 60px 60px; }
}

/* ============================================================
   PARTICLES
   ============================================================ */

.zed-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.zed-particle {
  position: absolute;
  width: 3px;
  height: 3px;
  background: rgba(168, 85, 247, 0.7);
  border-radius: 50%;
  box-shadow: 0 0 10px rgba(168, 85, 247, 0.8), 0 0 20px rgba(168, 85, 247, 0.4);
  animation: zed-particle-rise 12s linear infinite;
}
.zed-particle:nth-child(1) { left: 8%;  animation-delay: 0s;   animation-duration: 14s; }
.zed-particle:nth-child(2) { left: 22%; animation-delay: 2s;   animation-duration: 11s; }
.zed-particle:nth-child(3) { left: 38%; animation-delay: 4s;   animation-duration: 13s; }
.zed-particle:nth-child(4) { left: 55%; animation-delay: 1s;   animation-duration: 15s; }
.zed-particle:nth-child(5) { left: 70%; animation-delay: 3s;   animation-duration: 12s; }
.zed-particle:nth-child(6) { left: 85%; animation-delay: 5s;   animation-duration: 14s; }
.zed-particle:nth-child(7) { left: 92%; animation-delay: 6s;   animation-duration: 13s; }

@keyframes zed-particle-rise {
  0%   { transform: translateY(110vh) translateX(0);    opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(-10vh) translateX(40px); opacity: 0; }
}

/* ============================================================
   LOGO GLOW — Pulsing AI core
   ============================================================ */

.zed-logo-glow {
  position: relative;
}
.zed-logo-glow::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  background: radial-gradient(circle, rgba(168, 85, 247, 0.6), rgba(168, 85, 247, 0) 70%);
  filter: blur(12px);
  opacity: 0.7;
  z-index: -1;
  animation: zed-pulse-glow 3s ease-in-out infinite;
}

@keyframes zed-pulse-glow {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50%      { opacity: 0.85; transform: scale(1.08); }
}

/* ============================================================
   GRADIENT TEXT — Animated title gradients
   ============================================================ */

.zed-gradient-text {
  background: linear-gradient(110deg, #f5d0fe 0%, #e879f9 25%, #a855f7 50%, #e879f9 75%, #f5d0fe 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: zed-gradient-shift 6s linear infinite;
}

@keyframes zed-gradient-shift {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* ============================================================
   SCAN LINE EFFECT
   ============================================================ */

.zed-scan {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(168, 85, 247, 0.5), transparent);
  animation: zed-scan-move 8s ease-in-out infinite;
  pointer-events: none;
}

@keyframes zed-scan-move {
  0%   { transform: translateY(0);    opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(100vh); opacity: 0; }
}

/* ============================================================
   CARD TECH BORDER — Animated circuit border
   ============================================================ */

.zed-card-tech {
  position: relative;
  overflow: hidden;
}
.zed-card-tech::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(168, 85, 247, 0.5), rgba(139, 92, 246, 0.2), rgba(168, 85, 247, 0.5));
  background-size: 200% 200%;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.3s ease;
  animation: zed-gradient-shift 4s linear infinite;
  pointer-events: none;
}
.zed-card-tech:hover::before {
  opacity: 1;
}

/* ============================================================
   CASCADE ANIMATION — Sequential card reveal
   ============================================================ */

.zed-cascade > * {
  opacity: 0;
  transform: translateY(20px);
  animation: zed-cascade-in 0.7s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.zed-cascade > *:nth-child(1) { animation-delay: 0.05s; }
.zed-cascade > *:nth-child(2) { animation-delay: 0.12s; }
.zed-cascade > *:nth-child(3) { animation-delay: 0.19s; }
.zed-cascade > *:nth-child(4) { animation-delay: 0.26s; }
.zed-cascade > *:nth-child(5) { animation-delay: 0.33s; }
.zed-cascade > *:nth-child(6) { animation-delay: 0.40s; }
.zed-cascade > *:nth-child(7) { animation-delay: 0.47s; }
.zed-cascade > *:nth-child(8) { animation-delay: 0.54s; }
.zed-cascade > *:nth-child(n+9) { animation-delay: 0.6s; }

@keyframes zed-cascade-in {
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   CONFIRMATION BANNER — Premium treatment
   ============================================================ */

div[class*="rounded-[2rem]"][class*="border-fuchsia-300"] {
  box-shadow:
    0 0 0 1px rgba(168, 85, 247, 0.2),
    0 0 20px rgba(168, 85, 247, 0.15),
    0 0 50px rgba(168, 85, 247, 0.08) !important;
}

/* ============================================================
   OUTLINE GLOW BUTTONS — Black bg + illuminated fuchsia border
   (Voir l'automatisation, Voir nos agents IA, Je suis intéressé)
   ============================================================ */

.zed-btn-outline-glow {
  background: #000 !important;
  border: 1px solid rgba(232, 121, 249, 0.55) !important;
  color: #fff !important;
  box-shadow:
    0 0 0 1px rgba(232, 121, 249, 0.35),
    0 0 18px rgba(217, 70, 239, 0.45),
    0 0 40px rgba(168, 85, 247, 0.22) !important;
  transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease !important;
}
.zed-btn-outline-glow:hover {
  background: #000 !important;
  border-color: rgba(232, 121, 249, 0.95) !important;
  transform: scale(1.02);
  box-shadow:
    0 0 0 1px rgba(232, 121, 249, 0.55),
    0 0 28px rgba(217, 70, 239, 0.7),
    0 0 60px rgba(168, 85, 247, 0.4) !important;
}

/* ============================================================
   AGENT CARDS GLOW — Page Agents IA
   ============================================================ */

.zed-card-tech.bg-black,
button.zed-card-tech.bg-black {
  background: #000 !important;
  background-image: none !important;
  color: #fff !important;
  border: 2px solid rgba(232, 121, 249, 0.6) !important;
  animation: none !important;
  text-shadow: none !important;
  box-shadow:
    0 0 0 1px rgba(232, 121, 249, 0.35),
    0 0 22px rgba(217, 70, 239, 0.4),
    0 0 55px rgba(168, 85, 247, 0.22) !important;
  transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease !important;
}
.zed-card-tech.bg-black:hover,
button.zed-card-tech.bg-black:hover {
  background: #000 !important;
  background-image: none !important;
  border-color: rgba(232, 121, 249, 0.95) !important;
  box-shadow:
    0 0 0 1px rgba(232, 121, 249, 0.55),
    0 0 35px rgba(217, 70, 239, 0.65),
    0 0 80px rgba(168, 85, 247, 0.38) !important;
}

/* ============================================================
   BOOKING MODAL — Selected motif button glow (only the selected)
   ============================================================ */

.zed-motif-selected {
  background: linear-gradient(135deg, #e879f9 0%, #d946ef 50%, #c026d3 100%) !important;
  color: #0a0118 !important;
  border: 1px solid rgba(232, 121, 249, 0.55) !important;
  box-shadow:
    0 0 18px rgba(217, 70, 239, 0.7),
    0 0 40px rgba(217, 70, 239, 0.45),
    0 0 80px rgba(168, 85, 247, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.25) !important;
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .zed-orb, .zed-particle, .zed-grid, .zed-scan {
    display: none !important;
  }
}
