@charset "utf-8";

/* 改行 */
.article-body {
  word-wrap : break-word;
  overflow-wrap : break-word;
  word-break:normal;
}
body.smp .article-body {
  word-wrap : break-word;
  overflow-wrap : break-word;
  word-break:normal;
}

/* 記事本文 */
.article-body {
  font-size: 1em;
  line-height: 2;
}
body.smp .article-body {
  line-height: 1.5;
}
.article-body p {
  margin: .5em 0 1.5em;
  font-size: 1.5rem;
  letter-spacing: 0.15rem;
  line-height: 1.733;
}
.article-body h2 {
  font-size: 1.8rem;
  border-left: solid 11px;
  line-height: 1.5;
  padding: .6em 0 .6em .72em;
  margin: 3em 0;
  letter-spacing: 0.18rem;
}
.article-body.news h2 {
  border-color: #06468e;
}
.article-body.knowhow h2 {
  border-color: #1c8082;
}
.article-body.special h2 {
  border-color: #a98567;
}
.article-body.shop h2 {
  position: relative;
  border-color: #333;
  border-left-width: 5px;
  margin-left: 3px;
}
.article-body.shop h2::before {
  content: '';
  display: block;
  width: 0;
  position: absolute;
  left: -8px;
  top: 0;
  height: 100%;
  border-color: #ccc;
  border-left-style: solid;
  border-left-width: 3px;
}
.article-body.shop h2::after {
  content: '';
  display: block;
  width: 0;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  border-color: #ccc;
  border-left-style: solid;
  border-left-width: 3px;
}
body.smp .article-body h2 {
  font-size: 1em;
  padding-left: .5em;
  padding-top: .5em;
  padding-bottom: .5em;
  border-left-width: 8px;
  margin: .5em 0;
}
body.smp .article-body.shop h2 {
  position: relative;
  border-color: #333;
  border-left-width: 5px;
  margin-left: 3px;
}
body.smp .article-body.shop h2::before {
  content: '';
  display: block;
  width: 0;
  position: absolute;
  left: -8px;
  top: 0;
  height: 100%;
  border-color: #ccc;
  border-left-style: solid;
  border-left-width: 3px;
}
body.smp .article-body.shop h2::after {
  content: '';
  display: block;
  width: 0;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  border-color: #ccc;
  border-left-style: solid;
  border-left-width: 3px;
}

.article-body h3 {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 1.5em 0;
  letter-spacing: 0.18rem;
}
.article-body.news h3 {
  color: #06468e;
}
.article-body.knowhow h3 {
  color: #1c8082;
}
.article-body.special h3 {
  color: #a98567;
}
.article-body.shop h3 {
  color: #999;
}

body.smp .article-body h3 {
  font-size: 1em;
  margin: 1em 0;
}

.article-body h4 {
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 1em 0;
  letter-spacing: 0.18rem;
}
body.smp .article-body h4 {
  font-size: 0.9em;
}

/* 周り込み解除 */
.article-body .clearfix:before,
.article-body .clearfix:after {
  content:"";
  display:table;
}
.article-body .clearfix:after {
  clear:both;
}
.article-body .clearfix {
  zoom:1; /* For IE 6/7 (trigger hasLayout) */
}

/* 画像中央寄せ */
.article-body .figure-center {
  margin: 15px auto;
  text-align:center;
  max-width: 100%;
}
.article-body .fig-center {
  margin: 15px auto;
  text-align:center;
  max-width: 100%;
}
body.smp .article-body .figure-center {
  margin: 15px auto;
  text-align:center;
  max-width:100%;
}
body.smp .article-body .fig-center {
  margin: 15px auto;
  text-align:center;
  max-width:100%;
}

/* 画像右寄せ */
.article-body .figure-right {
  float: right;
  margin: 0 0 15px 15px;
  max-width: 100%;
}
.article-body .fig-right {
  float: right;
  margin: 0 0 15px 15px;
  max-width: 100%;
}
body.smp .article-body .figure-right {
  float: none;
  margin: 15px auto;
  max-width:100%;
  text-align:center;
}
body.smp .article-body .fig-right {
  float: none;
  margin: 15px auto;
  max-width:100%;
  text-align:center;
}

