@charset "UTF-8";

/*==================================
 2026.04 for arai
==================================*/

:root {
  --main-color: #459B2B; /* 基本色 */
  --text-color: #292929; /* 文字色 */
  --btn-color: var(--main-color); /* ボタン色 */
    --strong-text: #FF8E09;
}

:root { accent-color: var(--main-color); }
:focus-visible { outline-color: var(--main-color); }
::marker { color: var(--main-color); }

html {
    font-size: 62.5%;
}
body.customform {
  line-height: 1.7;
  font-size: 1.6em;
}

*, *::before, *::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
div#content ul {
  margin-left: 0;
}
div#content .note-01 li {
  font-size: 1.4rem;
  text-indent: -1em;
  padding-left: 1em;

}
div#content .note-01 li:before {
  content: "※";
}
.custom_form .th9 .note-01 li{
  color: #F68C2A;
}

div#content p {
  margin: 0 0 1.5rem 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}
div#content .bottom-space-01 {
  margin-bottom: 1.5rem;
}
div#content .text-deco-red {
  color: #FA5D4B;
  border: 0;
}

.text-orange-01 {
  color: var(--strong-text);
}
.bottom-space-30 {
  margin-bottom: 300px;
}

/*==================================
 2025.02 ver.4.0 ssc_design_room
==================================*/

/*========================
  CSS Reset
========================*/

input, button, textarea, select {
  font: inherit; 
}

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  -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;
}

/*--------------------------------------
 アクセントカラーの設定
 （メインカラーに準ずる）
--------------------------------------*/
:root { accent-color: #459B2B; }
:focus-visible { outline-color: #459B2B; }
::marker { color: #459B2B; }

/*--------------------------------------
 お問い合わせフォーム
--------------------------------------*/
div#content .custom_form > p {
    margin-bottom: 2rem;
}

/* input下のメッセージテキスト */
div#content .msgtxt {
  display: block;
  font-size: 1.4rem;
  font-weight: 500;
  margin: 1rem 0 0;
}

.custom_form table {
    margin: 0 auto 60px;
    width: 100%;
    table-layout: fixed;
}
.custom_form tr {
    border-bottom: 1px solid #E0E0E0;
    display: flex;
    align-items: center;
}

.custom_form th {
    width: 260px;
    display: flex;
    align-items: center;
    text-align: left;
    padding: 30px 0 30px 16px;
    flex-wrap: wrap;
}
.custom_form td {
    padding: 20px 0 20px 16px;
    width: calc(100% - 260px);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.custom_form input[type="text"],
.custom_form textarea {
    border: 1px solid #B8B8B8;
    border-radius: 4px;
    height: 44px;
    padding: 9px;
    font-size: 1.6rem;
}
.custom_form #name,
.custom_form #kana,
.custom_form #company,
.custom_form #email,
.custom_form #free_text1,
.custom_form #reEmail {
    width: 460px;
}
.custom_form #tel1 {
    width: 240px;
}
.custom_form #zip1 {
    width: 110px;
}
.custom_form #addr1 {
    width: 460px;
    margin-top: 16px;
}
.custom_form #free_textarea {
    width: 100%;
}
.custom_form #free_selectbox1,
.custom_form #tempo {
    width: 460px;
}


/* 生年月日 */
.custom_form td:has(#birth_year) input {
  margin-left: 1rem;
  margin-right: 1rem;
  width: 8rem;
}
.custom_form td:has(#birth_year) input:first-of-type {
  margin-left: 0;
}


/* 年齢 */
.custom_form td:has(#age) input {
  width: 8rem;
}
.custom_form td:has(#age) {
  position: relative;
}



/* 一般セレクトボックス */
.custom_form .selectarea {
    width: 100%;
    position: relative;
}
.custom_form .selectarea::after {
    content: "";
    position: absolute;
    transform: translateY(-50%);
    top: calc(50% - 1px);
    right: 16px;
    width: 10px;
    height: 10px;
    border-right: 3px solid #292929;
    border-bottom: 3px solid #292929;
    transform: translateY(-50%) rotate(45deg);s
}
.custom_form select {
    width: 100%;
    height: 44px;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #fff;
    color: #292929;
    border: 1px solid #B8B8B8;
    border-radius: 4px;
    height: 44px;
    padding: 9px;
    font-size: 1.6rem;
}


