@charset "utf-8";

/*--------------------------------------------------------------------
common
cssの初期化
--------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: none;
  text-decoration: none;
  outline: none;
  font-style: inherit;
  font-weight: inherit;
  zoom: 1;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section { display: block; }
h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}
table { border-collapse: collapse; }
table th, table td {
  text-align: left;
  vertical-align: top;
}
ul,ol { list-style: none; }
img {
  width /***/:auto;
  max-width: 100%;
  height: auto;
	object-fit: cover;
  vertical-align: bottom;
}
img , iframe { vertical-align: bottom; }
* { box-sizing: border-box; }
a {
	transition: 0.5s;
	color: inherit;
}
a:hover {
	transition: 0.5s;
}


/*--------------------------------------------------------------------
common
ページ共通部分
--------------------------------------------------------------------*/
:root {
	--gothic: "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Arial, Roboto, Verdana, "Droid Sans", sans-serif;
		
	--co-black:   #1e1e1e;	/*黒*/
	--co-white:   #ffffff;	/*白*/
	--co-green:   #074f7a;	/*青*/
	--co-day:     #595757;	/*日付用*/
	--co-sat:     #184770;	/*土曜*/
	--co-sun:     #e46b65;	/*日曜*/
	
	--tr-XY: translate(-50% , -50%);
	--tr-X:  translateX(-50%);
	--tr-Y:  translateY(-50%);
}

/*------------body---------------------------------------------------------------*/
html {
	height: 100%;
	background-color: var(--co-white);
	line-height: 1.8;
	font-family: var(--gothic);
	font-feature-settings: "palt" 1;
	font-size: 18px;
	font-weight: normal;
	color: var(--co-black);
}
body {
	height: 100%;
	overflow-y: scroll;
}
body > h1 {
	padding: 0.25em 1em;
	background-color: #074f7a;
	text-align: center;
	font-size: 0.87em;
	color: #fff;
}
.SpOnly { display: none; }
#PageTop a {
	position: fixed;
	display: block;
	width: 30px;
	height: 30px;
	background: url("img/pagetop.png") no-repeat center center / cover;
	right: 5%;
	bottom: 2%;
	overflow: hidden;
	line-height: 0;
	font-size: 0;
	z-index: 9999;
}
.pctel {
	cursor: text;
	pointer-events: none;
}
.noTxt {
	text-align: center;
	font-size: 2em;
	color: var(--co-main);
}


@media (max-width: 960px) {
	html { font-size: 16px; }
	div#PageTop a {
		width: 20px;
		height: 20px;
	}
	.pctel {
		cursor: pointer;
		pointer-events: auto;
	}
}

@media (max-width: 680px) {
	html { font-size: 14px; }
	.PcOnly { display: none; }
	.SpOnly { display: block; }
}

/*------------mainBox---------------------------------------------------------------*/
#mainBox {
	position: relative;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 30px;
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
}
header {
	position: sticky;
	top: 10px;
	left: 0;
	width: 24%;
	max-width: 350px;
	min-width: 250px;
}
header h1 a {
	display: block;
	padding-top: 238%;
	background: url("img/logo.jpg") no-repeat left top / contain;
	overflow: hidden;
	text-indent: -99999px;
	line-height: 0;
	font-size: 0;
}
header p,
header dl { display: none; }

main {
	width: 100%;
	padding: 10px 10px 0 0;
}

@media (max-width: 768px) {
	#mainBox { flex-direction: column; }
	header {
		position: relative;
		top: 0;
		width: 100%;
		max-width: inherit;
		min-width: inherit;
	}
	header h1 a {
		display: block;
		padding-top: 62.5%;
		background: url("img/logo-sp.jpg") no-repeat left top / cover;
		overflow: hidden;
		text-indent: -99999px;
		line-height: 0;
		font-size: 0;
	}
	main { padding: 10px; }
}

article:not(:last-of-type) { margin-bottom: 50px; }
article h2 {
	margin-bottom: 25px;
	padding: 0.5em 1em 0.35em;
	background-color: var(--co-green);
	text-align: center;
	line-height: 1.2;
	font-size: 1.87em;
	font-weight: bold;
	color: var(--co-white);
}
article h3 {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	margin-bottom: 0.5em;
	line-height: 1.2;
	font-size: 1.25em;
	font-weight: bold;
}
article h3 em {
	display: block;
	margin-right: 0.5em;
	margin-bottom: 0.15em;
	font-size: 0.75em;
}
article h3 strong {
	display: block;
	margin-bottom: 0.15em;
	font-size: 0.75em;
}

