@charset "utf-8";

body {
	width: 100%;
	position: relative;
	padding-top: 0;
}

#naoshima_wrapper {
	opacity: 0;
	transition: opacity 600ms ease-in-out 600ms;

	--nao-color-txt: #fff;
	--nao-color-bg: #1374c1;
}

#naoshima_wrapper.naoshimaLoad {
	opacity: 1;
}

main#naoshima_wrap {
	position: relative;
	background: var(--nao-color-txt);
	padding-top: 0;
}

.naoshima_cont {
	line-height: 1;
}

/* visual
--------------------------------------------------*/
#visual {
	position: relative;
	opacity: 0;
	padding: 0 0 100vh 0;
	transition: opacity 600ms ease-in-out 600ms;
}

#visual.hide {
	visibility: hidden;
}

#visual.visualLoad {
	opacity: 1;
}

#visual li {
	position: relative;
	opacity: 0;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	box-sizing: border-box;
	transition: opacity 800ms ease-out 0s;
}

#visual .visualIn+.nextIn {
	height: 50vh;
}

#visual li {
	padding-top: 80px;
}

@media screen and (min-width: 768px) {
	#visual li {
		padding-top: 100px;
	}
}

#visual li.visualFix {
	position: fixed;
}

#visual li.visualIn {
	opacity: 1;
	transition: opacity 1s ease-in-out 0s;
}

#visual .vi {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#visual .vt1,
#visual .vt2 {
	position: absolute;
	display: block;
	height: auto;
}

#visual .vt1 {
	bottom: 6.35%;
	right: 4.27%;
}

#visual .vt2 {
	bottom: 9.4%;
	left: 4.94%;
}

#visual_mark {
	position: fixed;
	opacity: 0;
	top: calc(50% + 35px);
	right: 60px;
	transform: translate(0, -50%);
	transition: opacity 600ms ease-in-out 600ms;
}

#visual.visualLoad+#visual_mark {
	opacity: 1;
}

#visual_mark li {
	padding: 6px 0;
}

#visual_mark a {
	position: relative;
	display: block;
	width: 8px;
	height: 8px;
	padding: 2px;
	cursor: pointer;
}

#visual_mark a::after {
	position: relative;
	content: '';
	display: block;
	width: 8px;
	height: 8px;
	background: transparent;
	border: solid 1px var(--nao-color-txt);
	border-radius: 50%;
}

#visual_mark a.act::after {
	background: var(--nao-color-txt);
}

@media screen and (max-width:767px) {
	#visual .vt1 {
		bottom: auto;
		top: 86%;
		transform: translate(0, -100%);
		width: calc(18.444vw + 140.978px);
	}

	#visual li:nth-child(n) .vt2 {
		bottom: 28%;
		left: 25px;
		right: auto;
	}

	#visual_mark {
		right: 25px;
	}

	#visual_mark {
		top: 50%;
	}

	#visual_mark li {
		padding: 2px 0;
	}

	#visual_mark a {
		padding: 8px;
	}
}

#wrapper {
	position: relative;
	background: var(--nao-color-txt);
}

/* 共通
--------------------------------------------------*/
.exsb {
	font-family: Overpass, 'Helvetica Neue', Arial, sans-serif;
	font-weight: 600;
}

.naoshima_cont {
	width: 1325px;
	max-width: 100%;
	margin: 0 auto;
	padding-left: 40px;
	padding-right: 40px;
	box-sizing: border-box;
	text-align: center;
}

@media (min-width:768px) and (max-width:1345px) {
	.naoshima_cont {
		padding-left: calc(3.484vw + -6.864px);
		padding-right: calc(3.484vw + -6.864px);
	}
}

@media screen and (max-width:767px) {
	.naoshima_cont {
		padding-left: calc(2.222vw + 2.889px);
		padding-right: calc(2.222vw + 2.889px);
	}
}

.naoshima_cont a {
	color: var(--color-hover);
}

.naoshima_cont a:not(.fade_In)[target] > span {
	display: inline-block;
}

