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


/*---------------------------------------------------------------------
	loader
---------------------------------------------------------------------*/ 
#loader-bg {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    background: #F8F8F8;
    z-index: 10000;
}
#loading{
    position: absolute;
    left: 50%;
    top: 40%;
}

.spinner {
    position: relative;
    width: 45px;
    height: 45px;
    margin: 0 auto;
}

.bubble-1,
.bubble-2 {
    position: absolute;
    top: 0;
    width: 25px;
    height: 25px;
    border-radius: 100%;
    background-color: #FFE43F;
}

.bubble-2 {
    top: auto;
    bottom: 0;
}

.load-9 .spinner {animation: loadingI 2s linear infinite;}
.load-9 .bubble-1, .load-9 .bubble-2 {animation: bounce 2s ease-in-out infinite;}
.load-9 .bubble-2 {animation-delay: -1.0s;}

@keyframes loadingI {
    100% {transform: rotate(360deg);}
}
@keyframes bounce  {
  0%, 100% {transform: scale(0.0); opacity: 0; }
  50% {transform: scale(1.0); opacity: 1; }
}

/*---------------------------------------------------------------------
	site_header
---------------------------------------------------------------------*/ 
#site_header { padding: 10px 20px 15px;}

.site_logo { float: left; }
.site_logo a { display: block; }

.header_list {
    float: right;
}

.header_menu {
	text-align: right;
	margin-bottom: 15px;
}
.header_menu > * {
	text-align: left;
	display: inline-block;
	vertical-align: middle;
	margin-left: 5px;
}

.site_lead { font-size: 12px; }

.search_form {
	background: #fff;
	border: 1px solid #ccc;
	position: relative;
}
#site_header .search_form {
	background: #F8F8F8;
	width: 180px;
}
.search_form .search_window {
    border: none;
	padding: 10px 30px 10px 8px;
    font-size: 12px;
	width: 100%;
	background: none;
}
.search_form .serch_button {
	width: 18px;
	height: 18px;
	position: absolute;
	right: 8px;
	top: 9px;
	text-indent: -9999px;
	border: none;
	background: rgba(0,0,0,0) url(../image/icon_search.png) no-repeat center center;
	background-size: 18px;
}
.search_form .serch_button:hover { opacity: .5; }


.lang_chang {
	border: 1px solid #ccc;
	padding: 0 10px;
	background-color: #fff;
	display: none !important;
}
.lang_chang li {
	display: inline-block;
	vertical-align: middle;
}
.lang_chang li a {
    color: #000;
    font-size: 14px;
    text-decoration: none;
    font-weight: bold;
    display: block;
    padding: 7px 8px 9px;
}
.lang_chang li a.active {
	background: url(../image/icon_cycle_01.png) no-repeat center center;
	background-size: 30px auto;
}

