/* 変数 */
@charset "utf-8";
/*************************************************************
*
* 変数
*
*************************************************************/
:root {
  /* カラー */

  /* gutters */
}
/**************************************************************
*
* インプットフォーム
*
**************************************************************/
/**************************************************************
* テンプレートクラス
**************************************************************/
.relation_item {
  display: none !important;
}
/*************************************************************
* ラベル
*************************************************************/
.label.__text {
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    -ms-transform: translate(0.555em, 0.702em);
        transform: translate(0.555em, 0.702em);

    pointer-events: none;

    color: #ababab;

    transition: 260ms cubic-bezier(0.225, 1, 0.320, 1.000);
    transition-property: transform, font-size;
  }
.label.__error .msg { color: #f14a2f; }
/*************************************************************
* テキスト
*************************************************************/
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"] {
  width: 100%;

  outline: none;
}
input[type="text"].__middle, input[type="email"].__middle, input[type="tel"].__middle, input[type="url"].__middle, input[type="password"].__middle { max-width: 520px; }
input[type="text"].__small, input[type="email"].__small, input[type="tel"].__small, input[type="url"].__small, input[type="password"].__small { max-width: 260px; }
input[type="text"].__micro, input[type="email"].__micro, input[type="tel"].__micro, input[type="url"].__micro, input[type="password"].__micro { max-width: 120px; }
@media screen and (max-width: 599px) {
    input[type="text"].__middle,
    input[type="text"].__small,
    input[type="email"].__middle,
    input[type="email"].__small,
    input[type="tel"].__middle,
    input[type="tel"].__small,
    input[type="url"].__middle,
    input[type="url"].__small,
    input[type="password"].__middle,
    input[type="password"].__small {
      max-width: 100%;
    }
  }
input[type="text"].day1,
  input[type="text"].day2,
  input[type="text"].day3,
  input[type="email"].day1,
  input[type="email"].day2,
  input[type="email"].day3,
  input[type="tel"].day1,
  input[type="tel"].day2,
  input[type="tel"].day3,
  input[type="url"].day1,
  input[type="url"].day2,
  input[type="url"].day3,
  input[type="password"].day1,
  input[type="password"].day2,
  input[type="password"].day3 {
    background-image: url(../img/contact/icon_calendar.png);
    background-position: right 5px center;
    background-size: 30px;
    background-repeat: no-repeat;
  }
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
      input[type="text"].day1, input[type="text"].day2, input[type="text"].day3, input[type="email"].day1, input[type="email"].day2, input[type="email"].day3, input[type="tel"].day1, input[type="tel"].day2, input[type="tel"].day3, input[type="url"].day1, input[type="url"].day2, input[type="url"].day3, input[type="password"].day1, input[type="password"].day2, input[type="password"].day3 {
        background-image: url(../img/contact/icon_calendar@2x.png);
      }
    }
/*************************************************************
* テキスト タイプ1
*************************************************************/
.input.text_type1[type="text"],
.input.text_type1[type="email"],
.input.text_type1[type="tel"],
.input.text_type1[type="url"],
.input.text_type1[type="password"] {
  position: relative;
  
  border: none;
  border-bottom: 1px solid #cdcdcd;
  background-color: #fff;

  padding: 0.455em 0.555em 0.355em;

  transition: 400ms cubic-bezier(0.075, 0.820, 0.165, 1.000);
  transition-property: border-color;

}
.input.text_type1[type="text"]:focus,
  .input.text_type1[type="text"]:not(:placeholder-shown),
  .input.text_type1[type="text"].__error,
  .input.text_type1[type="email"]:focus,
  .input.text_type1[type="email"]:not(:placeholder-shown),
  .input.text_type1[type="email"].__error,
  .input.text_type1[type="tel"]:focus,
  .input.text_type1[type="tel"]:not(:placeholder-shown),
  .input.text_type1[type="tel"].__error,
  .input.text_type1[type="url"]:focus,
  .input.text_type1[type="url"]:not(:placeholder-shown),
  .input.text_type1[type="url"].__error,
  .input.text_type1[type="password"]:focus,
  .input.text_type1[type="password"]:not(:placeholder-shown),
  .input.text_type1[type="password"].__error {
    border-width: 2px;

    padding-bottom: calc(0.355em - 1px);
  }
