@charset "UTF-8";
/*----- ResoponsiveTemplate02 -----*/
@import url("//share.cr-cms.net/hp_agency/hpagency.css");
@import url("//fonts.googleapis.com/css2?family=Open+Sans:wght@500;700&display=swap");
@import url("//use.fontawesome.com/releases/v5.6.1/css/all.css");
/* Reset --------------------*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video,
input,
textarea,
select {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

/* BasicSetting --------------------*/
@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Medium");
}
@font-face {
  font-family: YuGothicM;
  src: local("Yu Gothic Medium");
}
@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}
* {
  margin: 0;
  padding: 0;
  font-family: inherit;
}

html {
  scroll-behavior: smooth;
}

body {
  font-size: 18px;
  line-height: 2;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-family: "Open Sans", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "BIZ UDGothic", "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.serif {
  font-family: Georgia, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "BIZ UDPMincho", "Yu Mincho", "游明朝体", "YuMincho", "游明朝", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

strong {
  font-weight: bold;
}

h2,
h3,
h4,
h5,
h6,
#name,
.article.concept,
.title,
.comment {
  font-feature-settings: "palt";
}

#wrap * {
  box-sizing: border-box;
}

table {
  margin: auto;
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  border: none;
  vertical-align: bottom;
}

ol,
ul {
  list-style: none;
}
ol li,
ul li {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

/* Links --------------------*/
a {
  text-decoration: none;
  font-weight: bold;
}

.article a {
  text-decoration: underline;
}

a:hover {
  font-weight: bold;
  text-decoration: none;
}

.footer a:hover,
.footer p a:hover {
  font-weight: bold;
}

.ams-build a,
.ams-build a:hover {
  font-weight: normal;
}

#mainArticles a:hover img,
#sideBanners a:hover img,
div.freeHtml a:hover img,
div.image img.gallery:hover {
  filter: alpha(opacity=75);
  -moz-opacity: 0.75;
  opacity: 0.75;
}

.sideBanner_body a:hover,
.thumb a:hover,
.image a:hover {
  filter: alpha(opacity=80);
  opacity: 0.8;
}

/* BasicLayout --------------------*/
#wrap {
  width: 100%;
  overflow: hidden;
}

#wrap_body {
  display: flex;
  flex-direction: column;
}
#wrap_body #title {
  order: 1;
}
#wrap_body #mainImage {
  order: 3;
}
#wrap_body #topMenu {
  order: 2;
}
#wrap_body #contents {
  order: 4;
  margin: auto;
  box-sizing: border-box;
}
#wrap_body #footer {
  order: 5;
}

#title,
#mainImage,
#topMenu,
#contents,
#sideContents,
#footer {
  width: 100%;
  position: relative;
}

#title_outer,
#topMenu_outer,
#mainArticles,
#mainTopics_outer,
#sideContents_outer,
#footer_outer,
#mainBlogComments,
#mainBlogCommentForm {
  width: 1024px;
  margin: auto;
}

#pankuz {
  padding: 0;
  margin: 0 auto;
  width: 1024px;
}
#pankuz p {
  margin: 16px 0;
  text-align: right;
  font-size: 0.78em;
  line-height: 1;
}
#pankuz a {
  text-decoration: underline;
}
#pankuz a:hover {
  text-decoration: none;
}

/*Header*/
#title #title_outer {
  background: url("") right center no-repeat;
  margin: auto;
  padding: 0;
  height: 104px;
  display: flex;
  align-items: center;
}
#title h1 {
  background: url("") no-repeat;
  margin: 0 auto;
  padding: 0;
  text-align: left;
  /*height: 104px;*/
  width: 400px;
  float: left;
  font-size: 1.5em;
}
#title .description {
  text-indent: -9999px;
  visibility: hidden;
}

/*GlobalMenu*/
#topMenu_outer {
  padding: 0;
  box-sizing: border-box;
}
#topMenu_outer .topMenu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
#topMenu_outer .topMenu li {
  letter-spacing: normal;
  background: none;
  box-sizing: border-box;
  width: auto;
  text-align: center;
  flex: 1 0 auto;
}
#topMenu_outer .topMenu li a {
  width: 100%;
  box-sizing: border-box;
  display: block;
  padding: 0 0.5em;
  line-height: 56px;
  font-weight: bold;
  letter-spacing: 0.03em;
  text-decoration: none;
  position: relative;
}
#topMenu_outer .topMenu li a:after {
  content: "";
  width: 1px;
  height: 28px;
  display: inline-block;
  position: absolute;
  top: 16px;
  right: 0;
}
#topMenu_outer .topMenu li:last-of-type a:after {
  content: none;
}

/*Main image*/
#mainImage_body {
  text-align: center;
}

.mainImage img,
.mainImage #slider li img {
  max-width: 100%;
  min-width: 1024px;
  width: auto;
  height: auto;
  overflow: hidden;
  margin: auto;
}

/*Footer*/
#footer {
  font-size: 0.888em;
}

