@charset "UTF-8";
/* CSS Document */

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Noto+Serif+JP:wght@400;500;700&display=swap");

/*---------------------------*/

.contents .Common21__inner {
	width: auto;
}

/* tour_start */
.block-tour .caption {	
	text-align: center;
	margin-bottom: 20px;
}

.block-tour_inner {
	width: 1024px;
	height: auto;
	margin: 0 auto;
}

.block-tab {
	display: flex;
	justify-content: space-between;
}

.block-tab_item {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #fff;
	border: solid 1px #06286f;
	width: calc(100% / 9);
	font-weight: 600;
	color: #000;
	text-align: center;
	padding: 20px 0;
	cursor: pointer;
}

.block-tab_item:not(:last-child) {
	border-right: none;
}

.block-tab_item.current {
	background-color: #06286f;
	color: #fff;
}

.block-tab_contents {
	background-color: #06286f;
	margin-bottom: 50px;
	padding: 15px 10px;
}

.tour-link:not(:last-child) {
	display: block;
	margin-bottom: 10px;
}

.tour-template {
	display: flex;
	justify-content: space-between;
	background-color: #fff;
	padding: 15px;
}

.tour-template .image {
	width: 195px;
	height: auto;
}

.tour-template .image img {
	width: 195px;
	height: auto;
}

.tour-template .image .dept {
	border: solid 1px #06286f;
	font-size: 17px;
	font-weight: 600;
	line-height: 1;
	color: #06286f;
	text-align: center;
	margin-bottom: 10px;
	padding: 20px;
}

.tour-template .details {
	display: flex;
	flex-wrap: wrap;
	align-content: space-between;
	width: calc(100% - 195px - 20px);
}

.tour-template .details .name {
	font-size: 18px;
	font-weight: 600;
	line-height: 1.4;
	color: #333;
	padding-top: 10px;
}

.tour-template .details .details-inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	width: 100%;
}

.tour-template .details .details-inner .price {
	font-size: 20px;
	font-weight: 700;
	color: #ff0000;
}

.tour-template .details .details-inner .button {
	background-color: #ff0000;
	padding: 3px;
}

.tour-template .details .details-inner .button span {
	display: block;
	border: solid 1px #fff;
	font-size: 17px;
	font-weight: 600;
	text-align: center;
	color: #fff;
	padding: 5px 40px;
}

.notour {
	background-color: #fff;
	text-align: center;
	padding: 20px 0;
}
/* tour_end */

/*---2023/04/24 追加----------------------------------*/

.mainvisual_Wrapper {
	position: relative;
	height: 660px;
	/* background-color: #172942; */
}

