
body {
  font-size: 12px;
  font-size: 1.2rem;

}

a {
  position: relative;
  color: #333;
}

h1.title, h2.title {
  color: #333;
  margin-top: 10px;
  margin-top: 1.0rem;
  margin-bottom: 10px;
  margin-bottom: 1.0rem;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
}

h1.title a:hover, h2.title a:hover {
  background-color: #ff9999;
}

h1.title {
  line-height: 2.6;
  font-size: 14px;
  font-size: 1.4rem;
}

h2.title {
  line-height: 1.3;
  font-size: 13px;
  font-size: 1.3rem;
}

h3 {
  color: #333333;
  margin-top: auto;
  margin-bottom: auto;
  margin-left: auto;
  margin-right: auto;
  font-size: 12px;
  font-size: 1.2rem;
}

img {
  border:0;
  margin-top: 5px;
  margin-top: 0.5rem;
  margin-bottom: 10px;
  margin-bottom: 1.0rem;
  margin-left: 5px;
  margin-left: 0.5rem;
  margin-right: 5px;
  margin-right: 0.5rem;
  vertical-align:bottom;
  text-align: center;
}

.title-text {
  border-bottom: solid 4px #999;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
}

.CenterColumn-text {
  font-size: 10px;
  font-size: 1.0rem;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
  line-height: 1.5;
}
 
.CenterColumn-text a {
  margin-left: 5px;
  margin-left: 0.5rem;
  margin-right: 5px;
  margin-right: 0.5rem;
  margin-top: 5px;
  margin-top: 0.5rem;
  margin-bottom: 5px;
  margin-bottom: 0.5rem;
  color: #003399;
}

.CenterColumn-text a:hover {
  color:  #ff0000;
}

.Detail-page {
  font-size: 10px;
  font-size: 1.0rem;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
  line-height: 1.5;
  background-color: #333399;
  border-radius: 10px;
  text-align: center;
}

.Detail-page a {
  margin-left: 5px;
  margin-left: 0.5rem;
  margin-right: 5px;
  margin-right: 0.5rem;
  margin-top: 5px;
  margin-top: 0.5rem;
  margin-bottom: 5px;
  margin-bottom: 0.5rem;
  color: #ffffff;
}

.Detail-page a:hover {
  color:  #ff9999;
}

.Detail {
  font-size: 10px;
  font-size: 1.0rem;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
  line-height: 1.5;
  background-color: #333399;
  border-radius: 10px;
  text-align: center;
}

.Detail a {
  margin-left: 5px;
  margin-left: 0.5rem;
  margin-right: 5px;
  margin-right: 0.5rem;
  margin-top: 5px;
  margin-top: 0.5rem;
  margin-bottom: 5px;
  margin-bottom: 0.5rem;
  color: #ffffff;
}

.Detail a:hover {
  color:  #ff9999;
}

.CenterColumn-table {
  width: 100%;
  margin-top: 10px;
  margin-top: 1.0rem;
  margin-bottom: 10px;
  margin-bottom: 1.0rem;
  margin-left: auto;
  margin-right: auto;
  background-color: #99FF66;
}

.CenterColumn-table th {
  border: 1px solid #333333;
  background-color: #ffff99;
  max-width: 40px;
}

.CenterColumn-table td {
  border: 1px solid #333333;
  background-color: #ffff99;
}

.LeftColumn-text {
  font-size: 10px;
  font-size: 1.0rem;
  line-height: 1.5;
  margin-top: 10px;
  margin-top: 1.0rem;
  margin-bottom: 10px;
  margin-bottom: 1.0rem;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
  text-align: left;
}

.RightColumn-text {
  font-size: 10px;
  font-size: 1.0rem;
  line-height: 1.5;
  margin-top: 10px;
  margin-top: 1.0rem;
  margin-bottom: 10px;
  margin-bottom: 1.0rem;
  margin-left: 10px;
  margin-left: 1.0rem;
  margin-right: 10px;
  margin-right: 1.0rem;
  color: #fff;
  background-color: #4169e1;
  text-align: center;
}

.pageTop {
  margin-top: 10px;
  margin-top: 1.0rem;
  margin-bottom: 10px;
  margin-bottom: 1.0rem;
  padding:5px;
  text-align:center;
}

.pageTop a {
  font-size: 10px;
  font-size: 1.0rem;
}

.pageTop a:hover {
  color:  #ffffff;
  background-color: #006699;
}

