@charset "UTF-8";

html, body {
   font-family: "Times New Roman", Times, serif; 
}

body {
  position: relative;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: #000;
}

a:link, a:visited, a:active {
  color: #fff;
  border: 0;
  outline: none;
  text-decoration: none;
}

a:hover {
  color: #fff;
  border: 0;
  text-decoration: underline;
}

img {
  max-width: 100%;
  height: auto;
  border: 0;
}

/* ---------------------------

レイアウト

---------------------------- */
.container {
  margin: 0 auto;
  overflow: hidden;
}

.container_bottom {
  width: 100%;
  height: 31px;
  background: rgb(115,0,0);
  background: linear-gradient(90deg, rgba(115,0,0,1) 0%, rgba(203,0,18,1) 25%, rgba(203,0,18,1) 50%, rgba(203,0,18,1) 75%, rgba(115,0,0,1) 100%);
}

.wrap {
  margin: 0 auto;
  padding: 0 35px;
  width: 100%;
  max-width: 840px;
  
  background-color: #fff;
}

@media screen and (max-width: 563px) {
  .wrap {
    padding: 10px;
  }
}

/* ---------------------------

head

---------------------------- */
#na_partner {
	width: 100%;
	height: 30px;
	position: relative;
	border-bottom: 1px solid #C7C7C7;
  background-color: #FFF;
}

#na_partner .partner_inner {
  max-width: 966px;
	margin-right: auto;
	margin-left: auto;
  text-align: center;
}

#na_partner .partner_ti {
	height: 30px;
  font-family: "Arial", Gadget, "sans-serif";
  font-weight: 700;
  font-size: 18px;
  line-height: 100%;
  color: #999999;
  padding-top: 7px;
}

#na_partner .client_name {
  position: absolute;
  font-family: "Arial", Gadget, "sans-serif";
  font-size: 16px;
  line-height: 100%;
  color: #686868;
  top: 7px;
}

#na_partner .client_logo {
  height: 26px;
  position: absolute;
  font-family: "Arial", Gadget, "sans-serif";
  font-size: 16px;
  line-height: 100%;
  color: #686868;
  top: 2px;
}

@media screen and (max-width: 995px) { 
  #na_partner .client_name {
    margin-left: 14px;
  }
}

@media screen and (max-width: 780px) { 
  #na_partner {
    width: 100%;
    height: auto;
    padding-bottom: 8px;
  }
  
  #na_partner .client_name {
    position: static;
    font-family: "Arial", Gadget, "sans-serif";
    color: #686868;
    top: 0px;
  }
  
  #na_partner .client_logo {
    position: static;
    font-family: "Arial", Gadget, "sans-serif";
    font-size: 16px;
    line-height: 100%;
    color: #686868;
    top: 0px;
  }
}

.obi_top {
  width: 100%;
  height: 13px;
  background: rgb(115,0,0);
  background: linear-gradient(90deg, rgba(115,0,0,1) 0%, rgba(203,0,18,1) 25%, rgba(203,0,18,1) 50%, rgba(203,0,18,1) 75%, rgba(115,0,0,1) 100%);

}

/* ---------------------------

mainvisual

--------------------------- */
.mainvisual {
  width: 100%;
  max-width: 1280px; max-width: 1800px; max-width: 1600px;
  height: 730px;
  margin: 0 auto;
  background: url("../images/mv_bg.jpg") no-repeat right top;
   background-size: 1281px 639px; background-size: 1464px 730px;
  position: relative;
}

.maintitle {
  margin: 0;
  position: relative;
  top: 30px;
  right: 0;
  left: 4%;
}

h1 {
  font-size: clamp(60px,6.32812vw,81px);
  font-weight: 600;
  text-shadow: 0px 0px 6px rgba(255, 255, 255, 1), 0px 0px 6px rgba(255, 255, 255, 1);
}

.mainvisual .block_text {
  padding: 30px 0 0 0;
  width: 100%;
  height: auto;
  max-width: 682px;
  position: relative;
  top: 15px;
  left: 5%;
  font-size: 18px;
  line-height: 1.8;
  font-weight: 600;
  text-shadow: 0px 0px 6px rgba(255, 255, 255, 1);
}

@media screen and (max-width: 749px) {
  .mainvisual {
    background-size: cover;
  }

  h1 {
    font-size: clamp(42px,8.54472vw,64px);
    font-weight: 600;
    text-shadow: 0px 0px 6px rgba(255, 255, 255, 1), 0px 0px 6px rgba(255, 255, 255, 1);
  }

  .mainvisual .block_text {
    padding: 30px;
    left: 0;
  }

  .maintitle {
    left: 0;
    padding: 0 4%;
  }
}

@media screen and (max-width: 521px) {
  .maintitle {
    line-height: 1.4;
  }

  .mainvisual .block_text {
    left: 0;
    padding: 30px 3% 0 4%;
    line-height: 1.5;
  }
}

/* ---------------------------

Index

--------------------------- */
.index_area {
  padding: 10px 20px 10px clamp(100px,7%,500px); padding: 10px 20px 10px 10vw;
  width: 65%; width: 50%;
  /*max-width: 583px; max-width: clamp(600px, 50%, 1000px);*/
  height: auto; max-height: 240px;
  background-color: rgba(0,113,144,.4); 
  position: relative;
  top: -110px;
  left: 0;
}

.index_area_inner {
  display: flex;
  width: 300px;
  height: auto;
  position: relative;
  /*left: max(15%,30%); left: 10vw;*/
  /*max-width: 583px;*/
  right: 0;
}