.naoshima_cont a:not(.fade_In)[target] > span::after {
	content: url('data:image/svg+xml;utf-8,<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="13" height="13" viewBox="0 0 13 13"><g><rect x=".5" y=".5" width="10" height="10" style="fill: none; stroke: %23676767;"/><line x1="4" y1="12.5" x2="13" y2="12.5" style="fill: none; stroke: %23676767;"/><line x1="12.5" y1="4" x2="12.5" y2="13" style="fill: none; stroke: %23676767;"/></g></svg>');
	margin: 0 0 0 6px;
}

.fade_In {
	opacity: 0;
	transition: opacity 800ms ease-in-out 100ms;
}

.fade_In.scroll_In {
	opacity: 1;
}

a.over {
	transition: opacity 200ms;
}

a.over:hover {
	opacity: 0.7;
}

/* 企業理念
--------------------------------------------------*/
#naoshima_10 {
	padding-top: 160px;
	padding-bottom: 120px;
}

#naoshima_10>div h2 {
	font-size: 3.8rem;
	line-height: 1.842;
}

#naoshima_10>div h2:first-line {
	font-size: 2.5rem;
}

#naoshima_10>div p {
	max-width: 45em;
	margin: 60px auto 120px;
	font-size: 1.8rem;
	line-height: 1.78;
}

#naoshima_10>ul {
	display: flex;
	justify-content: space-between;
}

#naoshima_10>ul>li {
	width: 385px;
	background: var(--nao-color-bg);
}

#naoshima_10 .modal_open_tigger {
	height: 100%;
	transition: opacity 200ms;
	cursor: pointer;
}

#naoshima_10 .modal_open_tigger:hover {
	opacity: 0.7;
}

#naoshima_10 .modal_open_tigger .pic {
	width: 100%;
	overflow: hidden;
}

#naoshima_10 .modal_open_tigger .pic img {
	display: block;
	width: 100%;
	height: auto;
}

#naoshima_10 .modal_open_tigger .txt {
	padding: 35px 30px 45px;
	color: var(--nao-color-txt);
	text-align: left;
}

#naoshima_10 .modal_open_tigger .txt strong {
	display: block;
	font-size: 3.0rem;
	font-weight: 400;
}

#naoshima_10 .modal_open_tigger .txt>span {
	display: block;
	padding: 20px 0;
	font-size: 18px;
	letter-spacing: 0.1em;
}

#naoshima_10 .modal_open_tigger .txt span span {
	font-size: 0.67em;
}

#naoshima_10 .modal_open_tigger .txt p {
	font-size: 1.6rem;
	line-height: 1.4375;
}

@media (min-width:768px) and (max-width:1345px) {
	#naoshima_10>ul>li {
		width: calc(27.875vw + 10.087px);
	}

	#naoshima_10 .modal_open_tigger .txt {
		padding: 35px calc(2.836vw + -6.862px) 45px;
	}

	#naoshima_10 .modal_open_tigger .txt>span {
		font-size: calc(0.871vw + 6.284px);
	}
}

@media (min-width:768px) and (max-width:959px) {
	#naoshima_10 .modal_open_tigger .txt strong {
		font-size: calc(2.66vw + 4.495px);
	}

	#naoshima_10 .modal_open_tigger .txt p {
		font-size: calc(0.532vw + 10.899px);
	}
}

@media screen and (max-width:767px) {
	#naoshima_10 {
		padding-top: 20.78vw;
		padding-bottom: 15.6vw;
	}

	#naoshima_10>div p {
		margin: 7.8vw auto 15.58vw;
		font-size: calc(0.444vw + 14.578px);
		text-align: left;
	}

	#naoshima_10>ul {
		display: block;
	}

	#naoshima_10>ul>li {
		max-width: 100%;
		margin: 0 auto calc(2.222vw + 2.889px);
	}

	#naoshima_10 .modal_open_tigger .txt {
		padding: 35px 25px 45px;
	}
}

