

/* Global layout */
html,
body,
#root {
  height: 100%;
  margin: 0;
}

body {
  font-size: 18px;
}

/* Main content area - 18px minimum (exclude header, sidebar, and logo) */
main .MuiTypography-body1:not(.content-logo-wrapper *),
main .MuiTypography-body2:not(.content-logo-wrapper *),
[role="main"] .MuiTypography-body1:not(.content-logo-wrapper *),
[role="main"] .MuiTypography-body2:not(.content-logo-wrapper *) {
  font-size: 18px !important;
}

/* Content area logo wrapper */
.content-logo-wrapper {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
  margin-top: 8px;
}

/* Buttons in main content - 18px */
main .MuiButton-root,
[role="main"] .MuiButton-root {
  font-size: 18px !important;
}

/* Animated stripes for progress bar */
@keyframes stripes {
  from {
    background-position: 40px 0;
  }
  to {
    background-position: 0 0;
  }
}

.linear-striped {
  background-image: repeating-linear-gradient(
    45deg,
    rgba(255, 255, 255, 0.2) 0,
    rgba(255, 255, 255, 0.2) 10px,
    transparent 10px,
    transparent 20px
  );
  background-size: 40px 40px;
  animation: stripes 1s linear infinite;
}

/* Spin animation for loading icons */
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Blink animation for typing cursor */
@keyframes blink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}