/* Marker Loader for Education Website */

:root {
  /* Single color theme */
  --marker-color: #a2c144;
  --marker-dark: #8fb03a;
  --marker-crayon: #144835;
  --bg-color: #faf1e2;
  --text-color: #144835;
  
  /* Animation constants */
  --steps: 10;
  --duration: 3000ms;
  
  /* Generate single color variations */
  --color-01: var(--marker-color);
  --color-02: var(--marker-color);
  --color-03: var(--marker-color);
  --color-04: var(--marker-color);
  --color-05: var(--marker-color);
  --color-06: var(--marker-color);
  --color-07: var(--marker-color);
  --color-08: var(--marker-color);
  --color-09: var(--marker-color);
  --color-10: var(--marker-color);
  --color-11: var(--marker-color);
  
  /* Build backgrounds */
  --bg-01-a: no-repeat left       0% top    / 11%   0% linear-gradient(to right, var(--color-01), var(--color-02));
  --bg-01-b: no-repeat left       0% top    / 11% 100% linear-gradient(to right, var(--color-01), var(--color-02));
  --bg-02-a: no-repeat left   11.11% bottom / 11%   0% linear-gradient(to right, var(--color-02), var(--color-03));
  --bg-02-b: no-repeat left   11.11% bottom / 11% 100% linear-gradient(to right, var(--color-02), var(--color-03));
  --bg-03-a: no-repeat left   22.22% top    / 11%   0% linear-gradient(to right, var(--color-03), var(--color-04));
  --bg-03-b: no-repeat left   22.22% top    / 11% 100% linear-gradient(to right, var(--color-03), var(--color-04));
  --bg-04-a: no-repeat left   33.33% bottom / 11%   0% linear-gradient(to right, var(--color-04), var(--color-05));
  --bg-04-b: no-repeat left   33.33% bottom / 11% 100% linear-gradient(to right, var(--color-04), var(--color-05)); 
  --bg-05-a: no-repeat left   44.44% top    / 11%   0% linear-gradient(to right, var(--color-05), var(--color-06));
  --bg-05-b: no-repeat left   44.44% top    / 11% 100% linear-gradient(to right, var(--color-05), var(--color-06)); 
  --bg-06-a: no-repeat left   55.55% bottom / 11%   0% linear-gradient(to right, var(--color-06), var(--color-07));
  --bg-06-b: no-repeat left   55.55% bottom / 11% 100% linear-gradient(to right, var(--color-06), var(--color-07)); 
  --bg-07-a: no-repeat left   66.66% top    / 11%   0% linear-gradient(to right, var(--color-07), var(--color-08));
  --bg-07-b: no-repeat left   66.66% top    / 11% 100% linear-gradient(to right, var(--color-07), var(--color-08));
  --bg-08-a: no-repeat left   77.77% bottom / 11%   0% linear-gradient(to right, var(--color-08), var(--color-09));
  --bg-08-b: no-repeat left   77.77% bottom / 11% 100% linear-gradient(to right, var(--color-08), var(--color-09));
  --bg-09-a: no-repeat left   88.88% top    / 11%   0% linear-gradient(to right, var(--color-09), var(--color-10));
  --bg-09-b: no-repeat left   88.88% top    / 11% 100% linear-gradient(to right, var(--color-09), var(--color-10));  
  --bg-10-a: no-repeat left   99.99% bottom / 11%   0% linear-gradient(to right, var(--color-10), var(--color-11));
  --bg-10-b: no-repeat left   99.99% bottom / 12% 100% linear-gradient(to right, var(--color-10), var(--color-11));   
}

.site-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-color);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  opacity: 1;
  visibility: visible;
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: 'Jost', sans-serif;
  color: var(--text-color);
  padding: 1rem;
  box-sizing: border-box;
}

.site-loader.fade-out {
  opacity: 0;
  visibility: hidden;
  transform: scale(0.95);
}

.loader-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
}

/* Title */
.title {
  color: var(--text-color);
  font-size: 2rem;
  font-family: 'Jost', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 2rem;
  animation: titlePulse 2s ease-in-out infinite;
}

/* Marker Loader */
.rainbow-marker-loader {
  height: 4rem;
  width: 20rem;
  max-width: 100%;
  border: 0.5rem solid var(--marker-crayon);
  border-radius: 0.5rem;
  animation: infinite alternate marker-fill var(--duration) ease-in-out;
  box-sizing: border-box;
  position: relative;
  margin: 1rem;
  background:
    var(--bg-01-a),
    var(--bg-02-a),
    var(--bg-03-a),
    var(--bg-04-a),
    var(--bg-05-a),
    var(--bg-06-a),
    var(--bg-07-a),
    var(--bg-08-a),
    var(--bg-09-a),
    var(--bg-10-a);
  box-shadow: 0 10px 30px rgba(20, 72, 53, 0.2);
}

.rainbow-marker-loader::after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
  border-radius: 0.5rem;
  box-sizing: border-box;  
  margin-top: -7.5%;
  margin-left: -2.5%;
  animation: infinite alternate move-marker var(--duration) ease-in-out;    
  background:
    no-repeat left   0% top    / 3rem  50% linear-gradient(to bottom right, transparent, transparent 40%, var(--marker-crayon) 40%),
    no-repeat left   0% bottom / 3rem  50% linear-gradient(to top right, transparent, transparent 40%, var(--marker-crayon) 40%),
    no-repeat left 3rem bottom / 100% 100% linear-gradient(var(--marker-crayon), var(--marker-crayon));
}

