@charset "UTF-8";

/*  pc  */
@media screen and (min-width: 1200px) {
	#title {
		width: 100%;
		background: linear-gradient(150deg, #f7e3c4 0%, #f7e3c4 50%, #b4c3fe 50%, #b4c3fe 100%);
	}
}

/*  TB	*/
@media screen and (min-width: 768px) and (max-width: 1200px) {
	#title {
		width: 100%;
		background: linear-gradient(150deg, #f7e3c4 0%, #f7e3c4 50%, #b4c3fe 50%, #b4c3fe 100%);
	}
}

/*  SP	*/
@media screen and (max-width: 767px) {
	#title {
		width: 100%;
		background: linear-gradient(180deg, #f7e3c4 0%, #f7e3c4 20%, #b4c3fe 80%, #b4c3fe 100%);
	}
}

#tubasa img,
#insatu th img,
#meishi img,
#nenga img {
	margin: 0 auto;
}

#polo td img,
#lont td img,
#tsyatu td img,
#bag td img {
	width: 30%;
	height: auto;
	margin: 0 auto;
}

#polo ul,
#lont ul.kome,
#tsyatu ul.kome,
#bag ul.kome {
	list-style: none;
	margin-left: -2em;
}

#kanbatti ul.kome {
	list-style: none;
	margin-left: -4em;
}

#kanbatti ol {
	margin-left: 0em;
}

#polo ul.kome li {
	position: relative;
	font-size: 1.2em;
	padding-left: 2em;
}

#kanbatti ul.kome li {
	position: relative;
	font-size: 1em;
	padding-left: 2em;
}

#lont ul.kome li,
#tsyatu ul.kome li,
#bag ul.kome li {
	position: relative;
	font-size: 1.4em;
	padding-left: 2em;
}

#kanbatti ol li {
	position: relative;
	font-size: 1.4em;
	padding-left: 1em;
}

#polo ul.kome li::before,
#lont ul.kome li::before,
#tsyatu ul.kome li::before,
#bag ul.kome li::before,
#kanbatti ul.kome li::before {
	position: absolute;
	content: "※";
	left: 0;
}

#polo table.siz {
	margin-top: 20px;
}

#bag .table.tot tbody>tr>th.no {
	width: 5%;
	vertical-align: middle;
	text-align: center;
}

#bag .table.tot tbody>tr>td.tot {
	width: 15%;
	vertical-align: middle;
	text-align: center;
}

#bag .table.tot tbody>tr>td.tname {
	width: 45%;
	vertical-align: middle;
}


#insatu .table tbody>tr>td.quarter {
	width: 20%;
}

#insatu .table tbody>tr>th,
#insatu .table tbody>tr>td.half {
	width: 20%;
}

#kanbatti .table thead>tr>th,
#kanbatti .table tbody>tr>th {
	width: 30%;
	text-align: center;
}

#kanbatti .table tbody>tr>td,
#kanbatti .table thead>tr>td {
	width: 60%;
	text-align: right;
}

#insatu .table tbody>tr>td {
	width: 30%;
}

#nagare h3,
#insatu h3,
#meishi h3,
#nenga h3,
#polo h3,
#lont h3,
#tsyatu h3,
#bag h3,
#band h3,
#kanbatti h3,
#shiori h3,
#postcard h3,
#letter h3,
#iyashi h3 {
	font-size: 1.6em;
	padding: 5px 0;
	font-weight: normal;
	border: 2px solid transparent;
	border-radius: 5px;
	background-color: #b4c3fe;
	margin-bottom: 10px;
	text-align: center;
}

#kanbatti h5 span {
	position: absolute;
	right: 15px;
	bottom: 0;
}

.price {
	font-size: 1.4em;
	font-weight: bold;
	text-align: center;
}

#shiori .box {
	color: #000;
	background-color: #bfffdf;
	font-weight: bolder;
	border: 2px dashed transparent;
	border-radius: 5%;
	font-size: 1em;
}

#bag h4 {
	padding: 0.25em 0.5em;
	color: #494949;
	background-color: transparent;
	border-left: solid 5px #b4c3fe;
}

#insatu h4,
#meishi h4,
#polo h4,
#lont h4,
#kanbatti h4,
#tsyatu h4,
#bag h5,
#band h4,
#kanbatti h4 {
	font-size: 1.4em;
	position: relative;
	padding-left: 25px;
}

#insatu h4::before,
#meishi h4::before,
#polo h4::before,
#lont h4::before,
#tsyatu h4::before,
#bag h5::before,
#band h4::before,
#kanbatti h4::before {
	position: absolute;
	content: '';
	bottom: -3px;
	left: 0;
	width: 0;
	height: 0;
	border: none;
	border-left: solid 15px transparent;
	border-bottom: solid 15px #b4c3fe;
}