.custom_form th .label-required {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 0 12px;
    padding: 2px 8px;
    border-radius: 3px;
    background-color: var(--strong-text);
    color: #fff;
    font-size: 1.2rem;
    transform: translateY(-2px);
}

.custom_form td .label-required { 
    position: relative;
    font-size: 1.4rem;
    margin: 10px 0 0;
    padding-left: 26px;
    width: 100%;
}
.custom_form td .label-required::before { 
    position: absolute;
    display: block;
    width: 18px;
    height: 18px;
    left: 0;
    top: 2px;
    content: "";
    background-color: #EB2C2C;
    background-size: contain;
    clip-path: polygon(50% 0%,50% 0%,58.11% 0.654%,65.804% 2.549%,72.978% 5.581%,79.529% 9.647%,85.355% 14.645%,90.353% 20.471%,94.419% 27.022%,97.451% 34.196%,99.346% 41.89%,100% 50%,100% 50%,99.346% 58.11%,97.451% 65.804%,94.419% 72.978%,90.353% 79.529%,85.355% 85.355%,79.529% 90.353%,72.978% 94.419%,65.804% 97.451%,58.11% 99.346%,50% 100%,50% 100%,41.89% 99.346%,34.196% 97.451%,27.022% 94.419%,20.471% 90.353%,14.645% 85.355%,9.647% 79.529%,5.581% 72.978%,2.549% 65.804%,0.654% 58.11%,0% 50%,0% 50%,0.654% 41.89%,2.549% 34.196%,5.581% 27.022%,9.647% 20.471%,14.645% 14.645%,20.471% 9.647%,27.022% 5.581%,34.196% 2.549%,41.89% 0.654%,50% 0%,55.882% 70.588%,44.118% 70.588%,44.118% 82.353%,55.882% 82.353%,55.882% 70.588%,55.882% 20.588%,44.118% 20.588%,44.118% 61.765%,55.882% 61.765%,55.882% 20.588%);
}
.custom_form td:has(#tempo) .label-required,
.custom_form td:has(#free_textarea) .label-required {
    display: block;
    margin-bottom: 16px;
}


/* 確認・送信ボタン */
/* ボタン */

.btn-box {
    text-align: center;
}
.btn-box > div {
    margin: 0 10px;
}

.btn-able {
  position: relative;
  display: inline-block;
  background: var(--main-color);
  border: none;
  border-radius: 4px;
}
.btn-back,
.btn-disabled {
  position: relative;
  display: inline-block;
  background: #999;
  border: none;
  border-radius: 4px;
}
.btn-disabled {
  background: #CCC;
  opacity: 1; 
  cursor: default;
  pointer-events: none;
}
.btn-able::before,
.btn-back::before,
.btn-disabled::before {
  position: absolute;
  top: calc( 50% + -0.5rem );
  right: 1.5rem;
  width: 8px;
  height: 13px;
  content: '';
  background-repeat:  no-repeat;
  display: block;
  background-color: #FFF;
  clip-path: polygon(0% 11.75%,19.028% 0%,100% 50%,19.028% 100%,0% 88.25%,61.808% 50%);
}

.btn-back::before {
  left: 1.5rem;
  transform: rotateZ(180deg);
}
input.btn-link-12{
  position: relative;
  text-decoration: none;
  display: inline-block;
  color: #FFF;
  text-align: center;
  outline: none;
  background: transparent;
  font-weight: bold;
  padding: 2rem 3.2rem;
  font-size: 2rem;
  width: 300px;
  height: 80px;
  border: 0;
  border-radius: 8px;
}
.btn-able:hover,
.btn-back:hover {
  opacity: 0.6; 
}
.btn-disabled:hover {
  opacity: 1; 
}

input:disabled {
  cursor: default;
  pointer-events: none;
}

/* 各項目の個別対応 */
/* 一般ラジオボタン（横並び） */
.custom_form label:has(input[type="radio"]) {
  display: block;
  margin-right: 2rem;
  cursor: pointer;
}
.custom_form input[type="radio"] {
    margin: 0 5px 0 0;
    width: 28px;
    height: 28px;
    cursor: pointer;
}

/* 性別（縦並びに変更） */
.custom_form td:has(#gender) {
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    margin: 0;
    text-align: left;
}
.custom_form td:has(#gender) label:first-of-type {
    margin-bottom: 16px;
  }


/* 一般チェックボックス */
.custom_form label:has(input[type="checkbox"]) {
  display: block;
  margin-right: 2rem;
  cursor: pointer;
}
.custom_form input[type="checkbox"] {
  margin: 0 7px 0 2px;
  width: 24px;
  height: 24px;
  cursor: pointer;
}



/* 住所 */
.custom_form td:has(#zip1) {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
}

/* 店舗 */
.custom_form td:has(#tempo) {
  display: table-cell;
}
div#content .custom_form p.temponavi {
  margin: 16px 0 0;
}
.custom_form .temponavi a.link-arrow {
  margin-bottom: 0;
}