/*------------mainNav---------------------------------------------------------------*/
#mainNav {
	width: 90%;
	margin: 30px auto;
}
#mainNav ul {
	display: flex;
	justify-content: space-between;
	gap: 10px 40px;
}
#mainNav ul li {
	width: calc(100% - 40px * 2 / 3);
	background-color: var(--co-green);
	border-radius: 10px;
	transition: opacity .5s;
}
#mainNav ul li a {
	padding: 0.55em 2em 0.5em;
	font-size: 1.31em;
}

@media (max-width: 800px) {
	#mainNav ul { flex-flow: wrap; }
	#mainNav ul li { width: 100%; }
}

/*------------btnArr---------------------------------------------------------------*/
.btnArr a {
	position: relative;
	display: block;
	text-align: center;
	font-weight: bold;
	color: var(--co-white);
	transition: opacity .5s;
}
.btnArr a::before,
.btnArr a::after {
	position: absolute;
	display: block;
	content: "";
	width: 13px;
	height: 13px;
	background-color: var(--co-white);
	top: 50%;
	transform: var(--tr-Y);
	transition: opacity .5s;
}
.btnArr a::before {
	left: 1em;
	clip-path: polygon(100% 50%, 0 0, 0 100%);
}
.btnArr a::after {
	right: 1em;
	clip-path: polygon(0 50%, 100% 0, 100% 100%);
}
.btnArr a:hover { color: #ff0; }
.btnArr a:hover::before { background-color: #ff0; left: 1.2em; }
.btnArr a:hover::after  { background-color: #ff0; right: 1.2em; }


/*------------買おう---------------------------------------------------------------*/
#kaou h2 { background-color: #e03337; }
#kaou h3 { color: #e03337; }
#kaou .item { border-color: #e03337; }


/*------------観よう---------------------------------------------------------------*/
#miyou h2 { background-color: #d5931f; }
#miyou h3 { color: #d5931f; }
#miyou .item { border-color: #d5931f; }
#miyou h3 strong {
	width: fit-content;
	margin-right: 0.5em;
	padding: 0.25em;
	background-color: #d5931f;
	color: var(--co-white);
}


/*------------体験しよう---------------------------------------------------------------*/
#taiken h2 { background-color: #88699a; }
#taiken h3 {
	display: block;
	color: #88699a;
}
#taiken .item { border-color: #88699a; }
#taiken h3 strong {
	display: inline-block;
	width: fit-content;
	padding: 0.25em;
	background-color: #88699a;
	color: var(--co-white);
}


/*------------楽しもう---------------------------------------------------------------*/
#tanosimu h2 { background-color: #67ae28; }
#tanosimu h3 { color: #67ae28; }
#tanosimu .item { border-color: #67ae28; }


/*------------品野・水野エリア---------------------------------------------------------------*/
#shinano h2 { background-color: #237fc4; }
#shinano h3 { color: #237fc4; }
#shinano .item { border-color: #237fc4; }
#shinano > p {
	margin-bottom: 30px;
	text-align: center;
	font-weight: bold;
	color: #f00;
}


/*------------瀬戸蔵---------------------------------------------------------------*/
#setogura h2 { background-color: #e03337; }
#setogura h3 { color: #e03337; }
#setogura .item { border-color: #e03337; }
#setogura .floor { margin: 25px 0 10px; }
#setogura h3 strong {
	display: inline-block;
	width: fit-content;
	padding: 0.25em;
	background-color: #e03337;
	color: var(--co-white);
}


/*------------文化センター---------------------------------------------------------------*/
#bunka h2 { background-color: #88699a; }
#bunka h3 { color: #88699a; }
#bunka .item { border-color: #88699a; }


/*------------青の広場---------------------------------------------------------------*/
#hiroba h2 { background-color: #417bbe; }
#hiroba h3 { color: #417bbe; }
#hiroba .item { border-color: #417bbe; }
#hiroba .artistList dt {
	font-weight: bold;
	color: #417bbe;
}
#hiroba .artistList dd ul {
	display: flex;
	flex-wrap: wrap;
	font-size: 0.87em;
}
#hiroba .artistList dd ul li:not(:last-of-type)::after {
	margin: 0 0.25em;
	content: "/";
}
#hiroba #while { margin-top: 1em; }