@media screen and (max-width:600px) {
	#naoshima_10>div h2 {
		font-size: calc(4.286vw + 12.286px);
		white-space: nowrap;
	}

	#naoshima_10>div h2:first-line {
		font-size: calc(1.786vw + 14.286px);
	}
}


/* モーダル
------------------------------------------ */
html.std_modalOpen {
	overflow-y: scroll;
}

html.std_modalOpen body {
	position: fixed;
}

.stdModal .modal_open_box {
	display: none;
	position: fixed;
	z-index: 2010;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.stdModal .modal_open_box .frame1 {
	position: absolute;
	display: flex;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 50px 3vw;
	box-sizing: border-box;
	background-color: rgba(57, 57, 57, 0.4);
	transition: opacity 0.6s ease-in-out 0s;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}

.stdModal .modal_open_box .frame2 {
	position: relative;
	height: auto;
	max-height: 100%;
}

.stdModal .modal_open_box .frame2::after {
	display: block;
	content: '';
	height: 20px;
	margin: -1px 0 0 0;
	background: var(--nao-color-txt);
	border-radius: 0 0 20px 20px;
}

.stdModal .modal_open_box .x_Close {
	position: relative;
	height: 60px;
	background: var(--nao-color-txt);
	border-radius: 20px 20px 0 0;
	box-sizing: border-box;
}

.stdModal .modal_open_box .x_Close div {
	display: block;
	width: 40px;
	height: 40px;
	margin: 0 0 0 auto;
	padding: 19px 20px 0 0;
	cursor: pointer;
}

.stdModal .modal_open_box .x_Close svg {
	margin: 0;
}

.stdModal .modal_open_box .frame3 {
	position: relative;
	width: 100%;
	max-width: 640px;
	margin: -1px 0 0 0;
	background: var(--nao-color-txt);
	overflow: auto;
}

#naoshima_10 .stdModal .frame2::after {
	height: 16px;
	border-radius: 0 0 16px 16px;
}

#naoshima_10 .stdModal .x_Close {
	height: 60px;
	background: transparent;
	border-radius: 0;
}

#naoshima_10 .stdModal .x_Close div {
	display: block;
	width: 40px;
	height: 40px;
	margin: 0 0 0 auto;
	padding: 0;
	overflow: hidden;
}

#naoshima_10 .stdModal .x_Close::after {
	position: absolute;
	display: block;
	content: '';
	left: 0;
	bottom: 0;
	width: 100%;
	height: 16px;
	background: var(--nao-color-txt);
	-webkit-border-radius: 16px 16px 0 0;
	border-radius: 16px 16px 0 0;
}

#naoshima_10 .stdModal .x_Close svg {
	width: 100px;
	height: 100px;
	margin: -30px 0 0 -30px;
	cursor: pointer;
}

#naoshima_10 .stdModal .x_Close circle {
	fill: none;
}

#naoshima_10 .stdModal .x_Close path {
	fill: none;
}

#naoshima_10 .stdModal .x_Close line {
	fill: none;
	stroke: var(--nao-color-txt);
	stroke-width: 1px;
}

#naoshima_10 .stdModal .x_Close:hover line {
	stroke: var(--nao-color-txt);
}

#naoshima_10 .stdModal .frame1 {
	padding: 20px 3vw 40px;
	background-color: rgba(11, 11, 11, 0.8);
}

#naoshima_10 .stdModal .frame3 {
	max-width: 800px;
}

#naoshima_10 .naoshima_modal {
	padding: 25px 40px;
	text-align: left;
}

#naoshima_10 .naoshima_modal>h2 {
	padding: 20px 0 35px 0;
}

#naoshima_10 .naoshima_modal>h2 strong {
	display: block;
	font-size: 40px;
	font-weight: 400;
}

#naoshima_10 .naoshima_modal>h2>span {
	display: block;
	padding: 25px 0 0 0;
	font-size: 24px;
	letter-spacing: 0.1em;
}

#naoshima_10 .naoshima_modal>h2 span span {
	font-size: 0.666em;
}