.input.text_type1[type="text"]:focus + .label, .input.text_type1[type="text"]:not(:placeholder-shown) + .label, .input.text_type1[type="text"].__error + .label, .input.text_type1[type="email"]:focus + .label, .input.text_type1[type="email"]:not(:placeholder-shown) + .label, .input.text_type1[type="email"].__error + .label, .input.text_type1[type="tel"]:focus + .label, .input.text_type1[type="tel"]:not(:placeholder-shown) + .label, .input.text_type1[type="tel"].__error + .label, .input.text_type1[type="url"]:focus + .label, .input.text_type1[type="url"]:not(:placeholder-shown) + .label, .input.text_type1[type="url"].__error + .label, .input.text_type1[type="password"]:focus + .label, .input.text_type1[type="password"]:not(:placeholder-shown) + .label, .input.text_type1[type="password"].__error + .label {
      -ms-transform: translate(0.555em, -1.3em);
          transform: translate(0.555em, -1.3em);

      font-size: 0.79em;
      color: #666;
    }
.input.text_type1[type="text"]:focus,
  .input.text_type1[type="text"]:not(:placeholder-shown),
  .input.text_type1[type="email"]:focus,
  .input.text_type1[type="email"]:not(:placeholder-shown),
  .input.text_type1[type="tel"]:focus,
  .input.text_type1[type="tel"]:not(:placeholder-shown),
  .input.text_type1[type="url"]:focus,
  .input.text_type1[type="url"]:not(:placeholder-shown),
  .input.text_type1[type="password"]:focus,
  .input.text_type1[type="password"]:not(:placeholder-shown) {
    border-color: #e8640c;
  }
.input.text_type1[type="text"].__error,
  .input.text_type1[type="text"]:invalid,
  .input.text_type1[type="email"].__error,
  .input.text_type1[type="email"]:invalid,
  .input.text_type1[type="tel"].__error,
  .input.text_type1[type="tel"]:invalid,
  .input.text_type1[type="url"].__error,
  .input.text_type1[type="url"]:invalid,
  .input.text_type1[type="password"].__error,
  .input.text_type1[type="password"]:invalid {
    border-color: #f14a2f;
  }
/*************************************************************
* テキスト タイプ2
*************************************************************/
.input.text_type2[type="text"],
.input.text_type2[type="email"],
.input.text_type2[type="tel"],
.input.text_type2[type="url"],
.input.text_type2[type="password"] {
  border: 1px solid #cdcdcd;
  background-color: #fff;

  padding: 0.455em 0.555em;

  transition: 400ms cubic-bezier(0.075, 0.820, 0.165, 1.000);
  transition-property: border-color, background-color;
}
.input.text_type2[type="text"]:focus, .input.text_type2[type="email"]:focus, .input.text_type2[type="tel"]:focus, .input.text_type2[type="url"]:focus, .input.text_type2[type="password"]:focus {
    border-color: #e8640c;
    background-color: #fff9f4;
  }
.input.text_type2[type="text"].__error,
  .input.text_type2[type="text"]:invalid,
  .input.text_type2[type="email"].__error,
  .input.text_type2[type="email"]:invalid,
  .input.text_type2[type="tel"].__error,
  .input.text_type2[type="tel"]:invalid,
  .input.text_type2[type="url"].__error,
  .input.text_type2[type="url"]:invalid,
  .input.text_type2[type="password"].__error,
  .input.text_type2[type="password"]:invalid {
    border-color: #f14a2f;
  }