/*------------瀬戸観光案内所---------------------------------------------------------------*/
#kanko h2 { background-color: #d3a002; }
#kanko h3 { color: #d3a002; }
#kanko .item { border-color: #d3a002; }
#kanko .cooperation dt {
	font-weight: bold;
	color: #d3a002;
}
#kanko .cooperation dd ul {
	display: flex;
	flex-wrap: wrap;
	font-size: 0.87em;
}
#kanko .cooperation dd ul li:not(:last-of-type)::after {
	margin: 0 0.25em;
	content: "、";
}


/*------------新世紀工芸館---------------------------------------------------------------*/
#shinseiki h2 { background-color: #6eb92c; }
#shinseiki h3 { color: #6eb92c; }
#shinseiki .item { border-color: #6eb92c; }


/*------------瀬戸染付工芸館---------------------------------------------------------------*/
#sometuke h2 { background-color: #1fb8cd; }
#sometuke h3 { color: #1fb8cd; }
#sometuke .item { border-color: #1fb8cd; }


/*------------せとまちツクリテセンター---------------------------------------------------------------*/
#center h2 { background-color: #a96224; }
#center h3 { color: #a96224; }
#center .item { border-color: #a96224; }


/*------------その他---------------------------------------------------------------*/
#other h2 { background-color: #9c7952; }
#other h3 { color: #9c7952; }
#other .item { border-color: #9c7952; }
#other h3 em,
#other h3 strong { display: inline-block; }
#other h3 em { margin-right: 1em; }




/*---------------------------------------------------------------------------*/
.eventBox {
	display: flex;
	flex-wrap: wrap;
	gap: 1em;
}
.item {
	width: calc((100% - 1em) / 2);
	padding: 1em;
	background-color: var(--co-white);
	border: 1px solid #000;
	border-radius: 8px;
	overflow: hidden;
}
.item.column2 { width: 100%; }
.photo {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	gap: 0.5em;
}
.photo .photo {
	width: 100%;
	align-items: center;
}
.photo div { width: calc(100% - 0.5em - 40%); }
.img {
	width: 40%;
	margin-bottom: 0.5em;
	text-align: center;
}
img {
	width: 100%;
	max-width: 500px;
	text-align: center;
}
.img2 {
	width: 80%;
	margin: 0 auto 1em;
	text-align: center;
}
.time em {
	display: inline-block;
	margin-left: 0.5em;
	font-size:  0.76em;
}
.Paid {
	margin-left: 0.5em;
	padding: 0.15em 0.25em;
	line-height: 1;
}
.aster {
	margin-left: 0;
	padding-left: 1em;
	text-indent: -1em;
}
.tel {
	display: flex;
	align-items: center;
	flex-flow: wrap;
}
.tel i {
	margin-right: 0.5em;
	font-size:  0.76em;
}
.toi {
	display: flex;
	align-items: center;
	margin-right: 1em;
}
.day {
	display: flex;
	align-items: center;
	font-size: 1.15em;
}
.day em {
	font-size: 1rem;
}
.toi span,
.Sat,
.Sun {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 1.5em;
	height: 1.5em;
	margin: 0 0.15em;
	padding: 0.25em;
	border-radius: 50%;
	line-height: 1;
	font-size: 0.82rem;
	font-weight: bold;
	color: var(--co-white);
}
.Sat { background-color: var(--co-sat); }
.Sun { background-color: var(--co-sun); }
.toi span { background-color: var(--co-black); }
.area { display: flex; }
.area dt::after { content: "："; }
.area dd { flex: 1; }
.area span { display: inline-block; }
.ex {
	display: flex;
	flex-wrap: wrap;
}
.ex dt { padding-top: 0.15em; }
.ex dt::after { content: "："; }
.ex dd { flex: 1; }
.w100fle {
	display: flex;
	gap: 1em;
}
.w100fle > div { width: 50%; }

@media (max-width: 980px) {
	.item { width: calc((100% - 1em) / 2); }
	.photo { flex-direction: column; }
	.photo div { width: 100%; }
	.img {
		width: 100%;
		margin-bottom: 0.5em;
		text-align: center;
	}
}
@media (max-width: 540px) {
	.item { width: 100%; }
	.w100fle { flex-direction: column; }
	.w100fle > div { width: 100%; }
}
@media (max-width: 480px) {
}