#footer_body {
  display: flex;
  justify-content: flex-start;
  padding: 32px 0 88px;
}
#footer_body .topMenu,
#footer_body .services {
  margin: 8px;
  clear: none;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  width: 35%;
}
#footer_body .topMenu li,
#footer_body .services li {
  box-sizing: border-box;
  border: none;
  margin-bottom: 5px;
  margin-right: 8px;
  float: none;
  height: auto;
  line-height: 32px;
}
#footer_body .topMenu li a,
#footer_body .services li a {
  text-align: left;
  padding: 5px 15px;
  display: block;
}
#footer_body .topMenu li a:before,
#footer_body .services li a:before {
  font-family: "Font Awesome 5 Free";
  content: "\f105";
  font-weight: bold;
  margin-right: 8px;
}
#footer_body .topMenu li a:hover,
#footer_body .services li a:hover {
  text-decoration: none;
}
#footer_body .copyright {
  font-weight: bold;
  padding: 32px 0;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  clear: both;
  line-height: 18px;
  text-align: center;
}

/* ArticlesLayout --------------------*/
#mainContents {
  padding-bottom: 40px;
}

.mainArticles {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  justify-content: space-between;
}

/*LayoutOptions*/
.article,
.gallery {
  width: 1024px;
  margin: 0 auto 40px;
}
.article.full,
.gallery.full {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 40px;
}
.article.full .article_body,
.gallery.full .article_body {
  width: 1024px;
  margin: auto;
}
.article.full.bg, .article.full.theme, .article.full.gray,
.gallery.full.bg,
.gallery.full.theme,
.gallery.full.gray {
  padding-top: 40px;
  padding-bottom: 40px;
}
.article.max,
.gallery.max {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 40px;
}
.article.max .article_body,
.gallery.max .article_body {
  width: 100%;
}
.article.bg, .article.theme, .article.gray,
.gallery.bg,
.gallery.theme,
.gallery.gray {
  padding: 40px;
}
.article.bg h3, .article.theme h3, .article.gray h3,
.gallery.bg h3,
.gallery.theme h3,
.gallery.gray h3 {
  margin-top: 0;
  padding-top: 0;
}
.article.zero_margin,
.gallery.zero_margin {
  margin-bottom: 0;
  padding-bottom: 0;
}
.article p,
.gallery p {
  margin-bottom: 1em;
}

.article {
  /*MultipleColumn*/
  /*ImageLayout*/
}
.article.col2 {
  flex-basis: 49%;
}
.article.col3 {
  flex-basis: 32.5%;
}
.article.col4 {
  flex-basis: 24%;
}
.article.col5 {
  flex-basis: 19%;
}
.article.col2, .article.col3, .article.col4, .article.col5 {
  margin: 0 auto 40px;
}
.article.col2.bg, .article.col2.theme, .article.col2.gray, .article.col3.bg, .article.col3.theme, .article.col3.gray, .article.col4.bg, .article.col4.theme, .article.col4.gray, .article.col5.bg, .article.col5.theme, .article.col5.gray {
  padding: 40px;
}
.article.col2.bg h3, .article.col2.theme h3, .article.col2.gray h3, .article.col3.bg h3, .article.col3.theme h3, .article.col3.gray h3, .article.col4.bg h3, .article.col4.theme h3, .article.col4.gray h3, .article.col5.bg h3, .article.col5.theme h3, .article.col5.gray h3 {
  margin-top: 0;
  padding-top: 0;
}
.article.col4.bg, .article.col4.theme, .article.col4.gray, .article.col5.bg, .article.col5.theme, .article.col5.gray {
  padding: 20px;
}
.article.max {
  padding: 40px;
}
.article .image {
  width: auto;
  text-align: center;
  overflow: hidden;
}
.article .image img {
  max-width: 100%;
}
.article .article_left .image,
.article .article_right .image {
  max-width: 44%;
}
.article .article_left .image {
  float: left;
  margin-right: 2%;
}
.article .article_right .image {
  float: right;
  margin-left: 2%;
}
.article .article_center .image {
  margin-bottom: 1em;
}
.article.underImg .article_body {
  display: flex;
  flex-direction: column;
}
.article.underImg .article_body .image {
  order: 1;
}

/*Gallery*/
.gallery {
  /*MAX GALLERY*/
}
.gallery ul.galleryImages {
  display: flex;
  flex-wrap: wrap;
}
.gallery ul.galleryImages li {
  flex-basis: 20%;
  margin: 0 0 16px;
  padding: 4px;
  overflow: hidden;
}
.gallery ul.galleryImages li .image {
  margin-bottom: 8px;
  text-align: center;
}
.gallery ul.galleryImages li .image img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.gallery ul.galleryImages li .title {
  text-align: center;
  line-height: 1;
  font-size: 0.78em;
  font-weight: bold;
}
.gallery ul.galleryGrids .comment {
  font-size: 0.78em;
  text-align: center;
  font-weight: bold;
}
.gallery.max {
  padding-left: 0;
  padding-right: 0;
}
.gallery.max.bg, .gallery.max.theme, .gallery.max.gray {
  padding: 40px 0;
}
.gallery.max ul.galleryGrids {
  display: flex;
}
.gallery.max ul.galleryGrids li * {
  margin: 0;
  padding: 0;
}
.gallery.max .gallery_grid2 li {
  width: 50%;
}
.gallery.max .gallery_grid3 li {
  width: 33.3333333333%;
}
.gallery.max .gallery_grid4 li {
  width: 25%;
}
.gallery.max .gallery_grid5 li {
  width: 20%;
}