/* 画面サイズ 1023px以下 */
@media only screen and (max-width: 1023px) {

  .container{
    display:block;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: auto;
    margin-bottom: auto;
  }

  .header {
    display:block;
    width: 100%;
    line-height: 40px;
    background-color: #4169e1;
    text-align: left;
    color: #fff;
  }

  .header-table {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  	font-size: 8px;
  	font-size: 0.8rem;
  }

  .footer {
    height: 40px;
    line-height: 40px;
    background-color: #4169e1;
    text-align: center;
    color: #fff;
  }

  .CenterColumn {
    margin-left: auto;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: auto;
    margin-bottom: auto;
    background-color: #efffff;
  }

  .LeftColumn {
    width: 100%;
    color: #fff;
    margin-left: auto;
    margin-right: auto;
    margin-top: auto;
    margin-bottom: auto;
  }

  .LeftColumn ul{
    padding-left:0;
  }

  .LeftColumn li a {
    display: block;
    height: 44px;
    line-height: 44px;
    border-bottom: 2px solid #333;
    text-decoration: none;
    margin-top: 20px;
    margin-bottom: 20px;
    color: #333;
  }

  .LeftColumn li a:hover {
    color:  #ffffff;
    background-color: #006699;
  }

  .RightColumn {
    display: block;
    margin-left: 20px;
    border-bottom: 1px solid #333;
  }
  
  .RightColumn li a {
    display: block;
    height: 44px;
    line-height: 44px;
    border-bottom: 1px solid #333333;
    text-decoration: none;
    color: #4169e1;
  }

  .RightColumn li a:hover {
    color:  #ffffff;
    background-color: #006699;
  }


  .RightColumn div {
    display: flex;
    margin-bottom: 20px;
  }

  .RightColumn div a {
    display:block;
    line-height: 70px;
    background-color: #4169e1;
    text-decoration: none;
    text-align: center;
    color: #fff;
  }
  
  .RightColumn div a:hover {
    color:  #ffffff;
    background-color: #006699;
  }

  /* flex_box */
  .flex_box {
    display: block;
    padding:  10px;
  }

  /* flex_item */
  .flex_item {
    padding: 10px;
    color:  #0033ff;
    margin:  10px;
    border-radius:  5px;
  }

  .flex_item:nth-child(1) {
    background-color:  #33ff66;
    width: 95%;
    margin-left: auto;
    margin-right: auto;
  }

  .flex_item:nth-child(2) {
    background-color:  #ffcc33;
    width: 95%;
    margin-left: auto;
    margin-right: auto;
  }

  .CenterColumn-table {
    table-layout: fixed;
  }

  .CenterColumn-table th {
  	display: block;
    max-width: none;
  	width: 100%;
    word-wrap: break-word;
  }

  .CenterColumn-table td {
  	display: block;
  	width: 100%;
    word-wrap: break-word;
  }

  .header-table td {
    display: block;
    text-align: center;
    width: 100%;
  }

  .CenterColumn-table img {
    display: none;
  }

  .CenterColumn-text img {
    width: 100%;
  }

}

/* 画面サイズ 1024px以上 */
@media only screen and (min-width: 1024px), print {

  html {
  	font-size: 81.4286%;
  }

  .container{
    display:flex;
    position: relative;
    width: 1200px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .header {
    display:flex;
    position: relative;
    line-height: 40px;
    background-color: #4169e1;
    text-align: left;
    color: #fff;
  }

  .header-table {
    width: 1200px;
    margin-left: auto;
    margin-right: auto;
  }

  .footer {
    height: 40px;
    line-height: 40px;
    background-color: #4169e1;
    text-align: center;
    color: #fff;
  }

  .CenterColumn {
    flex: 2;
    margin-left: 10px;
    width: 620px;
    background-color: #efffff;
  }

  .LeftColumn {
    flex: 1;
    width: 360px;
    color: #fff;
  }

  .LeftColumn li a {
    display: block;
    height: 44px;
    line-height: 44px;
    border-bottom: 1px solid #333;
    text-decoration: none;
    color: #333;
  }

  .LeftColumn li a:hover {
    color:  #ffffff;
    background-color: #006699;
  }

  .RightColumn {
    display: block;
    flex: 1;
    margin-left: auto;
    margin-right: auto;
    text-align:center;
    height:700px;
    width: 100%;
    border-bottom: 1px solid #333;
    position: -webkit-sticky; /* Safari */
    position: sticky;
    top:0px;
  }
  
  .RightColumn li a {
    display: flex;
    height: 44px;
    line-height: 44px;
    border-bottom: 1px solid #333333;
    text-decoration: none;
    color: #4169e1;
  }

  .RightColumn li a:hover {
    color:  #ffffff;
    background-color: #006699;
  }


  .RightColumn div {
    display: flex;
    margin-bottom: 20px;
  }

  .RightColumn div a {
    display:block;
    height: 70px;
    line-height: 70px;
    background-color: #4169e1;
    text-decoration: none;
    text-align: center;
    color: #fff;
  }
  
  .RightColumn div a:hover {
    color:  #ffffff;
    background-color: #006699;
  }

  /* flex_box */
  .flex_box {
    display: flex;
    padding:  10px;
  }

  /* flex_item */
  .flex_item {
    padding: 10px;
    color:  #0033ff;
    margin:  10px;
    border-radius:  5px;
  }

  .flex_item:nth-child(1) {
    background-color:  #33ff66;
    width: 45%;
    margin-left: 5px;
    margin-right: auto;
  }

  .flex_item:nth-child(2) {
    background-color:  #ffcc33;
    width: 45%;
    margin-left: auto;
    margin-right: 5px;
  }

  .Detail-page {
    display: none;
  }

}