.mainvisualWrap01 {
	/* background-image: url(""), url("/attending/media/princess/images/mv_bg_img.jpg.jpg");
	background-repeat: repeat-x, no-repeat;
	background-position: center top, center center;
	background-size: auto 68px, 100% auto; */
	background-image: url("/attending/media/princess/images/mv_bg_img@2x.jpg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 100% auto;
	width: 1400px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.mainH101 {
	background-image: url("/attending/media/princess/images/mv_ttl@2x.png");
	background-repeat: no-repeat;
	background-position: center center;
	height: 660px;
	background-size: contain;
}
.mainH101 span {
	display: none;
}

/*---------------------------*/

.contIn1024 {
	width: 1024px;
	margin: auto;
	position: relative;
}

.mainBottomBlock01 {
	/* background-color: #e2fdfc; */
	background-color: #fff;
	padding: 30px 0px;
	border-bottom: 1px solid #c7af7c;
    width: 1024px;
    margin: 0 auto 30px;
}
.contFlex01 {
	display: flex;
	/* justify-content: space-between; */
	justify-content: center;
	flex-direction: column;
}
.contFlex01 .box01 {
	/* width: 650px; */
	/* width: 725px; */
}
.contFlex01 .box01 p {
	text-align: center;
	line-height: 2.4;
	font-weight: 500;
	font-family: "Noto Serif JP", serif;
}
.contFlex01 .box02 {
	width: 285px;
	margin-left: 14px;
}

.modalLink01 {
	font-family: "Noto Serif JP", serif;
	font-size: 18px;
	line-height: 1.8em;
	font-weight: 500;
	width: 1024px;
	margin: 0 auto 30px;
    text-align: center;
    color: #ff0000;
}

.modalLink01__btn{
	position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
	margin-top:10px;
    text-align: center;
    box-sizing: border-box;
    width: 100%;
	height: 76px;
    padding: 4px 20px;
    background-color: #e8307f;
	color: #ffffff;
    text-decoration: none;
	transition-duration: 0.3s;
}
.modalLink01__btn a{
	width: 100%;
    display: block;
    height: 100%;
}
.modalLink01__btn:hover{
	opacity:.6;
}

.modalLink01 a {
	text-decoration: underline;
}

.movieTit01 {
	background-color: #83274e;
	font-family: "Noto Serif JP", serif;
	color: #ffffff;
	font-size: 13px;
	line-height: 1.6em;
	font-weight: 500;
	letter-spacing: -0.05em;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 70px;
	text-align: center;
	margin-bottom: 10px;
}

/*----------------------*/

.contBlock01 {
	/* background-color: #fff8eb; */
	padding: 56px 0px 60px 0px;
}
.contH2 {
	text-align: center;
	margin-bottom: 18px;
}

.contH2.h201 img {
	width: auto;
	/*height: 201px;*/
	height: auto;
}
.contH2.h202 img {
	width: auto;
	height: 102px;
}
.contH2.h203 img {
	width: auto;
	height: 180px;
}
.contH2.h204 img {
	width: auto;
	height: 100px;
}
.contH2.h205 img {
	width: auto;
	height: 102px;
}
.contH2.h206 img {
	width: 100%;
	height: auto;
}
.contH2.h207 img {
	width: auto;
	height: auto;
}
.contH2.h208 img {
	width: auto;
	height: 201px;
}

.contFlex02 {
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
}

.contFlex02 li {
	box-sizing: border-box;
	width: 48.5%;
	border: 2px solid #83274e;
}
.contFlex02 li .p01 {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	border: 1px solid #ffffff;
	height: 70px;
	background-color: #83274e;
	color: #ffffff;
	font-family: "Noto Serif JP", serif;
	font-size: 34px;
	line-height: 1em;
}

.contFlex02 li.li02 {
	border: 2px solid #05286e;
}
.contFlex02 li.li02 .p01 {
	background-color: #05286e;
}

.contFlex02 li .s01 {
	font-size: 26px;
}

/*----------------------*/

.contBlock02 {
	background-color: #f4ffe5;
	padding: 35px 0px 25px 0px;
}
.contPointFlex01 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.contPointFlex01 .pointWrap {
	margin-bottom: 36px;
}
.contPointFlex01 .img01 {
	width: 495px;
}
.contPointFlex01 .img02 {
	width: 100%;
}

/*----------------------*/

.contBlock03 {
	background-image: url("/attending/media/princess/images/cont_bg01.png");
	background-repeat: repeat-x;
	background-position: center bottom;
	background-color: #05286e;
	padding: 55px 0px 55px;
}
.contBlock03_note {
	font-size: 16px;
    line-height: 1.6;
	color: #fff;
	text-align: center;
}
.contInBox01 {
	background-color: #ffffff;
	padding: 30px 38px 30px 38px;
	margin-bottom: 55px;
}
.contInBox02 {
	background-color: #ffffff;
	padding: 30px 38px 30px 38px;
	margin-bottom: 40px;
}

.contText01 {
	font-size: 16px;
	line-height: 1.85em;
	text-align: center;
}
.contImg01 {
	margin-top: 15px;
}
.contFlex03 {
	display: flex;
	justify-content: space-between;
	margin-top: 40px;
}
.contFlex03 li {
	width: 31.6%;
}
.contFlex03 li dt {
	border: 3px solid #bbecfa;
}
.contFlex03 li dt span {
	border: 1px solid #ffffff;
	background-color: #bbecfa;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: 50px;
	color: #05286e;
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	line-height: 1em;
}
.contFlex03 li dd {
	padding-top: 12px;
	font-size: 16px;
	line-height: 1.85em;
}

.contH301 {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-image: url("/attending/media/princess/images/cont_tit_bg01.png"), url("/attending/media/princess/images/cont_tit_bg01.png");
	background-repeat: no-repeat, no-repeat;
	background-position: left 20px center, right 20px center;
	background-color: #05286e;
	box-sizing: border-box;
	height: 70px;
	padding: 5px 60px 5px 60px;
	color: #ffffff;
	font-family: "Noto Serif JP", serif;
	font-size: 30px;
	line-height: 1.2em;
	font-weight: 500;
	margin-bottom: 20px;
}
.contH301 .s01 {
	font-size: 20px;
}

.contFlex04 {
	display: flex;
	justify-content: space-between;
}
.contFlex04 .box01 {
	width: 400px;
}
.pht{
	position: relative;
}
.pht .copyright {
	position: absolute;
	right: 5px;
	bottom: 5px;
	font-size: 12px;
	text-align: right;
	line-height: 1.3;
	color: #fff;
	text-shadow: 
	-1px -1px 2px rgba(0, 0, 0, 0.9),
	1px 1px 2px rgba(0, 0, 0, 0.9),
	-1px 1px 2px rgba(0, 0, 0, 0.9),
	1px -1px 2px rgba(0, 0, 0, 0.9)
	;
}
.pht .copyright .caption {
	font-size: 16px;
	font-weight: 600;
	line-height: 1.4;
}
.floor img {
	object-fit: contain;
}
.contFlex04 .floor {
	margin-top: 10px;
}
.contFlex04 .box01 .pht > img {
	width: 400px;
	height: 200px;
	object-fit: cover;
}
.contFlex04 .box01 .pht > img {
}
.contText02 {
	font-size: 16px;
	line-height: 1.85em;
	letter-spacing: -0.05em;
	margin-bottom: 14px;
}

.contFlex04 .box02 {
	width: 520px;
}
.contFlex04 .box02 .pht > img {
	width: 520px;
	height: 470px;
	object-fit: cover;
}
.contBoxFlex01 {
	display: flex;
	border: 3px solid #bbecfa;
	margin-top: 20px;
}
.contBoxFlex01 .box01 {
	border-right: 3px solid #bbecfa;
}
.contBoxFlex01 .box01 .boxIn01 {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	box-sizing: border-box;
	background-color: #bbecfa;
	border: 1px solid #ffffff;
	width: 296px;
	height: 100%;
	color: #05286e;
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	line-height: 1.2em;
	font-weight: bold;
}
.contFlex13 .contBoxFlex01 {
	/* width: 150px; */
	flex-direction: column;
}
.contFlex13 .contBoxFlex01 .box01 .boxIn01 {
	width: 100%;
	height: 35px;
}

.contBoxFlex01 .box02 {
    text-align: left;
    display: flex;
    align-items: flex-start;
    padding: 5px 20px 5px 20px;
    flex-direction: column;
    justify-content: center;
}

.contFlex05 {
	display: flex;
	gap: 20px;
}
.contFlex05 .box01 img {
	width: 520px;
}
.contFlex05 .box01 .txt {
	/* margin-top: 10px; */
}

.contFlex05 .box02 img {
	width: 400px;
	height: 230px;
	object-fit: cover;
}
.contFlex05 .box02 .tokuten {
	font-family: "Noto Serif JP", serif;
	background-color: #05286e;
	margin-bottom: 20px;
}
.contFlex05 .box02 .tokuten .ttl {
	text-align: center;
	font-size: 18px;
	line-height: 1.2;
	font-weight: 700;
	color: #05286e;
	border: 2px solid #05286e;
	background-color: #fff;
	padding: 5px 0;
}
.contFlex05 .box02 .tokuten .txt {
	font-size: 14px;
	line-height: 1.2;
	font-weight: 700;
	color: #fff;
	padding: 10px;
}
.contFlex05 .box02 .flex {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.contFlex05 .floor {
	margin: 0 auto;
}
.contFlex05 .floor img {
	width: 400px;
	height: 140px;
	object-fit: cover;
}
.contFlex06 {
	display: flex;
	justify-content: space-between;
}
.contFlex06 .box01 {
	width: 404px;
}
.contFlex06 .box02 {
	width: 530px;
	border: 1px solid #2981d2;
}
.contFlex06 .box02 dt {
	background-color: #bbecfa;
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	height: 38px;
	padding: 4px 20px;
	font-size: 18px;
	line-height: 1.6em;
}
.contFlex06 .box02 dd {
	padding: 14px 20px 14px 20px;
	font-size: 16px;
	line-height: 1.8em;
	letter-spacing: -0.05em;
}
.contFlex06 .box02 dd li {
	text-indent: -1em;
	padding-left: 1em;
}

.contFlex07 {
	display: flex;
	justify-content: space-around;
	margin-top: 20px;
}
.contFlex07 li {
	width: 210px;
	text-align: left;
}
.contTyusyaku01 {
	font-size: 13px;
	line-height: 1.7em;
	text-align: right;
	margin-top: 10px;
}

/*-----------------------*/

.contBlock04 {
	background-image: url("/attending/media/princess/images/bg_SP22-054374D.jpg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	padding: 55px 0px 60px 0px;
}
.contInBox03 {
	background-color: #ffffff;
	padding: 40px 40px 10px 40px;
}
.contFlex08 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.contFlex08 li {
	width: 298px;
	margin-bottom: 30px;
}
.contFlex08 li img {
	width: 298px;
	height: 198px;
	object-fit: cover;
}
.contFlex08 li dt {
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	line-height: 1.3em;
	font-weight: bold;
	margin: 15px auto 10px auto;
	text-align: center;
}
.contFlex08 li dd {
	font-size: 16px;
	line-height: 1.85em;
	text-align: left;
}

.contTyusyaku02 {
	font-size: 14px;
	line-height: 1.7em;
	color: #ff0000;
	margin-top: 15px;
}

/*----------------------*/

.contBlock05 {
	background-color: #fcedd3;
	padding: 45px 0px 60px 0px;
}
.contFlex09 {
	display: flex;
	justify-content: space-between;
}
.contFlex09 li {
	width: 32%;
}
.contFlex09 li span {
	text-align: right;
	display: block;
	font-size: 13px;
	margin-top: 3px;
}
.alc {
	text-align: center;
}

.contFlex10 {
	display: flex;
	align-items: center;
	padding: 20px 0px;
	margin: 60px 0px 20px;
	position: relative;
}
section:has(.contFlex10):first-of-type .contFlex10 {
	margin-top: 20px;
}
.contFlex10 .box01 {
	width: 46%;
	position: relative;
	z-index: 1;
}
.contFlex10 .box02 {
	background-color: #ffffff;
	box-sizing: border-box;
	padding: 10px 20px;
	width: 74%;
	position: relative;
	z-index: 0;
}
.flex10Bg01 {
	border: 1px solid #78191c;
	background-color: #78191c;
	width: 52%;
	height: 100%;
	position: absolute;
	left: 0px;
	top: 0px;
}
.flex10Bg01::before {
	content: "";
	width: calc(100% - 2px);
	height: calc(100% - 2px);
	border: 1px solid #ffffff;
	position: absolute;
	left: 1px;
	top: 1px;
}
.contH302 {
	color: #ffffff;
	font-family: "Noto Serif JP", serif;
	font-size: 29px;
	line-height: 1.2em;
	font-weight: bold;
	letter-spacing: -0.05em;
	display: inline-block;
	padding: 0px 20px 0px 20px;
	position: relative;
}
.contH302::before {
	content: "";
	width: 90px;
	height: 1px;
	background-color: #fff;
	position: absolute;
	right: -90px;
	top: 50%;
}
#meal .contText02 {
	margin-bottom: 0;
}
.meal_decoration {
	font-family: "Noto Serif JP", serif;
    margin-bottom: 20px;
}
.mealFlex02 {
	display: flex;
	gap: 20px;
	margin-top: 20px;
}
.mealFlex02 .pht {
	/* width: 328px; */
}
.mealFlex02 .pht img {
	width: 500px;
	height: 220px;
	object-fit: cover;
}
.mealFlex03 {
	margin-top: 20px;
}
.meal_decoration .ttl {
	position: relative;
	font-size: 24px;
	font-weight: 600;
	color: #8f1d22;
	border-bottom: 1px solid #8f1d22;
	padding-bottom: 10px;
    line-height: 1;
}
.meal_decoration .ttl::after {
	content: '';
	position: absolute;
	background-image: url(/attending/media/princess/images/meal_arrow.svg);
	bottom: -28px;
	right: 0px;
	background-size: contain;
	width: 22px;
	height: 100%;
	background-repeat: no-repeat;
}
.meal_decoration .txt {
	padding-top: 10px;
	font-size: 16px;
	line-height: 1.4;
}
.mealFlex01 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(2, 1fr);
	grid-column-gap: 0px;
	grid-row-gap: 0px;
	gap: 20px;
}
.mealFlex01 li .pht img {
	object-fit: cover;
}
.mealFlex01 li:nth-of-type(1) .pht img {
	height: 430px;
}
.mealFlex01 li:nth-of-type(2) .pht img ,
.mealFlex01 li:nth-of-type(3) .pht img {
	height: 205px;
}

.mealFlex01 li:nth-of-type(1) { grid-area: 1 / 1 / 3 / 3; }
.mealFlex01 li:nth-of-type(2) { grid-area: 1 / 3 / 2 / 4; }
.mealFlex01 li:nth-of-type(3) { grid-area: 2 / 3 / 3 / 4; }

.mealFlex04 {
	display: flex;
	gap: 10px;
	margin-top: 10px;
}
#meal_casual .mealFlex04 li:has(.txt) {
	width: 334px;
	font-family: "Noto Serif JP", serif;
}
#meal_speciality .mealFlex04 {
	gap: 20px;
}
.mealFlex04 .pht img {
	height: 223px;
	object-fit: cover;
}
.mealFlex04 .pht.column04 img {
	height: 165px;
	object-fit: cover;
}
.contFlex11 {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
}
.contFlex11 li {
	width: 32%;
	background-color: #ffffff;
}
.contFlex11 li dl {
	padding: 0px 20px 15px 20px;
}