/* 画像左寄せ */
.article-body .figure-left {
  float: left;
  clear:left;
  margin: 0 15px 15px 0;
  max-width: 100%;
}
.article-body .fig-left {
  float: left;
  clear:left;
  margin: 0 15px 15px 0;
  max-width: 100%;
}
body.smp .article-body .figure-left {
  float: none;
  margin: 15px auto;
  max-width:100%;
  text-align:center;
}
body.smp .article-body .fig-left {
  float: none;
  margin: 15px auto;
  max-width:100%;
  text-align:center;
}

/* 説明文（エトキ） */
.article-body .caption {
  font-size: .8em;
  display:block;
  line-height: 1.5;
  text-align:left;
}
body.smp .article-body .caption {
  width: 100% !important;
  padding: 5px 0px;
  font-size: .875em;
}
.article-body .blank-caption{display:none;}

/* 記事本文内画像 */
.article-body .image-area {
  clear: both;
}
.article-body .image-area img {
  max-width: 100%;
  height: auto !important;
  /* padding: 5px 0px; */
}

/* 画像2,3枚並び */
.article-body .images-2cols,
.article-body .images-3cols {
  margin-bottom: 1.5em;
  clear: both;
  display: block;
  text-align: center;
  font-size: 0;
}
.article-body .images-2cols .image-area,
.article-body .images-3cols .image-area {
  clear: none;
  display: inline-block;
  max-width: calc((100% - 15px) / 2);
  font-size: 1.6rem;
  margin-left: 15px;
  vertical-align: top;
}
.article-body .images-3cols .image-area {
  max-width: calc((100% - 30px) / 3);
}
.article-body .images-2cols .image-area:first-child,
.article-body .images-3cols .image-area:first-child {
  margin-left: 0;
}
body.smp .article-body .virtical {
  font-size: inherit;
}
body.smp .article-body .virtical .image-area {
  clear: none;
  display: block;
  max-width: 100%;
  margin: auto;
  margin-bottom: .5em;
}
body.smp .article-body .virtical .image-area:last-child {
  margin-bottom: 0;
}
body.smp .article-body .virtical .image-area img {
  vertical-align: bottom;
}

/** YouTubeなど **/
.article-body iframe{
display:block;
margin:20px auto;
}

.article-body .video{
//position:relative;
//height:0;
//overflow:hidden;
//margin:35px 0;
padding-bottom:10px;
//padding-top:30px;
}
.article-body .sound{
height:70px;
padding-bottom:15%;
}
.article-body .sound.sc_visual{
height:450px;
padding:20px 0;
}
.article-body .video iframe{
margin:0px auto;
width:100%;
height:400px;
}
.article-body .ted{
padding-bottom:67.25%;
}
.article-body .ted iframe{
overflow:hidden;
}


/* 3つの要約 */
body {
  counter-reset: j;
}
.article-body .points {
  margin: 1.5em 0;
}
.article-body .points p {
  font-family: serif;
  font-size: 2.4rem;
  font-style: italic;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}
.article-body .points li {
  display: block;
  font-size: 1.5rem;
  letter-spacing: 0.15rem;
  border-bottom-style: solid;
  border-bottom-width: 2px;
  line-height: 1.8;
  position: relative;
  padding: .5em 0 .5em 3em;
}
.article-body .points li::before {
  counter-increment: j;
  content: counter(j);
  font-family: 'Arial';
  font-weight: 700;
  font-size: 2.4rem;
  transform: skew(-10deg) scaleX(0.9);
  margin-left: 16px;
  margin-right: 12px;
  display: inline-block;
  position: absolute;
  left: 0;
  top: -.05em;
}
.article-body.news .points p,
.article-body.news .points li::before {
  color: #06468e;
}
.article-body.knowhow .points p,
.article-body.knowhow .points li::before  {
  color: #1c8082;
}
.article-body.special .points p,
.article-body.special .points li::before  {
  color: #a98567;
}
.article-body.shop .points p,
.article-body.shop .points li::before  {
  color: #ccc;
}
/*
.article-body.special .points,
.article-body.special .points li::before  {
  border-color: #a98567;
}
.article-body.shop .points,
.article-body.shop .points li::before  {
  border-color: #ccc;
}
*/
.article-body.news .points li {
  border-color: rgba(6, 70, 142, 0.2);
}
.article-body.knowhow .points li {
  border-color: rgba(28, 128, 130, 0.2);
}
.article-body.special .points li {
  border-color: rgba(169, 133, 103, 0.2);
}
.article-body.shop .points li {
  border-color: rgba(51, 51, 51, 0.2);
}

