@charset "UTF-8";
/* CSS Document */
*,*::before,
*::after{
	box-sizing: border-box;
}

html{
	font-style: 62.5%;
	height: 100%;
}

.wrapper {
		padding: 0 20px;
}

body {
	width: 100vw;
	font-size: 1rem;
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
	line-height: 1.7;
	background: #fefdee;
	color: #402021;
    font-style: normal;
    text-align: center;
    -webkit-text-size-adjust: 100%;
	margin: auto;
	
}


img {
	max-width: 100%;
	height: auto;
	margin: auto;
}

header {
	margin-bottom: 150px;
}

 a:link,a:visited,a:hover,a:active {
	color: #fff;
	text-decoration: none;	
}


a:hover {
	transition: 0.3s;
	
}

h1 {
	font-size: 2rem;
	margin: 0px auto 50px;

}

p {
	text-align: left;
	line-height: 2;
}


.main-text {
	margin: 0px auto 100px;
	padding: 0 10px;
}

.main-text-p,
.main-text-p-center {
	text-align: center;
}



.campaign-present {
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 3.5rem;
	text-align: left;
	margin: 20px auto ;
}

.campaign-present-img {
	margin-top: 30px;
	
}


.page-link-button {
	width: 180px;
	color: #fff;
	background:  #402021;
	line-height: 2rem;
	border-radius: 5px;
	margin: 20px auto;
	margin-right:0;
}

h3 {
	width: 300px;
	color: #fff;
	background: #402021;
	font-size: 1.5rem;
	line-height: 3.5rem;
	font-weight: bold;
	text-align: center;
	border-radius: 35px;
	margin: 0 auto 20px;
	
}

h3:hover{
	color: #402021;
	background: #fff;
	transition: 0.3s;
}




.content-title {
	margin-bottom: 20px;
}

.campaign-list {
	max-width: 600px;
	font-size: 1rem;
	margin: 10px auto 100px;
	
}


.campaign-text {
	text-align: center;
}

datails {
	display: block;
}

summary {
	width: 300px;
	font-size: 1.5rem;
	color: #fff;
	background: #402021;
	font-weight: bold;
	line-height: 3.5rem;
	text-align: center;
	transition: 0.3s;
	border-radius: 35px;
	margin: 0 auto 20px;
	
}

.entry-content:hover {
    cursor: pointer; 
	background-color: #fff;
	color: #402021;

}


.entry-rule {
	max-width: 850px;
	text-align: left;
	border: solid #555 1px;
	padding: 2vw;
	margin: 0 auto 12px;
}

.title {
	text-align: left;
}

p.title:nth-child(1) {
	margin-bottom: 30px;
}

p.title:nth-child(2) {
	margin-bottom: 30px;
}

.text {
	padding-left: 3vw;
	margin-top: 0;

}

.ol-text,
.ul-text{
	margin-bottom: 30px;
}


.ul-child {
	padding-top: 10px;
}

.ul-text a {
	color: #4f96f6;
		
}

.ul-text a:hover{
	color: #4f96f6;
	text-decoration: underline;
	transition: 0.3s;
		
}

.entry-button {  
	width: 100%;
	font-size: 1.5rem;
	color: #fff;
	text-align: center;
	font-weight: bold;
    background: #402021;
 	margin: 0 auto;
	padding: 5px;
}

.entry-button:hover {
	color: #402021;
	background: #fff;
	text-decoration: underline;
}

.sp {
	display: none;
}

.button a:hover,
.button-02 a
{
	color: #402021;
}

.button,
.button-02:hover {
	color: #402021;
	text-decoration: underline;

}

.button-02 {
	margin-bottom: 10px;
}
/*---------------------------------神社参拝企画*/

.article-content-title {
	max-width: 850px;
	font-size: 1.5rem;
	text-align: left;
	margin: 0 auto 20px;
	
}