.contFlex11 li dt {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: 90px;
	color: #78191c;
	font-family: "Noto Serif JP", serif;
	font-size: 21px;
	line-height: 1.4em;
	letter-spacing: -0.05em;
}
.contFlex11 li dt .s01 {
	font-size: 16px;
}

.contFlex11 li dt .s02 {
	font-size: 16px;
	line-height: 1em;
	font-weight: bold;
	color: #ffffff;
	background-color: #05286e;
	border-radius: 30px;
	display: flex;
	align-items: center;
	box-sizing: border-box;
	height: 25px;
	padding: 2px 15px;
	position: absolute;
	right: 0px;
	bottom: 15px;
}

/*----------------------*/

.contBlock06 {
	/* background-image: url("/attending/media/princess/images/map_bg01.png"); */
	/* background-repeat: repeat-x;
	background-position: center top; */
	/* background-color: #ffffff; */
	padding: 55px 0px 55px 0px;
}

/* ---------------------------- */
/* --- Base --- */
/* ---------------------------- */
.swiperModalButton {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-around;
}

.swiperModalButton a {
	position: absolute;
}
.popup-box {
	background: #fff;
	width: auto;
	max-width: 684px;
	margin: 0 auto;
	border-radius: 2px;
}

.gallery-arrow {
	position: absolute;
	top: 50%;
	margin-top: -15px;
	display: block;
	width: 60px;
	height: 60px;
	line-height: 60px;
	left: 50%;
	cursor: pointer;
}
.gallery-arrow-left:before {
	content: "〈";
	color: #fff;
	font-size: 60px;
}
.gallery-arrow-right:before {
	content: "〉";
	color: #fff;
	font-size: 60px;
}
/* スケジュールモーダル */
.mfp-auto-cursor .mfp-content {
	text-align: center;
}

.popup-modal-dismiss {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 35px;
	width: 296px;
	height: 55px;
	margin: 0 auto;
	text-indent: -9999px;
	cursor: pointer;
}
.mfp-container {
	padding-left: 60px;
	padding-right: 60px;
}
.mfp-close-btn-in .mfp-close {
	color: #fff;
	font-size: 50px;
	font-family: "Noto Serif JP";
	width: 40px;
	height: 40px;
	top: -70px;
	right: -40px;
	opacity: 1;
}