#naoshima_10 .naoshima_modal>h3 {
	padding: 30px 0 0;
	font-size: 26px;
	line-height: 1.5;
	font-weight: 500;
}

#naoshima_10 .naoshima_modal>p {
	padding: 25px 0 10px 0;
	font-size: 16px;
	line-height: 1.7;
}

@media screen and (max-width:768px) {
	#naoshima_10 .naoshima_modal {
		padding: 25px calc(5.556vw + -2.778px);
	}

	#naoshima_10 .naoshima_modal>h2 {
		padding: calc(4.444vw + -14.222px) 0 35px 0;
	}

	#naoshima_10 .naoshima_modal>h2 strong {
		font-size: calc(2.222vw + 22.889px);
	}

	#naoshima_10 .naoshima_modal>h2>span {
		font-size: calc(1.333vw + 13.733px);
	}

	#naoshima_10 .naoshima_modal>h3 {
		padding: 30px 0 0;
		font-size: calc(1.333vw + 15.733px);
	}

	#naoshima_10 .naoshima_modal>p {
		font-size: 16px;
	}
}

@media screen and (max-width:414px) {
	#naoshima_10 .naoshima_modal>p {
		font-size: 15px;
	}
}

#naoshima_10 .naoshima_modal article {
	margin: 25px 0 0 0;
	padding: 24px 36px 24px 18px;
	line-height: 1.5;
	background: #faf8f4;
	border-left: solid 7px #dededd;
}

#naoshima_10 .naoshima_modal article h2 {
	padding: 0 0 5px 0;
	font-size: 20px;
	font-weight: 500;
}

#naoshima_10 .naoshima_modal article h3 {
	font-size: 16px;
	font-weight: 500;
}

#naoshima_10 .naoshima_modal article p {
	padding: 15px 0 0 0;
	font-size: 15px;
}

#naoshima_10 .naoshima_modal article a {
	text-decoration: underline;
}

/* 歴史 */
#naoshima_11_modal li {
	display: flex;
	margin: 0 0 1px 0;
}

#naoshima_11_modal ul li:nth-child(odd) {
	background: #f5f5f5;
}

#naoshima_11_modal .pic {
	width: 246px;
}

#naoshima_11_modal .pic img {
	display: block;
	width: 100%;
	height: auto;
}

#naoshima_11_modal .txt {
	width: calc(100% - 246px);
}

#naoshima_11_modal .txt dt {
	width: 7em;
	height: 36px;
	font-size: 16px;
	line-height: 36px;
	color: var(--nao-color-txt);
	text-align: center;
	background: var(--nao-color-bg);
}

#naoshima_11_modal .txt dd {
	display: flex;
	height: calc(100% - 40px);
	padding: 0 20px;
	font-size: 15px;
	line-height: 1.4;
	align-items: center;
}

#naoshima_11_modal .txt strong {
	display: block;
	padding: 0 0 8px 0;
	font-size: 16px;
	font-weight: 500;
}

#naoshima_11_modal .txt dd small {
	display: block;
	padding: 5px 0 0 0;
	font-size: 14px;
}

/* 地域づくり */
#naoshima_12_modal.naoshima_modal article p {
	padding: 0;
	&:first-of-type {
		padding-top: 15px;
	}
}

#naoshima_12_modal.naoshima_modal article p>img {
	margin: 0 0 0 50px;
	float: right;
}

#naoshima_13_modal.naoshima_modal article p + p {
	margin: 0;
}

@media (min-width:768px) and (max-width:959px) {
	#naoshima_11_modal .txt dd {
		font-size: 14px;
	}

	#naoshima_11_modal .txt strong {
		font-size: 15px;
	}

	#naoshima_11_modal .txt dd small {
		font-size: 13px;
	}
}

