@charset "utf-8";
html, body{
    margin: 0;
    padding: 0;
    background-color: #f5f5f5;
}
#top-gNavi{
    display: flex;
    align-items: center;
    justify-content: space-between; /* 左：globalNav / 右：headerSub-flex */
    padding-left: 0.8vw;
    width: 100%;
    box-sizing: border-box;
}
#p-globalNav{
    display: flex;
    align-items: center;
    list-style: none;
    padding-left: 0;
    margin: 0;
    gap: 1.5vw; /* paddingより扱いやすいので任意 */
  }
.p-globalNav_link{
    padding: 0;
} /* gapを使うならpaddingは薄くする */
.p-globalNav_link:nth-of-type(1){
    padding-top: 1vh;
}
.p-globalNav_link img{
    height: 7.5vh;
}
.p-globalNav_link a:link{
    text-decoration: none;
    color:black;
    font-weight: bold;
}
.p-globalNav_link a:visited{
    text-decoration: none;
    color:black;
    font-weight: bold;
}
.p-globalNav_link a:hover{
    text-decoration: underline;
    text-decoration-color: #02ab2f;
    text-underline-offset: 8px;
    color:black;
    font-weight: bold;
}

/* mainタグ */
#request{
    background-color: white;
    width: 900px;
    display: flex;
    flex-direction: column;
    margin-right: auto;
    margin-left: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    padding: 50px 80px 50px 80px;
    border-radius: 30px;
}
#request2{
    background-color: white;
    width: 900px;
    display: flex;
    flex-direction: column;
    margin-right: auto;
    margin-left: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    padding: 50px 80px 50px 80px;
    border-radius: 30px;
}
#top_message{
    line-height: 28px;
    justify-content: left;
}
#input_flow{
    background-color: white;
    text-align: center;
    width: 900px;
    margin-right: auto;
    margin-left: auto;
    margin-top: 20px;
    margin-bottom: 70px;
    padding: 30px 80px 30px 80px;
    border-radius: 30px;
    font-size: 17px;
    font-weight: bold;
}
#input01{
    color: #02ab2f;
    text-decoration: underline;
    text-underline-offset: 8px;
}
#input02{
    color: #02ab2f;
    text-decoration: underline;
    text-underline-offset: 8px;
}
#input03{
    color: #02ab2f;
    text-decoration: underline;
    text-underline-offset: 8px;
}

/*回収スポット基本情報*/
.basic{
    position: relative;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    margin-top: 5vh;
    width: 1060px;
}
.basic_view_confirm{
    position: relative;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    margin-top: -70px;
    width: 1060px;
}
.basic_view_spot{
    position: relative;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0;
    width: 1060px;
}
#basic_title{
    position: absolute;
    left: 0;
    top: -40px;
}
.info{
    background-color: white;
    margin-top: 2.5vh;
    padding: 50px 80px 80px 80px;
    border-radius: 35px;
}
.info_table{
    border-spacing: 0;
}
.c-formTable_th{
    text-align: left;
    width: 200px;
    height: 100px;
    border-right: none;
    border-bottom: 1px solid #e6e6e6;
}
.c-formTable_td{
    text-align: left;
    width: 700px;
    height: 100px;
    border-bottom: 1px solid #e6e6e6;
}
#facility_name{
    width: 700px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#facility_name_label::after {
    content: "必須";
    background-color: red;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    min-width: 10px;
    padding: 3px 7px;
    margin: 0px 5px;
    line-height: 16px;
    white-space: nowrap;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    position: relative;
    top: 1.25vh;
    transform: translateY(-50%);
  }
