@charset "UTF-8";
/*------------------------------------------------------------------

BASE

--------------------------------------------------------------------*/
@font-face {
  font-family: "MyYuGothic";
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regurar"); }
@font-face {
  font-family: "MyYuGothic";
  font-weight: bold;
  src: local("YuGothic-Bold"), local("Yu Gothic"); }
/*Easing*/
/*Screen*/
html, body, div, article, section, span, p, ul, ol, li, table, tr, td, th, hr, h1, h2, h3, h4, h5, h6, a, em, strong, b, img, input, textarea, svg, button, fieldset, figure, header, footer, label {
  padding: 0;
  margin: 0;
  border: none;
  outline: none;
  font-size: 100%;
  vertical-align: baseline;
  list-style-type: none;
  -webkit-text-size-adjust: none;
  box-sizing: border-box;
  line-height: 1em;
  border-collapse: collapse; }

html {
  font-size: 16px;
  overflow-x: hidden;
  min-height: 100%; }

body {
  color: #000;
  background: #FAFAFA;
  font-family: -apple-system, "BlinkMacSystemFont", Arial, "ヒラギノ角ゴシック", "Hiragino Kaku Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", MyYuGothic, "游ゴシック体", YuGothic, "メイリオ", Meiryo, sans-serif;
  font-weight: 300;
  position: relative;
  word-break: normal;
  word-wrap: break-word;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch;
  min-height: 100vh; }

html, body {
  zoom: 1; }

.serif {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", YuMincho, "ＭＳ Ｐ明朝", Georgia, serif; }

.sans-serif {
  font-family: -apple-system, "BlinkMacSystemFont", Arial, "ヒラギノ角ゴシック", "Hiragino Kaku Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", MyYuGothic, "游ゴシック体", YuGothic, "メイリオ", Meiryo, sans-serif; }

.mono {
  font-family: "Courier", "Osaka－等幅", Osaka-mono, "ＭＳ ゴシック", "MS Gothic", monospace; }

input[type=text],
input[type=url],
input[type=tel],
input[type=email],
input[type=radio],
input[type=checkbox],
input[type=submit],
input[type=search],
select,
textarea {
  -webkit-appearance: none;
  outline: none; }

input[type=submit]:hover {
  cursor: pointer; }

strong, b,
h1, h2, h3, h4, h5, h6 {
  font-weight: 600; }

a {
  color: #00aaf2;
  outline: none;
  text-decoration: none; }
  a:hover {
    text-decoration: underline; }
  a:active {
    text-decoration: none; }

@media screen and (min-width: 813px) {
  a[href^="tel:"] {
    pointer-events: none; } }
p {
  margin: 0;
  padding: 0 0 1.5em;
  line-height: 1.75em;
  line-break: strict; }
  p a {
    color: #00aaf2; }
  p a:hover {
    text-decoration: underline; }
  p:last-child {
    padding-bottom: 0; }

img {
  display: inline-block;
  outline: none;
  -moz-user-select: none;
  /* These user-select properties are inheritable, used to prevent text selection */
  -webkit-user-select: none;
  -ms-user-select: none;
  /* From IE10 only */
  user-select: none;
  /* Not valid CSS yet, as of July 2012 */
  -webkit-user-drag: none;
  /* Prevents dragging of images/divs etc */
  user-drag: none; }

.clear {
  width: 100%;
  font-size: 0px;
  height: 1px;
  overflow: hidden;
  clear: both;
  float: none;
  margin: 0 0 -1px 0;
  display: block; }

.clear_after:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  margin: 0 0 -1px 0;
  clear: both;
  float: none; }

.l,
.alignleft {
  float: left; }

.r,
.alignright {
  float: right; }

.c,
.aligncenter {
  text-align: center;
  margin-left: auto;
  margin-right: auto; }

.has-text-align-left {
  text-align: left; }

.has-text-align-center {
  text-align: center; }

.has-text-align-right {
  text-align: right; }

.tsume_lr {
  margin: 0 -0.1em; }

.none {
  display: none; }

.hidden {
  visibility: hidden; }

.nopc {
  display: none;
  visibility: hidden; }
  @media screen and (max-width: 812px) {
    .nopc {
      display: inherit;
      visibility: visible; } }

@media screen and (max-width: 812px) {
  .nosp {
    display: none;
    visibility: hidden; } }

.sp320 {
  display: none;
  visibility: hidden; }
  @media screen and (max-width: 320px) {
    .sp320 {
      display: inherit;
      visibility: visible; } }

/*------------------------------------------------------------------

ANIMATION

--------------------------------------------------------------------*/
@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes rtate360 {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }
/*------------------------------------------------------------------

HEADER

--------------------------------------------------------------------*/
header {
  text-align: center;
  padding: 30px 0 15px; }
  header img {
    max-width: 80%;
    height: auto; }

#container {
  max-width: 480px;
  width: 100%;
  margin: 0 auto;
  padding: 20px; }

h1 {
  font-size: 1.75rem;
  line-height: 1.5em;
  margin: 1rem 0;
  text-align: center; }

/*------------------------------------------------------------------

フォーム

--------------------------------------------------------------------*/
.form_area {
  width: 100%;
  margin: 0 auto;
  padding: 0 0 50px 0; }
  .form_area > p {
    font-size: 0.9375rem; }
  .form_area form {
    padding-top: 1rem; }

form.sent {
  opacity: 0; }

#loading {
  width: 40px;
  height: 40px;
  position: fixed;
  top: 50%;
  left: 50%;
  margin: -20px 0 0 -20px;
  border-radius: 50% 50%;
  border: 3px dotted #00aaf2;
  animation: rtate360 3.4s linear 0s infinite; }

