@charset "utf-8";

@import url("https://fonts.googleapis.com/css2?family=Cherry+Bomb+One&family=Noto+Sans+JP:wght@400;700;900&display=swap");

html {
	font-size: 62.5%;
	overflow-y: scroll;
}

body {
	font-size: 1.6rem;
	line-height: 1.5;
  font-family: "Noto Sans JP", sans-serif;
  background: #fdf5e6
}

a {
  color: #333;
  text-decoration: none;
}

/* header */

header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 102.4rem;
  margin: 0 auto;
  height: 8rem;
  padding: 0 1.6rem;
}

header h1 {
  width: 200px;  
}

header nav ul {
  display: flex;
}

header nav ul li {
  margin-left: 2.5em;
  font-size: 1.2em;
}

/* main */

main section h2 {
  text-align: center;
  font-weight: bold;
}

main section h2 span {
  display: block;
}

main section h2 span:first-child {
  color: #ffa500;
}

main section h2 span:last-child {
  font-size: 2em;
}

/* .firstview */

main .firstview {
  background-image: url(../images/main_visual.jpg);
  background-size: cover;
  background-position: center;
  height: 70rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

main .firstview p {
  font-size: 5.5em;
  font-weight: bold;
  letter-spacing: 0.25em;
  color: #fff;
}

main .firstview p::first-letter {
  color: #ffa500;
}

/* #about */

main #about {
  max-width: 80rem;
  margin: 12rem auto 0;
}

main #about .about-wrapper {
  display: flex;
  margin-top: 6rem;
}

main #about .about-wrapper .about-image {
  margin-top: 4rem;
}

main #about .about-wrapper .about-text {
  margin: 0 1.6rem 0 8rem;
}

main #about .about-wrapper .about-text div h3 {
  font-size: 1.5em;
  color: #ffa500;
  margin-bottom: 0.5em;
}

main #about .about-wrapper .about-text div p {
  text-align: justify; 
}

main #about .about-wrapper .about-text div:last-child {
  margin-top: 3rem;
}

/* #skills */

main #skills {
  max-width: 102.4rem;
  margin: 12rem auto 0;
  padding: 0 1.6rem;
}

main #skills h3 {
  background: #ffa500;
  border-radius: 20px;  
}

main #skills ul {
  margin: 6rem auto;
  display: flex;
  flex-wrap: wrap;
  gap: 4rem 2rem;
  max-width: 100%;
}

main #skills ul li {
  width: 23rem;
}

main #skills ul li h3 {
  font-size: 1.5em;
  font-weight: bold;
  text-align: center;
}

main #skills ul li p {
  margin-top: 1em;
  text-align: justify; 
}

/* #works */

main #works {
  max-width: 90rem;
  margin: 12rem auto 0;
}

main #works .comment {
  text-align: center;
}

main #works ul {
  margin-top: 6rem;
}

main #works ul li {
  display: flex;
  gap: 0 5rem;
  margin-top: 4.5rem;
}

main #works ul li:nth-child(even) {
  flex-direction: row-reverse;
}

main #works ul li div {
  width: 50%;
}

main #works ul li div:nth-child(even) {
  margin-top: 2em;
}

main #works ul li div p {
  padding: 0 0.4rem;
}

main #works ul li div img {
  width: 100%;
  height: auto;
}

main #works ul li div p:first-child {
  font-weight: bold;

}

main #works ul li div p:last-child {
  margin-top: 1em;
  text-align: justify; 
}

/* #contact */

main #contact {
  margin: 12rem 0;
  text-align: center;
}

main #contact div p:first-child {
  margin-top: 6rem;
}

main #contact div p:last-child {
  font-size: 2em;
  font-weight: bold;
  margin-bottom: 3rem;
}

main #contact div a {
  margin: 0 1em;
}

/* footer */

footer {
  background: #ddd;
  padding: 3rem 0 1rem;
}

footer nav ul {
  display: flex;
  justify-content: space-between;
  max-width: 40rem;
  margin: 0 auto;
}

footer nav ul li {
  font-size: 1.2em;
}

footer p {
  margin-top: 2em;
  text-align: center;
}

/* 画面サイズ1024px未満の場合 */

@media (max-width: 1023px) {

  header nav ul li a {
    font-size: 1.775rem;
  }

  main #skills ul {
    max-width: 50rem;
  }

}

/* 画面サイズ768px未満の場合 */

@media (max-width: 767px) {
  body {
    font-size: 1.4rem;
  }

    /* header */

  header {
    display: block;
    height: auto;
    padding: 2rem 1.6rem;
  }

  header nav ul {
    margin-top: 1.5rem;
    justify-content: space-between;
  }

  header nav ul li {
    margin-left: 0;
  }

  /* main */

  /* .firstview */

  main .firstview p {
    font-size: 3em;
    letter-spacing: 0.16em;
  }

  /* #about */

  main #about .about-wrapper {
    display: block;
  }

  main #about .about-wrapper .about-image {
    text-align: center;
  }

  main #about .about-wrapper .about-text {
    margin-top: 4rem;
    margin-left: 1.6rem;
    width: auto;
  }

  /* #skills */

  main #skills ul li {
    margin-left: 1.6rem;
    width: auto;
  }

  /* #works */

  main #works ul li {
    display: block;
  }

  main #works ul li div {
    width: auto;
  }

  main #works ul li div:nth-child(even) {
    padding: 0 1.6rem;
  }

  /* #contact */

  /* footer */

  footer {
    padding: 3rem 1.6rem 1rem;
  }

}

