/* --------------------------------------------------------- */
/* reset
------------------------------------------------------------ */
/* reset */
body, div, dl, dt, dd, ul, ol, li, p, figure, h1, h2, h3, h4, h5, h6 {
  padding: 0;
  margin: 0;
}
h1, h2, h3, h4, h5, h6, p, ul, ol, dl {
  font-size: 1em;
}
li {
  list-style: none;
}
/* common */
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
html {
  font-family: 'Noto Sans JP', sans-serif;
  /*font-family:"ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";*/
  
  -webkit-text-size-adjust: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
}
body {
  /*min-width: 1180px;*/
  font-size: 100%;
  line-height: 1.8;
  color: #221714;
  letter-spacing: .1rem;
  font-weight: 400;
  overflow-x: hidden;
}
html, body {
  width: 100%;
}
img {
  vertical-align: top;
  border: 0;
  height: auto;
  max-width: 100%;
}
a img {
  border: 0;
}
a img:hover {
  opacity: 0.8;
}
a:link, a:visited {
  text-decoration: none;
  color: #000;
}
a:hover, a:active {
  text-decoration: none;
  color: #000;
}
.pc {
  display: block;
}
.sp {
  display: none;
}
.mb10 {
  margin-bottom: 10px;
}
.mb20 {
  margin-bottom: 20px;
}
.mb30 {
  margin-bottom: 30px;
}
.mb40 {
  margin-bottom: 40px;
}
.mb50 {
  margin-bottom: 50px;
}
.mb60 {
  margin-bottom: 60px;
}
.mb70 {
  margin-bottom: 70px;
}
.mb80 {
  margin-bottom: 80px;
}
@media screen and (max-width: 768px) {
  body {
    min-width: 360px;
    letter-spacing: normal;
    line-height: 1.8;
  }
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  .mb10 {
    margin-bottom: 5px;
  }
  .mb20 {
    margin-bottom: 10px;
  }
  .mb30 {
    margin-bottom: 15px;
  }
  .mb40 {
    margin-bottom: 20px;
  }
  .mb50 {
    margin-bottom: 25px;
  }
  .mb60 {
    margin-bottom: 30px;
  }
  .mb70 {
    margin-bottom: 35px;
  }
  .mb80 {
    margin-bottom: 40px;
  }
}
/* --------------------------------------------------------- */
/* 共通パーツ
------------------------------------------------------------ */
.contWrap {
  max-width: 700px;
  margin: 0 auto 80px auto;
}
.mapWrap {
  max-width: 700px;
  margin: 0 auto 80px auto;
  text-align: center;
}
.gmap {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    /* 16:9のアスペクト比 */
    height: 0;
}