.g_navi {
	width: 822px;
	display: table;
	table-layout: fixed;
}
.g_navi li {
	display: table-cell;
	vertical-align: middle;
	border-right: 1px solid #aaa;
}
.g_navi li:first-child { border-left: 1px solid #aaa; }
.g_navi li a {
	color: #000;
	font-size: 16px;
	font-weight: bold;
	display: block;
	text-align: center;
	text-decoration: none;
	padding: 10px;
	transition: .3s;
}

.g_navi li a:hover {
	color: #C51015;
	background-color: #FBEEEE;
}

/*---------------------------------------------------------------------
	topic_path_top
---------------------------------------------------------------------*/
.topic_path_top {
	color: #fff;
	background-color: #000;
}
.topic_path_top > ol {
	font-size: 13px;
	font-size: 1.3rem;
	box-sizing: content-box;
    margin: 0 auto;
    max-width: 1200px;
    padding: 6px 15px;
}
.topic_path_top > ol > li { display: inline-block; }
.topic_path_top > ol > li + li::before {
	content: ">";
	margin: 0 5px;
}
.topic_path_top > ol > li a { color: #fff; text-decoration: underline; }
	
/*---------------------------------------------------------------------
	pagebody
---------------------------------------------------------------------*/
.body_inner {
    margin: 0 auto;
    width: 1200px;
	padding: 60px 0;
}
.body_inner_02 {
    margin: 0 auto;
    width: 920px;
	padding: 60px 0;
}
.bg_body_inner {
	background: url(../image/bg_02.jpg);
	margin-bottom: 40px;
}
.bg_body_inner_02 {
    background: #F6F6F6;
}
.page_ttl + .bg_body_inner,
.page_ttl + .bg_body_inner_02 { /*margin-top: -40px;*/ }

#alpha { float: left; width: 920px; }
#beta { float: right; width:  220px; }

/*--------- text -----------*/
.page_ttl {
	color: #fff;
	background: no-repeat center top fixed;
	background-image: url(/userfiles/images/bg_ttl_default.jpg);
	background-size: 100% auto;
	background-size: cover;
	text-align: center;
	display: table;
	width: 100%;
	height: 400px;
	/*margin-bottom: 40px;*/
}
	/* ページごと */
	.item_id_campaign .page_ttl { background-image: url(/userfiles/images/bg_ttl_campaign.jpg); background-position: center -150px; }
	.item_id_shop .page_ttl { background-image: url(/userfiles/images/bg_ttl_shop.jpg); }
	.item_id_lineup .page_ttl { background-image: url(/userfiles/images/bg_ttl_lineup.jpg); }
	.item_id_gallery .page_ttl { background-image: url(/userfiles/images/bg_ttl_gallery.jpg); }
	.item_id_about_awamori .page_ttl { background-image: url(/userfiles/images/bg_ttl_about_awamori.jpg); }
	.item_id_recruit .page_ttl { background-image: url(/userfiles/images/bg_ttl_recruit.jpg); background-position: center -150px; }
	.item_id_topics .page_ttl { background-image: url(/userfiles/images/bg_ttl_topics.jpg); background-position: center -150px; }

.page_ttl .inner {
	display: table-cell;
	vertical-align: middle;
	background-color: rgba(0,0,0,.5);
}
.page_ttl .ttl {
	font-size: 38px;
	font-weight: bold;
}

.content1 p { margin: 0.5em 0 1em; line-height: 2.2; }
.content1 h2 + p,
.content1 h3 + p,
.content1 h4 + p,
.content1 h5 + p,
.content1 h6 + p { margin-top: 0; }
.content1 div > p { margin-top: 0; }

/* headline */
.content1 * + h2 { margin-top: 120px; }
.content1 * + h3 { margin-top: 50px; }
.content1 * + h4 { margin-top: 40px; }
.content1 * + h5 { margin-top: 20px; }
.content1 h2 + h3,
.content1 h3 + h4 { margin-top: 0 }

/* utility */
.content1 * + dl,
.content1 * + ol,
.content1 * + ul,
.content1 * + table { margin-top: 20px; }



.lead_01 {
	color: #000;
	font-size: 38px;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
	position: relative;
	padding: 8px 0 22px;
	margin-bottom: 35px;
}
.lead_01::before {
	content: "";
	width: 54px;
	height: 3px;
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -27px;
	background-color: #999999;
}
.lead_01::after {
	content: "";
	width: 12px;
	height: 12px;
	position: absolute;
	left: 50%;
	bottom: 0;
	margin-left: -6px;
	border-radius: 50%;
	background-color: #C51015;
}

.lead_02,
.content1 h2 {
	color: #000;
	font-size: 34px;
    font-weight: bold;
    margin-bottom: 30px;
    padding-bottom: 18px;
	position: relative;
}
.lead_02::before,
.content1 h2::before {
	content: "";
	width: 100%;
	height: 8px;
	position: absolute;
	left: 0;
	bottom: 0;
	border-radius: 5px 0 0 3px;
	background: #333333 url(../image/line_01.png) no-repeat right top;
}

.lead_03,
.content1 h3 {
	font-size: 28px;
    font-weight: bold;
    padding: 0 0 15px;
    margin-bottom: 20px;
    position: relative;
}
.lead_03::before,
.content1 h3::before {
	content: "";
	width: 80px;
	height: 3px;
	position: absolute;
	left: 0;
	bottom: 0;
	background-color: #004C66;
}

.lead_04,
.content1 h4 {
	font-size: 20px;
	font-weight: bold;
	padding: 11px;
	border-left: 5px solid #004C66;
	background-color: #eee;
}

.lead_05 {
	color: #004C66;
	font-size: 24px;
	line-height: 1.6 !important;
}
.lead_06 {
	border-bottom: 1px dotted #ccc;
}

.caution_box_01 {
	padding: 35px;
	border: 4px solid #CCCCCC;
}
.caution_box_02 {
	padding: 35px;
	border: 4px solid #004C66;
}
.caution_box_03 {
	padding: 35px;
	border: 4px solid #C51015;
}

.fc_01 { color: #C51015; }
.fc_02 { color: #004C66; }

.vertical_rl {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	white-space: nowrap;
	    text-align: justify;
    word-break:keep-all;
}

.modified_date {
    color: #333;
    font-size: 14px;
    margin-bottom: 50px;
    text-align: center;
    border-bottom: 1px dotted #aaa;
    padding-bottom: 30px;
}

.line_table {
	border: none;
}
.line_table tr {
    border-top: 2px solid #CCCCCC;
    border-bottom: 2px solid #CCCCCC;
}
.line_table th,
.line_table td {
	background: none;
	border: none;
	padding: 25px 10px 25px 0;
}

ol[style*="decimal"],
ol[style*="roman"],
ol[style*="alpha"] { padding-left: 22px; }

ul[style*="disc"],
ul[style*="circle"],
ul[style*="square"] { padding-left: 20px; }

#g_map {
	width: 100%;
	height: 300px;
}

iframe {
	max-width: 100%;
	height: 300px;
}
iframe[name="google_conversion_frame"] {
    width: 1px;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 0;
}

.btn_01 {
    color: #fff !important;
    font-size: 20px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    padding: 10px 54px;
    transition: .3s;
    background-color: #333;
}
.btn_01:hover {
	color: #fff;
	background-color: #000;
}
.btn_02 {
    color: #fff !important;
    font-size: 20px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    padding: 10px 54px;
    transition: .3s;
    background-color: #004C66;
}
.btn_02:hover {
	color: #fff;
	background-color: #7FA5B2;
}
.btn_03 {
    color: #fff !important;
    font-size: 20px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    padding: 10px 54px;
    transition: .3s;
    background-color: #BD0F13;
}
.btn_03:hover {
	color: #fff;
	background-color: #D76F71;
}

/* float */
.fll_360 { float: left; width: 360px; }
.fll_530 { float: left; width: 530px; }
.fll_780 { float: left; width: 780px; }

.flr_360 { float: right; width: 360px; }
.flr_670 { float: right; width: 670px; }
.flr_780 { float: right; width: 780px; }

/* navi_links */
.navi_links > ul {
	font-size: 0;
}
.navi_links > ul + ul { margin-top: 10px; }
.navi_links .list_01 li {
	font-size: 16px;
	display: inline-block;
	vertical-align: middle;
	margin: 0 0.83% 0 0;
	width: 32.75%;
}
.navi_links .list_01 li:nth-child(3n) { margin-right: 0; }
.navi_links .list_02 li {
	font-size: 16px;
	display: inline-block;
	vertical-align: middle;
	margin: 0 0.83% 0 0;
	width: 49.58%;
}
.navi_links .list_02 li:nth-child(2n) { margin-right: 0; }

.navi_links li {
	position: relative;
	overflow: hidden;
}
.navi_links .bg {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 0;
}
.navi_links .bg img {
	transition: .5s;
}
.navi_links li:hover .bg img {
	transform: scale(1.2);
	-webkit-filter: blur(2px);
	-ms-filter: blur(3px);
	filter: blur(3px);
}
.navi_links a {
    display: block;
    position: relative;
    z-index: 1;
}
.navi_links a img {
	transition: .8s;
}
.navi_links a:hover img {
	opacity: 1;
}

/* slide_bnr */
.slide_bnr .bx-wrapper .bx-viewport {
    background: none;
    left: 0;
    border: none;
    box-shadow: none;
}
.slide_bnr .bx-viewport li { width: 580px !important; }

.slide_bnr .bx-wrapper .bx-prev {
    background: url(../image/icon_arrow_01.png) no-repeat 0 0;
    width: 21px;
    height: 41px;
    left: -40px;
}
.slide_bnr .bx-wrapper .bx-next {
	background: url(../image/icon_arrow_02.png) no-repeat 0 0;
	width: 21px;
    height: 41px;
    right: -40px;
}
.slide_bnr .bx-wrapper .bx-pager { bottom: -50px; }
.slide_bnr .bx-wrapper .bx-pager.bx-default-pager a {
	width: 16px;
	height: 16px;
	background-color: #ccc;
	border-radius: 50%;
}
.slide_bnr .bx-wrapper .bx-pager.bx-default-pager a:hover,
.slide_bnr .bx-wrapper .bx-pager.bx-default-pager a.active {
	background-color: #000;
}

/* list_search */
.list_search li {
    border: 1px solid #ccc;
    border-radius: 8px;
    padding: 15px 20px;
}
.list_search li + li {
	margin-top: 15px;
}

/* sns_btns */
.sns_btns {
    margin: 50px auto 0;
    text-align: left;
}
.sns_btns li {
    display: inline-block;
    vertical-align: top;
	margin: 3px;
}
.sns_btns .fb_btn span {
    vertical-align: top !important;
}

/*--------------------------------------------------
	company
--------------------------------------------------*/
.greeting {
	text-align: center;
	max-width: 785px;
	margin: 0 auto;
}
.greeting .logo { margin-bottom: 70px; }
.greeting .text { margin-bottom: 40px; line-height: 2.2; }
.greeting .name { font-size: 14px; }
.greeting .name strong { font-size: 26px; }

.outline_list {
	display: table;
	width: 100%;
	table-layout: fixed;
}
.outline_list > * {
	display: table-cell;
	vertical-align: top;
}
.outline_list .detail {
	padding: 30px 40px;
	background: #ECEDE8 url(/image/bg_02.jpg);
}
.outline_list dl {
	display: table;
	width: 100%;
	padding: 25px 0;
	margin: 0;
}
.outline_list dl + dl { border-top: 1px dotted #000; }
.outline_list dt {
	display: table-cell;
	vertical-align: top;
	width: 140px;
	font-weight: bold;
}
.outline_list dd {
	display: table-cell;
	vertical-align: top;
}
.btn_g_map {
    color: #fff !important;
    text-decoration: none;
    display: inline-block;
    background: #004C66 url(/image/icon_g_map.png) no-repeat 10px 7px;
    background-size: 20px;
    font-size: 14px;
    padding: 4px 10px 6px 40px;
	transition: .3s;
}
.btn_g_map:hover {
	color: #fff;
	background-color: #6694A3;
}


/*--------------------------------------------------
	gallery
--------------------------------------------------*/
.commercial_navi {
	text-align: center;
	background: url(../image/bg_02.jpg);
	padding: 25px;
	margin-bottom: 60px;
}
.commercial_navi li {
	display: inline-block;
	vertical-align: middle;
	margin: 0 8px;
}
.commercial_navi li a {
	color: #000;
	text-decoration: none;
	position: relative;
	padding-left: 13px;
}
.commercial_navi li a::before {
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: #004C66;
	position: absolute;
	left: 0;
	top: 50%;
	margin-top: -2px;
}

.commercial_list > * + section { margin-top: 40px; }
.commercial_list .list_01 { font-size: 0; }
.commercial_list .list_01 li {
	font-size: 16px;
	display: inline-block;
	vertical-align: top;
	width: 150px;
	margin: 0 60px 60px 0;
}
.commercial_list .list_01 li:nth-child(6n) { margin-right: 0; }

.commercial_list .list_02 { font-size: 0; }
.commercial_list .list_02 li {
	font-size: 16px;
	display: inline-block;
	vertical-align: top;
	width: 570px;
	margin: 0 60px 60px 0;
}
.commercial_list .list_02 li:nth-child(2n) { margin-right: 0; }

.commercial_list .list_03 { font-size: 0; }
.commercial_list .list_03 li {
	font-size: 16px;
	display: inline-block;
	vertical-align: top;
	width: 360px;
	margin: 0 60px 60px 0;
}
.commercial_list .list_03 li:nth-child(3n) { margin-right: 0; }


/* walk_list */
.walk_list .item {}
.walk_list .item + .item { margin-top: 140px; }
.walk_list .thumb { width: 510px; position: relative; }
.walk_list .detail { width: 630px; }

	.walk_list .thumb_r .thumb { float: right; }
	.walk_list .thumb_r .detail { float: left; }

	.walk_list .thumb_l .thumb { float: left; text-align: right; }
	.walk_list .thumb_l .detail { float: right; }

.walk_list .thumb a {
    color: #fff;
    font-size: 14px;
    text-decoration: none;
    text-align: center;
    display: inline-block;
    background: #004C66 url(../image/icon_play.png) no-repeat center 13px;
    background-size: 30px;
    position: absolute;
    bottom: -30px;
    border-top: 5px solid #fff;
    transition: .3s;
    padding: 47px 5px 6px;
    width: 110px;
}
	.walk_list .thumb_r .thumb a { right: 0; border-left: 5px solid #fff; }
	.walk_list .thumb_l .thumb a { left: 0; border-right: 5px solid #fff; }

.walk_list .thumb a:hover {
	background-color: #C51015;
}

/* list_photographs */
.list_photographs { margin-top: 60px !important; }
.list_photographs .item {
	float: left;
	width: 255px;
	margin-bottom: 60px;
}
.list_photographs li a {
	display: block;
	position: relative;
}
.list_photographs li a::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,.6) url(../image/icon_zoom.png) no-repeat center center;
	background-size: 30px;
	opacity: 0;
	transition: .8s;
	transform: scale(0);
}
.list_photographs li a:hover::before {
	opacity: 1;
	transform: scale(1);
}
.list_photographs li a:hover img { opacity: 1; }

/*--------------------------------------------------
	about_awamori
--------------------------------------------------*/
.howto_lead {
	padding: 80px 0 100px;
	text-align: center;
	background: #F4F5F0 url(/image/bg_02.jpg);
}
.howto_lead .ttl {
    font-weight: normal;
    font-size: 30px;
	padding: 0;
    margin-bottom: 40px;
}
.howto_lead .ttl::before { display: none; }
.howto_lead > p { margin-bottom: 55px; }

.howto_movie {
	text-align: center;
	margin: 80px auto;
}

.howto_list {}
.howto_list .item {}
.howto_list .item + .item { margin-top: 60px; }

.howto_list .item .inner {
	display: table;
	width: 100%;
	background-color: #000;
	margin-bottom: 10px;
}
.howto_list .item .ttl {
	color: #fff;
	font-size: 20px;
	text-align: center;
	display: table-cell;
	vertical-align: middle;
	width: 340px;
	padding: 0;
    margin: 0;
}
.howto_list .item .ttl::before { display: none; }
.howto_list .item .thumb {
	display: table-cell;
	vertical-align: middle;
}

/*--------------------------------------------------
	list_index
--------------------------------------------------*/
#list_index {
    margin: 40px auto 10px;
}
#list_index .list_index_contents {
	float: left;
    width: 30%;
    margin: 0 5% 5% 0;
}
#list_index .list_index_contents:nth-child(3n) {
    margin-right: 0;
}

.list_index_contents > .list_index_h a {
	color: #000;
	text-decoration: none;
	display: block;
	transition: .3s;
}
.list_index_contents > .list_index_h a:hover {}

.list_index_contents > .list_index_h .thumb {
	position: relative;
	padding-bottom: 66.66%;
	overflow: hidden;
	margin-bottom: 20px;
}
.list_index_contents > .list_index_h .thumb img {
	bottom: -100%;
    height: auto;
    left: -100%;
    margin: auto;
    position: absolute;
    right: -100%;
    top: -100%;
    width: auto;
    max-width: 100%;
}
.list_index_contents > .list_index_h h3 {
    font-size: 20px;
    background: url(../image/iocn_cycle_02.png) no-repeat 0 0;
    padding: 1px 0 1px 36px;
}

.list_index_contents > ul { margin-top: 10px; }
.list_index_contents > ul li {
	margin-left: 30px;
	list-style: disc outside;
}


/*--------------------------------------------------
	lineup
--------------------------------------------------*/
/* index */
#lineup_index {
	width: 100%;
    max-width: 1620px;
	min-width: 1200px;
    margin: 0 auto;
	padding: 0 60px;
    overflow: hidden;
}
#lineup_category {
	width: 1200px;
	margin: 0 auto 35px;
}
#lineup_category .ttl {
    float: left;
    width: 190px;
	font-size: 22px;
	font-weight: bold;
    background: url(../image/icon_search.png) no-repeat 0 center;
    padding-left: 30px;
    margin-top: 25px;
}
#lineup_category .inner {
	float: left;
	width: 1010px;
}
#lineup_category .inner dl {
	font-size: 0;
}
#lineup_category .inner dl + dl { margin-top: 10px; }
#lineup_category .inner dt {
    font-size: 16px;
    width: 135px;
    display: inline-block;
    vertical-align: middle;
    font-weight: bold;
    position: relative;
	padding-left: 14px;
}
#lineup_category .inner dt::before {
    content: "";
    width: 7px;
    height: 7px;
    position: absolute;
    left: 0;
    top: 9px;
    border-radius: 50%;
}
#lineup_category .inner .cat_alcohol dt::before { background-color: #004C66; }
#lineup_category .inner .cat_type dt::before { background-color: #C51015; }
#lineup_category .inner .cat_alcohol dd input, #lineup_category .inner .cat_type dd input { display: none; }