.article-content {
	max-width: 850px;
	text-align: left;
	margin: auto;
	background: #fff;
	padding: 30px;
	margin-bottom: 20px;
}

.article-content p a,
.shrinearticle-text a{
	color: #4f96f6;
	text-decoration: underline;
}

.article-text-content {
	width: 70%;
	text-align: left;
	padding-left: 20px;
}

.shrinearticle-text {
	margin: 1rem auto;
}
s
.article-imgbox {
	max-width: 600px;
	height: 500px;
	margin: auto;

}

.article-imgbox img {
	width: 100%;
	height: 100%;
	object-fit: cover;

}

.article-title {
	font-size: 1.5rem;
	margin:0px auto 5px;
}

.article-subtitle {
	margin-bottom: 20px;
}

.article-button-box {
	max-width:830px;
	
}

.ul-title {
	line-height: 2;
	border: solid 1px;
	padding: 5px;
}

.underline {
	line-height: 2;
	text-decoration: underline;
	text-underline-offset: 5px;

}

.article-img-flex {
	display: flex;
	justify-content: center;
	max-width: 830px;
	width: 50%;
	margin:auto;
	padding: 2px;
}

.article-img {
	max-width: 830px;
	width: 100%;
	margin:auto;

}

.article-button-box img {
	padding: 2px;
}

.article-img img {
	width: 100%;
	padding: 1px;
}

summary.article-button {
	width: 150px;
	height: 40px;
	font-size: 1rem;
	line-height: 2.5rem;
	border-radius: 5px;
	
}

.article-button-box a {
	color: #4f96f6;

}

.height275 img{
	max-height:  260px;
}

/*---------------------------------社長取材企画*/

.flex {
	display: flex;
	align-items:center;

}

.travelarticle-content {
	max-width: 850px;
	text-align: left;
	margin: auto;
	background: #fff;
	padding: 30px;
	margin-bottom: 20px;

}

.travelarticle-title{
	font-size: 1.5rem;
	margin:0px auto 5px;
	
}

.travelarticle-subtitle{
	margin-bottom: 20px;
	
}
.article-imgbox-small {
	width: 30%;

}

.article-imgbox-small img  {
	width: 100%;
	align-content: center;

}

.travelarticle-text-content {
	width: 70%;
	text-align: left;
	padding-left: 20px;

}

.ul {
	padding-left:1rem;
	margin: 0 auto;
}

.article-button {
	display: block;
	width: 150px;
	height: 40px;
	font-size: 1rem;
	text-align: center;
	line-height: 2.5;
	background: #402021;
	border-radius: 5px;
	margin: 0 0 0 auto;
}

.red {
	color: red;
}

.blue {
	color: blue;
}

.bold {
	font-weight: bold;
}

.-title {
	display: inline;
	font-weight: bold;
	border: solid 1px;
	padding: 3px;

}

.travelarticle-img	{
	margin: 10px auto;
}

.travelarticle-text {
	margin: 1rem auto;
}
.travelarticle-text a {
	color: #4f96f6;
	text-decoration: underline;

	
}
	
.table01,
.table02{
	width: 100%;
	border:solid 1px;
	border-collapse: collapse;
	margin: 0 auto 20px 0;
}

th,td{
	border: solid 1px;
	padding: 5px;
	
}

.table01 th {
	text-align: center;
}

.table02 th {
	text-align: center;
}

.border-box {
	width: 65%;
	border: double;
	padding: 15px 10px 15px 20px;
	margin: auto;
}

.center {
	text-align: center;
}

.travel-border-box-ol,
.travel-border-box-ol-2{
	padding: 0 10px;
	margin: auto;
}

.travel-border-box-ol li:nth-of-type(1){
	padding-top: 15px;
}

.travel-border-box-ol li {
	padding-bottom: 5px;
}



/*----------------------------------footer*/

.footer {
	width: 100%;
	margin: 150px auto 0;
}


.copyright {
	text-align: center;
	margin: 0;
	padding-bottom: 50px;
	
}