/* Loading Text */
.loader-text {
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--text-color);
  margin-top: 2rem;
  letter-spacing: 1px;
  animation: textFade 1.5s ease-in-out infinite;
}

/* Brand Text */
.loader-brand {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--marker-color);
  margin-top: 1.5rem;
  letter-spacing: 2px;
  filter: drop-shadow(0 0 10px rgba(162, 193, 68, 0.3));
  animation: brandGlow 2s ease-in-out infinite;
  will-change: filter;
}

/* Animations */
@keyframes move-marker {
  10% {
    transform: translate(5%, 100%) rotate(2.5deg);
  }
  20% {
    transform: translate(20%, 0) rotate(-5deg);
  }
  30% {
    transform: translate(30%, 100%) rotate(2.5deg);
  }  
  40% {
    transform: translate(40%, 0) rotate(-5deg);
  } 
  50% {
    transform: translate(50%, 100%) rotate(2.5deg);
  }   
  60% {
    transform: translate(60%, 0) rotate(-5deg);
  }   
  70% {
    transform: translate(70%, 100%) rotate(2.5deg);
  }  
  80% {
    transform: translate(80%, 0) rotate(-5deg);
  }  
  90% {
    transform: translate(90%, 100%) rotate(2.5deg);
  }  
  100% {
    transform: translate(100%, 0) rotate(-5deg);
  }   
}

@keyframes marker-fill {
  0% {
    background:
      var(--bg-01-a),
      var(--bg-02-a),
      var(--bg-03-a),
      var(--bg-04-a),
      var(--bg-05-a),
      var(--bg-06-a),
      var(--bg-07-a),
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);
  }
  10% {
    background:
      var(--bg-01-b),
      var(--bg-02-a),
      var(--bg-03-a),
      var(--bg-04-a),
      var(--bg-05-a),
      var(--bg-06-a),
      var(--bg-07-a),
      var(--bg-08-a),  
      var(--bg-09-a), 
      var(--bg-10-a);      
  }
  20% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-a),   
      var(--bg-04-a),
      var(--bg-05-a),
      var(--bg-06-a),
      var(--bg-07-a),  
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);      
  }
  30% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-a),
      var(--bg-05-a),
      var(--bg-06-a),
      var(--bg-07-a),  
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);      
  }
  40% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-a), 
      var(--bg-06-a), 
      var(--bg-07-a),  
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);      
  }
  50% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-b), 
      var(--bg-06-a),
      var(--bg-07-a),   
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);      
  }
  60% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-b), 
      var(--bg-06-b), 
      var(--bg-07-a),   
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);      
  }    
  70% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-b), 
      var(--bg-06-b), 
      var(--bg-07-b),  
      var(--bg-08-a),
      var(--bg-09-a),
      var(--bg-10-a);      
  }  
  80% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-b), 
      var(--bg-06-b), 
      var(--bg-07-b),  
      var(--bg-08-b),
      var(--bg-09-a),
      var(--bg-10-a);      
  }
  90% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-b), 
      var(--bg-06-b), 
      var(--bg-07-b),  
      var(--bg-08-b),
      var(--bg-09-b), 
      var(--bg-10-a);     
  }   
  100% {
    background:
      var(--bg-01-b),
      var(--bg-02-b),
      var(--bg-03-b),
      var(--bg-04-b), 
      var(--bg-05-b), 
      var(--bg-06-b), 
      var(--bg-07-b),  
      var(--bg-08-b),
      var(--bg-09-b), 
      var(--bg-10-b);     
  }
}

@keyframes titlePulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.8;
    transform: scale(1.02);
  }
}

@keyframes textFade {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.6;
  }
}

@keyframes brandGlow {
  0%, 100% {
    filter: drop-shadow(0 0 10px rgba(162, 193, 68, 0.3));
  }
  50% {
    filter: drop-shadow(0 0 20px rgba(162, 193, 68, 0.6)) drop-shadow(0 0 30px rgba(162, 193, 68, 0.3));
  }
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .title {
    font-size: 1.5rem;
    letter-spacing: 1px;
    margin-bottom: 1.5rem;
  }
  
  .rainbow-marker-loader {
    height: 3rem;
    width: 16rem;
  }
  
  .loader-text {
    font-size: 1rem;
    margin-top: 1.5rem;
  }
  
  .loader-brand {
    font-size: 1.2rem;
    margin-top: 1rem;
    letter-spacing: 1px;
  }
}

@media (max-width: 480px) {
  .title {
    font-size: 1.2rem;
    letter-spacing: 0.5px;
    margin-bottom: 1rem;
  }
  
  .rainbow-marker-loader {
    height: 2.5rem;
    width: 12rem;
  }
  
  .loader-text {
    font-size: 0.9rem;
    margin-top: 1rem;
  }
  
  .loader-brand {
    font-size: 1rem;
    margin-top: 0.8rem;
    letter-spacing: 0.5px;
  }
}