@charset "UTF-8";

/**
* .sb-type-TYPE, .sb-type-TYPE > .sb-subtype-X:after
*
* コマ(アイコンと吹き出しをまとめたもの)部分
* frame(speaker icon and name, serief) part
*/

.sb-type-ln {
  overflow: hidden;
  padding: 10px 20px;
  margin: 0;
  line-height: 1.5;
  color: #333333;
}

.sb-type-ln > .sb-subtype-a:after,
.sb-type-ln > .sb-subtype-b:after,
.sb-type-ln > .sb-subtype-c:after,
.sb-type-ln > .sb-subtype-d:after {
  display: block;
  clear: both;
  content: "";
}

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-speaker
*
* 話者領域      
* Speaker Field 
*/

.sb-type-ln > .sb-subtype-a > .sb-speaker,
.sb-type-ln > .sb-subtype-c > .sb-speaker {
  float: left;
  position: relative;
  margin-right: -70px;
  width: 70px;
}

.sb-type-ln > .sb-subtype-b > .sb-speaker,
.sb-type-ln > .sb-subtype-d > .sb-speaker {
  float: right;
  position: relative;
  margin-left: -70px;
  width: 70px;
}

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-speaker > .sb-icon
*
* 話者のアイコン部分
* Speaker Icon part 
*/

.sb-type-ln > .sb-subtype-a > .sb-speaker > .sb-icon,
.sb-type-ln > .sb-subtype-b > .sb-speaker > .sb-icon,
.sb-type-ln > .sb-subtype-c > .sb-speaker > .sb-icon,
.sb-type-ln > .sb-subtype-d > .sb-speaker > .sb-icon {
  text-align: center;
  height: 60px;
}

.sb-type-ln > .sb-subtype-a > .sb-speaker > .sb-icon > img.sb-icon,
.sb-type-ln > .sb-subtype-b > .sb-speaker > .sb-icon > img.sb-icon,
.sb-type-ln > .sb-subtype-c > .sb-speaker > .sb-icon > img.sb-icon,
.sb-type-ln > .sb-subtype-d > .sb-speaker > .sb-icon > img.sb-icon {
  height: 60px;
  width: 60px;
  border-style: none;
}

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-speaker > .sb-name
*
* 話者の名称部分   
* Speaker name part
*/

.sb-type-ln > .sb-subtype-a > .sb-speaker > .sb-name,
.sb-type-ln > .sb-subtype-b > .sb-speaker > .sb-name,
.sb-type-ln > .sb-subtype-c > .sb-speaker > .sb-name,
.sb-type-ln > .sb-subtype-d > .sb-speaker > .sb-name {
  position: absolute;
  overflow: hidden;
  top: 0;
  font-size: 12px;
  white-space: nowrap;
}

.sb-type-ln > .sb-subtype-a > .sb-speaker > .sb-name,
.sb-type-ln > .sb-subtype-c > .sb-speaker > .sb-name {
  left: 80px;
}

.sb-type-ln > .sb-subtype-b > .sb-speaker > .sb-name,
.sb-type-ln > .sb-subtype-d > .sb-speaker > .sb-name {
  right: 80px;
}

/*----------------------------------------------------------------------------------*/
/* lnタイプの吹き出し                                                               */
/* ln Type   (For a,b)                                                              */
/*----------------------------------------------------------------------------------*/

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-content
* .sb-type-TYPE > .sb-subtype-X > .sb-content:befor, :after
*
* セリフ&引き出し 部分 
* Serief& Tail part    
*/

@media screen and (min-width: 721px) {
  .sb-type-ln > .sb-subtype-a > .sb-content {
    float: left;
    position: relative;
    padding-top: 26px;
    margin-right: 80px;
    margin-left: 80px;
  }
}

@media screen and (max-width: 720px) {
  .sb-type-ln > .sb-subtype-a > .sb-content {
    float: left;
    position: relative;
    padding-top: 26px;
    margin-left: 80px;
  }
}

.sb-type-ln > .sb-subtype-a > .sb-content:before {
  position: absolute;
  top: 26px;
  left: -8px;
  z-index: 1;
  height: 0;
  width: 0;
  border-style: solid none none solid;
  border-width: 8px;
  border-color: #aaaaaa transparent;
  content: "";
}

.sb-type-ln > .sb-subtype-a > .sb-content:after {
  position: absolute;
  top: 27px;
  left: -6px;
  z-index: 3;
  height: 0;
  width: 0;
  border-style: solid none none solid;
  border-width: 8px;
  border-color: #f9f9f9 transparent;
  content: "";
}

@media screen and (min-width: 721px) {
  .sb-type-ln > .sb-subtype-b > .sb-content {
    float: right;
    position: relative;
    padding-top: 26px;
    margin-right: 80px;
    margin-left: 80px;
  }
}

@media screen and (max-width: 720px) {
  .sb-type-ln > .sb-subtype-b > .sb-content {
    float: right;
    position: relative;
    padding-top: 26px;
    margin-right: 80px;
  }
}

.sb-type-ln > .sb-subtype-b > .sb-content:before {
  position: absolute;
  top: 26px;
  right: -8px;
  z-index: 1;
  height: 0;
  width: 0;
  border-style: solid solid none none;
  border-width: 8px;
  border-color: #aaaaaa transparent;
  content: "";
}

.sb-type-ln > .sb-subtype-b > .sb-content:after {
  position: absolute;
  top: 27px;
  right: -6px;
  z-index: 3;
  height: 0;
  width: 0;
  border-style: solid solid none none;
  border-width: 8px;
  border-color: #ccff88 transparent;
  content: "";
}

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-content > .sb-speech-bubble
*
* 吹き出しの本体部分      
* Speach bubble' body part
*/