/* メール */
.custom_form td:has(#email) {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
}
.custom_form #email {
    margin-bottom: 16px;
}

/* お問い合わせ内容 */
.custom_form #free_textarea {
    height: 294px;
    resize: vertical;
}

.custom_form-contact .link-arrow {
    margin: 0 auto 1.5rem;
}


/* 注意事項 */
div#content .custom_form p.form-notice {
    display: inline-block;
    font-size: 1.4rem;
    font-weight: 500;
    margin: 0;
}

/* 必須項目 */
.custom_form th .label-required {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 0 12px;
    padding: 2px 8px;
    border-radius: 3px;
    background-color: #F68C2A;
    color: #fff;
    font-size: 1.2rem;
    transform: translateY(-2px);
}

/* 同意するのチェックボックス */
#agree_form {
    text-align: center;
}

#agree_form label {
    margin: 60px auto 16px;
    position: relative;
    display: none;
    cursor: pointer;
    display: inline-block;
    position: relative;
    font-size: 1.7rem;
}
#agree_form input[type="checkbox"] {
    margin-right: 25px;
}

#agree_form input[type="checkbox"]::before {
    content: "";
    position: absolute;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 28px;
    height: 28px;
    margin-top: -10px;
    left: 0;
    top: 9px;
    background: #fff;
    border-radius: 3px;
    border: 1px solid #B8B8B8;
}

#agree_form input[type="checkbox"]:checked::before {
    border-color: #fff;
    background: #459B2B;
}

#agree_form input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 14px;
    height: 8px;
    margin-top: -4px;
    top: 40%;
    left: 8px;
    transform: rotate(-45deg);
    background: #459B2B;
    border-bottom: 4px solid;
    border-left: 4px solid;
    border-color: #fff;
}

@media screen and (width <= 767px){
    .custom_form tr {
        flex-direction: column;
        lign-items: left;
    }
    .custom_form th {
        width: 100%;
        display: block;
        align-items: left;
        text-align: left;
        padding: 20px 12px 0 12px;
    }
    .custom_form td {
        padding: 20px 20px 20px 16px;
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        align-items: left;
    }
    .custom_form td:has(select) {

    }
    .custom_form td .selectarea,
    .custom_form td select {
        width: 100%;
    }
    
    .custom_form td:has(#zip1),
    .custom_form td:has(#email),
    .custom_form #name,
    .custom_form #kana,
    .custom_form #addr1,
    .custom_form #email,
    .custom_form #reEmail,
    .custom_form #tel1,
    .custom_form #free_textarea {
        width: 100%;
    }
    .custom_form .btn-link-12 {
        width: 200px;
    }

    /* 性別 */
    .custom_form .radio-list {
        display: block;
    }
    .custom_form .radio-item:not(:first-of-type) {
        margin: 20px 0 0 0;
    }
    .custom_form th:has(.note-01) {
      display: flex;
      align-items: baseline;
    }
    .custom_form .note-01 {
      margin-left: 20px;
    }
    .custom_form td:has(#free_textarea) {
      padding-top: 0;
    }
    .custom_form #free_textarea {
        margin-top: 0;
        margin-bottom: 0;
    }

}