@media screen and (max-width:767px) {
	#naoshima_10 .naoshima_modal article {
		padding: 24px 18px 24px 12px;
		border-left: solid 5px #dededd;
	}

	#naoshima_10 .naoshima_modal article h2 {
		font-size: calc(0.444vw + 16.578px);
	}

	/* 歴史 */
	#naoshima_11_modal li {
		position: relative;
		display: block;
	}

	#naoshima_11_modal ul li:nth-child(odd) {
		background: var(--nao-color-txt);
	}

	#naoshima_11_modal .txt {
		width: auto;
	}

	#naoshima_11_modal .txt dt {
		position: absolute;
		top: 0;
		left: 0;
		height: 30px;
		font-size: 15px;
		line-height: 30px;
	}

	#naoshima_11_modal .txt dd {
		display: block;
		height: auto;
		padding: 5px 0 30px 0;
	}

	#naoshima_11_modal .txt strong {
		padding: 0 0 5px 0;
		font-size: 16px;
	}

	/* 地域づくり */
	#naoshima_12_modal.naoshima_modal article p>img {
		margin: 0 0 0 calc(7.042vw + -4.225px);
	}
}

@media screen and (max-width:414px) {
	#naoshima_12_modal.naoshima_modal article p>img {
		display: block;
		margin: 0 0 30px 0;
		float: none;
	}
}


/* ベネッセアートサイト直島 ウェブサイト
--------------------------------------------------*/
#naoshima_20 {
	padding-bottom: 160px;
}

#naoshima_20 a {
	position: relative;
	display: block;
	overflow: hidden;
}

#naoshima_20 a img {
	position: relative;
	display: block;
	width: 100%;
	height: auto;
}

#naoshima_20 span {
	position: absolute;
	display: flex;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center;
}

#naoshima_20 strong {
	display: block;
	width: 27em;
	padding: 30px 0 30px;
	font-size: 1.6rem;
	font-weight: 400;
	color: #000;
	background: var(--nao-color-txt);
}

@media (min-width: 768px) and (max-width: 959px) {
	#naoshima_20 a img {
		width: auto;
		height: 175px;
		left: 50%;
		transform: translate(-50%, 0);
	}
}

@media screen and (max-width:767px) {
	#naoshima_20 {
		padding-bottom: 20.78vw;
	}

	#naoshima_20 a img {
		width: auto;
		height: 175px;
		left: 50%;
		transform: translate(-50%, 0);
	}

	#naoshima_20 strong {
		display: inline-block;
		width: auto;
		padding: 30px 15px;
		font-size: calc(0.444vw + 12.578px);
	}
}

/* TOPICS
--------------------------------------------------*/
#naoshima_30 {
	padding: 80px 0 0;
	background: #f8f8f8;
}

#naoshima_30 h2 {
	font-size: 3.4rem;
	text-align: left;
	letter-spacing: 0.1em;
}

#naoshima_30 ul {
	display: flex;
	padding: 40px 0 0 0;
	justify-content: space-between;
	flex-wrap: wrap;
}

#naoshima_30 li,
#naoshima_30 ul::after {
	width: 385px;
}

#naoshima_30 li {
	padding: 0 0 80px 0;
}

#naoshima_30 ul::after {
	display: block;
	content: '';
	height: 1px;
	overflow: hidden;
}

#naoshima_30 .pic {
	width: 100%;
	overflow: visible;
}

#naoshima_30 .pic img {
	display: block;
	width: 100%;
	height: auto;
}

#naoshima_30 .pic figure {
	position: relative;
}

#naoshima_30 .pic figcaption {
	position: absolute;
	right: 0;
	bottom: -1.2em;
	font-size: 12px;
}

#naoshima_30 .txt {
	text-align: left;
}

#naoshima_30 .txt strong {
	display: block;
	min-height: 6em;
	padding: 1.5em 0 1em 0;
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: 400;
}

#naoshima_30 .txt p {
	font-size: 1.5rem;
	line-height: 1.8;
}

#naoshima_30 ul li:nth-child(3) p {
	line-height: 1.6;
}

#naoshima_30 .txt p + a {
	display: inline-block;
	margin: 0.3em 0 1.5em 0;
	line-height: 1.5;
	text-decoration: none;
}
@media (min-width: 768px) and (max-width: 1345px) {

	#naoshima_30 li,
	#naoshima_30 ul::after {
		width: calc(27.875vw + 10.087px);
	}
}