.footer-flex {
	justify-content: center;
	align-items: flex-end;
	
}

.footer-flex a{
	color: #4f96f6;
}

.footer-flex a:hover{
	text-decoration: underline;
}


.footer-text {
	display: block;
	margin: 0;
	margin-bottom: 3px;

}



/*スマートフォン---------------------------------*/
@media only screen and (max-width:599px){

	header {
		margin-bottom: 30px;
	}
	
	.main-text {
		padding: 0 20px;
		margin-bottom: 30px;
	}
	
	.main-text-p,
	p {
		font-size: 1rem;
		line-height: 1.7;
		text-align: left;
		margin: 15px auto;
	}
	
	.campaign-number {
		margin-top: 20px;
		line-height: 1.5rem;
	}
	
	h1 {
		font-size: 1.7rem;
		line-height: 1.5;
		text-align: center;
		margin: 0 auto 10px;
	}
	
	h2 {
		font-size: 1rem;
		line-height: 1.5;
	}
	
	h3 {
		width: 200px;
		height: 2rem;
		font-size: 1rem;
		font-weight: normal;
		line-height: 2rem;
		margin-bottom: 10px;
	}
	
	.campaign-present {
		font-size: 1.2rem;
		text-align: center;
		margin-bottom: 0;
	}
	
	
	.campaign-list {
		font-size: 1rem;
		background: #fff;
		margin-bottom: 20px;
		padding: 0 20px 20px;
		
	}
	
	.campaign-text {
		font-size: 1rem;
		text-align: left;
	}
	
	.page-link-button {
		width: 160px;
		font-size: 1rem;
		line-height: 3;
		margin: auto;
	}
	
	.main-text-p-center {
	text-align: center;
	}

	
	summary {
		width: 200px;
		height: 2rem;
		font-size: 1rem;
		line-height: 2rem;
		margin-bottom: 10px;
		font-weight: normal;
		
	}
	
	.entry-rule {
		font-size: 0.8rem;
		border: none;
		padding: 0;
	}
	
	.ol-text,
	.ul-text {
		margin-bottom: 15px;
		padding: 0 0 0 20px;
	}
	
	.ul-child {
		padding: 10px 0 0 15px;
	}
	
	p.title:nth-child(1),
	p.title:nth-child(2) {
		margin-bottom: 15px;
	}
	
	.entry-button {
		width: 100%;
		height: 54px;
		line-height: 1.5;
		font-size: 0.9rem;
		
	}
	
	.pc{
		display: none;
	}
	
	.sp {
		display: block;
	}


	.footer {
		font-size: 0.8rem;
		margin-top: 50px;
	}
		
	.copyright {
		font-size: 0.5rem;
		line-height: 1.5rem;
		padding-bottom: 10px;
	}
	
	
/*---------------------------------神社参拝企画*/
	
	.article-content {
		padding: 20px 10px;
	}
	
	.article-text-content {
		width: 100%;
	}
	
	.article-content-title {
		font-size: 1rem;
	}
	
	.article-imgbox {
		height: 300px;
	}	
	
	.height275 img {
		height: 104px
	}
	
	


/*---------------------------------社長取材企画*/

 	.travelarticle-title{
		font-size: 1rem;
		font-weight: bold;
		margin:0px auto 5px;
		
	
	}

	.travelarticle-subtitle{
		text-align: left;
		margin-bottom: 10px;
	
	}

	.flex {
		display: block;
	}


	.article-imgbox-small {
		width: 100%;
		padding: 0;
	}
	
	.travelarticle-content {
		font-size: 14px;
		padding: 20px;
		margin-bottom: 10px;
	}

	
	.travelarticle-text-content {
		width: 100%;
		padding: 0;
	}
	
	.article-button {
		margin: auto;
	}
	
	.red {
		font-size: 0.6rem;
	}
	
	.border-box {
		width: 100%;
		border: double;
		
	}

	
}