#lineup_category .inner dd {
	font-size: 14px;
	display: inline-block;
	vertical-align: middle;
    width: 170px;
    margin-left: 5px;
	text-align: center;
}
#lineup_category a {
    display: block;
    color: #000;
	font-weight: bold;
    background-color: #fff;
    border: 1px solid #999;
	border-radius: 6px;
    text-decoration: none;
    padding: 8px 5px 8px 5px;
    position: relative;
	transition: .3s;
}
#lineup_category a:not(.is_current):hover { background-color: #F3F3F3; }
#lineup_category a.is_current {
	color: #fff;
	pointer-events: none;
}
#lineup_category .cat_alcohol a.is_current { background-color: #004C66; }
#lineup_category .cat_type a.is_current { background-color: #C51015; }

#lineup_category a::before {
	content: "";
	width: 15px;
	height: 15px;
	border: 1px solid #999;
	background-color: #fff;
	border-radius: 50%;
	position: absolute;
	left: 12px;
	top: 11px;
	box-sizing: border-box;
}
#lineup_category a.is_current::before {
	border: 3px solid #fff;
	background-color: #000;
}

#lineup_list {
    padding: 40px 0;
    border-top: 1px dotted #aaa;
}
#lineup_list .inner {
	margin-right: -3.57%;
    overflow: hidden;
	font-size: 0;
}
#lineup_list .item {
	font-size: 13px;
    display: none;
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    width: 21.42%;
    margin: 0 3.57% 3.57% 0;
	vertical-align: top;
}

	#lineup_index.cat_alcohol_all .fill_alcohol_all,
	#lineup_index.cat_alcohol_all .fill_alcohol_01,
	#lineup_index.cat_alcohol_all .fill_alcohol_02,
	#lineup_index.cat_alcohol_all .fill_alcohol_03,
	#lineup_index.cat_alcohol_all .fill_alcohol_04,
	#lineup_index.cat_alcohol_01 .fill_alcohol_01,
	#lineup_index.cat_alcohol_02 .fill_alcohol_02,
	#lineup_index.cat_alcohol_03 .fill_alcohol_03,
	#lineup_index.cat_alcohol_04 .fill_alcohol_04,
	#lineup_index.cat_type_all .fill_type_all,
	#lineup_index.cat_type_all .fill_type_01,
	#lineup_index.cat_type_all .fill_type_02,
	#lineup_index.cat_type_all .fill_type_03,
	#lineup_index.cat_type_01 .fill_type_01,
	#lineup_index.cat_type_02 .fill_type_02,
	#lineup_index.cat_type_03 .fill_type_03 {
	  display: inline-block;
	  -webkit-animation: show .5s linear 0s forwards;
			  animation: show .5s linear 0s forwards;
	}
	@-webkit-keyframes show {
		from {
		  opacity: 0;
		  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		}
		to {
		  opacity: 1;
		  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
		}
	}
	@keyframes show {
		from {
		  opacity: 0;
		  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		}
		to {
		  opacity: 1;
		  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
		}
	}