#insatu h4::after,
#meishi h4::after,
#polo h4::after,
#lont h4::after,
#tsyatu h4::after,
#bag h5::after,
#band h4::after,
#kanbatti h4::after {
	position: absolute;
	content: '';
	bottom: -3px;
	left: 10px;
	width: 100%;
	border-bottom: solid 3px #b4c3fe;
}

p.small,
li.small,
#bag .table.tot td.small {
	font-size: 1em;
}

#meishi,
#nenga,
#lont,
#tsyatu,
#bag,
#band,
#shiori,
#postcard,
#letter,
#iyashi {
	padding-top: 150px;
	margin-top: -150px;
}

#meishi ul {
	padding: 0;
	list-style-type: none;
}

#meishi ul li {
	position: relative;
	padding-left: 25px;
	font-size: 1.5em;
	line-height: 2;
}

#meishi ul li::before {
	position: absolute;
	left: 0;
	font: var(--fa-font-solid);
	content: "\f105";
	font-size: 0.8em;
	line-height: 2;
	color: #804000;
	background-color: transparent;
}

#meishi ul li span {
	position: absolute;
	top: 0.5em;
	right: 0.5em;
	bottom: 0;
}

#tubasa-access a:link {
	color: #00f;
	background-color: transparent;
}

#tubasa-access a:hover {
	color: #f00;
	background-color: transparent;
}

.ruby_flag {
	#bag h5 ruby[data-ruby]::before {
		bottom: 100%
	}
}

/*  pc  */
@media (min-width: 1200px) {

	#polo .table.col tbody>tr>th,
	#lont .table.col tbody>tr>th.no,
	#tsyatu .table.col tbody>tr>th.no {
		width: 5%;
		vertical-align: middle;
		text-align: center;
	}

	#polo .table.col tbody>tr>td.sam,
	#lont .table.col tbody>tr>td.sam,
	#tsyatu .table.col tbody>tr>td.sam,
	#polo .table.siz thead>tr>th,
	#polo .table.siz thead>tr>td,
	#polo .table.siz tbody>tr>th,
	#polo .table.siz tbody>tr>td,
	#lont .table.siz tbody>tr>th,
	#lont .table.siz tbody>tr>td,
	#tsyatu .table.siz tbody>tr>th,
	#tsyatu .table.siz tbody>tr>td {
		width: 10%;
		vertical-align: middle;
	}

	#polo .table.col tbody>tr>td.cor,
	#lont .table.col tbody>tr>td.cor,
	#tsyatu .table.col tbody>tr>td.cor {
		width: 15%;
		vertical-align: middle;
		font-size: 1em;
	}

	#polo .table.siz tbody>tr>th span,
	#polo .table.siz tbody>tr>td span,
	#lont .table.siz tbody>tr>th span,
	#lont .table.siz tbody>tr>td span,
	#tsyatu .table.siz tbody>tr>th span,
	#tsyatu .table.siz tbody>tr>td span {
		display: none;
	}

	#nagare dl {
		display: flex;
		flex-wrap: wrap;
		width: 100%;
	}

	#nagare dt {
		width: 35%;
		height: 35px;
		font-size: 1.4em;
		text-align: center;
		padding-top: 10px;
		border-bottom: #b4c3fe 2px solid;
		margin-right: 5%;
	}

	#nagare dd {
		width: 60%;
		padding-top: 10px;
		font-size: 1.4em;
	}
}

/*  TB	*/
@media screen and (min-width: 768px) and (max-width: 1200px) {

	#polo .table.col tbody>tr>th,
	#lont .table.col tbody>tr>th.no,
	#tsyatu .table.col tbody>tr>th.no {
		width: 5%;
		vertical-align: middle;
		text-align: center;
	}

	#polo .table.col tbody>tr>td.sam,
	#lont .col td.sam,
	#tsyatu .col td.sam,
	#polo .table.siz tbody>tr>th,
	#polo .table.siz tbody>tr>td,
	#lont .table.siz tbody>tr>th,
	#lont .table.siz tbody>tr>td,
	#tsyatu .table.siz tbody>tr>th,
	#tsyatu .table.siz tbody>tr>td {
		width: 10%;
		vertical-align: middle;
	}

	#polo .table.siz tbody>tr>th,
	#lont .table.siz tbody>tr>th,
	#tsyatu .table.siz tbody>tr>th {
		font-size: 1em;
	}

	#polo .table.col tbody>tr>td.cor,
	#lont .table.col tbody>tr>td.cor {
		width: 35%;
		vertical-align: middle;
		font-size: 1em;
	}

	#tsyatu .table.col tbody>tr>td.cor {
		width: 15%;
		vertical-align: middle;
		font-size: 1em;
	}

	#polo .table.siz tbody>tr>th span,
	#polo .table.siz tbody>tr>td span,
	#lont .table.siz tbody>tr>th span,
	#lont .table.siz tbody>tr>td span,
	#tsyatu .table.siz tbody>tr>th span,
	#tsyatu .table.siz tbody>tr>td span {
		display: none;
	}

	#shiori .box {
		width: 40%;
		margin-left: 5%;
	}

	#nagare dl {
		display: flex;
		flex-wrap: wrap;
		width: 100%;
	}

	#nagare dt {
		width: 45%;
		height: 35px;
		font-size: 1.4em;
		text-align: center;
		padding-top: 10px;
		border-bottom: #b4c3fe 2px solid;
		margin-right: 5%;
	}

	#nagare dd {
		width: 50%;
		padding-top: 10px;
		font-size: 1.4em;
	}
}