#type{
    width: 400px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#type_name_label::after {
    content: "必須";
    background-color: red;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    min-width: 10px;
    padding: 3px 7px;
    margin: 0px 5px;
    line-height: 16px;
    white-space: nowrap;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    position: relative;
    top: 1.25vh;
    transform: translateY(-50%);
}
#usage{
    width: 400px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#usage_name_label::after {
    content: "必須";
    background-color: red;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    min-width: 10px;
    padding: 3px 7px;
    margin: 0px 5px;
    line-height: 16px;
    white-space: nowrap;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    position: relative;
    top: 1.25vh;
    transform: translateY(-50%);
}
#dvPassport{
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
}
#point-flex{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    margin-top: 10px;
}
#point-target{
    padding-top: 10px;
    padding-bottom: 10px;
}
#point-card{
    width: 200px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#point-detail-title{
    padding-top: 10px;
    padding-bottom: 10px;
}
#point-detail{
    width: 700px;
    height: 15vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#postcode{
    width: 200px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#prefecture{
    width: 200px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#address1{
    width: 700px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#address1_name_label::after {
    content: "必須";
    background-color: red;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    min-width: 10px;
    padding: 3px 7px;
    margin: 0px 5px;
    line-height: 16px;
    white-space: nowrap;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    position: relative;
    top: 1.25vh;
    transform: translateY(-50%);
}
#address2{
    width: 700px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#address2_name_label::after {
    content: "必須";
    background-color: red;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    min-width: 10px;
    padding: 3px 7px;
    margin: 0px 5px;
    line-height: 16px;
    white-space: nowrap;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    position: relative;
    top: 1.25vh;
    transform: translateY(-50%);
}
#address3{
    width: 700px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#access{
    width: 700px;
    height: 10vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#dvParking{
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
}
#parking-detail-title{
    padding-top: 10px;
    padding-bottom: 10px;
}
#parking-detail{
    width: 700px;
    height: 15vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#tel{
    width: 700px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#homepage{
    width: 700px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
/*営業時間*/
.opening-times{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: start;
}
.opening-times span{
    padding-top: 14px;
}
#monday{
    margin-top: 15px;
}
#sunday{
    margin-bottom: 15px;
}
.c-formBusinessTimesTime{
    width: 150px;
    position: relative;
    margin-bottom: 10px;
}
.c-formBusinessTimesTime_label{
    position: absolute;
    font-size: 12px;
    padding: 0 5px;
    line-height: 1;
    top: -5px;
    left: 10px;
    color: #888;
    background-color: #fff;
    z-index: 1;
}
.c-formBusinessTimesTime input{
    border: 3px solid #eee;
    border-radius: 8px;
    background: none;
    display: inline-block;
    box-sizing: border-box;
    vertical-align: middle;
    width: 100%;
    padding: 14px;
    appearance: none;
    outline: none;
    margin-bottom: 5px;
}
.closed-day{
    padding-top: 14px;
    padding-left: 32px;
}
.closed-day-php{
    padding-left: 32px;
}
.notes{
    font-weight: normal;
    font-size: 14px;
    margin-bottom: 15px;
    padding-left: 15px;
    text-align: left;
}
/*営業時間補足*/
#supplement{
    width: 700px;
    height: 10vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
/*月定休日*/
.formItem{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: start;
}
.js-list__item{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: start;
}
.c-formSelect select{
    border: 3px solid #eee;
    border-radius: 8px;
    background: none;
    display: inline-block;
    box-sizing: border-box;
    vertical-align: middle;
    width: 50px;
    padding: 14px;
    appearance: none;
    outline: none;
    margin-bottom: 15px;
}
.formItem span{
    padding-top: 14px;
}
.week{
    margin-left: 15px;
}
.js-add-btn{
    margin-left: 19px;
    margin-bottom: 15px;
    border: 3px solid #02ab2f;
    border-radius: 8px;
    height: 30px;
    color: #fff;
    background-color: #02ab2f;
    cursor: pointer;
}
.js-delete-btn{
    margin-left: 25px;
    margin-bottom: 15px;
    margin-top: 11px;
    border: 3px solid #02ab2f;
    border-radius: 8px;
    height: 30px;
    color: #fff;
    background-color: #02ab2f;
    cursor: pointer;
}
/*不定期な休業日*/
#closed-supplement{
    width: 700px;
    height: 10vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
    margin-bottom: 15px;
}
/*事前連絡*/
#dvAdvance{
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
}
#advance-title{
    padding-top: 10px;
    padding-bottom: 10px;
    font-weight: bold;
}
#advance-notice{
    width: 700px;
    height: 15vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