#lineup_list .item a {
    color: #000;
    text-decoration: none;
    display: block;
    position: relative;
}
#lineup_list .item .thumb {
    border: 1px solid #aaa;
    background-color: #fff;
    position: relative;
    padding-bottom: 100%;
    overflow: hidden;
    margin-bottom: 15px;
}
#lineup_list .item .thumb img {
    bottom: -100%;
    height: auto;
    max-height: 90%;
    left: -100%;
    margin: auto;
    position: absolute;
    right: -100%;
    top: -100%;
    width: auto;
    max-width: 90%;
}
#lineup_list .item .thumb .cover {
    width: 100%;
    height: 100%;
    background-color: rgba(0,76,102,0.9);
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10;
    text-align: center;
    display: block;
    opacity: 0;
	transition: .8s;
	transform: rotateX(-100deg);
    transform-origin: bottom left;
}
#lineup_list .item .thumb .cover span {
	color: #fff;
	font-size: 18px;
    display: block;
    vertical-align: middle;
    text-align: center;
    margin: auto;
    position: relative;
    top: 46%;
}
#lineup_list .item .thumb:hover .cover {
	opacity: 1;
	transform: rotateX(0deg);
}
#lineup_list .item .detail {}
#lineup_list .item .tag {}
#lineup_list .item .tag span {
    color: #fff;
    background-color: #000;
    width: 86px;
    display: inline-block;
    text-align: center;
    padding: 2px;
    position: absolute;
    top: 10px;
    right: 10px;
}
#lineup_list .item .tag .tag_new {
    color: #000;
    background-color: #FFDA04;
    width: 50px;
    left: 10px;
    top: 10px;
    position: absolute;
    border-radius: 50%;
    height: 50px;
    padding: 15px 2px;
}
#lineup_list .item .ttl {
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 15px;
}
#lineup_list .item .ttl strong {
	display: block;
	font-size: 26px;
	color: #004C66;
}
#lineup_list .item .lead {}


/* detail */
.lineup_detail {
    border-bottom: 1px solid #aaa;
    padding-bottom: 150px;
}
.lineup_detail .main { margin-bottom: 90px; }
.lineup_detail .main .thumb {
	float: right;
	width: 580px;
	border: 1px solid #ccc;
}
.lineup_detail .main .thumb span {
	display: block;
	position: relative;
	padding-bottom: 100%;
	overflow: hidden;
}
.lineup_detail .main .thumb span img {
    bottom: -100%;
    height: auto;
    left: -100%;
    margin: auto;
    position: absolute;
    right: -100%;
    top: -100%;
    width: auto;
    max-width: 100%;
}