/*------------topページ---------------------------------------------------------------*/
#topTxt p {
	text-align: center;
	font-size: 1.15em;
}
.flexBox {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px;
}

/*------------eyeball---------------------------------------------------------------*/
#eyeball h2 span { display: inline-block; }
#eyeball h2 em {
	display: block;
	font-size: 0.6em;
	font-weight: normal;
}
#eyeball .flexBox { flex-flow: nowrap; }
#eyeball .eyeBox { 
	width: 100%;
	max-width: 480px;
}
#eyeball .eyeBox dl * { text-align: center; }
#eyeball .eyeBox dl dt {
	margin-top: 20px;
	font-size: 1.5em;
	font-weight: bold;
	color: var(--co-green);
}

@media (max-width: 800px) {
	#eyeball .flexBox { flex-flow: wrap; }
	#eyeball .eyeBox { margin: 0 auto; }
	#eyeball .eyeBox:not(:first-of-type) { margin-top: 40px; }
}

/*------------program---------------------------------------------------------------*/
#program .flexBox { flex-flow: nowrap; }
#program .proBox {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 480px;
	padding: 20px 20px 0;
	border: 20px solid var(--co-green);
	background-color: var(--co-white);
}
#program .proBox dl { margin-bottom: 15px; }
#program .proBox dl * { text-align: center; }
#program .proBox dl dt {
	margin-top: 20px;
	font-size: 1.18em;
	font-weight: bold;
	color: var(--co-green);
}
#program .proBox .proBtn {
	margin-top: auto;
	background-color: var(--co-green);
	border-radius: 10px 10px 0 0;
}
#program .proBox .proBtn a {
	padding: 0.55em 2em 0.35em;
	font-size: 1.125em;
}

@media (max-width: 800px) {
	#program .flexBox { flex-flow: wrap; }
	#program .proBox { margin: 0 auto; }
	#program .proBox:not(:first-of-type) { margin-top: 40px; }
}

/*------------map---------------------------------------------------------------*/
#map {
	width: 100%;
	max-width: 1400px;
}
#map p {
	margin-bottom: 20px;
	text-align: center;
}
#map .flexBox {
	align-items: center;
	flex-flow: nowrap;
}
#map .mapBox:nth-of-type(1) {
	width: 48%;
	max-width: 625px;
}
#map .mapBox:nth-of-type(2) {
	width: 52%;
	max-width: 700px;
}

@media (max-width: 800px) {
	#map .flexBox {
		flex-flow: wrap;
		justify-content: center;
	}
	#map .mapBox:nth-of-type(1) {
		width: 100%;
		text-align: center;
	}
	#map .mapBox:nth-of-type(2) {
		width: 100%;
		text-align: center;
	}
}

/*------------sponsorship---------------------------------------------------------------*/
#sponsorship { padding: 0 1em; }
#sponsorship h2 em {
	display: inline-block;
	font-size: 1.25rem;
	font-weight: bold;
	color: var(--co-green);
}
#sponsorship h2 span {
	display: inline-block;
	margin-left: 0.5em;
}
#sponsorship h2 + ul {
	justify-content: center;
	margin-bottom: 1em;
}
#sponsorship ul {
	display: flex;
	flex-wrap: wrap;
}
#sponsorship ul li::after { content: "、"; }
#sponsorship ul li:nth-last-of-type(1)::after { content: ""; }
#sponsorship dl {
	display: flex;
	justify-content: flex-start;
}
#sponsorship dl dt {
	width: 3em;
	padding-right: 1em;
	white-space: nowrap;
	font-weight: bold;
	color: var(--co-green);
}

@media (max-width: 480px) {
	#sponsorship h2 span { margin: 0 0.5em; }
}

/*------------footer---------------------------------------------------------------*/
footer {
	display: flex;
	justify-content: center;
	margin-top: 120px;
	padding-bottom: 50px;
}
footer dl {
	display: flex;
	justify-content: center;
}
footer dl#contact > dt { margin-right: 1em; }
footer dl + dl,
footer p { margin-left: 1em; }
footer dl + dl > dt::after { content: "："; }
footer a { color: var(--co-black); }

@media (max-width: 800px) {
	footer { display: block; }
	footer dl#contact {
		display: block;
		text-align: center;
	}
	footer dl#contact > dt { margin-right: 0; }
	footer dl + dl,
	footer p { margin-left: 0; }
	footer p { text-align: center; }
}