.index_area .stit {
  margin: 0 22px 0 0;
  max-width: 38px;
  width: 100%;
  height: auto;
}
.index_area .stit img {
  display: block;
}

.index_area .link_list {
  width: 100%;
  height: auto;
  font-size: 18px;
  line-height: 1.3;
  font-family: arial, helvetica, 'Hiragino Sans', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', sans-serif;
}

.index_area .link_list a {
  text-decoration: none !important;
}

.index_area .link_list a:hover {
  opacity: .8;
}

@media screen and (min-width: 1600px) {

  .index_area_inner {
    /*left: 5%;*/
    right: -20%; right: -30%;
  }
}

@media screen and (max-width: 749px) {
  .index_area {
    margin-top: 10px;
    padding-left: 5%;
    width: 90%;
    height: 180px;
    top: 0;
  }
}

@media screen and (max-width: 441px) {
  .index_area {
    width: 100%;
  }
  
  .index_area_inner {
    left: 20px;
  }
}

/* ---------------------------

見出し

--------------------------- */
.inner {
  display: inline-block;
}

.obi_block {
  display: block;
  margin: 3% auto 0;
  position: relative;
  font-family: arial, helvetica, 'Hiragino Sans', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', sans-serif;
}

.obi_block .obi {
  margin: auto;
  padding: 5px;
  width: 100%;
  height: 100%;
  max-width: 770px;
  background: rgb(115,0,0);
  background: linear-gradient(90deg, rgba(115,0,0,1) 0%, rgba(203,0,18,1) 25%, rgba(203,0,18,1) 50%, rgba(203,0,18,1) 75%, rgba(115,0,0,1) 100%);
  font-weight: 600;
  font-size: 33px;
  text-align: center;
  line-height: normal;
  color: #fff; 
}

.obi_block .stit {
  margin: 1em auto 1.5em;
  max-width: 700px;
  font-size: 20px;
  font-weight: 800;
  text-align: center;
  line-height: 1;
}

h2 {
  margin: 2em auto 1em;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -.05em;
  text-align: center;
  color: #fff;
}

@media screen and (max-width: 749px) {
  .obi_block {
    position: relative;
  }
  
  .obi_block .obi {
    font-size: 5vw;
  }
  
  .obi_block .stit {
  }
}

/* ---------------------------

本文

--------------------------- */
.int_area {
  margin: 0 auto;
  max-width: 600px;
}

.int {
  margin-bottom: 1em;
}

@media screen and (max-width: 749px) {
  .int {
    text-align: left;
  }
}

/* ---------------------------

分割

--------------------------- */
.flex_area {
  display: flex;
}

.flex_area_right-text{
  max-width: 546px;
}

@media screen and (max-width: 749px) {
  .flex_area {
    display: block;
  }

  .flex_area_right-text{
    max-width: 100%;
  }
}

/* ---------------------------

photo

--------------------------- */
.photo_left {
  float: left;
  margin: 0 2em 0 0;
  width: 100%;
  height: auto;
  max-width: 190px;
  min-width: 190px;
}

.photo_right {
  float: right;
  margin: 0 0 0 2em;
  width: 100%;
  height: auto;
  max-width: 190px;
  min-width: 190px;
}

@media screen and (max-width: 749px) {
  .photo_left, .photo_right {
    float: none;
    margin: 2em auto;
    text-align: center;
  }
}

.photo_center {
  margin: 0 auto 1em;
  text-align: center;
}

@media screen and (max-width: 261px) {
  .photo_left {
    max-width: 100%;
    min-width: 100%;
  }

  .photo_right {
    max-width: 100%;
    min-width: 100%;
  }
}

/* ------------------------

section01

------------------------ */
.cont1 {
  margin-top: -6vh;
  width: 100%;
  position: relative;
  background: url("../images/bg.jpg") no-repeat center bottom;
  background-size: cover;
}

.section01 {
  margin: 0 auto 0;
  width: 100%;
  background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(255,255,255,0) 100%);
  background-size: 100% 10%;
  background-repeat: no-repeat;
}

@media screen and (max-width: 996px) {
  .section01 {
    padding-left: 1em;
    padding-right: 1em;
    width: 100%;
  }
}

@media screen and (max-width: 749px) {
  .cont1 {
    margin-top: 0 !important;
  }
}

/* ------------------------

footer_logo

------------------------ */
.footer_logo {
  display: flex;
  margin: 50px auto 15px;
  padding: 0;
  max-width: 840px;
  height: auto;
  align-items: center;
  justify-content: center;
}

.footer_logo .icon {
  margin: 0 auto;
  width: 50%;
  height: auto;
  text-align: center;
}

.footer_logo .icon .jsda {
  height: auto;
  max-width: 155px;
}

.footer_logo .icon .jpx {
  height: auto;
  max-width: 107px;
}

@media screen and (max-width: 441px) {
  .footer_logo {
    display: block;
  }
  .footer_logo .icon {
    margin: 10px auto;
  }
}

/* --------------------

ページトップへ

-------------------- */
#pagetop {
  width: 60px;
  height: 60px;
  position: fixed;
  right: 25px;
  bottom: 25px;
  z-index: 10;
  cursor: pointer
}

#pagetop:hover {
  opacity: 0.7
}

@media screen and (max-width:911px) {
  #pagetop:hover {
    opacity: 1
  }
}

@media screen and (max-width:414px) {
  #pagetop {
    right: 10px;
    bottom: 10px;
    width: 42px;
    height: 42px
  }
}
  