.lineup_detail .main .detail { float: left; width: 580px; }
.lineup_detail .lineup_tag {
	font-size: 0;
	margin-bottom: 35px;
}
.lineup_detail .lineup_tag span {
    color: #fff;
    font-size: 13px;
    background-color: #000;
    text-align: center;
    display: inline-block;
    width: 86px;
	padding: 2px;
    margin-right: 10px;
}
.lineup_detail .lineup_tag .tag_new { color: #000; background-color: #FFDA04; }
.lineup_detail .main .detail > .ttl {
	font-size: 20px;
	margin-bottom: 40px;
}
.lineup_detail .main .detail > .ttl strong {
	display: block;
	font-size: 40px;
	color: #004C66;
}
.lineup_detail .main .detail > .lead {
	font-size: 18px;
}

.taste_chart { margin-top: 46px; }
.taste_chart > .chart_ttl {
	font-size: 22px;
	font-weight: bold;
	padding-left: 40px;
	margin-bottom: 10px;
	background: url(../image/icon_cap.png) no-repeat 0 8px;
}
.taste_chart table {
    border: none;
	table-layout: fixed;
}
.taste_chart .inner {
    position: relative;
    border: 1px solid #ccc;
    padding: 40px 49px;
}
.chart_caption li {
	position: absolute;
	text-align: center;
}
	.chart_caption .cap_01 { left: -100%; right: -100%; top: 13px; }
	.chart_caption .cap_02 { top: -100%; bottom: -100%; right: 22px; }
	.chart_caption .cap_03 { left: -100%; right: -100%; bottom: 13px; }
	.chart_caption .cap_04 { top: -100%; bottom: -100%; left: 22px; }

	.chart_caption li span {
		font-size: 16px;
    	font-weight: bold;
		border: 1px solid #999;
		border-radius: 5px;
		text-align: center;
		display: inline-block;
		background-color: #fff;
	}
	.chart_caption .cap_01 span,
	.chart_caption .cap_03 span { width: 100px; }
	.chart_caption .cap_02 span,
	.chart_caption .cap_04 span { height: 100px; }
	
.taste_chart table td {
    border: none;
	padding: 5px 0 0 5px;
}

.taste_chart table tr:nth-child(2) {
    border-bottom: 1px solid #ccc;
}

.taste_chart table tr td:nth-child(2) {
    border-right: 1px solid #ccc;
	padding-right: 5px;
}
.taste_chart table tr td:nth-child(1) { padding-left: 10px; }
.taste_chart table tr td:nth-child(4) { padding-right: 10px; }
.taste_chart table tr:nth-child(1) td { padding-top: 10px; }
.taste_chart table tr:nth-child(2) td { padding-bottom: 5px; }
.taste_chart table tr:nth-child(4) td { padding-bottom: 10px; }
	
.taste_chart table span {
	background-color: #E7E2D3;
	display: block;
	height: 25px;
}
.taste_chart table .select span { background-color: #004C66; }


.lineup_detail .sub_item { margin-top: 100px; }
.lineup_detail .sub_item .item {
	padding: 80px 150px;
	background: #F7F7F7 url(/image/bg_03.jpg);
}
.lineup_detail .sub_item .item + .item { margin-top: 20px; }
.lineup_detail .sub_item .thumb {
	float: right;
	width: 290px;
	border: 1px solid #ccc;
	background-color: #fff;
}
.lineup_detail .sub_item .thumb span {
	display: block;
	position: relative;
	padding-bottom: 100%;
	overflow: hidden;
}
.lineup_detail .sub_item .thumb span img {
    bottom: -100%;
    height: auto;
    left: -100%;
    margin: auto;
    position: absolute;
    right: -100%;
    top: -100%;
    width: auto;
    max-width: 100%;
}
.lineup_detail .sub_item .detail {
	float: left;
	width: 580px;
}
.lineup_detail .sub_item dl {
	font-size: 15px;
	line-height: 1.6;
	display: table;
	width: 100%;
	padding: 17px 0;
	border-bottom: 1px dotted #aaa;
}
.lineup_detail .sub_item dl:first-child { border-top: 1px dotted #aaa; }
.lineup_detail .sub_item dt {
	color: #004C66;
	display: table-cell;
	vertical-align: top;
	width: 140px;
}
.lineup_detail .sub_item dd {
	display: table-cell;
	vertical-align: top;
}

.lineup_detail .pr_item { margin-top: 150px; }
.lineup_detail .pr_item .item {
	padding: 0 150px;
	text-align: center;
}
.lineup_detail .pr_item .item + .item { margin-top: 20px; }
.lineup_detail .pr_item iframe {
	width: 700px;
	height: 393px;
}

/*--------------------------------------------------
	campaign
--------------------------------------------------*/
.campaign_now { margin-bottom: 100px; }
.campaign_coming { margin-bottom: 100px; }

.list_campaign_01 { margin-top: 30px; }
.list_campaign_01 .item {
	background-color: #fff;
	border: 1px solid #aaa;
	padding: 30px 30px 20px;
	display: table;
    width: 100%;
}
.list_campaign_01 .item + .item { margin-top: 30px; }

.list_campaign_01 .thumb {
	display: table-cell;
	vertical-align: top;
	width: 260px;
}
.list_campaign_01 .detail {
	display: table-cell;
	vertical-align: top;
	padding-left: 30px;
}

.list_campaign_01 .item .tag { margin-bottom: 15px; }
.list_campaign_01 .item .tag span {
    color: #fff;
    font-size: 13px;
    display: inline-block;
    vertical-align: top;
    background-color: #F49807;
    padding: 3px 10px;
	margin-right: 3px;
}
.list_campaign_01 .item .tag span.tag_coming {
    background-color: #FFDA04;
    color: #000;
}
.list_campaign_01 .item .ttl { font-size: 30px; }
.list_campaign_01 .item .date { margin: 30px 0 45px; }
.list_campaign_01 .item .link { text-align: right; }
.list_campaign_01 .item .link a {
    text-align: center;
    color: #fff;
    text-decoration: none;
    background-color: #004C66;
    position: relative;
    display: inline-block;
    padding: 10px;
    width: 210px;
	transition: .3s;
}
.list_campaign_01 .item .link a:hover {
	color: #fff;
	background-color: #7FA5B2;
}
.list_campaign_01 .item .link a::before {
    content: "";
    width: 8px;
    height: 8px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    position: absolute;
    right: 11px;
    top: 50%;
    margin-top: -5px;
    transform: rotate(-45deg);
}


.list_campaign_02 {}
.list_campaign_02 li {
	border-bottom: 1px dotted #ccc;
}
.list_campaign_02 li:first-child { border-top: 1px dotted #ccc; }
.list_campaign_02 li:nth-child(2n) {
	background-color: rgba(255,255,255,.6);
}

.list_campaign_02 li a {
    color: #000;
    text-decoration: none;
    transition: .3s;
    -webkit-transition: .3s;
    position: relative;
	display: block;
    padding: 43px 20px;
    transition: .3s;
}
.list_campaign_02 li a:hover {
	color: #fff;
	background-color: #004C66;
}
.list_campaign_02 li a::before {
    content: "";
    width: 8px;
    height: 8px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: rotate(-45deg);
    margin-top: -5px;
	transition: .3s;
}
.list_campaign_02 li a:hover::before {
	border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
}

/*--------------------------------------------------
	shop
--------------------------------------------------*/
.shop_list {}
.shop_list .item {}
.shop_list .item + .item { margin-top: 30px; }
.shop_list .item a {
	color: #000;
    text-decoration: none;
	display: table;
	width: 100%;
	border: 1px solid #aaa;
	background-color: #fff;
	transition: .3s;
}
.shop_list .item a:hover {
	color: #fff !important;
	background-color: #004C66;
}

.shop_list .thumb {
	display: table-cell;
	vertical-align: top;
	width: 255px;
	height: 170px;
	overflow: hidden;
	position: relative;
	background-color: #AAAAAA;
}
.shop_list .thumb img {
	width: 100%;
	height: auto;
    position: absolute;
    top: 0;
	left: 0;
	transition: .3s;
}
.shop_list a:hover .thumb img {
	transform: scale(1.1);
	opacity: 1;
}
.shop_list .detail {
	display: table-cell;
	vertical-align: top;
	padding: 30px 20px;
	position: relative;
}

.shop_list .date {
	text-align: right;
	font-size: 12px;
	position: absolute;
	right: 20px;
	top: 30px;
}
.shop_list .address { margin-bottom: 10px; }
.shop_list .ttl {
	color: #004C66;
	font-size: 24px;
	font-weight: bold;
}
.shop_list .item a:hover .ttl { color: #fff; }


/* shop_navi */
.shop_navi {
	padding-top: 157px;
	background: url(../image/bg_shop_navi.png) no-repeat center top;
}
.shop_navi .area_item {
	font-size: 0;
	padding-bottom: 40px;
	margin-bottom: 20px;
	background: url(../image/icon_flour.png) no-repeat center bottom;
}
.shop_navi .area_item li {
	font-size: 13px;
	display: inline-block;
	vertical-align: top;
	width: 105px;
	margin: 0 0 10px 10px;
}
.shop_navi .area_item li:first-child {
	margin-left: 0;
	width: 100%;
}
.shop_navi .area_item li:nth-child(2n) { margin-left: 0; }
.shop_navi .area_item li a {
	color: #000;
	display: block;
	text-align: center;
	text-decoration: none;
	border: 1px solid #aaa;
	background-color: #fff;
	transition: .3s;
	padding: 9px 5px;
}
.shop_navi .area_item li a:hover {
	color: #fff;
	background-color: #EB6300;
}
.shop_archives {
	font-size: 13px;
    background-color: #fff;
    border: 1px solid #aaa;
	position: relative;
}
.shop_archives .ttl {
    text-align: center;
    padding: 11px 10px;
    position: relative;
    cursor: pointer;
}
.shop_archives .ttl::before {
    content: "";
    width: 0;
    height: 0;
    border: 5px solid transparent;
    border-top: 8px solid #004C66;
    position: absolute;
    right: 18px;
    top: 50%;
    margin-top: -5px;
}
.shop_archives .inner {
    display: none;
    padding: 10px;
    border-top: 1px dotted #aaa;
    position: absolute;
    left: 0;
    background-color: rgba(255,255,255,.8);
    width: 100%;
    text-align: center;
    z-index: 1;
}
.shop_archives .inner li + li {
	border-top: 1px dotted #aaa;
}
.shop_archives .inner li a {
	color: #000;
	text-decoration: none;
	display: block;
	padding: 10px;
}
.shop_archives .inner li a:hover {
	color: #004C66;
}

/*--------------------------------------------------
	topics
--------------------------------------------------*/
.topics_archives {
    float: left;
    width: 280px;
    background-color: #fff;
    border: 1px solid #aaa;
	position: relative;
}
.topics_archives .ttl {
    text-align: center;
    font-size: 16px;
    padding: 19px 10px;
    position: relative;
    cursor: pointer;
}
.topics_archives .ttl::before {
    content: "";
    width: 0;
    height: 0;
    border: 8px solid transparent;
    border-top: 12px solid #004C66;
    position: absolute;
    right: 18px;
    top: 50%;
    margin-top: -5px;
}
.topics_archives .inner {
    display: none;
    padding: 10px;
    border-top: 1px dotted #aaa;
    position: absolute;
    left: 0;
    background-color: rgba(255,255,255,.8);
    width: 100%;
    text-align: center;
    z-index: 1;
}
.topics_archives .inner li + li {
	border-top: 1px dotted #aaa;
}
.topics_archives .inner li a {
	color: #000;
	text-decoration: none;
	display: block;
	padding: 8px;
}
.topics_archives .inner li a:hover {
	color: #004C66;
}


.link_facebook {
	float: right;
}

/* list_topics */
.list_topics dl {
	border-bottom: 1px dashed #ccc;
}
.list_topics dl:first-child {
	border-top: 1px dashed #ccc;
}
.list_topics dl:nth-child(2n) {
	background-color: rgba(255,255,255,.6);
}
.list_topics dl a {
	display: table;
	width: 100%;
	color: #000;
	text-decoration: none;
	transition: .3s;
	-webkit-transition: .3s;
	position: relative;
	padding: 43px 20px;
	transition: .3s;
}
.list_topics dl a:hover {
	color: #fff;
	background-color: #004C66;
}
.list_topics dl a::before {
    content: "";
    width: 8px;
    height: 8px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: rotate(-45deg);
    margin-top: -5px;
	transition: .3s;
}
.list_topics dl a:hover::before {
	border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
}
.list_topics dl dt {
    display: table-cell;
    vertical-align: top;
    width: 155px;
}
.list_topics dl dd {
    display: table-cell;
	vertical-align: top;
}

/* pager */
.pager {
	text-align: center;
	margin-top: 60px;
}
.pager li {
	display: inline-block;
	vertical-align: top;
}
.pager li a,
.pager li span {
	color: #000;
    text-decoration: none;
    display: block;
    width: 43px;
    height: 43px;
    background-color: #fff;
    border: 1px solid #aaa;
    transition: .3s;
    border-radius: 50%;
    padding: 7px;
    text-align: center;
}
.pager li span {
	color: #fff;
	background-color: #004C66;
	border: 1px solid #004C66;
}
.pager li a:hover {
	color: #fff;
	background-color: #8AABB7;
}

/* detail_topics */
.detail_topics {
    background-color: #fff;
    padding: 60px;
}

.alpha_contents {}
.alpha_contents img {
	max-width: 100%;
	height: auto;
}
.fll_img {
    float: left;
    margin: 0 20px 20px 0;
    /*width: 40%;*/
}
.flr_img {
	float: right;
	margin: 0 0 20px 20px;
	/*width: 40%;*/
}

.list_1column .caption,
.list_2column .caption,
.list_3column .caption {
	font-size: 86.66%;
	text-align: center;
}

.list_2column { font-size: 0; }
.list_2column .item {
	width: 48.71%;
	font-size: 15px;
	font-size: 1.5rem;
	display: inline-block;
	vertical-align: top;
	margin: 0 2.56% 2.56% 0;
}
.list_2column .item:nth-child(2n) { margin-right: 0; }

.list_3column { font-size: 0; }
.list_3column .item {
    width: 30%;
    font-size: 15px;
    font-size: 1.5rem;
    display: inline-block;
    vertical-align: top;
    margin: 0 5% 5% 0;
}
.list_3column .item:nth-child(3n) { margin-right: 0; }

.list_4column { font-size: 0; }
.list_4column .item {
    width: 23.33%;
    font-size: 15px;
    font-size: 1.5rem;
    display: inline-block;
    vertical-align: top;
    margin: 0 2.16% 2.16% 0;
}
.list_4column .item:nth-child(4n) { margin-right: 0; }

/* link_prev_next */
.link_prev_next {
	text-align: center;
	margin-top: 40px;
}
.link_prev_next .prev {
	float: left;
	position: relative;
	padding-left: 25px;
}
.link_prev_next .prev::before {
    content: "";
    width: 0;
    height: 0;
    border: 8px solid transparent;
    border-right: 12px solid #004C66;
    position: absolute;
    left: -6px;
    top: 50%;
    margin-top: -8px;
}
.link_prev_next .next {
	float: right;
	position: relative;
	padding-right: 25px;
}
.link_prev_next .next::before {
	content: "";
    width: 0;
    height: 0;
    border: 8px solid transparent;
    border-left: 12px solid #004C66;
    position: absolute;
    right: -6px;
    top: 50%;
    margin-top: -8px;
}
.link_prev_next a {
	color: #004C66;
	text-decoration: none;
}
.link_prev_next a:hover {}


/*---------------------------------------------------
	sidemenu
---------------------------------------------------*/
#side_menu {
	background-color: #fff;
	border: 1px solid #ccc;
	margin-bottom: 20px;
}
#side_menu .ttl {
	color: #fff;
    font-size: 100%;
    font-weight: normal;
    padding: 10px;
	background-color: #8A8A8A;
}

#side_menu a {
	display: block;
	padding: 5px;
	text-decoration: none;
}
#side_menu a:hover { text-decoration: underline; }

#side_menu .level0 > a {}

#side_menu .level1 > a {}

#side_menu .level2 > a {}

#side_menu .level3 > a {}


#side_menu li + li,
#side_menu li > ul {
    border-top: 1px dashed #ccc;
}

/*---------------------------------------------------------------------
	faq
---------------------------------------------------------------------*/
.list_faq {}
.list_faq .item {
    margin-bottom: 20px;
}
.list_faq .btn_q {}
.list_faq .btn_q a {
    background-color: #d3e3f3;
    color: #1f3f99;
    display: block;
    font-size: 1.7rem;
    font-weight: normal;
    padding: 10px 10px 10px 41px;
    position: relative;
    text-decoration: none;
}
.list_faq .btn_q a::before {
    color: #1f3f99;
    content: "Q";
	display: inline-block;
    font-size: 28px;
	font-size: 2.8rem;
    position: absolute;
    top: 2px;
	left: 10px;
}
.list_faq .box_a {
	display: none;
    border: 1px solid #d3e3f3;
    padding: 15px 15px 15px 40px;
    position: relative;
}
.list_faq .box_a::before {
    color: #ff8000;
    content: "A";
    display: inline-block;
    font-size: 24px;
	font-size: 2.4rem;
    position: absolute;
    top: 5px;
	left: 11px;
}


.faq_contents {}
.faq_contents .icon_q {}
.faq_contents .icon_a {}

/*---------------------------------------------------------------------
	contact
---------------------------------------------------------------------*/
/* tel_list */
.tel_list {
	margin-bottom: 40px;
}
.tel_list .item {
	float: left;
	width: 430px;
	padding: 30px;
	background-color: #fff;
}
.tel_list .item:first-child {
	margin-right: 60px;
}

/**/
.mail_form {
    padding: 50px;
	background: #fff;
}
.mail_form form {
	margin: 0 auto;
}
.mail_form form dl {
	display: table;
	width: 100%;
	margin-bottom: 30px;
}
.mail_form form dt {
	width: 30%;
	/*text-align: right;*/
	display: table-cell;
	vertical-align: top;
	font-size: 93.75%;
	padding-right: 10px;
	padding-top: 12px;
}
.mail_form form dd {
	display: table-cell;
	vertical-align: top;
}
.mail_form form .bg_on {
	background-color: #ececec;
	padding: 12px;
}
.mail_form form .bg_on label {
	/*width: 20%;*/
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}
.mail_form form .border_on {
	border: 1px solid #CCCCCC;
	padding: 12px;
	background-color: #fff;
}
.mail_form.confirm_list dd {
	background-color: #F6F6F6;
	padding: 12px;
	word-break: break-all;
}
.mail_form .btn_list {
	text-align: center;
	margin: 20px auto;
}
.mail_form .icon_required::after {
    content: "必須";
    color: #fff;
    font-size: 90%;
    display: inline-block;
    vertical-align: top;
    margin-top: 1px;
    margin-left: 10px;
    background-color: #D80000;
    padding: 0 10px;
    border-radius: 4px;
}
.mail_form .error {
	color: #d71618;
	font-size: 13px;
}

.mail_form.type_02 form {
    max-width: none;
}
.mail_form.type_02 form dl {
    max-width: 870px;
}
.mail_form.type_02 form dl dt {
    width: 35%;
}
.mail_form input,
.mail_form button,
.mail_form textarea,
.mail_form select {
	margin: 0;
	font-size: 16px;
	padding: 12px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
}
.mail_form input:-ms-input-placeholder {
    color: #808080;
}
.mail_form select,
.mail_form textarea,
.mail_form input[type="tel"],
.mail_form input[type="text"],
.mail_form input[type="email"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 1px solid #ccc;
	border-radius: 0;
	outline: none;
	width: 100%;
	background-color: #fff;
}
.mail_form input.small {
	width: 27%;
}

.mail_form input[type="file"] {
	font-size: 16px;
}

.mail_form input[type="radio"] {
	margin-right: 5px;
	padding: 5px;
}
.mail_form input[type="checkbox"] {
	margin-right: 5px;
	padding: 5px;
}
.mail_form select {
	-webkit-appearance: select;
	-moz-appearance: select;
	appearance: select;
	background-color: #ececec;
}
.mail_form .twin {
	font-size: 0;
}
.mail_form .twin input + input {
	margin-left: 3.44%;
}
.mail_form .twin input {
	width: 48.26%;
	display: inline-block;
}
.mail_form textarea {
	width: 100%;
	height: 150px;
	background-color: #fff;
}
.mail_form input[type="text"]:focus,
.mail_form input[type="email"]:focus,
.mail_form textarea:focus {
	box-shadow: 0 0 7px #008CD6;
}

.btm_text {
    width: 70%;
	margin-left: auto;
}
.mail_form input[type="submit"] {
	color: #fff;
	padding: 1em 5em;
	background-color: #00698C;
	border: none;
	border-radius: 0;
}
.mail_form input[type="submit"]:hover {
	background-color: #055FAD;
}
.mail_form input[type="reset"],
.mail_form input.back {
	color: #fff;
	padding: 0.6em 1em;
	background-color: #b5b5b5;
	border: none;
	border-radius: 0;
}
.mail_form input[type="reset"]:hover,
.mail_form input.back:hover {
	background-color: #555;
}
.mail_form .btn_backhome {
	color: #fff;
	padding: 0.6em 1em;
	background-color: #00698C;
	text-decoration: none;
	border: none;
	border-radius: 0;
}
.mail_form .btn_backhome:hover {
	color: #fff;
	padding: 0.6em 1em;
	background-color: #b5b5b5;
}

.form_message {
    background-color: #ffffbb;
    border: 2px solid #df0000;
    color: #df0000;
    font-size: 120%;
    font-weight: bold;
    margin: 10px auto;
    padding: 10px 15px;
}

@media screen and (max-width: 768px) {
	.mail_form {
		padding: 12px;
		border: 4px solid #e3d8d4;
	}
	.mail_form form dl {
		padding: 0 10px;
		margin-bottom: 15px;
	}
	.mail_form form dt{
		display: block;
		width: auto;
		text-align: left;
		margin: 0;
		padding: 0;
	}
	.mail_form form dd {
		display: block;
		width: auto;
	}
	.mail_form input,
	.mail_form button,
	.mail_form textarea,
	.mail_form select {
		padding: 10px;
	}
	.mail_form input.small {
		width: 50%;
	}
	.mail_form input[type="submit"] {
		padding: 1em;
	}
	.btm_text {
		width: auto;
	}
}

/*---------------------------------------------------------------------
    list_sitemap
---------------------------------------------------------------------*/
.list_sitemap_02 li {
    float: left;
    width: 255px;
    margin: 0 60px 60px 0;
}
.list_sitemap_02 li:nth-child(4n) { margin-right: 0; }
.list_sitemap_02 li a {
    color: #000;
    font-size: 22px;
	line-height: 1.4;
    text-decoration: none;
    background-color: #F3F3F3;
    display: table;
    text-align: center;
    height: 200px;
    width: 100%;
	transition: .3s;
}
.list_sitemap_02 li a span {
	display: table-cell;
	vertical-align: middle;
}
.list_sitemap_02 li a:hover {
	color: #fff;
	background-color: #004C66;
}

.list_sitemap > h2 {
	font-size: 22px;
	font-weight: normal;
	margin-bottom: 20px;
	margin-left: 0 !important;
}
.list_sitemap > * + h2 {
    margin-top: 40px;
}
.list_sitemap > h2 a {
    color: #333;
    text-decoration: none;
    display: block;
    padding: 25px 20px 25px 60px;
    position: relative;
    background-color: #F3F3F3;
	transition: all .3s ease 0s;
	-webkit-transition: all .3s  ease 0s;
}
.list_sitemap > h2 a::after {
    content: "";
    position: absolute;
    left: 25px;
    top: 50%;
    width: 12px;
    height: 12px;
    margin-top: -6px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transition: all .3s;
    -webkit-transition: all .3s;
}
.list_sitemap > h2 a:hover {
	color: #fff;
	background-color: #004C66;
}
.list_sitemap > h2 a:hover::after {
	right: 15px;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
}
.list_sitemap > ul {
    color: #004C66;
	margin-left: 40px;
    overflow: hidden;
}
.list_sitemap > ul > li {
    width: 345px;
    float: left;
    font-size: 18px;
    padding-left: 20px;
    margin: 0 60px 20px 0;
    position: relative;
}
.list_sitemap > ul > li:nth-child(3n) {
    margin-right: 0;
}
.list_sitemap > ul > li::before {
    content: "";
    position: absolute;
    left: -4px;
    top: 8px;
    width: 8px;
    height: 8px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transition: all .3s;
    -webkit-transition: all .3s;
}
.list_sitemap > ul > li a {
    color: #000;
    text-decoration: none;
    line-height: 1.4;
    display: block;
}
.list_sitemap > ul > li a:hover {
    color: #004C66;
}
.list_sitemap > ul > li > ul {
    margin: 20px 0 0;
}
.list_sitemap > ul > li > ul li {
    font-size: 14px;
	padding-left: 12px;
    position: relative;
}
.list_sitemap > ul > li > ul li + li {
    margin-top: 10px;
}
.list_sitemap > ul > li > ul li::before {
    content: "";
    background-color: #000;
    position: absolute;
    left: 0;
    top: 9px;
    border-radius: 50%;
    width: 3px;
    height: 3px;
}


/*---------------------------------------------------------------------
	404
---------------------------------------------------------------------*/
.thumb_404 {
	margin-right: 40px;
	float: left;
	width: 20%;
}
.border_box {
	padding: 20px;
	background: #F9F9F9 url(/image/bg_03.jpg);
}
.border_box > ul {
	margin: 15px 0 0;
}
.border_box > ul > li {
    display: inline-block;
	margin-right: 5px;
}
.border_box > ul > li a {
	color: #fff;
	text-decoration: none;
	display: block;
	background-color: #000;
	padding: 8px 35px 8px 15px;
	position: relative;
}
.border_box > ul > li a::before {
	content: "";
	width: 8px;
	height: 8px;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	position: absolute;
	right: 15px;
	top: 50%;
	margin-top: -4px;
	transform: rotate(-45deg);
}

/*---------------------------------------------------------------------
	page_scroll
---------------------------------------------------------------------*/
#page_scroll_navi {
	text-align: right;
	overflow: hidden;
	margin: 20px;
}
#page_scroll_navi a {
	display: inline-block;
	position: relative;
}


