@charset "UTF-8";
/*初期設定
----------------------------------------------------*/
body {
  min-width: 320px;
  line-height: 1.5;
      border-top: 4px solid #7fcef4;
}
img {
  max-width: 100%;
  height: auto;
}
.ie8 img{
  width: auto;
}
/*clearfix*/
.clearfix {
  zoom: 1;
}
.clearfix:after {
  content: "";
  display: block;
  clear: both;
}
.sp {
  display: block;
}
.pc {
  display: none;
}
.aka {
  color: #ff0000;
}
.b_a {
  background: #ff0000;
  color: #fff;
  padding: 3px;
}
.b_b {
  background:#442eee;
  color: #fff;
  padding: 3px;
}
.bold {
  font-weight: bold;
}
.small {
  font-size: 0.8em;
}
.pink {
  color: #e731c1;
}
.bg_pink {
  background-color: #e782c0;
  padding: 8px;
  font-size: 1.1em;
  clear: both;
  margin-top: 5px;
}
.bg_pink2 {
  background-color: #ffdcff;
  padding: 8px;
  margin-top: -5px;
}
.ub {
  text-decoration: underline;
}
.g_b {
  padding: 10px;
  border: 1px solid #ccc;
}
.m_b {
  border: 3px solid #7fcef4;
  padding: 10px;
}
.g_b2 {
  background-color: #e9e9e9;
    border-radius: 5px;
      padding: 10px;
  line-height: 1.1;
  font-size: 1.3em;
  font-weight: bold;
}
.fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 97%;
  z-index: 10;
}
.h100{
  height: 100px;
}
/*layout
----------------------------------------------------*/
#wrapper{
  max-width: 960px;
  margin: 0 auto;
}
nav {
  display: none;
}
header {
  padding: 25px 5px 0 5px;
}
header img {
  width: 100%;
}
header h1 {
    margin: 0;
}

#content {
  margin: 0 10px 20px;
}
#content h1 {
  font-size: 2.5em;
  font-weight: normal;
  line-height: 1.1;
  font-family: 'Trocchi', serif;
}
#content h2 {
  padding: 10px;
  line-height: 1.1;
  font-size: 1.3em;
  font-weight: bold;
  background-color: #7fcef4;
  border-radius: 5px;
}
#content h2.yoyaku {
  padding: 10px;
  line-height: 1.1;
  font-size: 1.5em;
  font-weight: bold;
  border-left: 3px solid #ff552a;
  background-color: #fff;
  border-radius: 0px;
  clear: both;
}
#action_b {
margin:0 auto;
padding:5px 6px;
background-color: rgba(255,255,255,0.8);
}
#action_b li {
  margin: 0 auto;
  float:left;
  list-style-type:none;
}
#action_b li#ac {
  width:24%;
  background:#442eee;
}
#action_b li#phone {
  width:36%;
  margin-left: 2%;
  background:#ffca48;
  line-height: 1.429;
}
#action_b li#form {
  width:36%;
   margin-left: 2%;
  background:#ff571d;
}
#action_b li a {
  color:#fff;
  font-size:14px;
  font-weight:bold;
  text-align:center;
  display:block;
  padding:15px 8px;
  text-decoration: none;
}
#action_b li#phone a {
  padding: 6px 8px;
}
#content #cp_ipcheck {
  margin: 2em auto;
  text-align: left;
  line-height: 2.0;
   margin:5px 0 10px;
}
#content #cp_ipcheck ul {
  margin: 0.5rem 0rem 1rem 0rem;
  padding: 0.5rem 0.7rem;
  list-style: none;
  border: 1px solid #7fcef4;
}
#content #cp_ipcheck .list_item {
  margin: 0 0 0.5rem 0;
  padding: 0;
}
#content #cp_ipcheck label {
  line-height: 135%;
  position: relative;
  margin: 0.5rem;
  cursor: pointer;
}
#content #cp_ipcheck .option-input05 {
  position: relative;
  margin: 0 1rem 0 0;
  cursor: pointer;
}
#content #cp_ipcheck .option-input05:before {
  position: absolute;
  z-index: 1;
  top: 0.125rem;
  left: 0.23rem;
  width: 0.75rem;
  height: 0.375rem;
  content: '';
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
          transition:         transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
  -webkit-transform: rotate(-45deg) scale(0, 0);
          transform: rotate(-45deg) scale(0, 0);
  border: 2px solid #da3c41;
  border-top-style: none;
  border-right-style: none;
}
#content #cp_ipcheck .option-input05:checked:before {
  -webkit-transform: rotate(-45deg) scale(1, 1);
          transform: rotate(-45deg) scale(1, 1);
}
#content #cp_ipcheck .option-input05:after {
  position: absolute;
  top: -0.18rem;
  left: -0.08rem;
  width: 1rem;
  height: 1rem;
  content: '';
  cursor: pointer;
   padding: 1px;
  border: 2px solid #ccc;
  background: #ffffff;
}
section {
  margin-bottom: 3em;
}
.box {
  margin: 0;
  padding: -5px 0;
  clear: both;
  overflow: auto;
}
.le {
  float: left;
  width: 4%;
  margin-top: 0;
  margin-bottom: 0;
} 
.box .text {
  width: 95%;
  float: right;
  margin: 0;
}
.kcm img {
  float: right;
  width: 135px;
  padding-left: 10px;
  padding-bottom: 10px;
}
.coment {
}
aside {
  margin-top: 0;
  margin-bottom: 20px;
  background: #fff;
  display: none;
}
aside h3 {
  margin-top: 0;
  padding: 5px 5px 5px 10px;
  background: #e5e5e5;
  border-radius: 3px;
}
aside ul {
  margin: 0;
  padding: 0;
  -webkit-column-width: 240px;
  -moz-column-width: 240px;
  column-width: 240px;
  -webkit-column-gap: 20px;
  -moz-column-gap: 20px;
  column-gap: 20px;
  text-align: center;
}
aside ul li {
  padding-bottom: 15px;
  list-style-type: none;
}
.ie7 aside ul li{
  display: inline;
  padding: 0 10px;
}
.ie8 aside ul li,
.ie9 aside ul li{
  display: inline-block;
  padding: 0 10px;
}
footer {
  clear: both;
  padding: 30px;
  background: #f2f2f2;
  color: #fff;
  text-align: center;
  margin-bottom: 60px;
}
#footerFloatingMenu {
    display: block;
    width: 100%;
    position: fixed;
    left: 0px;
    bottom: -6px;
    z-index: 9999;
    text-align: center;
    margin: 0;
    padding: 0 auto;
}
 