.modalBox01 {
	padding: 15px 20px 15px 20px;
}
.modalBox01 dt {
	font-family: "Noto Serif JP", serif;
	font-size: 38px;
	line-height: 1em;
	font-weight: bold;
	margin-bottom: 10px;
	text-align: center;
}
.modalBox01 dd {
	font-size: 16px;
	line-height: 2em;
	text-align: left;
}

/*-----------------------------*/

.mapAreaWrap01 {
	position: relative;
	background-repeat: no-repeat;
	background-position: top left;
	/* margin-bottom: 100px; */
	margin-top: 30px;
}
#tab1 .mapAreaWrap01 {
	background-image: url("/attending/media/princess/images/map_img01__cts01@2x.jpg");
	background-size: 100%;
	width: 1024px;
	height: 777px;
}
#tab2 .mapAreaWrap01 {
	background-image: url("/attending/media/princess/images/map_img01__cts02@2x.jpg");
	background-size: 100%;
	width: 1024px;
	height: 702px;
}
.mapAreaWrap01 button:hover {
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
	transition-duration: 0.3s;
}

.mapAreaWrap01 button {
	position: absolute;
}
/*台湾*/
.mapAreaWrap01 .btn01 {
	position: absolute;
	left: 20px;
	top: 150px;
}
/*那覇*/
.mapAreaWrap01 .btn02 {
	right: 280px;
	top: 0px;
}
/*石垣島*/
.mapAreaWrap01 .btn03 {
	left: 420px;
	bottom: 10px;
}
/*宮古島*/
.mapAreaWrap01 .btn04 {
	right: 40px;
	bottom: 180px;
}

.mapText01 {
	font-size: 16px;
	line-height: 1.6;
	text-align: center;
	margin: 50px auto 100px;
}

.mapContBox01 {
	margin-top: 38px;
}

.table {
	display: flex;
	justify-content: space-between;
}

.mapContFlex01 {
	display: flex;
	justify-content: center;
}
.column02 li {
	width: 512px;
}

.column01_wapper {
	background-color: #cce4d8;
	border: 2px solid #007a3c;
	padding: 20px;
	margin: 30px auto 0;
	width: 760px;
}

.mapContFlex01 li .dl03 dt,
.mapContFlex01 li .dl03 dd {
	padding: 5px 134px;
	font-size: 22px;
}

.mapContBox01 h3.term {
	display: block;
	text-align: center;
	margin: 15px 0;
}

.mapContBox01 h3.term small {
	font-size: 60%;
}

.mapContFlex01 li .dl03 dd {
	background-color: #fff;
}
/*.column01 li {
	width: 512px; 
}*/
.mapContBox01 h3 {
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	line-height: 1;
	font-weight: bold;
	margin-bottom: 5px;
	display: flex;
}

.column01_wapper .new,
.column01_wapper h3 {
	position: relative;
	font-size: 40px;
	margin: 0 10px 5px;
}

.column01_wapper .new {
	font-family: "Noto Serif JP", serif;
	font-size: 40px;
	line-height: 1;
	color: #ff0000;
	font-weight: bold;
	text-align: center;
	margin-bottom: 10px;
}

.column01_wapper .new::after {
	content: "";
	width: 22%;
	height: 60px;
	background-image: url(/attending/media/princess/images/ico_new.png);
	background-size: cover;
	position: absolute;
	top: 45px;
	left: -35px;
	transform: rotate(-10deg);
}

.column01_wapper .note,
.contBlock08 .note {
	text-align: left;
	font-size: 80%;
	margin-bottom: 5px;
}

.mapContFlex01 li dt {
	background-color: #b80606;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	box-sizing: border-box;
	height: auto;
	padding: 5px 20px;
	color: #ffffff;
	font-size: 18px;
	line-height: 1.3em;
	font-weight: bold;
	font-feature-settings: "palt";
}

.mapContFlex01 li dd {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	box-sizing: border-box;
	border-right: 1px solid #cccccc;
	border-bottom: 1px solid #cccccc;
	border-left: 1px solid #cccccc;
	height: 56px;
	padding: 5px 20px;
	font-size: 16px;
	line-height: 1.3em;
	font-weight: bold;
	letter-spacing: -0.05em;
}
.mapContFlex01 li dd .s01 {
	color: #b80606;
}

.mapContFlex01 li .dl02 dt {
	background-color: #05286e;
}
.mapContFlex01 li .dl02 dd .s01 {
	color: #05286e;
}

.mapContFlex01 li .dl03 dt {
	background-color: #007a3c;
}
.mapContFlex01 li .dl03 dd .s01 {
	color: #007a3c;
}

.mapContTyusyaku01 {
	margin-top: 15px;
}
.mapContTyusyaku01 li {
	font-size: 13px;
	line-height: 1.6em;
	text-indent: -1em;
	padding-left: 1em;
}

/*---------------------*/

.contBlock08 {
	/* background-color: #fff8eb; */
	padding: 60px 0px;
}

.contBlock09 {
	/* background-image: url("/attending/media/princess/images/banner_cont_bg01.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover; */
	/* background-color: #172942; */
	padding: 40px 0px 35px 0px;
}
.bannerFlex01 {
	display: flex;
	justify-content: space-between;
}
.bannerFlex01 li {
	width: 49%;
}
.bannerFlex01 li a:hover {
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
	transition-duration: 0.3s;
}
.bannerTyusyaku01 {
	font-size: 14px;
	line-height: 1.6em;
	color: #ffffff;
	text-align: center;
	margin-top: 6px;
}

.tel_wapper {
	font-family: "Noto Serif JP", serif;
	border: 2px solid #06286f;
	background-color: #fff;
	padding: 2%;
}

.tel_wapper h3 {
	font-size: 26px;
	font-weight: 600;
	line-height: 1;
	color: #06286f;
	padding-bottom: 1%;
	margin-bottom: 2%;
	border-bottom: 2px solid #06286f;
}

.tel_wapper h3 img {
	width: 26px;
	height: 26px;
	margin-right: 1%;
}

.tel_wapper h3 span {
	font-size: 18px;
}

.tel_wapper dl {
	display: flex;
	align-items: center;
	justify-content: center;
}

.tel_wapper dt {
	font-size: 29px;
	letter-spacing: -0.05em;
	margin-bottom: 1%;
	margin-right: 2.5%;
}

.tel_wapper dd span {
	color: #fff;
	background-color: #06286f;
	padding: 0 1.25%;
	font-size: 22px;
}

.tel_wapper dd strong {
	font-size: 22px;
	margin-left: 10px;
}

.tel_wapper dd a {
	color: #ff0000;
	line-height: 1;
	font-size: 58px;
	font-weight: 600;
	pointer-events: none;
}

.tel_wapper .note {
	font-size: 13px;
	margin-bottom: 1%;
}

.tel_wapper .time {
	font-size: 20px;
	font-weight: 600;
}

.tel_wapper .time span {
	background-color: #000;
	color: #fff;
	padding: 0 1%;
	margin-right: 1%;
}