/*---------------------------------------------------------------------
	site_footer
---------------------------------------------------------------------*/
#site_footer {
	background: #F3F3E9 url(../image/bg_01.jpg);
}

#site_footer .inner {
    box-sizing: content-box;
    margin: 0 auto;
    padding: 30px 0;
    width: 1200px;
}

#site_footer .company_info {
    float: left;
	width: 390px;
	border-right: 1px solid #999;
}
#site_footer .company_logo {
    float: left;
	margin-right: 40px;
}
#site_footer .footer_address {
    overflow: hidden;
}
#site_footer .footer_address dl {
    font-size: 13px;
	line-height: 1.8;
}
#site_footer .footer_address dl + dl {
    margin-top: 10px;
}
#site_footer .footer_address dl dt {
    font-weight: bold;
}
#site_footer .footer_address .ttl {
    font-size: 18px;
	font-weight: bold;
    margin-bottom: 15px;
}
#site_footer .company_info > p {
	margin-top: 30px;
	position: relative;
	padding-left: 20px;
	font-size: 13px;
}
#site_footer .company_info > p::before {
	content: "";
	width: 10px;
	height: 10px;
	background-color: #000;
	position: absolute;
	left: 0;
	top: 5px;
	transform: rotate(45deg);
}

.footer_navi {
	float: right;
	width: 810px;
	padding-left: 40px;
}
.footer_navi .list_01 {
	font-size: 0;
	margin-bottom: 20px;
}
.footer_navi .list_01 li {
	display: inline-block;
	vertical-align: top;
	font-size: 15px;
	width: 230px;
	margin:  0 40px 10px 0;
}
.footer_navi .list_01 li:nth-child(3n) { margin-right: 0; }