/*  SP	*/
@media screen and (max-width: 767px) {
	#insatu .table {
		max-width: 95%;
	}

	#insatu .table>tbody>tr>th {
		width: 10%;
		padding-right: 0;
	}

	#insatu .table>tbody>tr>td.text-center {
		width: 30%;
		padding-right: 0;
	}

	#insatu .table>tbody>tr>td.text-right {
		width: 10%;
		padding-right: 0;
	}

	#meishi ul li span {
		position: absolute;
		top: 1.5em;
		right: 0.5em;
		bottom: 0;
	}

	#polo .table.col tbody>tr>th,
	#lont .table.col tbody>tr>th.no,
	#tsyatu .table.col tbody>tr>th.no {
		width: 10%;
		vertical-align: middle;
		text-align: center;
	}

	#polo .table.col tbody>tr>td.sam,
	#lont .table.col tbody>tr>td.sam,
	#tsyatu .table.col tbody>tr>td.sam,
	#polo .table.siz tbody>tr>th,
	#lont .table.siz tbody>tr>th,
	#lont .table.siz tbody>tr>td,
	#tsyatu .table.siz tbody>tr>th,
	#tsyatu .table.siz tbody>tr>td #bag td.tot {
		width: 20%;
		vertical-align: middle;
	}

	#polo .table.siz thead>tr>th,
	#lont .table.siz thead>tr>th,
	#tsyatu .table.siz thead>tr>th {
		display: none;
	}

	#polo .table.siz tbody>tr>th,
	#lont .table.siz tbody>tr>th,
	#tsyatu .table.siz tbody>tr>th {
		display: block;
		width: 100%;
	}

	#polo .table.siz tbody>tr>td,
	#lont .table.siz tbody>tr>td,
	#tsyatu .table.siz tbody>tr>td {
		display: inline-block;
		width: 50%;
	}

	#polo .table.col tbody>tr>td.cor,
	#lont .table.col tbody>tr>td.cor,
	#tsyatu .table.col tbody>tr>td.cor #bag td.tname {
		width: 35%;
		vertical-align: middle;
		font-size: 1em;
	}

	#tubasa-access span {
		width: 5.5em;
	}

	#tubasa-access a {
		font-size: 0.8em;
	}

	#shiori .box {
		width: 80%;
		margin-left: 10%;
	}

	#nagare dt {
		width: 100%;
		margin-top: 5px;
		display: block;
		font-size: 1.4em;
		text-align: center;
		border-bottom: #b4c3fe 2px solid;
	}

	#nagare dd {
		width: 100%;
		display: block;
		font-size: 1.4em;
		text-align: center;
	}

	#kanbatti .table {
		width: 95%;
	}

	#kanbatti .table thead>tr>th,
	#kanbatti .table tbody>tr>th {
		display: inline-block;
		width: 45%;
	}

	#kanbatti .table thead>tr>td,
	#kanbatti .table tbody>tr>td {
		display: inline-block;
		width: 55%;
	}

	.ruby_flag {

		#nagare dt,
		#nagare dd {
			padding-top: 15px;
		}

		#kanbatti ol li,
		#kanbatti ul.kome li {
			margin-right: 0.5em;
		}
	}
}

.ruby_flag {
	section img {
		margin-bottom: 1.2em;
	}

	#meishi ul li span,
	.table td.text-right {
		padding-right: 0.5em;
	}

	#nagare h3,
	#insatu h3,
	#meishi h3,
	#nenga h3,
	#polo h3,
	#lont h3,
	#tsyatu h3,
	#bag h3,
	#band h3,
	#kanbatti h3,
	#shiori h3,
	#postcard h3,
	#letter h3,
	#iyashi h3 {
		padding: 0.75em 0 0.25em 0;
	}

	#shiori p {
		padding: 0.75em 0 0 0;
		line-height: 1.8;
	}
}