.gmap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.gmap {
  
}
.address {
  margin-bottom: 20px;
}
.yoyakuWrap {
  
}
.yoyakuTxt {
  text-align: center;
}
h2 {
  font-size: 24px;
  margin-bottom: 30px;
}
.footer {
  text-align: center;
  padding: 20px;
  font-size: 10px;
}
.privacyWrap {
  
}
.privacy {
   height: 150px;
    padding: 1em;
    border: 2px solid #999;
    overflow-y: scroll;
  width: 100%;
  word-wrap: break-word;
    overflow-wrap: break-word;
  font-size: 12px;
  color: #767676;
}
.redTxt {
  color: #B70003;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .contWrap {
    max-width: 100%;
    margin: 0 auto 40px auto;
  }
  .mapWrap {
    max-width: 100%;
    margin: 0 auto 40px auto;
    padding: 0 10px;
  }
  .address {
    margin-bottom: 20px;
  }
  .yoyakuWrap {

  }
  .yoyakuTxt {
    text-align: center;
    padding: 0 10px;
    font-size: 15px;
  }
  h2 {
    font-size: 24px;
    margin-bottom: 30px;
  }
  .footer {
    text-align: center;
    padding: 20px;
    font-size: 10px;
  }
  .privacyWrap {

  }
  .privacy {
     height: 150px;
      padding: 1em;
      border: 2px solid #999;
      overflow-y: scroll;
    width: 100%;
    word-wrap: break-word;
      overflow-wrap: break-word;
    font-size: 12px;
    color: #767676;
  }
  .redTxt {
    color: #B70003;
    margin-bottom: 30px;
  }
}
/* 基本的なスタイル設定 */
        body {
            /*background-color: #f4f7f6;
            color: #333;
            line-height: 1.6;*/
        }

        h1 {
            color: #2c3e50;
            text-align: center;
            margin-bottom: 30px;
        }

        form {
            max-width: 600px;
            margin: 0 auto;
            padding: 30px;
            background-color: #fff;
            border-radius: 8px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
        }

        .form-group {
            margin-bottom: 20px;
        }

        label {
            display: block;
            margin-bottom: 8px;
            font-weight: bold;
            color: #34495e;
        }

        /* 入力フィールドのスタイル */
        input[type="text"],
        input[type="email"],
        input[type="tel"],
        input[type="date"],
        select {
            width: calc(100% - 20px); /* Paddingを考慮 */
            padding: 10px;
            border: 1px solid #ddd;
            border-radius: 5px;
            box-sizing: border-box; /* Paddingがwidthに含まれるように */
            font-size: 16px;
            transition: border-color 0.3s ease;
        }

        input[type="text"]:focus,
        input[type="email"]:focus,
        input[type="tel"]:focus,
        input[type="date"]:focus,
        select:focus {
            border-color: #3498db;
            outline: none;
        }

        /* エラー状態のスタイル */
        .form-group.error input,
        .form-group.error select,
        fieldset.error {
            border-color: #e74c3c !important;
            box-shadow: 0 0 5px rgba(231, 76, 60, 0.3);
        }

        /* ラジオボタンとチェックボックスのスタイル */
        input[type="radio"],
        input[type="checkbox"] {
            margin-right: 8px;
            transform: scale(1.1); /* 少し大きく表示 */
        }

        .form-group label[for="storeOita"],
        .form-group label[for="storeParkPlace"],
        .form-group label[for="childcareYes"],
        .form-group label[for="childcareNo"],
        .form-group label[for="privacyPolicy"],
        .form-group label[for="consultationVisit"], /* 追加 */
        .form-group label[for="consultationOnline"] /* 追加 */
         {
            display: inline-block;
            font-weight: normal;
            margin-right: 15px;
            margin-bottom: 0;
            cursor: pointer;
        }

        /* fieldsetとlegendのスタイル */
        fieldset {
            border: 1px solid #ccc;
            border-radius: 5px;
            padding: 15px;
            margin-bottom: 20px;
        }

        legend {
            font-size: 1.1em;
            font-weight: bold;
            color: #34495e;
            padding: 0 10px;
            margin-left: -5px; /* fieldsetのpaddingと合わせて調整 */
        }
        /* legendが必須の場合のスタイル */
        legend.required::after {
            content: " 必須";
            color: #e74c3c;
            margin-left: 3px;
          font-size: 12px;
        }


        /* エラーメッセージのスタイル */
        .error-message {
            color: #e74c3c;
            font-size: 0.85em;
            margin-top: 5px;
            min-height: 18px; /* エラーメッセージがない場合でも高さを確保 */
            font-weight: bold;
        }

        /* 必須項目マーク */
        .required::after {
            content: " 必須";
            color: #e74c3c;
            margin-left: 3px;
          font-size: 12px;
        }

        /* 送信ボタンのスタイル */
        button[type="submit"] {
            display: block;
            width: 100%;
            padding: 12px 20px;
            background-color: #3498db;
            color: white;
            border: none;
            border-radius: 5px;
            font-size: 18px;
            cursor: pointer;
            transition: background-color 0.3s ease;
            margin-top: 20px;
        }

        button[type="submit"]:hover {
            background-color: #2980b9;
        }

        /* お子様情報セクションのタイトル */
        h3 {
            color: #34495e;
            margin-top: 30px;
            margin-bottom: 15px;
            border-bottom: 1px solid #eee;
            padding-bottom: 5px;
        }

        /* スクロール対象のハイライト */
        .scroll-target {
            animation: highlight 2s ease-in-out;
        }
.disIn {
  display: inline;
  margin-left: 5px;
}

        @keyframes highlight {
            0% { background-color: rgba(231, 76, 60, 0.1); }
            50% { background-color: rgba(231, 76, 60, 0.2); }
            100% { background-color: transparent; }
        }

@media screen and (max-width: 768px) {
  form {
            max-width: 100%;
            margin: 0 auto;
            padding: 15px;
            /*background-color: #fff;
            border-radius: 8px;*/
            /*box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1)*/;
    box-shadow: none;
        }
  input[type="radio"],
        input[type="checkbox"] {
            margin-right: 2px;
        }
}


.thanksWrap {
  text-align: center;
  padding-top: 30px;
}
.thanksWrap .logo {
  margin-bottom: 20px;
}
.thanksWrap h1 {
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .thanksWrap {
    padding: 20px;
  }
}
table.gaiyouTbl {
  /* テーブル全体のスタイル（任意） */
  width: 100%;
  border-collapse: collapse; /* セルの境界線を結合 */
  font-size: 15px;
  margin-bottom: 20px;
}

 table.gaiyouTbl th, table.gaiyouTbl td {
  /* セル共通のスタイル（任意） */
  padding: 8px;
  border: 1px solid #ddd; /* 罫線 */
  text-align: left; /* テキスト左寄せ */
}

table.gaiyouTbl th {
  /* 見出しセル(<th>)のスタイル */
  background-color: #f2f2f2; /* 薄いグレーの背景色 */
  color: #333; /* 文字色（見やすい色に） */
}
.disIn {
  display: inline-block;
  margin-left: 5px;
}
