/* common css */

.flex-box{
  display: flex;
  flex-wrap: wrap;
  justify-content:space-between;
  align-items:center;
  gap: 20px;
  padding: 20px;
}

/* 共通ベーススタイル（余白調整など） */
ul.listmark-y li,
ul.listmark-g li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 0.8em;
  list-style: none;
}

ul.listmark-y li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em; 
  width: 10px;
  height: 10px;
  background-color: #fcc800;
  border-radius: 50%;
}

ul.listmark-g li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em; 
  width: 10px;
  height: 10px;
  background-color: #8ca735;
  border-radius: 50%;
}

/* cost */

#cost li{
	margin-bottom:0;
}

#cost .con04 .box{
	border:solid 1px #010101;
    margin: 30px 0 0 0;
}

#cost .con04 h5{
    margin: 0 0 0 20px;
}

#cost .con04 .box ul {
	padding: 10px 30px;
}

#cost .con05 h5,
#cost .con06 h5{
	position:relative;
    padding-left: 25px;
        font-size: 16px;
        font-weight: bold;
	margin-top:15px;
}

#cost .con06 h5.sub-ttl:before{
    content: '■';
    position: absolute;
    bottom: 0;
    top: 5px;
    left: 7px;
    font-size: 12px;
    color: #00B9E7;
    display: block;
}

#cost .flex-box01,
#cost .flex-box02{
	display:flex;
    justify-content: space-evenly;
	align-items: center;
	margin: 15px auto 30px;
}

#cost .flex-box01 > p,
#cost .flex-box02 > p{
	font-size:30px;
	font-weight:bold;
}

#cost .flex-box01 .flex-item ,
#cost .flex-box02 .flex-item{
	display:flex;
	align-items:center;
	justify-content:center;
	width: 170px;
    height: 170px;
    vertical-align: middle;
    border: 2px solid #00B9E7;
    margin: 0;
    color: #00B9E7;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    box-sizing: border-box;
    letter-spacing: normal;
}

#cost .flex-box01 .flex-item:last-child,
#cost .flex-box02 .flex-item:first-child{
   color: #ffffff;
   font-size: 20px;
   background: #00B9E7;
}

#cost .con05 span,
#cost .con06 span{
	font-size: 16px;
}

@media screen and (max-width: 900px) {	
  #cost .symbol-minus {
    position: relative;
  }

  #cost .symbol-minus::before {
        content: '引く';
        position: absolute;
        top: 9px;
        left: 50%;
        transform: translateX(-50%);
        font-size: 10px;
        color: #333;
        white-space: nowrap;
  }

  #cost .flex-box01,
  #cost .flex-box02 {
    flex-direction: column;
  }

  #cost .flex-box01 .flex-item,
  #cost .flex-box02 .flex-item {
    width: 80%;
	max-width: 400px;
    height: auto;
    min-height: 100px;
    padding: 20px;
	font-size: 16px;
}
	
#cost .flex-box01 .flex-item:last-child,
#cost .flex-box02 .flex-item:first-child{
    font-size: 16px;
}
	
	#cost .con05 span, #cost .con06 span {
    font-size: 12px;
}
}
	
@media screen and (max-width: 468px) {	
	  #cost h4.sub-ttl {
        font-size: 16px;
    }

	#cost h5.sub-ttl {
        font-size: 14px;
		        margin-top: 10px;
    }
	
	#cost .con04 .box ul{
	    padding: 10px 15px;
		font-size:12px;
}
	
	#cost .con06 h5.sub-ttl:before {
    content: '■';
    position: absolute;
    bottom: 0;
    top: 5px;
    left: 10px;
    font-size: 10px;
    color: #00B9E7;
    display: block;
}
}	



/*スタッフ紹介*/

.staff-mem{
    padding: 100px 0px;
}

section#takeuchidr {
    background: #fffcea;
}
section#aimudr {
    background: #fafff7;
}
section#hosoidr {
    background: #fffcea;
}

section#watanabedr {
    background: #fafff7;
}
section#ukaidr {
    background: #fffcea;
}

section#ukaidr {
    background: #fffcea;
}
section#nakamuradr {
    background: #fafff7;
}

section#yamakawadr {
    background: #fffcea;
}


.circle-text {
  font-weight: bold;
  font-family: sans-serif;
}

/*.line {
  display: flex;
  margin-bottom: 12px;
}*/

.line span {
  display: inline-flex;
  align-items: center;
  justify-content:center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  color: white;
  font-size: 30px;
  margin-left: -6px; /* ← ここで重ね具合を調整 */
  z-index: 1;
  position: relative;
}

/* 最初の文字だけ margin なくす */
.line span:first-child {
  margin-left: 0;
}

.orange span {
  background-color: lab(68 34.79 83.24 / 0.7);;
}

.green span {
    background-color: lab(40 -26.99 -7.34 / 0.78);
}