.advance-radio{
    margin-bottom: 20px;
}
/*常設スポット無し*/
#extra-spot{
    margin-bottom: 15px;
}
.c-form_helpText{
    font-size: 14px;
    justify-content: left;
}
/* 臨時休業・短縮営業・閉業情報 */
#completely-closed{
    width: 700px;
    height: 10vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
    margin: 15px 0;
}
#closed-reference{
    width: 700px;
    height: 7vh;
    margin-bottom: 20px;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}

/*資源物情報*/
#resource_title{
    position: relative;
    left: 0;
    bottom: -25px;
}
.tab-area {
    padding-left: 0;
    list-style-type: none;
    display: flex;
    cursor: pointer;
}
.tab{
    width: calc(900px/6);
    padding: 10px;
    text-align: center;
    font-weight: bold;
    color: #888;
    background-color: #fafafa;
}
.tab:nth-child(1){
    border-radius: 8px 0 0 8px;
}
.tab:nth-child(6){
    border-radius: 0 8px 8px 0;
}
.tab:nth-child(n+2){
    border-left: 2px solid #e6e6e6;
 }
.tab.active{
    background-color: #000;
    color: #fff;
}
.panel{
    display: none;
    text-align: center;
}
.panel.active{
    display: block;
}
/*金属類*/
.resource_select{
    width: 200px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
.resource_label{
    margin-right: 20px;
}
.metal-repro{
    width: 350px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#what-will-it-be{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
#metal-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#what-will-it-be-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#warning{
    height: 180px;
}
#notice_table{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 180px;
}
#notice_title{
    margin-bottom: 5vh;
}
.resource_notice{
    width: 600px;
    height: 150px;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#js-add-metal{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    width: 400px;
    border-radius: 8px;
    cursor: pointer;
}
.js-metal-delete-btn{
    color: #fff;
    background:#02ab2f;
    padding:0.5em 0.5em;
    border: none;
    font-size: 16px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 200px;
    border-radius: 8px;
    cursor: pointer;
}
.addtable{
    border-top: 5px solid #e6e6e6;
}
/*古紙類*/
#paper-repro{
    width: 350px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#what-will-it-be-paper{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
#paper-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#what-will-it-be-paper-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#js-add-paper{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    width: 400px;
    border-radius: 8px;
    cursor: pointer;
}
.js-paper-delete-btn{
    color: #fff;
    background:#02ab2f;
    padding:0.5em 0.5em;
    border: none;
    font-size: 16px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 200px;
    border-radius: 8px;
    cursor: pointer;
}
#notice_table_paper{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 180px;
}
/*プラスチック*/
#plastic-repro{
    width: 350px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#what-will-it-be-plastic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
#plastic-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#what-will-it-be-plastic-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#js-add-plastic{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    width: 400px;
    border-radius: 8px;
    cursor: pointer;
}
.js-plastic-delete-btn{
    color: #fff;
    background:#02ab2f;
    padding:0.5em 0.5em;
    border: none;
    font-size: 16px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 200px;
    border-radius: 8px;
    cursor: pointer;
}
#notice_table_plastic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 180px;
}
/*ガラス類*/
#glass-repro{
    width: 350px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#what-will-it-be-glass{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
#glass-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#what-will-it-be-glass-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#js-add-glass{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    width: 400px;
    border-radius: 8px;
    cursor: pointer;
}
.js-glass-delete-btn{
    color: #fff;
    background:#02ab2f;
    padding:0.5em 0.5em;
    border: none;
    font-size: 16px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 200px;
    border-radius: 8px;
    cursor: pointer;
}
#notice_table_glass{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 180px;
}
/*布・木・油*/
#nature-repro{
    width: 350px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#what-will-it-be-nature{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