.sb-type-ln > .sb-subtype-a > .sb-content > .sb-speech-bubble,
.sb-type-ln > .sb-subtype-b > .sb-content > .sb-speech-bubble {
  position: relative;
  z-index: 2;
  padding: 6px 12px;
  background-color: #fcfcfc;
  border-style: solid;
  border-width: 1px;
  border-color: #aaaaaa #999999 #777777;
  border-radius: 15px;
  color: #333333;
}

.sb-type-ln > .sb-subtype-a > .sb-content > .sb-speech-bubble {
  border-radius: 0 15px 15px 15px;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(0, 0, 0, 0.1) inset;
}

.sb-type-ln > .sb-subtype-b > .sb-content > .sb-speech-bubble {
  background-color: #bbff77;
  border-radius: 15px 0 15px 15px;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(90, 127, 60, 0.2) inset;
}

/*----------------------------------------------------------------------------------*/
/* ln用に調整した考えてるタイプの吹き出し                                           */
/* ln-Think Type   (For c,d)                                                        */
/*----------------------------------------------------------------------------------*/

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-content
* .sb-type-TYPE > .sb-subtype-X > .sb-content:befor, :after
*
* セリフ&引き出し 部分 
* Serief& Tail part    
*/

@media screen and (min-width: 721px) {
  .sb-type-ln > .sb-subtype-c > .sb-content {
    float: left;
    position: relative;
    padding-top: 1.5em;
    margin-left: 100px;
    margin-right: 80px;
  }
}

@media screen and (max-width: 720px) {
  .sb-type-ln > .sb-subtype-c > .sb-content {
    float: left;
    position: relative;
    padding-top: 1.5em;
    margin-left: 100px;
  }
}

.sb-type-ln > .sb-subtype-c > .sb-content:before {
  position: absolute;
  top: 24px;
  left: -17px;
  height: 12px;
  width: 12px;
  background-color: #fcfcfc;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(0, 0, 0, 0.1) inset;
  border: solid 1px #ababab;
  border-radius: 10px;
  color: #333333;
  content: "";
}

.sb-type-ln > .sb-subtype-c > .sb-content:after {
  position: absolute;
  top: 20px;
  left: -28px;
  height: 8px;
  width: 8px;
  background-color: #fcfcfc;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(0, 0, 0, 0.1) inset;
  border: solid 1px #ababab;
  border-radius: 5px;
  color: #333333;
  content: "";
}

@media screen and (min-width: 721px) {
  .sb-type-ln > .sb-subtype-d > .sb-content {
    float: right;
    position: relative;
    padding-top: 1.5em;
    margin-left: 80px;
    margin-right: 100px;
  }
}

@media screen and (max-width: 720px) {
  .sb-type-ln > .sb-subtype-d > .sb-content {
    float: right;
    position: relative;
    padding-top: 1.5em;
    margin-right: 100px;
  }
}

.sb-type-ln > .sb-subtype-d > .sb-content:before {
  position: absolute;
  top: 24px;
  right: -17px;
  height: 12px;
  width: 12px;
  background-color: #bbff77;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(90, 127, 60, 0.2) inset;
  border: solid 1px #aaaaaa;
  border-radius: 10px;
  content: "";
}

.sb-type-ln > .sb-subtype-d > .sb-content:after {
  position: absolute;
  top: 20px;
  right: -27px;
  height: 8px;
  width: 8px;
  background-color: #bbff77;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(90, 127, 60, 0.2) inset;
  border: solid 1px #aaaaaa;
  border-radius: 5px;
  content: "";
}

/**
* .sb-type-TYPE > .sb-subtype-X > .sb-content > .sb-speech-bubble
*
* 吹き出しの本体部分      
* Speach bubble' body part
*/

.sb-type-ln > .sb-subtype-c > .sb-content > .sb-speech-bubble,
.sb-type-ln > .sb-subtype-d > .sb-content > .sb-speech-bubble {
  position: relative;
  padding: 6px 12px;
  z-index: 2;
  background-color: #fcfcfc;
  border-style: solid;
  border-width: 1px;
  border-color: #aaaaaa #999999 #777777;
  border-radius: 15px;
  color: #333333;
}

.sb-type-ln > .sb-subtype-c > .sb-content > .sb-speech-bubble {
  border-radius: 15px 15px 15px 15px;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(0, 0, 0, 0.1) inset;
}

.sb-type-ln > .sb-subtype-d > .sb-content > .sb-speech-bubble {
  background-color: #bbff77;
  border-radius: 15px 15px 15px 15px;
  box-shadow:
    0px 1px 1px rgba(0, 0, 0, 0.4),
    0 10px 10px rgba(255, 255, 255, 0.5) inset,
    0 -10px 10px rgba(90, 127, 60, 0.2) inset;
}

@media screen and (max-width: 721px) {
  .sb-type-ln {
    padding: 10px 0;
  }
  .sb-type-ln > .sb-subtype-a > .sb-content > .sb-speech-bubble,
  .sb-type-ln > .sb-subtype-b > .sb-content > .sb-speech-bubble,
  .sb-type-ln > .sb-subtype-c > .sb-content > .sb-speech-bubble,
  .sb-type-ln > .sb-subtype-d > .sb-content > .sb-speech-bubble {
    font-size: 16px;
    font-size: 1.6rem;
  }

  .sb-type-ln > .sb-subtype-b > .sb-speaker > .sb-icon > img.sb-icon,
  .sb-type-ln > .sb-subtype-c > .sb-speaker > .sb-icon > img.sb-icon,
  .sb-type-ln > .sb-subtype-d > .sb-speaker > .sb-icon > img.sb-icon {
    height: 45px;
    width: 45px;
  }
}