p.name-en {
    color: #fcc800;
    display: inline-block;
    letter-spacing: 3px;
    margin: 5px;
}
p.position {
    font-weight: 600;
    letter-spacing: 2px;
    margin-bottom: 10px;
    color: #606060;
}



@media screen and (max-width: 750px) {
.staff-mem{
	padding: 60px 0px 50px 0px;
}	
.line span {
  width: 60px;
  height: 60px;
  font-size: 20px;
}
p.name-en {
	font-size:13px;
}	
}	


/*略歴*/

.step-flow {
  border-left: 3px solid #c0d3cf;
  margin: 40px auto;
  max-width: 800px;
  margin-left: 60px;	
}

.step-item {
  position: relative;
  margin-bottom: 5px;
  margin-left: 0px;	
}

.step-number {
  position: absolute;
  left: -50px;
  top: 0;
  width: 100px;
  height: 30px;
  background-color: #006b6a;
  color: white;
  font-size: 16px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.step-content {
  margin: 0 0 0px 90px;
  font-size: 16px;
  font-weight: 500;
  color: #333;
  line-height: 1.8;
}

@media screen and (max-width: 960px) {	
.step-content {
  font-size: 14px;
  font-weight: 500;
}
}

@media screen and (max-width: 760px) {	
.step-flow {
    border-left: 3px solid #c0d3cf;
    margin: 30px 0px 0px 30px;
    max-width: unset;
}
.step-content {
  margin: 0 0 0px 0px;	
  font-size: 14px;
  line-height: 1.5;
}
.step-number {
    left: -90px;
    top: -2px;
	width: 70px;
    height: 25px;
    color: white;
    font-size: 14px;
}
.step-item {
	margin: 5px 5px 9px 55px;
}	
}


.staff-wrap {
    display: flex;
    justify-content: space-between;	
}
.staff-img{
    width:30%;
}
.staff-img {
    display: flex;
    flex-direction: column;
}
.staff-contents{
	width:65%;
}
.staff-text-box {
    display: flex;
    justify-content: space-between;
}
.shikaku {
    width: 30%;
}
.keireki {
    width: 65%;
}
.syumi{
    width: 48%;
}
.hitokoto{
  width: 48%;
  font-size: 16px;	
  font-weight: 500;		
}

.counseling-content h4 {
    color: #006b6a;
    font-weight: 600;
}

p.position {
    font-size: 20px;	
    font-weight: 600;
    letter-spacing: 2px;
    margin-bottom: 5px;
    color: #606060;
    text-align: center;
}
.circle-text {
    font-weight: bold;
    font-family: sans-serif;
    text-align: center;
}



@media screen and (max-width: 1200px) {	
.staff-wrap {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
}
.staff-img p {
        text-align: center;
}	
.staff-img {
    width: 100%;
}
.staff-contents {
    width: 100%;
}
}	



@media screen and (max-width: 760px) {	
p.position {
    font-size: 14px;	
}	
.staff-wrap {
    flex-direction: column;
    justify-content: space-between;
}
.staff-img{
    width:100%;
	flex-direction: column;
    justify-content: space-between;	
    align-items: center;	
}
.staff-img p {
        width: 70%;
}
/*.staff-img img {
    width: 100%;
	height: fit-content;
}	*/
.staff-contents{
	width:100%;
}
.staff-text-box {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
	gap: 40px;
	margin-top: 40px;
}
.shikaku {
	width: 100%;
}
.keireki {
	width: 100%;
}	
.syumi{
    width: 100%;
}
.hitokoto{
    width: 100%;
  font-size: 14px;		
}
}	


.list01 ul {
  font-size: 16px;	
  list-style: disc;
  font-weight: 500;	
}
.list01 {
    padding-left: 30px;
}
.list01 ul ::marker {
    color: #fed60c;
}


ul.list04 li {
  list-style: circle;
  font-weight: 500;	
}
.list04 {
    padding-left: 20px;
}
.list04 ul ::marker {
    color: #fed60c;
}

@media screen and (max-width: 760px) {	
.list01 ul {
  font-size: 14px;	
}
}



/*メッセージ*/
.counseling-box {
  border: 2px solid #fcc800;
  border-radius: 12px;
  padding: 60px 90px 30px;
  position: relative;
  background: #fff;
  position: relative;
  background: #fff;	
  text-align: center;
  margin: 40px auto;
}

.ribbon {
  position: absolute;
  top: -25px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #fcc800;
  color: #fff;
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 5px;	
  padding: 8px 40px;
  border-radius: 999px;
  white-space: nowrap;
  z-index: 1;
}

.counseling-content {
  font-size: 18px;
  text-align:left;	
  font-weight: 500;
  margin-bottom: 20px;
  color: #333;
}

@media screen and (max-width: 760px) {	
.counseling-box {
  padding: 40px 20px;
}
.counseling-content {
	font-size: 15px;
}
.ribbon {
  top: -25px;
  font-size: 18px;
  letter-spacing: 5px;	
  padding: 8px 40px;
}	
}		