form.sent + #loading,
#loading.show {
  display: block; }

.message_area {
  padding: 50px 0; }

#counter,
#limit {
  display: none; }

.wpcf7-form-control-wrap {
  display: block;
  padding: 0.25em 0; }

.wpcf7-list-item {
  margin: 5px 1.5em 0.5em 0;
  display: inline-block; }
  .wpcf7-list-item.has-free-text {
    white-space: nowrap; }
    .wpcf7-list-item.has-free-text input[type=text] {
      width: auto;
      padding: 3px 5px;
      margin: 4px 0 0 4px; }

input, textarea {
  font-family: -apple-system, "BlinkMacSystemFont", Arial, "ヒラギノ角ゴシック", "Hiragino Kaku Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", MyYuGothic, "游ゴシック体", YuGothic, "メイリオ", Meiryo, sans-serif;
  font-weight: normal; }

input[type=text],
input[type=tel],
input[type=email] {
  border: 1px solid #DDD;
  background-color: #FFF;
  width: 100%;
  max-width: 360px;
  padding: 5px 8px;
  font-size: 1rem;
  margin: 4px 0 0;
  line-height: 1.5em; }
  input[type=text].wpcf7-not-valid,
  input[type=tel].wpcf7-not-valid,
  input[type=email].wpcf7-not-valid {
    background-color: #fae9e9; }
  input[type=text]:disabled,
  input[type=tel]:disabled,
  input[type=email]:disabled {
    color: #555;
    -webkit-text-fill-color: #555;
    opacity: 1; }

input[type=text]:focus,
input[type=tel]:focus,
input[type=email]:focus,
textarea:focus {
  background-color: #FFFFDD; }

textarea {
  padding: 5px 8px;
  font-size: 1rem;
  border: 1px solid #DDD;
  background-color: #FFF;
  width: 100%;
  max-width: 640px;
  margin: 4px 0 0;
  line-height: 1.5em; }
  textarea.error {
    background-color: #fae9e9; }
  textarea:disabled {
    color: #555;
    -webkit-text-fill-color: #555;
    opacity: 1; }

.select_wrapper {
  margin: 4px 0 0;
  border-radius: 8px;
  border: 1px solid #DDD;
  background-color: #F5F5F5;
  display: inline-block;
  position: relative;
  max-width: 100%; }
  .select_wrapper:after {
    content: "";
    display: block;
    width: 7px;
    height: 7px;
    border-bottom: 3px solid #000;
    border-right: 3px solid #000;
    transform: rotate(45deg);
    position: absolute;
    right: 10px;
    top: 50%;
    margin: -7px 0 0 0; }
  .select_wrapper select {
    font-size: 1rem;
    padding: 5px 30px 5px 12px;
    line-height: 1.5em;
    background: transparent;
    border: none;
    border-radius: 8px; }
    .select_wrapper select.error {
      background-color: #fae9e9; }
    .select_wrapper select:disabled {
      color: #555; }

input[type=radio],
input[type=checkbox] {
  display: none; }

input[type=checkbox] + .wpcf7-list-item-label {
  position: relative;
  display: inline-block;
  padding: 0 0 0 23px;
  cursor: pointer; }
  input[type=checkbox] + .wpcf7-list-item-label:after {
    position: absolute;
    top: 50%;
    left: 0px;
    display: block;
    margin-top: -9px;
    width: 16px;
    height: 16px;
    border: 1px solid #D0D0D0;
    background-color: #FFF;
    border-radius: 3px;
    content: '';
    transition: background-color 0.3s ease; }
  input[type=checkbox] + .wpcf7-list-item-label:before {
    position: absolute;
    top: 50%;
    left: 5px;
    display: block;
    margin-top: -9px;
    width: 5px;
    height: 11px;
    border-right: 3px solid #FFF;
    border-bottom: 3px solid #FFF;
    content: '';
    opacity: 0;
    z-index: 5;
    transform: rotate(40deg) scale(0.4, 0.4);
    transition: all 0.2s cubic-bezier(0.175, 0.885, 0.605, 1.465); }

input[type=checkbox]:checked + .wpcf7-list-item-label:after {
  border: 1px solid #00aaf2;
  background-color: #00aaf2; }
input[type=checkbox]:checked + .wpcf7-list-item-label:before {
  opacity: 1;
  transform: rotate(40deg) scale(1, 1); }

input[type=radio] + .wpcf7-list-item-label {
  position: relative;
  display: inline-block;
  padding: 0 0 0 23px;
  cursor: pointer; }
  input[type=radio] + .wpcf7-list-item-label:after {
    position: absolute;
    top: 50%;
    left: 0px;
    display: block;
    margin-top: -9px;
    width: 17px;
    height: 17px;
    background-color: #FFF;
    border-radius: 50%;
    border: 1px solid #D0D0D0;
    content: ''; }
  input[type=radio] + .wpcf7-list-item-label:before {
    position: absolute;
    top: 50%;
    left: 4px;
    display: block;
    margin-top: -5px;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    content: '';
    background-color: #00aaf2;
    opacity: 0;
    z-index: 5;
    transform: scale(0.1, 0.1);
    transition: all 0.2s cubic-bezier(0.175, 0.885, 0.605, 1.465); }

input[type=radio]:checked + .wpcf7-list-item-label:after {
  background-color: #FFF; }
input[type=radio]:checked + .wpcf7-list-item-label:before {
  opacity: 1;
  transform: scale(1, 1); }

.select_wrapper {
  margin: 4px 0 0;
  border-radius: 7px;
  border: 1px solid #DDD;
  background-color: #FFF;
  display: inline-block;
  position: relative;
  font-size: 0;
  line-height: 0; }
  .select_wrapper:after {
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    border-bottom: 3px solid #00aaf2;
    border-right: 3px solid #00aaf2;
    transform: rotate(45deg);
    position: absolute;
    right: 10px;
    top: 50%;
    margin: -6px 0 0 0;
    z-index: 1; }
  .select_wrapper select {
    font-size: 1rem;
    padding: 8px 30px 6px 8px;
    line-height: 1em;
    background: transparent;
    border: none;
    border-radius: 8px;
    z-index: 2;
    position: relative; }
    .select_wrapper select.error {
      background-color: #fae9e9; }
    .select_wrapper select:disabled {
      color: #555; }

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer; }

input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none; }

input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px; }

input[type=submit] {
  background-color: #00aaf2;
  color: #FFF;
  margin: 30px auto 0;
  padding: 13px 50px;
  border-radius: 3px;
  display: block;
  position: relative;
  box-shadow: 0 3px 0 0 rgba(0, 0, 0, 0.1);
  cursor: pointer; }
  input[type=submit]:active {
    top: 1px;
    box-shadow: 0 2px 0 0 rgba(0, 0, 0, 0.1); }

.q_img {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  font-size: 0;
  line-height: 0;
  margin: 10px 0 16px; }
  .q_img .wpcf7-form-control-wrap {
    width: 100%; }
  .q_img .wpcf7-form-control {
    width: 100%;
    font-size: 0.9375rem;
    line-height: 1.75em;
    text-align: center;
    display: flex;
    justify-content: space-between; }
  .q_img .wpcf7-list-item {
    display: inline-block;
    margin: 5px 0; }
  .q_img br {
    display: none;
    visibility: hidden; }
  .q_img img {
    max-width: 100%;
    height: auto;
    margin-bottom: 5px;
    border-radius: 2px;
    cursor: pointer; }

.q_img2 img,
.q_img2 .wpcf7-list-item {
  width: calc(50% - 5px); }

.vline .wpcf7-list-item {
  display: block;
  padding: 4px 0; }

/*------------------------------------------------------------------

エラー表示

--------------------------------------------------------------------*/
.screen-reader-response,
.wpcf7-response-output {
  display: none;
  visibility: hidden;
  font-size: 0;
  line-height: 0; }

.wpcf7-not-valid-tip {
  display: block;
  font-size: 0.8125rem;
  color: red;
  line-height: 1.75em; }

/*# sourceMappingURL=common.css.map */