#nature-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#what-will-it-be-nature-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#js-add-nature{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    width: 400px;
    border-radius: 8px;
    cursor: pointer;
}
.js-nature-delete-btn{
    color: #fff;
    background:#02ab2f;
    padding:0.5em 0.5em;
    border: none;
    font-size: 16px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 200px;
    border-radius: 8px;
    cursor: pointer;
}
#notice_table_nature{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 180px;
}
/*家電製品*/
#appliances-repro{
    width: 350px;
    height: 7vh;
    border: none;
    outline: solid 3px #e6e6e6;
    border-radius: 10px;
}
#what-will-it-be-appliances{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
#appliances-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#what-will-it-be-appliances-pic{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 300px;
}
#js-add-appliances{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    width: 400px;
    border-radius: 8px;
    cursor: pointer;
}
.js-appliances-delete-btn{
    color: #fff;
    background:#02ab2f;
    padding:0.5em 0.5em;
    border: none;
    font-size: 16px;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 200px;
    border-radius: 8px;
    cursor: pointer;
}
#notice_table_appliances{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    height: 180px;
}

/*画像アップロード*/
#picture_title{
    position: relative;
    left: 0;
    bottom: -25px;
}

/*メイン画像登録フォーム*/
.drop-area {
    border: 3px dashed #C8C8C8 !important;
    background-color: #F0F0F0 !important;
    border-radius: 5px;
    padding: 20px;
    height: 250px;
    text-align: center;
}
.pic_copywrite{
    color: #909090;
}
.drop-area label {
    width: 100%;
    display: inline-block;
}
.drop-area label:hover {
    cursor: pointer;
}
.drop-area label input {
    display: none;
}
.drop-area label svg {
    width: 50px;
    fill: currentColor;
    color: #909090;
}
.drop-area label .preview-area {
    width: 100%;
    margin: 15px auto;
    height: 130px;
}
.drop-area label .preview-area img {
    height: 100%;
    max-width: 100%;
    width: auto;
}

/*サブ画像登録フォーム*/
.picture-flex{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}
.sub-picture_title{
    margin: 10px;
}
.drop-area-sub {
    border: 3px dashed #C8C8C8 !important;
    background-color: #F0F0F0 !important;
    border-radius: 5px;
    margin: 0 1.5px 1.5px 1.5px;
    padding: 20px;
    width: 250px;
    height: 250px;
    text-align: center;
}
.pic_copywrite-sub{
    color: #909090;
}
.drop-area-sub label {
    width: 100%;
    display: inline-block;
}
.drop-area-sub label:hover {
    cursor: pointer;
}
.drop-area-sub label input {
    display: none;
}
.drop-area-sub label svg {
    width: 50px;
    fill: currentColor;
    color: #909090;
}
.drop-area-sub label .preview-area {
    width: 40%;
    margin: 15px auto;
    height: auto;
}
.drop-area-sub label .preview-area-sub img {
    height: 40%;
    max-width: 40%;
    width: auto;
}
.php-preview-sub{
    width: 300px;
    height: 300px;
    text-align: center;
}
.sub-caption{
    width: 290px;
    height: 25px;
    border: none;
    outline: 2px solid #C8C8C8 !important;
    border-radius: 5px;
    text-align: left;
    margin-top: 5px;
    margin-left: 3px;
    margin-right: 3px;
}
.caption-x{
    font-weight: bold;
    font-size: 14px;
    margin: 0 auto 20px;
    border: none;
    outline: 2px solid #C8C8C8 !important;
    border-radius: 5px;
    width: fit-content;
    /* 1. 通常の単語の途中で改行を許可 */
    overflow-wrap: break-word; 
    /* または word-wrap: break-word; (古いブラウザとの互換性のため) */
        
    /* 2. 特に長いURLや英数字の塊でも強制的に改行させる */
    word-break: break-all;
        
    /* 3. 親要素の幅を明示的に設定（既に設定されている場合は確認） */
    width: 290px; 
}