/*--2023/07/20-------------------*/

.contBlock11 {
	background: url(/attending/media/princess/images/cont_new_bg01.png) no-repeat top 6% right calc(50% - 522px) / 288px, url(/attending/media/princess/images/cont_new_bg02.png) no-repeat bottom 10px left calc(50% - 522px), #e2ffe0;
	padding: 50px 0px 55px 0px;
	position: relative;
}
.contH201 {
	text-align: center;
	margin-bottom: 40px;
}
.contH201 img {
	width: auto;
	height: auto;
}
.contFlex1102 {
	display: flex;
	justify-content: space-between;
}
.contFlex1102 li {
	width: 32%;
	flex-shrink: 0;
	background-color: transparent;
}

.contBlock12 {
	/* background: url(/attending/media/princess/images/cont_new_bg03.png) no-repeat top 6% left calc(50% - 560px), url(/attending/media/princess/images/cont_new_bg04.png) no-repeat bottom 10px right calc(50% - 580px); */
	padding: 50px 0px 55px 0px;
	position: relative;
}
.contFlex12 {
	/*display: flex;*/
	justify-content: space-between;
}
.contFlex12 li {
	width: 32%;
	flex-shrink: 0;
	background-color: #ffffff;
}
.contFlex12 li .box01 {
	padding: 15px 20px 20px 20px;
}
.contFlex12 li .box01 dt {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: 80px;
	color: #78191c;
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	line-height: 1.3em;
	font-weight: bold;
}
.contFlex12 li .box01 dd {
	font-size: 16px;
	line-height: 1.85;
}

/*--2023 08 02-----------------*/

.contNewBg01 {
	position: absolute;
	top: 160px;
	left: 42%;
	margin-left: 452px;
}
.contNewBg01 img {
	width: auto;
	height: auto;
}

.contNewBg02 {
	position: absolute;
	/*top: 92px;*/
	bottom: 10px;
	right: 50%;
	margin-right: 400px;
}
.contNewBg02 img {
	width: auto;
	height: auto;
}

.contNewBg03 {
	position: absolute;
	bottom: 20px;
	left: 50%;
	margin-left: 452px;
}
.contNewBg03 img {
	width: auto;
	height: auto;
}

.note {
	margin-top: 10px;
	text-align: center;
}
.s03 {
	font-size: 16px;
	line-height: 1em;
	font-weight: bold;
	color: #ffffff;
	background-color: #05286e;
	border-radius: 30px;
	display: flex;
	align-items: center;
	box-sizing: border-box;
	height: 25px;
	padding: 2px 15px;
	display: inline-flex;
}
.time {
	font-size: 15px;
	white-space: nowrap;
}

small {
	display: inline-block;
}

/*-------------------------------
	2024/01/31 追加
--------------------------------*/

.mapNewImg01 {
	position: absolute;
	top: 60px;
	left: 40px;
}
.mapNewImg02 {
	position: absolute;
	top: 540px;
	left: 330px;
}
.mapNewImg03 {
	position: absolute;
	top: 400px;
	/*left: 300px;*/
	right: 0px;
}
.cruise_wapper {
	display: flex;
	align-items: flex-end;
	gap: 15px;
	position: absolute;
	top: 744px;
	left: 352px;
}
.map_txt span {
	display: inline;
	background: linear-gradient(transparent 60%, #fffbb3 0%);
	line-height: 1.5;
}
.mapNewContBox01 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	width: 680px;
	padding: 10px;
	border: 1px solid #05286e;
	background-color: #b5fbf9;
	/*position: absolute;
	right: 0px;
	bottom: 40px;*/
	margin: 0px auto 20px auto;
}
.mapNewFlexBox01 {
	width: 26%;
}
.mapNewFlexBox02 {
	width: 71%;
}
.mapNewFlexBox02 dt {
	color: #05286e;
	font-size: 21px;
	line-height: 1.1em;
	font-weight: bold;
	margin-bottom: 10px;
}
.mapNewFlexBox02 dd {
	font-size: 15px;
	line-height: 1.5em;
	font-weight: normal;
}

/*--2024/02/14 追加------------------*/


.contNewText02 {
	display: block;
	width: 700px;
	font-size: 16px;
	line-height: 1.5em;
	font-weight: normal;
	margin: 0 auto 30px;
}

.contFlex12 li .box01 dt .s01 {
	display: block;
	font-size: 14px;
}

.note.tal {
	text-align: left;
}

/* 2024/03/26追加 */
.schedule_close img {
	position: absolute;
	bottom: 22px;
	width: 84px;
	height: auto;
	left: calc(50% - 84px / 2);
}

.contBlock13 {
	margin-top: 70px;
}
.cpn__block {
	position: relative;
	width: 1024px;
	height: 679px;
	background: url(/attending/media/princess/images/cpn_SP24-059492D_SP24-009630D_SP24-037646D.png);
}
.cpn__block h3 {
	display: none;
}
.cpn__txt01 {
	display: block;
	width: 440px;
	font-size: 16px;
	line-height: 1.6;
	position: absolute;
	top: 247px;
	right: 40px;
}
.cpn__txt02 {
	width: 430px;
	font-size: 13px;
	font-weight: 300;
	position: absolute;
	top: 540px;
	left: 40px;
}
.cpn__txt02 p {
	text-indent: -1em;
	padding-left: 1em;
}

.posiRe01 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.ports {
	width: 500px;
	/*height: 660px;*/
	margin-bottom: 30px;
}
.contNewH301 {
	width: 100%;
}
.ports h3 {
	display: inline-block;
	color: #fff;
	background-color: #78191c;
	text-align: center;
	line-height: 28px;
	padding: 5px 5px;
	font-size: 24px;
	font-weight: 600;
	font-family: "Noto Serif JP", serif;
	position: relative;
	z-index: 1;
}
.ports h3 span {
	font-size: 16px;
}
.ports_block {
	/*margin-top: -30px;*/
	background: #ffffff;
	padding: 10px;
	display: flex;
	/*gap: 15px;*/
	height: 545px;
}
/* .ports.a .ports_block, .ports.b .ports_block{
    height: 595px;
} */
.ports_img01 {
	display: block;
	/*width: 310px;*/
}
.ports_wrap01 {
	width: 100%;
}
.ports_txt {
	margin-top: 15px;
	font-size: 14px;
}
.ports_txt2 {
	margin-top: 15px;
	font-size: 14px;
	border-top: 1px dashed #828282;
	padding-top: 15px;
}
/* .ports_txt2.bb{
	margin-bottom: 15px;
	border-bottom: 1px dashed #828282;
    padding-bottom: 15px;
} */
.red {
	color: #ff0000;
}
.blue {
	color: #0077e6;
}
.orange {
	color: #ff7800;
}
.fs12 {
	font-size: 12px;
}