.article-body strong, .article-body b {
  font-weight: 700;
}

/* リード文 */
.article-body .lead {
  margin: 2.5em 0;
  padding: 1.5em 1.5em;
  clear: both;
}
.article-body.news .lead {
  background-color: rgba(6, 70, 142, 0.07);
}
.article-body.knowhow .lead {
  background-color: rgba(28, 128, 130, 0.07);
}
.article-body.special .lead {
  background-color: rgba(169, 133, 103, 0.07);
}
.article-body.shop .lead {
  background-color: rgba(51, 51, 51, 0.07);
}
.article-body .lead p {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.15rem;
  line-height: 1.733;
  margin: .5em 0;
}
/* リード文（写真入り）ブロック */
.article-body .leadwpic {
  margin: 2em 0;
  padding: 1em;
  clear: both;
}
.article-body .leadwpic::after {
  content: '';
  clear: both;
  display: table;
}
.article-body.news .leadwpic {
  background-color: rgba(6, 70, 142, 0.07);
}
.article-body.knowhow .leadwpic {
  background-color: rgba(28, 128, 130, 0.07);
}
.article-body.special .leadwpic {
  /* background-color: rgba(169, 133, 103, 0.07); */
}
.article-body.shop .leadwpic {
  background-color: rgba(51, 51, 51, 0.07);
}
.article-body .leadwpic p {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.15rem;
  line-height: 1.733;
  margin: .5em 0;
}
.article-body .leadwpic .image-area {
  margin: 0;
}
.article-body .leadwpic .image-area.figure-right {
  margin-left: 1em;
}
.article-body .leadwpic .image-area.figure-left {
  margin-right: 1em;
}
.article-body .leadwpic .image-area img {
  vertical-align: bottom;
}
/* 引用 */
.article-body .quote {
  background-color: #f4f4f4;
  padding: 2em 5em;
  margin: 40px 0;
  position: relative;
}
body.smp .article-body .quote {
  padding: 2em 4em;
}
.article-body .quote p {
  font-size: 1.7rem;
  line-height: 1.5;
  letter-spacing: 0.17rem;
  margin: .5em 0;
}
.article-body .quote::before {
  content: '';
  width: 70px;
  height: 70px;
  background: url(../../../../common/sgk/images/v1/quote1.png) center center no-repeat;
  background-size: 42px auto;
  opacity: .3;
  position: absolute;
  top: 0;
  left: 0;
}
.article-body .quote::after {
  content: '';
  width: 70px;
  height: 70px;
  background: url(../../../../common/sgk/images/v1/quote2.png) center center no-repeat;
  background-size: 42px auto;
  opacity: .3;
  position: absolute;
  bottom: 0;
  right: 0;
}
/* インタビュー */
.article-body .interview li {
  font-size: 1.5rem;
  letter-spacing: 0.15rem;
  margin: 1.6em 0;
}
.article-body .interview p {
  font-size: 1.5rem;
  letter-spacing: 0.15rem;
  margin: 1.6em 0;
}
/* マップ */
.article-body .map {
  margin: 40px auto 32px auto;
  text-align: center;
  max-width: 100%;
}
#map {
  margin: 40px auto 32px auto;
  text-align: center;
  max-width: 100%;
  background-color:#eee;
  min-height:200px;
}
/* プロフィール */
div.profile {
  margin: 20px 0;
  clear:both;
}
div.profile::after{
  content:"";
  clear:both;
  display:block;
  height:0;
  visibility:hidden;
}
div.profile span{
  font-weight:bold;
}
div.profile p{
  font-size:12px;
  display:block;
}

/* 企業データ */
ul.data {
  clear:both;
}