.footer_navi .list_01 li a {
	color: #000;
	text-decoration: none;
	display: block;
	padding: 8px 0;
	border-bottom: 1px dotted #000;
	position: relative;
}
.footer_navi .list_01 li a::after {
    content: "";
    width: 0;
    height: 1px;
	background-color: #00698C;
    position: absolute;
    left: 0;
    bottom: -1px;
	transition: .3s;
}
.footer_navi .list_01 li a:hover { color: #00698C; }
.footer_navi .list_01 li a:hover::after { width:100%; }

.footer_navi .list_02 {
	font-size: 0;
}
.footer_navi .list_02 li {
	display: inline-block;
	vertical-align: top;
	font-size: 12px;
	margin: 0 40px 10px 0;
}
.footer_navi .list_02 li a {
	color: #000;
	text-decoration: none;
	display: block;
	position: relative;
	padding-left: 15px;
}
.footer_navi .list_02 li a::before {
    content: "";
    width: 5px;
    height: 5px;
    position: absolute;
    left: 0;
    top: 6px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    transform: rotate(-45deg);
}
.footer_navi .list_02 li a::after {
    content: "";
    width: 0;
    height: 1px;
	background-color: #333;
    position: absolute;
    left: 0;
    bottom: -4px;
	transition: .3s;
}
.footer_navi .list_02 li a:hover::after { width:100%; }

.copyright {
	color: #fff;
	font-size: 12px;
	text-align: center;
	background-color: #000;
	padding: 8px;
}



/*---------------------------------------------------------------------
	anime
---------------------------------------------------------------------*/
.anime_typing_sub,
.anime_typing span {
    opacity: 0;
}

#container .anime_fade_up {
	opacity: 0;
	animation-duration: 1s;
	animation-fill-mode: both;
}
#container .anime_fade_up.anime_on {
	-webkit-animation-name: fadeInUp;
	-moz-animation-name: fadeInUp;
	-o-animation-name: fadeInUp;
	animation-name: fadeInUp;
}
@-webkit-keyframes fadeInUp {
	0% {
		opacity: 0;
		-webkit-transform: translateY(60px);
	}	
	100% {
		opacity: 1;
		-webkit-transform: translateY(0);
	}
}
@keyframes fadeInUp {
	0% {
		opacity: 0;
		transform: translateY(60px);
	}	
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes zoom {
    from { -webkit-transform: scale(1,0); }
    to { -webkit-transform: scale(1.5,1.5); }
}
@keyframes zoom {
   from { transform: scale(1,1); }
   to { transform: scale(1.5,1.5); }
}