#footerFloatingMenu img {
    max-width: 100%;
}
.m-h {
    animation-duration: 1.4s;
    animation-name: movieee;
    animation-iteration-count: infinite;
}
@keyframes movieee {
  0% {
    transform: skewX(9deg); }
  10% {
    transform: skewX(-8deg); }
  20% {
    transform: skewX(7deg); }
  30% {
    transform: skewX(-6deg); }
  40% {
    transform: skewX(5deg); }
  50% {
    transform: skewX(-4deg); }
  60% {
    transform: skewX(3deg); }
  70% {
    transform: skewX(-2deg); }
  80% {
    transform: skewX(1deg); }
  90% {
    transform: skewX(0deg); }
  100% {
    transform: skewX(0deg); } }
/*media Queries
----------------------------------------------------*/

@media only screen and (min-width: 800px) {
  header img {
  width: 640px;
}
nav {
  display: none;
}
  #contentInner {
    float: left;
    width: 100%;
    margin-right: -260px;
  }
  article {
    margin-right: 260px;
  }
  .kcm img {
  float: right;
  width: 180px;
  padding-left: 5px;
  padding-bottom: 10px;
}
  aside {
    float: right;
    width: 240px;
    margin-top: 1.0em;
    margin-right: 5px;
  }
    /*IEで要素がズレるのを対応*/
    .ie7 aside ul li,
    .ie8 aside ul li,
    .ie9 aside ul li{
    display: list-item;
    padding: 0;
  }
}
@media only screen and (min-width: 980px) {
  .sp {
  display: none;
}
.pc {
  display: block;
}
.fixed {
  position: fixed;
  top: 0;
  left: auto;
  right:auto;
  width: 700px;
  z-index: 10;
}
nav {
  display: none;
}
  #wrapper {
    margin-bottom: 20px;
  }
  #content {
  margin: 0 0 20px;
}
nav {
  text-align: center;
      border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
nav ul {
  margin: 0;
  padding: 0;
}
nav ul li {
  float: left;
  text-align: center;
  margin-right: 20px;
}
nav ul li a {
  display: block;
  padding: 15px 0;
  color: #000;
  text-decoration: none;
}
aside {
  display: block;
  margin-top:0;
}
#action_b {
margin:0;
padding:5px 0;
margin-top: 50px;
}
#action_b li {
  margin: 0 5px;
  float:left;
  list-style-type:none;
}
#action_b li#ac {
  width:20%;
  background:#442eee;
}
#action_b li#phone {
  width:37.6%;
  margin-left: 5px;
  background:#ffca48;
}
#action_b li#form {
  width:37.6%;
  background:#ff571d;
  margin-top: 0;
  margin-left: 5px;
}
#action_b li a {
  color:#fff;
  font-size:16px;
  font-weight:bold;
  text-align:center;
  display:block;
  padding:15px 8px;
  text-decoration: none;
}
.ie7 nav ul{
  background: #1d4000;
}
.ie7 nav ul li{
  width: 24.84375%;
}
footer {
    margin-bottom: 0px;
}
#footerFloatingMenu {
    display: none;
}
}
.m-h {
    animation-duration: initial;
    animation-name: initial;
    animation-iteration-count: initial;
}
.m-h:active {
  position: relative;
  top: 7px;
  box-shadow: none;
}

/*--- cssアニメーション ここから ---*/
.keyframe {
  animation-name: anim_sc;
  transform: scale(0.6, 0.6);
}

@keyframes anim_sc {
  100% {
    transform: scale(1, 1);
  }
}

.animation {
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-duration: 1.5s;
}

/*--- cssアニメーション ここまで ---*/