/*確認画面遷移ボタン*/
.button{
    color: #fff;
    background:#02ab2f;
    padding:1em 1em;
    border: none;
    font-size: 17px;
    font-weight: bold;
    display:flex;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 400px;
    border-radius: 1em;
    cursor: pointer;
}

/* =========================================================
   input.php スマホ対応
   input.css の末尾にそのまま追記
========================================================= */
@media screen and (max-width: 767px) {

  html,
  body {
    overflow-x: hidden;
  }

  main {
    overflow-x: hidden;
  }

  /* ==========================
     上部説明エリア
  ========================== */
  #request,
  #request2,
  #input_flow {
    width: calc(100% - 20px);
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
  }

  #request,
  #request2 {
    margin-top: 16px;
    margin-bottom: 16px;
    padding: 24px 12px;
    border-radius: 24px;
  }

  #request h1,
  #request2 h1 {
    font-size: 28px;
    line-height: 1.4;
    margin-top: 0;
    margin-bottom: 14px;
  }

  #top_message {
    font-size: 14px;
    line-height: 1.9;
  }

  #input_flow {
    margin-top: 12px;
    margin-bottom: 28px;
    padding: 18px 12px;
    border-radius: 24px;
    font-size: 14px;
    line-height: 1.8;
  }

  /* ==========================
     フォーム共通ラッパ
  ========================== */
  .basic,
  .basic_view_confirm,
  .basic_view_spot {
    width: 100%;
    max-width: none;
    margin-top: 24px;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box;
  }

  .basic_view_confirm {
    margin-top: 24px;
  }

  #basic_title,
  #resource_title {
    position: static;
    left: auto;
    top: auto;
    bottom: auto;
    margin: 0 0 10px;
    font-size: 22px;
    line-height: 1.5;
  }

  .info {
    margin-top: 0;
    padding: 24px 12px 28px;
    border-radius: 24px;
    box-sizing: border-box;
    overflow: hidden;
  }

  .info > h3 {
    font-size: 15px;
    line-height: 1.9;
    word-break: break-word;
  }

  /* ==========================
     テーブルを縦積み化
  ========================== */
  .info_table,
  .info_table tbody,
  .info_table tr,
  .info_table th,
  .info_table td,
  .c-formTable_th,
  .c-formTable_td {
    display: block;
    width: 100% !important;
    min-width: 0;
    box-sizing: border-box;
  }

  .info_table {
    border-spacing: 0;
  }

  .info_table tr {
    margin-bottom: 18px;
    padding-bottom: 18px;
    border-bottom: 1px solid #e6e6e6;
  }

  .info_table tr:last-child {
    margin-bottom: 0;
  }

  .c-formTable_th {
    height: auto;
    margin-bottom: 10px;
    padding: 0;
    border-bottom: none;
    text-align: left;
    font-size: 16px;
    line-height: 1.6;
  }

  .c-formTable_td {
    height: auto;
    padding: 0;
    border-bottom: none;
    text-align: left;
  }

  .c-formText {
    width: 100%;
    box-sizing: border-box;
  }

  /* ==========================
     必須ラベルの位置補正
  ========================== */
  #facility_name_label::after,
  #type_name_label::after,
  #usage_name_label::after,
  #address1_name_label::after,
  #address2_name_label::after {
    position: static;
    top: auto;
    transform: none;
    margin-left: 6px;
    font-size: 10px;
    line-height: 1;
    padding: 4px 7px;
    vertical-align: middle;
  }

  /* ==========================
     入力欄共通
  ========================== */
  #facility_name,
  #type,
  #usage,
  #point-card,
  #postcode,
  #prefecture,
  #address1,
  #address2,
  #address3,
  #access,
  #point-detail,
  #parking-detail,
  #tel,
  #homepage,
  #supplement,
  #closed-supplement,
  #advance-notice,
  #completely-closed,
  #closed-reference,
  .resource_select,
  .metal-repro,
  #paper-repro,
  #plastic-repro,
  #glass-repro,
  #nature-repro,
  #home-electric-repro,
  .resource_notice,
  .sub-caption,
  .button {
    width: 100% !important;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  #facility_name,
  #type,
  #usage,
  #point-card,
  #postcode,
  #prefecture,
  #address1,
  #address2,
  #address3,
  #tel,
  #homepage,
  #closed-reference,
  .resource_select,
  .metal-repro,
  #paper-repro,
  #plastic-repro,
  #glass-repro,
  #nature-repro,
  #home-electric-repro {
    height: 48px;
    font-size: 16px;
  }

  #access,
  #point-detail,
  #parking-detail,
  #supplement,
  #closed-supplement,
  #advance-notice,
  #completely-closed,
  .resource_notice {
    min-height: 120px;
    height: auto;
    padding: 12px;
    font-size: 16px;
    line-height: 1.7;
  }

  /* ==========================
     ラジオ・補助説明
  ========================== */
  .radio-list {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 16px;
    align-items: center;
  }

  .c-form_helpText,
  .notes {
    font-size: 13px;
    line-height: 1.8;
  }

  .notes {
    margin-top: 12px;
    padding-left: 18px;
  }

  /* ==========================
     ポイント付与 / 駐車場 / 事前連絡
  ========================== */
  #dvPassport,
  #dvParking,
  #dvAdvance {
    margin-top: 12px;
  }

  #point-flex {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 10px;
  }

  #point-target,
  #point-detail-title,
  #parking-detail-title,
  #advance-title {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 14px;
    line-height: 1.7;
  }

  /* ==========================
     営業時間
  ========================== */
  .opening-times {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 12px 0;
    border-bottom: 1px solid #f1f1f1;
  }

  .opening-times:last-of-type {
    border-bottom: none;
  }

  .opening-times > span {
    padding-top: 0;
    font-weight: bold;
    font-size: 15px;
    line-height: 1.5;
  }

  .c-formBusinessTimesTime {
    width: 100%;
    margin-bottom: 0;
  }

  .c-formBusinessTimesTime_label {
    left: 12px;
    font-size: 11px;
  }

  .c-formBusinessTimesTime input {
    width: 100%;
    padding: 14px 12px;
    font-size: 16px;
  }

  .closed-day,
  .closed-day-php {
    padding-top: 0;
    padding-left: 0;
  }

  /* ==========================
     月定休日
  ========================== */
  .formItem,
  .js-list__item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
  }

  .formItem span,
  .js-list__item span {
    padding-top: 0;
    font-size: 14px;
    line-height: 1.5;
  }

  .c-formSelect select {
    width: 70px;
    padding: 12px 8px;
    margin-bottom: 0;
    font-size: 16px;
  }

  .week {
    margin-left: 0;
  }

  .js-add-btn,
  .js-delete-btn {
    margin-left: 0;
    margin-top: 12px;
    margin-bottom: 0;
    min-height: 40px;
    padding: 0 14px;
    font-size: 14px;
  }

  /* ==========================
     特記事項
  ========================== */
  #extra-spot {
    margin-bottom: 0;
  }

  .reference {
    font-size: 13px;
    line-height: 1.8;
    word-break: break-word;
  }

  /* ==========================
     資源物タブ
  ========================== */
  .tab-area {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-left: 0;
    margin: 0 0 16px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .tab-area::-webkit-scrollbar {
    display: none;
  }

  .tab {
    flex: 0 0 auto;
    width: auto;
    min-width: 110px;
    padding: 10px 12px;
    font-size: 13px;
    line-height: 1.4;
    border-radius: 10px !important;
    border-left: none !important;
  }

  /* ==========================
     パネル
  ========================== */
  .panel {
    text-align: left;
  }

  .panel.active {
    display: block;
  }

  /* ==========================
     再生後は / 注意事項 / 画像欄
  ========================== */
  #what-will-it-be,
  #what-will-it-be-paper,
  #what-will-it-be-plastic,
  #what-will-it-be-glass,
  #what-will-it-be-nature,
  #what-will-it-be-home-electric,
  #metal-pic,
  #paper-pic,
  #plastic-pic,
  #glass-pic,
  #nature-pic,
  #home-electric-pic,
  #what-will-it-be-pic,
  #what-will-it-be-paper-pic,
  #what-will-it-be-plastic-pic,
  #what-will-it-be-glass-pic,
  #what-will-it-be-nature-pic,
  #what-will-it-be-home-electric-pic,
  #notice_table,
  #notice_table_paper,
  #notice_table_plastic,
  #notice_table_glass,
  #notice_table_nature,
  #notice_table_home-electric {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    height: auto !important;
  }

  #warning,
  #warning_paper,
  #warning_plastic,
  #warning_glass,
  #warning_nature,
  #warning_home-electric {
    height: auto !important;
  }

  .resource_label {
    display: inline-block;
    margin-right: 0;
    font-size: 14px;
    line-height: 1.7;
  }

  /* ==========================
     画像アップロード
  ========================== */
  .drop-area-sub {
    width: 100%;
    height: auto;
    min-height: 220px;
    margin: 0;
    padding: 16px 12px;
    box-sizing: border-box;
    border-radius: 12px;
  }

  .pic_copywrite-sub {
    font-size: 13px;
    line-height: 1.7;
    word-break: break-word;
  }

  .drop-area-sub label svg {
    width: 42px;
    margin-top: 8px;
  }

  .drop-area-sub label .preview-area {
    width: 70%;
    margin: 12px auto;
  }

  .drop-area-sub label .preview-area-sub img {
    max-width: 70%;
    height: auto;
  }

  .php-preview-sub {
    width: 100%;
    height: auto;
  }

  .sub-caption {
    width: 100% !important;
    height: 40px;
    margin: 8px 0 0;
    font-size: 14px;
  }

  .caption-x {
    width: 100%;
    margin: 8px 0 16px;
    font-size: 13px;
    line-height: 1.7;
  }

  .picture-flex {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .sub-picture_title {
    margin: 0 0 8px;
    font-size: 14px;
    line-height: 1.6;
  }

  /* ==========================
     追加・削除ボタン
  ========================== */
  #js-add-metal,
  #js-add-paper,
  #js-add-plastic,
  #js-add-glass,
  #js-add-nature,
  #js-add-home-electric,
  .js-metal-delete-btn,
  .js-paper-delete-btn,
  .js-plastic-delete-btn,
  .js-glass-delete-btn,
  .js-nature-delete-btn,
  .js-home-electric-delete-btn,
  .button {
    display: block;
    width: 100% !important;
    max-width: 100%;
    box-sizing: border-box;
    min-height: 48px;
    font-size: 16px;
    margin-left: 0;
    margin-right: 0;
  }

  .js-metal-delete-btn,
  .js-paper-delete-btn,
  .js-plastic-delete-btn,
  .js-glass-delete-btn,
  .js-nature-delete-btn,
  .js-home-electric-delete-btn {
    margin-top: 14px;
    margin-bottom: 12px;
  }

  .button {
    justify-content: center;
    margin-top: 20px;
    margin-bottom: 20px;
    border-radius: 14px;
  }

  .addtable {
    border-top-width: 3px;
    margin-top: 20px;
    padding-top: 12px;
  }

  /* 画像プレビューの中央揃え */
  .drop-area-sub label {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .preview-area-sub {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 12px auto 0;
    text-align: center;
  }

  .preview-area-sub img,
  .preview-area-sub canvas,
  .preview-area-sub .php-preview-sub {
    display: block;
    margin-left: auto;
    margin-right: auto;
  }

  .drop-area-sub label .preview-area-sub img {
    max-width: min(240px, 70%);
    height: auto;
  }
}