.tourist {
	width: 1024px;
	/*height: 660px;*/
	margin-bottom: 30px;
}
.tourist h3 {
	display: inline-block;
	color: #fff;
	background-color: #78191c;
	text-align: center;
	line-height: 28px;
	padding: 5px 5px;
	font-size: 24px;
	font-weight: 600;
	font-family: "Noto Serif JP", serif;
	position: relative;
	z-index: 1;
}
.tourist h3 span {
	font-size: 16px;
}
.tourist_block {
	/*margin-top: -30px;*/
	background: #ffffff;
	padding: 20px;
	display: flex;
	gap: 15px;
	/* height: 420px; */
}
.tourist_img01 {
	/* position:relative; */
	display: block;
	width: 60%;
}
.tourist_img01 span {
	/* position:absolute; */
	bottom: 5px;
	right: 5px;
	display: block;
	padding: 3px 0px 0px;
	text-align: right;
	background: #fff;
	font-size: 12px;
	color: #333;
}
.tourist:nth-child(even) .tourist_block .tourist_img01 {
	order: 2;
}

.tourist_wrap01 {
	width: 40%;
	position: relative;
}
.tourist_ttl {
	/*margin-top: 15px;*/
	display: block;
	background-color: #d5faff;
	font-size: 30px;
	font-weight: 700;
	text-align: center;
	font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
	color: #05286e;
}
.tourist_ttl::before {
	content: "";
	background: url(/attending/media/princess/images/kazari.png) no-repeat;
	width: 20px;
	height: 43px;
	position: absolute;
	left: 2px;
	top: 2px;
}
.tourist_ttl::after {
	content: "";
	background: url(/attending/media/princess/images/kazari.png) no-repeat;
	width: 20px;
	height: 43px;
	position: absolute;
	right: 2px;
	top: 2px;
	transform: scale(-1, 1);
	/*display:inline-block;*/
}
.tourist_txt {
	margin: 10px 0px 14px;
	font-size: 16px;
}
.tourist_img-col {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 8px;
}
/* .tourist_img-col div{
	position:relative;
} */
.tourist_img-col div span {
	/* position:absolute; */
	bottom: 5px;
	right: 5px;
	display: block;
	padding: 3px 0px 0px;
	text-align: right;
	background: #fff;
	font-size: 12px;
	color: #333;
}

.tour-note[data-astro-cid-lcesmlr4] {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 30px;
	margin-bottom: 40px;
	padding: 50px;
	background-color: #fff;
}

.tour-note__header[data-astro-cid-lcesmlr4] {
	display: grid;
	gap: 20px;
}

.tour-note__h3[data-astro-cid-lcesmlr4] {
	position: relative;
	color: #06286f;
	font-family: "Noto Serif JP", serif;
	font-weight: 900;
	font-style: normal;
	font-size: 30px;
	transform: skew(-10deg);
	letter-spacing: -0.05em;
	line-height: 1.2;
	background: linear-gradient(transparent 75%, #fff8eb 50%);
}

.tour-note__h3[data-astro-cid-lcesmlr4]:before,
.tour-note__h3[data-astro-cid-lcesmlr4]:after {
	content: "";
	position: absolute;
	top: 4px;
	display: block;
	width: 16px;
	height: 32px;
	background: url(/attending/media/princess/images/deco_accent.svg) no-repeat center / contain;
}

.tour-note__h3[data-astro-cid-lcesmlr4]:before {
	left: -30px;
	transform: skew(10deg);
}

.tour-note__h3[data-astro-cid-lcesmlr4]:after {
	right: -30px;
	transform: rotate(180deg) skew(10deg);
}

.tour-note__caption[data-astro-cid-lcesmlr4] {
	color: #06286f;
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	font-style: normal;
	font-size: 20px;
	text-align: center;
	letter-spacing: -0.05em;
}

.tour-note__dl[data-astro-cid-lcesmlr4] {
	display: grid;
	grid-template-columns: 99px 1fr;
	align-items: center;
	column-gap: 16px;
	width: 100%;
}

.tour-note__logo[data-astro-cid-lcesmlr4] {
	grid-area: 1 / 1 / 3 / 2;
}

.tour-note__title[data-astro-cid-lcesmlr4] {
	grid-area: 1 / 2 / 2 / 3;
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	font-style: normal;
	font-size: 24px;
	letter-spacing: -0.05em;
}

.tour-note__text[data-astro-cid-lcesmlr4] {
	grid-area: 2 / 2 / 3 / 3;
	font-size: 14px;
}

.tour-note__note[data-astro-cid-lcesmlr4] {
	display: block;
	width: 100%;
	margin-top: -10px;
	font-size: 14px;
}

.global__gold-frame {
	border: 1px solid;
	border-image: linear-gradient(to bottom, #b28836, #fff7cc, #b28836) 1;
}

/*タブ*/
.tabBlock{
	background-color: #f4ffe5;
	/* padding-top: 30px; */
}
.tabs {
	display: flex;
	width: 1024px;
	margin: 0 auto 0;
    justify-content: center;
	gap: 20px;
}

.tab-contents {
	display: none;
}

.tab-contents.active {
	display: block;
}

.JS_tab:hover{
	cursor: pointer;
}

.tab1,
.tab2 {
    flex-grow: 1;
    padding: 25px 0;
    list-style: none;
    text-align: center;
    border-radius: 20px 20px 0 0;
    transition: all 0.3s ease;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 0.07em;
    background: #f5f5f5;
}
.tab1 {
    color: #aeaeae;
	/*color:#777;*/
	cursor: pointer;
/*
    border-top: 2px #237daf solid;
    border-left: 2px #237daf solid;
    border-right: 2px #237daf solid;
*/
}
.tab1:hover,
.tab1.active {
	background-color: #d6edf7;
    transition: all 0.2s ease-out;
    opacity: 1;
    border: none;
	color: #237daf;
}
.tab2 {
    color: #aeaeae;
	cursor: pointer;
/*	
    border-top: 2px #3CC4D0 solid;
    border-left: 2px #3CC4D0 solid;
    border-right: 2px #3CC4D0 solid;
*/
}
.tab2:hover,
.tab2.active {
	background-color: #d1daf1;
    transition: all 0.2s ease-out;
    opacity: 1;
    border: none;
	color: #4a5a84;
}
#tab1,
#tab2 {
	position: relative;
}
.tab1.active,
.tab2.active {
	cursor: auto;
}
/* #tab1::after,
#tab2::after {
	content:'';
	width: 100%;
	height: 100%;
	inset: 0;
	position: absolute;
} */
/* #tab1::after {
	border: 15px solid #d6edf7;
}
#tab2::after {
	border: 15px solid #d1daf1;
} */
#tab1 {
	/* border: 20px solid #d6edf7; */
	background-color: #d6edf7;
}
#tab2 {
	/* border: 20px solid #d1daf1; */
	background-color: #d1daf1;
}
.cts_mainTtl_group {
	font-family: "Noto Serif JP", serif;
	width: 1024px;
	margin: 0 auto 20px;
	font-feature-settings: "palt"1;
}
.cts_mainTtl {
	font-size: 46px;
	line-height: 1.1;
	font-weight: 700;
    text-align: center;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	text-shadow: 
	0px  0px 15px #fff,
	-0px  0px 15px #fff,
	0px -0px 15px #fff,
	-0px -0px 15px #fff
	;
	padding: 50px 0 30px;
	color: #05286e;
}
#tab1 .cts_mainTtl {
	color: #237daf;
}
#tab2 .cts_mainTtl {
	color: #4a5a84;
}
.cts_mainTtl > img {
	position: relative;
	top: 10px;
	left: -20px;
	width: 80px;
}
.cts_subTtl {
	font-size: 24px;
	line-height: 1.2;
	font-weight: 700;
	text-align: center;
	margin-bottom: 10px;
}
.cts_place_list {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	filter: drop-shadow(2px 3px 3px rgba(0, 0, 0, 0.4));

}
.cts_place {
	font-size: 20px;
	line-height: 1.2;
	font-weight: 700;
	text-align: center;
	color: #fff;
	background-color: #05286e;
	padding: 7px 0;
	width: 100%;
	border-radius: 3px;
}