/* プレースホルダー */
input:placeholder-shown { color: #ccc;}
input::-webkit-input-placeholder { color: #ccc;}
input:-moz-placeholder { color: #ccc;}
input::-moz-placeholder { color: #ccc;}
input:-ms-input-placeholder { color: #ccc;}
/*************************************************************
* テキストエリア
*************************************************************/
textarea {
  width: 100%;
  min-height: 180px;
  resize: vertical;
  outline: none;
  
  border: #cdcdcd 1px solid;
  border-radius: 3px;
  background-color: #fff;
  
  padding: 0.455em 0.555em;

  font-size: 1em;
  line-height: 1.75;
  
  transition: 320ms cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-property: background-color, border-color;
}
textarea:focus {
    border-color: #e8640c;
    background-color: #fff9f4;
  }
textarea.large { heaight: 300px; }
textarea.middle { heaight: 200px; }
textarea.small { heaight: 100px; }
/*************************************************************
* セレクト
*************************************************************/
.input.select {
  outline: none;
  display: block;
  width: 100%;

  border: none;
  background-color: transparent;
}
.select_item {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  widows: 100%;

  border: 1px solid #ccc;
  background-color: #fff;

  padding: 0.255em 0.455em 0.355em;
  padding-right: 0;
  margin-right: 5px;
}
.select_item.__middle { max-width: 500px; }
.select_item.__small { max-width: 100px; }
.select_item.__micro { max-width: 60px; }
@media screen and (max-width: 599px) {
    .select_item {
      padding: 0.324em;
    }

    .select_item.middle,
    .select_item.small {
      max-width: 100%; 
    }
  }
/*************************************************************
* トグルスイッチ
*************************************************************/
.toggle_item {}
.input.toggle {
  opacity: 0;
  width: 0px;
}
.input.toggle + .label {
    padding-left: 2.8em;

    position: relative;

    line-height: 1.75;
  }
.input.toggle + .label:before {
    content: "";
    width: 2rem;
    height: 1rem;
    display: inline-block;

    position: absolute;
    top: 0;
    left: 0;

    margin-right: 4px;

    background-color: #e6e6e6;
    border-radius: 8px;
    box-shadow: 0 2px 8px -2px rgba(0, 0, 0, 0.24) inset;
  }
.input.toggle + .label:after {
    content: '';
    display: block;
    width: calc(1rem - 4px);
    height: calc(1rem - 4px);

    position: absolute;
    top: 2px;
    left: 2px;
    
    border: 1px solid #ededed;
    border-radius: 50%;
    background-color: #fff;
    box-shadow: 0 4px 8px -4px rgba(0, 0, 0, 0.6);
    
    transition: transform 100ms cubic-bezier(0.215, 0.61, 0.355, 1);
  }
.input.toggle:checked + .label:before {
      background-color: #fdc23e;
      border-color: #fdc23e;
    }
.input.toggle:checked + .label:after {
      -ms-transform: translateX(1rem);
          transform: translateX(1rem);
    }
/*************************************************************
* チェックボックス
*************************************************************/
.check_item {
  display: inline-block;

  margin-right: 10px;
}
.input.checkbox {
  opacity: 0;
  width: 0px;
}
.input.checkbox[disabled] + .label {
    color: #ababab;
  }
.input.checkbox:not([disabled]) + .label {
      padding-left: 1.602em;

      position: relative;

      line-height: 1.75;
    }
.input.checkbox:not([disabled]) + .label:before {
        content: "";
        width: 1rem;
        height: 1rem;
        display: inline-block;

        position: absolute;
        top: 7px;
        left: 0;

        margin-right: 4px;

        background-color: #fff;
        border-radius: 3px;
        box-shadow: 0 2px 8px -2px rgba(0, 0, 0, 0.24) inset;
        border: 1px solid #ccc;
      }
.input.checkbox:not([disabled]) + .label:after {
        content: '';
        display: block;
        width: 6px;
        height: 12px;

        position: absolute;
        top:0px;
        bottom: 0;
        left: 5px;
        
        margin: auto;
        
        border-right: 3px solid #fff;
        border-bottom: 3px solid #fff;
        opacity: 0;
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
        
        transition: opacity 100ms cubic-bezier(0.215, 0.61, 0.355, 1);
      }
.input.checkbox:checked + .label:before {
        background-color: #e8640c;
        border-color: #fdc23e;
      }
.input.checkbox:checked + .label:after {
        opacity: 1;
      }
/*************************************************************
* ラジオボタン
*************************************************************/
.radio_item {
  display: inline-block;

  margin-right: 20px;
}
.input.radio {
  opacity: 0;
  width: 0px;

}
.input.radio[disabled] + .label {
      color: #ababab;
    }
.input.radio:not([disabled]) + .label {
      padding-left: 1.602em;

      position: relative;

      display: inline-block;

      line-height: 2;
    }
.input.radio:not([disabled]) + .label:before {
        content: "";
        width: 1em;
        height: 1em;
        display: block;

        border-radius: 50%;
        border: #cfcfcf 1px solid;
        box-shadow: 0 2px 8px -2px rgba(0, 0, 0, 0.24) inset;
        background-color: #fff;
        
        position: absolute;
        left: 0;
        top: 8px;
      }
.input.radio:not([disabled]) + .label:after {
        content: "";
        width: calc(1rem - 8px);
        height: calc(1rem - 8px);
        display: block;
        
        margin: auto;
        
        background-color: #fff;
        border-radius: 50%;
        opacity: 0;
        
        position: absolute;
        top: 12px;
        left: 4px;
        
        transition: opacity 200ms cubic-bezier(0.215, 0.61, 0.355, 1);
      }
.input.radio:checked + .label:before {
      background-color: #e8640c;
      border-color: #e8640c;
    }
.input.radio:checked + .label:after {
      opacity: 1;
    }
/* ブロック */
/*# sourceMappingURL=form.css.map */