:root {
  --main-object-margin-height: 45px;
  --site-main-color: #3573c9;
  --site-white-color: #f1f1f1;
  --site-black-color: #333333;
  --site-red-color: #ca4c4c;
}

.clearfix:after{
  content: ".";
  clear:both;
  display:block;
  height:0;
  font-size: 0;
}

br { letter-spacing:0; }

body, td, th {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
  font-size: 21px;
  color: var(--site-black-color);
}

body {
  min-width: 1260px;
  background-color: var(--site-white-color);
}

footer {
  width: 100%;
}

#footer-link {
  padding: 40px 0;
  //background-color: #efeeed;
  background-color: #ffffff;
}

#footer-link ul {
  text-align: center;
}

#footer-link ul li {
  display: inline-block;
  text-align: left;
  margin: 0 1em;
  font-size: 18px;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-style: normal;
  line-height: 1.3em;
}

#footer-link ul li a {
  color: var(--site-black-color);
  text-decoration: none;
}

#footer-link ul li a:hover {
  text-decoration: underline;
}

#footer-link ul li a h1 {
  font-weight:bold;
  margin-bottom: 0.5em;
}

#footer-link ul li a img {
  vertical-align: top;
  margin-left: 2px;
  margin-top: 4px;
  width: 18px;
}

#footer-contact {
  width: 100%;
  padding: 40px 0;
  font-size: 0;
  text-align: center;
  background-color: #dededd;
}

#footer-contact-left {
  display: inline-block;
  vertical-align: top;
  width: 410px;
}

#footer-contact-left:hover {
  opacity: 0.7;
}

#footer-contact-right {
  display: inline-block;
  vertical-align: top;
  width: 360px;
  margin-left: 60px;
  line-height: 1.4em;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 17px;
  font-weight: bold;
  color: var(--site-black-color);
  text-align: left;
}

#footer-contact-right-pamphlet {
  margin-top: 0.7em;
  line-height: 1em;
  font-size: 16px;
}

#footer-contact-right-pamphlet img {
  vertical-align: top;
  margin-right: 6px;
  height: 18px;
}

#footer-contact-right-pamphlet a {
  color: var(--site-black-color);
  text-decoration: none;
}

#footer-contact-right-pamphlet a:hover {
  text-decoration: underline;
}

.uchikeshi {
  display: inline-block;
  position: relative;
  z-index: 1;
}

.uchikeshi:before {
  content: '';
  width: 100%;
  height: 1px;
  border-top: solid 1px var(--site-black-color);
  position: absolute;
  left: 0 ;
  top: calc(50% - 3px) ;
}

.uchikeshi:after {
  content: '';
  width: 100%;
  height: 1px;
  border-bottom: solid 1px var(--site-black-color);
  position: absolute;
  left: 0 ;
  bottom: calc(50% - 3px);
}

img.file-icon {
  height: 1.4em;
  vertical-align: bottom;
  margin-right: 0.5em;
}

sub {
  font-size: 0.7em;
  vertical-align: sub;
}
