/* MFP Default CSS - add */

/* mailformpro.cssから下記コメントアウト */
/*.mfp_element_text,
.mfp_element_number,
.mfp_element_select-one,
.mfp_element_email,
.mfp_element_tel,
.mfp_element_textarea,
.mfp_element_date,
.mfp_element_password {
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	padding: 3px 8px;
	margin: 2px;
	vertical-align: middle;
}*/

/* MFP Default CSS に追記していたもの */
#mfp_warning{
	/* display:none !important; */
}

.mfp_element_all {
	margin-bottom:10px;
	margin-top:10px;
}

label {
	white-space: inherit !important;
}

.must{
      padding: 1px 5px;
      height: fit-content;
}
.mustbot{
      transform: translate3d(0, 50%, 0);
}

.keisan {
  border: none;
  font-size: .9rem;
  padding: 0.5em 1em;
  border-radius: 5px;
}

.calcBtnAndResuBox .keisan{
  margin: 0;
}

.calcBtnAndResuBox h4{
  border-bottom: 1px solid #595959;
  margin-block-end: 0;
  padding-bottom: .5em;
  font-weight: bold;
}

.calcBtnAndResuBox{
  padding: 0.8em;
  margin-top: 0.5em;
  border-radius: 4px;
  border: 1px dotted #595959;
  background-color: #ffffe7;
  padding: 10px;
  margin-top: 16px;
}


.calcBtnAndResuBox .asteriskExplanation{
  font-size: .8rem;
  padding-bottom: 0;
}

.sec3-CDS-3__kanaWrap{
  border-top: 1px solid #595959;
  margin-top: 1.5rem;
  padding: 1rem 0 ;
  
}
.flex{
  display: flex;
  align-items: center;
}

/* ▼ */
.triangle_under{
  width: 100px;
  height: 25px;
  margin: 1rem auto;
  background-color: #7e7e7e;
  clip-path: polygon(0% 0, 50% 100%, 100% 0%);
}

/* zentai */
h2 {
    width: 100%;
    background: #a9a9a9;
    text-align: center;
    font-size: 20px;
    color: white;
    margin-bottom: 10px;
    padding: 10px;
    margin-top: 0px;
}

h4 {
    font-size: 15px;
}

.secItemContent .secItemContent:not(:first-child) {
	font-size: 15px;
  margin-bottom: 1rem;
} 

input, select,label {
    font-size: 15px;
}

/* color */
.colorBlue {
  color: #0563C1;
}

.u-line {
	text-decoration: underline solid #000000;
}



/* Responsive */
.pc-hidden{
	display:none;  /*パソコンで非表示*/
}
.pc-open{
	display:inline;/*パソコンで表示*/
}

/*sumaho改行　<br class="sp-open pc-hidden">*/
@media (max-width:767px){
	.sp-hidden{
		display:none;/*スマホで非表示*/
	} 	
	.sp-open{
		display:inline;/*スマホで表示*/
	}

	.yohaku-s{
		margin-left:0em !important;
	}
}
.readonly{
  background-color: rgb(248, 248, 248);
  border: solid 1px #CCC;
}

/*sec3----------------------------------------------- */

/*以下イメージViewer----------------------------------------------- */

.subpage{
  background-color: #888;
  min-height: 100vh;
}

.subpage-pdf-area{
  transform-origin: top center;
  transition: transform 0.2s;
  text-align: center;
}

.pdf-image {
  width: 80%;
  display: inline-block;
  margin: 0 auto;
}
@media (max-width:767px){
  .pdf-image {
    display: block;
    width: 100%;
    margin: 0 auto;
  }
}

.zoom-controls {
  position: fixed;
  bottom: 10px;
  right: 10px;
  background: rgba(0,0,0,0.5);
  padding: 5px;
  border-radius: 8px;
}

.zoom-controls button {
  font-size: 18px;
  margin: 0 3px;
  padding: 5px 10px;
  cursor: pointer;
}


/* margin */
.mt-0 {
  margin-top: 0;
}

.mt-0_5rem {
  margin-top: 0.5rem;
}

.mt-1rem {
  margin-top: 1rem;
}

.mt-1_5rem {
  margin-top: 1.5rem;
}

.mt-2rem {
  margin-top: 2rem;
}

.ml-0_5rem {
  margin-left: 0.5rem;
}

.ml-1rem {
  margin-left: 1rem;
}

.ml-1_5rem {
  margin-left: 1.5rem;
}

.ml-2rem {
  margin-left: 2rem;
}

.mb-0_5rem {
  margin-bottom: 0.5rem;
}

.addInfoWaku{
	border-top: #ccc 1px dashed;
	border-bottom: #ccc 1px solid;
	margin-top: .5rem;
	padding: 1rem .5rem .5rem;
}


.swal-modal{
  width: 90% !important;
  max-width: 550px;
}


.table#mfp_confirm_table tr th{
  width: 100% !important;
  white-space: normal !important;
}


.sec3 input[type="text"]{
  max-width: 42px;
}