/* Responsive --------------------*/
#toggle {
  display: none;
}

@media only screen and (max-width: 1024px) {
  #title_outer,
  #topMenu_outer,
  #pankuz,
  #mainArticles,
  #mainTopics_outer,
  #sideContents_outer,
  #footer_outer,
  #mainBlogComments,
  #mainBlogCommentForm {
    width: 100%;
  }
  #sideContents_outer {
    padding-left: 4%;
    padding-right: 4%;
  }
  .mainImage img,
  .mainImage #slider li img {
    min-width: 100%;
  }
  .article {
    width: 100%;
    padding-left: 4%;
    padding-right: 4%;
  }
  .article.col2, .article.col3, .article.col4, .article.col5 {
    margin: 0 0 40px;
    padding-left: 2% !important;
    padding-right: 2% !important;
  }
  .article.col2 .article_body, .article.col3 .article_body, .article.col4 .article_body, .article.col5 .article_body {
    width: 100%;
  }
  .article.col4, .article.col5 {
    flex-basis: 49%;
  }
  .article.full, .article.max {
    margin: 0 0 40px;
    width: 100%;
    flex-basis: 100%;
    padding-left: 4%;
    padding-right: 4%;
  }
  .article.full .article_body, .article.max .article_body {
    width: 100%;
  }
  .article.bg, .article.theme, .article.gray {
    padding-left: 4%;
    padding-right: 4%;
  }
  .gallery {
    width: 100%;
    padding-left: 4%;
    padding-right: 4%;
  }
  .gallery.bg, .gallery.theme, .gallery.gray {
    padding-left: 4%;
    padding-right: 4%;
  }
  .gallery.full, .gallery.max {
    width: 100%;
    margin: 0 0 40px;
    padding: 0;
  }
  .gallery.full {
    padding-left: 4%;
    padding-right: 4%;
  }
  .gallery.full .article_body {
    width: 100%;
  }
  #mainBlogComments_body,
  #mainBlogCommentForm_body {
    width: 100%;
    padding-left: 4%;
    padding-right: 4%;
  }
}
@media only screen and (max-width: 600px) {
  body {
    font-size: 16px;
  }
  #title #title_outer {
    height: 56px;
    background: none;
  }
  #title h1 {
    padding-left: 4%;
  }
  #pankuz p {
    font-size: 0.75em;
  }
  /*MENU*/
  #toggle {
    width: 56px;
    height: 56px;
    padding: 0;
    display: block;
    text-align: center;
    cursor: pointer;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 10001;
  }
  #topMenu {
    position: unset;
    height: 0;
    min-height: 0;
    overflow: hidden;
    transition: all 0.5s;
  }
  body.active #topMenu {
    height: 245px;
  }
  #topMenu_outer {
    height: 0;
    padding: 0;
  }
  #topMenu_outer .topMenu {
    flex-direction: column;
  }
  #topMenu_outer .topMenu li a {
    padding: 0 0 0 4%;
    line-height: 1.25;
    min-height: 48px;
    text-align: left;
    display: flex;
    align-items: center;
  }
  #topMenu_outer .topMenu li a:after {
    content: none;
  }
  /*Footer*/
  #footer_body {
    display: block;
    padding: 24px 0 0;
  }
  #footer_body .topMenu,
  #footer_body .services {
    width: 100%;
    margin: 0;
  }
  #footer_body .topMenu li,
  #footer_body .services li {
    margin: 0;
  }
  #footer_body .services {
    margin-bottom: 24px;
  }
  #footer_body .copyright {
    position: unset;
  }
  /*Articles*/
  .article.col2, .article.col3, .article.col4, .article.col5 {
    flex-basis: 100%;
    padding-left: 4% !important;
    padding-right: 4% !important;
  }
  .article .article_left .image,
  .article .article_right .image {
    max-width: 100%;
    margin: 0px auto 1em;
    float: none;
  }
  /*Gallery*/
  .gallery ul.galleryImages li {
    flex-basis: 50%;
  }
  .gallery .gallery_grid2 li.galleryGrid,
  .gallery .gallery_grid3 li.galleryGrid,
  .gallery .gallery_grid4 li.galleryGrid,
  .gallery .gallery_grid5 li.galleryGrid {
    width: 50%;
  }
  .gallery ul.galleryGrids .comment,
  .gallery ul.galleryImages li .title {
    font-size: 0.888em;
  }
}/*# sourceMappingURL=common.css.map */