:root {
    --root-bg-main: rgba(255, 255, 255, 1);
    --root-bg-secondary: rgb(0, 0, 0);
    --root-bg-accent: rgba(242, 243, 247, 1);
    --root-bg-accent-secondary: rgba(35, 74, 224, 1);
    --root-color-main: rgb(255, 255, 255);
    --root-color-secondary: rgb(0, 0, 0);
    --root-font-family: "roboto", 'helvetica', arial, sans-serif;
    --root-line-height: 1.25rem;
    --root-font-weight: 400;
    --root-font-weight-med: 600;
    --root-font-weight-bold: 700;
    --root-font-style: normal;
    --font-size-sm: clamp(0.8rem, 0.07vi + 0.78rem, 0.84rem);
    --font-size-base: clamp(1rem, 0.19vi + 0.96rem, 1.13rem);
    --font-size-md: clamp(1.25rem, 0.38vi + 1.16rem, 1.5rem);
    --font-size-lg: clamp(1.56rem, 0.66vi + 1.41rem, 2rem);
    --font-size-xl: clamp(1.95rem, 1.07vi + 1.7rem, 2.66rem);
    --font-size-xxl: clamp(2.44rem, 1.67vi + 2.05rem, 3.55rem);
    --font-size-xxxl: clamp(3.05rem, 2.53vi + 2.46rem, 4.73rem);
}



/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Prevent font size inflation */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  scroll-behavior: smooth;
}

/* Remove default margin in favour of better control in authored CSS */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin-block-end: 0;
  margin: 0;
  padding: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role="list"],
ol[role="list"] {
  list-style: none;
}

Set shorter line heights on headings and interactive elements h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: 1.3;
}

/* Balance text wrapping on headings */
h1,
h2,
h3,
h4 {
  text-wrap: balance;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}

/* Make images easier to work with */
img,
picture {
  max-inline-size: 100%;
  max-height: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
}

/* Make sure textareas without a rows attribute are not tiny */
textarea:not([rows]) {
  min-height: 10em;
}

/* Anything that has been anchored to should have extra scroll margin */
:target {
  scroll-margin-block: 5ex;
}

body {
  font-family: "roboto", Arial, Helvetica, sans-serif;
  background-color: var(--root-bg-secondary);
  color: var(--root-color-main)
}

.text-focus-in {
	-webkit-animation: text-focus-in 600ms ease-in both;
	        animation: text-focus-in 600ms ease-in both;
}

@-webkit-keyframes text-focus-in {
  0% {
    -webkit-filter: blur(12px);
            filter: blur(12px);
    opacity: 0;
  }
  100% {
    -webkit-filter: blur(0px);
            filter: blur(0px);
    opacity: 1;
  }
}
@keyframes text-focus-in {
  0% {
    -webkit-filter: blur(12px);
            filter: blur(12px);
    opacity: 0;
  }
  100% {
    -webkit-filter: blur(0px);
            filter: blur(0px);
    opacity: 1;
  }
}


.top-nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    align-items: center;
    justify-content: center;
    text-align: center;
    padding-top: 1rem;
    padding-inline: min(2rem, 4%);
}

.logo-wordmark {
    grid-column-start: 2;
    justify-self: center;
}

.logo-image-link {
    width: 100%;
    height: auto;
    justify-self: center;
}

.logo-image {
width: 100%;
min-width: 350px;
max-width: 450px;
height: auto;	
}

.social-media-links {
    justify-self: center;
}



/* STYLING FOR MENU WITH TEXT AND MULTIPLE ICONS */

/* .menu-items-stacked {
    grid-column-start: 3;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-self: right;
    padding-right: 2rem;
} */

/* .top-nav-links {
    display: flex;
    gap: 1.5rem;
    align-items: center;
} */

/* .social-media-links {
    display: flex;
    gap: 1rem;
} 
    
/* li {
    text-decoration: none;
    list-style: none;
}

li a {
    text-decoration: none;
}

li:hover {
    text-decoration: underline;
    text-underline-offset: 8px;
    transition: opacity 0.3s ease;
}

ul {
    margin: 0;
    padding: 0;
} */

.social-media-links {
  text-align: center;
}

.social-media-links img {
  max-width: 32px;
}

.main-wrapper {
    max-width: 100%;
    margin: 0 auto;
    width: 1400px;
    padding-inline: min(2rem, 4%);
}

.hero-text {
    padding-block: 3rem;
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.hero-text h1 {
    font-weight: 400;
    font-size: var(--font-size-lg);
    font-family: "EB Garamond", "roboto", Arial, Helvetica, sans-serif;
}

.artist-image-grid {
    display: grid;
    gap: 1.5rem;
    padding-block: 2rem;
    justify-content: center;
}

.image-container {
    position: relative;
    text-align: center;
}

.image-container a {
  text-decoration: none;
}

.artist-images-square {
  aspect-ratio: 1 / 1;
  object-fit: cover;
}


@media (min-width: 1024px) {

.artist-image-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: repeat(auto-fit, minmax(325px, 1fr));
    padding-block: 3rem;
}

.artist-image-grid :last-child {
  grid-column-start: 2;
}

  .image-overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    opacity: 0;
    transition: opacity 0.3s ease;
    background-color: rgba(83, 79, 79, 0.5);
    display: flex;
    justify-content: center;
    align-items: center;
    backdrop-filter: blur(2px);
}

.image-container:hover .image-overlay {
    opacity: 1;
}

.image-text {
      padding-top: 0px;
}
}


.image-text {
    color: var(--root-color-main);
    font-size: var(--font-size-md);
    text-align: center;
    font-weight: 400;
    letter-spacing: 0.1rem;
}

  .image-overlay {
    padding-top: 1rem;
    padding-bottom: 2rem;
}

.divider-line {
  opacity: 30%;
}

.footer-wrapper {
    padding-block: 2rem;
    background-color: var(--root-bg-secondary);
    text-align: center;
}

.footer-layout {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(325px, 1fr));
    align-items: center;
}

.footer-layout img {
  justify-self: center;
  padding-block: 1rem;
}

.social-media-links-footer {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  justify-content: center;
  text-align: center;
  align-items: center;
}

.insta-icon-footer {
  max-width: 32px;
  justify-self: center;
  text-align: center;
}

.social-media-links-footer a {
  text-decoration: none;
}