.port_ttlWrap {
	margin: 20px auto 0;
}
.port_ttlWrap .contH2 {
	margin-bottom: 0;
}
/* .port_ttlWrap {
	background-color: #05286e; 
	padding: 10px 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.port_ttl {
	color: #f7e6a0; 
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	font-weight: bold;
	margin: 0 20px;
	display: flex;
	align-items: center;
	white-space: nowrap;
}


.port_ttl::before,
.port_ttl::after {
	content: "";
	height: 1.5px; 
	width: 100px;  
	display: block;
}


.port_ttl::before {
  margin-right: 15px;
  background: linear-gradient(to left, #f7e6a0, transparent);
}


.port_ttl::after {
  margin-left: 15px;
  background: linear-gradient(to right, #f7e6a0, transparent);
} */



.sightFlex01{
	position: relative;
	display: flex;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}
.sightFlex01 li {
	background-color: #ffffff;
	width: 328px;
}
.sightFlex01 li:has(.map) {
	background: none;
}
.sightFlex01 li img {
	width: 328px;
	height: 200px;
	object-fit: cover;
}
.sightFlex01 .pht.clip02 img {
	height: 183px;
}
.sightFlex01 li.main_pht {
	width: 676px;
}
.sightFlex01 li.main_pht img {
	width: 676px;
	height: 330px;
	object-fit: cover;
}
.sightFlex01 li.main_pht .pht.clip {
	position: absolute;
	top: -70px;
    left: 560px;
}
.sightFlex01 li.main_pht .pht.clip img {
	height: auto;
	object-fit: contain;
}
.sightFlex01 .pht.clip img {
	height: auto;
	object-fit: contain;
}
.sightFlex01 li.column02 {
	width: 502px;
}
.sightFlex01 li.column02 img {
	width: 502px;
	height: 300px;
	object-fit: cover;
}
#port_kochi .sightFlex01 li.main_pht .pht.clip img {
	width: 130px;
}
#port_nagasaki02 .sightFlex01 li.main_pht .pht.clip img {
	width: 150px;
}
#port_pusan .sightFlex01 .pht.clip,
#port_sakaiminato .sightFlex01 .pht.clip {
	position: absolute;
	bottom: 0;
    left: 400px;
	z-index: 1;
}
#port_pusan .sightFlex01 .pht.clip img,
#port_sakaiminato .sightFlex01 .pht.clip img {
	/* width: fit-content; */
}
#port_pusan .sightFlex01 li .pht.clip img {
	width: 197px;
}
#port_sakaiminato .sightFlex01 li .pht.clip img {
	width: 195px;
}
#port_pusan .pht .copyright,
#port_sakaiminato .pht .copyright {
	text-align: center;
	margin: auto;
	inset: auto 0 5px;
}

.sightFlex01 .map {
	width: 328px;
	height: auto;
	background: none;
	/* background-color: #f0e4cc; */
	margin-bottom: 20px;
}
.sightFlex01 .map img {
	width: 328px;
	height: auto;
	object-fit: contain;
}
.sightFlex01 li .box01 {
	padding: 15px 0px;
	background-color: #fff;
}
.sightFlex01 li .box01 .contH303 {
}
.sightFlex01 li .box01 .contText16_185_n {
	padding: 0 20px;
}
.contH303 {
	font-family: 'Noto Serif JP', serif;
	font-weight: bold;
	text-align: center;
	color: #05286e;
	margin-bottom: 5px;
}
.contH303 .s01 {
	display: block;
	font-size: 14px;
	line-height: 1.4em;
	/* padding-top: 10px; */
}
.contH303 .s02 {
	display: block;
	font-size: 24px;
	line-height: 1.4em;
}
.contText16_185_n {
	font-size: 16px;
	line-height: 1.7;
}


.posiWrap01 {
	position: relative;
}
.posiWrap01 .badges {
	position: absolute;
	top: 30px;
	right: 0;
	display: flex;
	gap: 10px;
}
.posiWrap01 .badge_il {
	font-family: 'Noto Serif JP', serif;
	font-size: 16px;
	line-height: 1.4;
	color: #c7000a;
	background-color: #ffffff;
	border: 1px solid #c7000a;
	padding: 5px 10px;
}
.posiWrap01 .badge_il > img {
	position: relative;
	top: 0;
	height: 1em;
	width: auto;
	vertical-align: -2px;
}
.posiWrap01 .badge_txt {
	font-family: 'Noto Serif JP', serif;
	font-size: 16px;
	line-height: 1.4;
	color: #fff;
	background-color: #c7000a;
	border: 1px solid #7c0006;
	padding: 5px 10px;
}
#port_sakaiminato {}
.sight__il_ship01 {
	font-size: 24px;
	color: #fff;
	position: relative;
	width: 166px;
	height: 93px;
	z-index: 1;
	display: flex;
    justify-content: center;
    align-items: flex-end;
	font-weight: 600;
	margin-top: 10px;
}
.sight__il_ship01 img {
	position: absolute;
	width: 100%;
	inset: 0;
	margin: auto;
	z-index: -1;
}

.sightDeco01 {
	position: absolute;
	left: -86px;
	bottom: -40px;
}
.sightDeco02 {
	position: absolute;
	top: -60px;
	right: -114px;
}

.sightDeco03 {
	position: absolute;
	right: -100px;
	bottom: -44px;
}