@media screen and (max-width:767px) {
	#naoshima_30 {
		padding: calc(4.444vw + 45.778px) 0 80px;
	}

	#naoshima_30 h2 {
		width: 385px;
		max-width: 100%;
		margin: 0 auto;
	}

	#naoshima_30 ul {
		display: block;
		padding: 0;
	}

	#naoshima_30 li {
		max-width: 100%;
		margin: 0 auto;
		padding: 50px 0 0;
	}

	#naoshima_30 ul::after {
		content: none;
	}

	#naoshima_30 .txt strong {
		min-height: 0;
		padding: 2em 0 1.5em 0;
	}
}


/* GALLERY
--------------------------------------------------*/
#naoshima_40 {
	padding-top: 100px;
	padding-bottom: 180px;
	background: var(--nao-color-bg);
}

#naoshima_40 h2 span {
	display: block;
	font-size: 1.8rem;
	line-height: 1.7;
	color: var(--nao-color-txt);
}

#naoshima_40 h2 .exsb {
	font-size: 3.4rem;
	letter-spacing: 0.1em;
}

#naoshima_gallery {
	padding-top: 70px;
	box-sizing: border-box;
}

#naoshima_gallery a {
	display: block;
	width: 100%;
	overflow: hidden;
}

#naoshima_gallery img {
	display: block;
	width: 100%;
	transform: scale(1.01, 1.01);
}

.gallery_flex {
	display: flex;
}

.gallery_reverse {
	flex-direction: row-reverse;
}

.gallery_flex>li {
	width: 50%;
}

@media (min-width:768px) and (max-width:1345px) {
	#naoshima_40 {
		padding-bottom: calc(10.453vw + 39.408px);
	}
}

@media screen and (max-width:767px) {
	#naoshima_40 {
		padding-top: calc(11.111vw + 14.444px);
		padding-bottom: calc(26.667vw + -25.333px);
	}

	#naoshima_gallery {
		width: 385px;
		max-width: 100%;
		margin: 0 auto;
		padding-top: calc(5.556vw + 27.222px);
	}

	.gallery_flex.sp_block {
		display: block;
	}

	.gallery_flex>li {
		width: auto;
	}
}

.gallery-fade.mfp-bg {
	opacity: 0;
	transition: opacity 0.3s ease-out;
}

.gallery-fade.mfp-bg.mfp-ready {
	opacity: 0.8;
}

.gallery-fade.mfp-bg.mfp-removing {
	opacity: 0;
}

.gallery-fade.mfp-wrap .mfp-content {
	opacity: 0;
	transition: opacity 0.3s ease-out;
}

.gallery-fade.mfp-wrap.mfp-ready .mfp-content {
	opacity: 1;
}

.gallery-fade.mfp-wrap.mfp-removing .mfp-content {
	opacity: 0;
}

.gallery-fade .mfp-arrow-left:before {
	border-right: 27px solid var(--nao-color-txt);
}

.gallery-fade .mfp-arrow-right:before {
	border-left: 27px solid var(--nao-color-txt);
}

.gallery-fade.mfp-wrap .mfp-arrow-left:after,
.gallery-fade.mfp-wrap .mfp-arrow-right:after {
	content: none
}

.gallery-fade.mfp-wrap .mfp-close,
.gallery-fade.mfp-wrap .mfp-arrow {
	opacity: 0;
	transition: opacity 0.3s ease-out;
}

.gallery-fade.mfp-wrap.mfp-ready .mfp-close {
	opacity: 1;
}

.gallery-fade.mfp-wrap.mfp-ready .mfp-arrow {
	opacity: 0.6;
}

.gallery-fade.mfp-wrap.mfp-ready .mfp-arrow:hover {
	opacity: 1;
}

.gallery-fade.mfp-wrap.mfp-removing .mfp-close,
.gallery-fade.mfp-wrap.mfp-removing .mfp-arrow {
	opacity: 0;
}