.sightBox01 {
	background-color: #076e0c;
	border-radius: 24px;
	padding: 5px;
	margin-top: 50px;
}
.sightBox01In {
	border: 2px solid #eaf89f;
	border-radius: 20px;
	padding: 30px;
}
.sightH301 {
	margin-bottom: 40px;
}
.sightText01 {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 15px;
}
.sightText01 .p01 {
	font-size: 24px;
	line-height: 1.9em;
	font-weight: bold;
	color: #076e0c;
	background-color: #eaf89f;
	padding: 2px 18px;
	margin-right: 7px;
}
.sightText01 .p02 {
	font-size: 24px;
	line-height: 1.9em;
	font-weight: bold;
	color: #eaf89f;
}
.sightText02 {
	text-align: center;
	color: #ffffff;
	font-size: 16px;
	line-height: 1.6em;
}

.sightText03 {
	background-color: #78191c;
	padding: 3px 10px;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 106px;
	height: 35px;
	color: #ffffff;
	font-family: 'Noto Serif JP', serif;
	font-size: 20px;
	line-height: 1.0em;
	position: absolute;
	top: 0px;
	left: 0px;
}

.sightFlex02 {
	display: flex;
	justify-content: space-between;
	margin: 34px auto 28px;
}
.sightFlex02 li {
	width: 32.5%;
	background-color: #ffffff;
}
.sightFlex02 li .box01 {
	padding: 13px;
}

.sightColBlue {
	color: #44aaff;
}
.sightColOre {
	color: #ff8a44;
}
.sightColOre02 {
	color: #ff4444;
}
.sightText04 {
	color: #ffffff;
	font-size: 14px;
	line-height: 1.5em;
}

.contBlock114 {
	background-color: #f9fede;
	padding: 55px 0px 60px;
}



.cruiseBlock {
	background-color: #ffffff;
    padding: 30px 38px 30px 38px;
    margin-bottom: 40px;
}
.cruiseBlock__h {
	color: #05286e;
	font-size: 30px;
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
}
.cruiseBlock__rank {
	display: flex;
	gap: 20px;
	border: 2px solid #05286e;
}
.cruiseBlock__h .ship_of_year img {
	width: 530px;

}
.cruiseBlock__rank .ttl {
	background-color: #05286e;
	color: #fff;
	padding: 5px 10px;
	font-size: 18px;
	line-height: 1.2;
	font-weight: 600;
	margin-bottom: 10px;
}
.cruiseBlock__rank .txt {
	font-size: 16px;
    line-height: 1.8;
    letter-spacing: -0.05em;
	padding-left:10px;
}
.cruiseBlock__rank .pht img {
	width: 390px;

}
.cruiseBlock__h {
	font-size:22px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 20px;
	margin-bottom: 10px;
}
.cruiseBlock__box01 {
	display: flex;
	justify-content:center;
	gap:10px;
}
.cruiseBlock__box01 .txt {

}
.cruiseBlock__box01 .pht img {
	width: 300px;
	height: 200px;
    object-fit: cover;
}
.cruiseBlock__box01 .pht {

}
.cruiseBlock__box02 {
	display: flex;
	justify-content:center;
	gap:30px;
}
.cruiseBlock__box02_inner {
}
.cruiseBlock__box02_inner .flex{
	display: flex;
	gap: 10px;
}
.cruiseBlock__box02 .cruiseBlock__h {
	
}
.cruiseBlock__box02 .pht img {
	width: 280px;
    height: 160px;
    object-fit: cover;
}
.cruiseBlock__box02 .txt {

}
.cruiseBlock__box02 .cruiseBlock__h {

}
.cruiseBlock__box02 .pht {

}
.cruiseBlock__box02 .txt {

}

.contFlex13 {
	display: flex;
	gap: 20px;
}
.contFlex13 > div {
	width: 464px;
}
.contFlex13 .box01 .pht img {
	object-fit: cover;
	height: 300px;
}
.contFlex13 .floor img {
	/* object-fit: contain;
	height: 300px; */
}
.contFlex13 .contText02 {
	text-align: center;
}
.contFlex13 .contH301 {
	text-align: center;
	margin-bottom: 14px;
}
.pointBlock {
	padding: 50px 0px 55px 0px;
	background-color: #f4ffe5;
}

.charm_bg {
	/* background-color: #fff8dc; */
    padding: 25px 0 0;
}
.charm .txt_imgs {
	width: 1024px;
	display: flex;
	justify-content: space-between;
	position: relative;
	padding: 0;
}
.charm .badge img {
	position: absolute;
	inset: 280px 0 0;
	margin: 0 auto;
	width: 280px;
	height: 280px;
}
.charm .txt_img {
	width: 500px;
}

.point {
}
.point .ttl {
	background-color: #005686;
	padding: 20px 0;
	margin: 20px 20px 0px;
}
.point .ttl img {
	width: 800px;
	margin: 0 auto;
	display: block;
}
.point .txt_img {
    margin: 10px auto;
}
.present img {
	margin: 40px auto 0;
}

/* .seo_ttl img {
	font-size: 24px;
	font-family: "Noto Serif JP", serif;
	font-weight: 600;
	line-height: 1;
	text-align: center;
	position: relative;
	color: #c7af7c;
	background: linear-gradient(0deg, #988d25, #d2c79c 50%, #988d25);
	background: -webkit-linear-gradient(90deg, #988d25, #d2c79c 50%, #988d25);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
} */
.seo_ttl {
	margin: 20px auto;
	height: 36px;
}
.seo_ttl img {
	height: 36px;
	width: auto;
}
.seo_ttl::before ,
.seo_ttl::after {
	content: '';
	background-color: #c7af7c;
	width: 300px;
	height: 1px;
	position: absolute;
}
.seo_ttl::after {
	right: 10px;
	top: calc(36px + 2px);
}
.seo_ttl::before {
	left: 10px;
	top: calc(36px + 2px);
}

.drinkpack {

}
.mealFlex05 {
	margin-top: 30px;
	font-family: "Noto Serif JP", serif;
	text-align: center;
}
.mealFlex05 .header {
	background-color: #005687;
	padding: 20px 0;
	line-height: 1.6;
	font-weight: 700;
	font-size: 28px;
	color: #fff;
	position: relative;
}
.mealFlex05 .bubble {
	font-family: initial;
	position: absolute;
	inset: -40px auto auto 10px; 
	padding: 7px 10px;
	border: 2px solid #78181c;
	border-radius: 6px;
	background-color: #ffffff;
	text-align: center;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.3;
	color: #78181c;
	letter-spacing: 0;
	rotate: -6deg;
}

.mealFlex05 .bubble::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 66%;
	border-style: solid;
	border-width: 16px 0 0 16px;
	border-color: #78181c transparent transparent;
	translate: -50% 100%;
}

.mealFlex05 .bubble::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 66%;
	border-style: solid;
	border-width: 11.2px 0 0 11.2px;
	border-color: #ffffff transparent transparent;
	translate: calc(-50% + 0.4px) 100%;
}
.mealFlex05 .ttl {
	font-weight: 700;
	font-size: 24px;
	color: #005687;
	margin: 10px auto;
}
.mealFlex05 .txt {
	margin-bottom: 20px;
}
#meal_speciality .note{
	font-size: 12px;
	text-align: right;
}

