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

/* =========================
	body
========================= */
*, *:before, *:after {
    -webkit-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
.clearfix:before,
.clearfix:after {
    content: " ";
	display: table;}
.clearfix:after {
    clear: both;
}
body{
	font-size: 14px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	line-height: 160%;
	letter-spacing: 0.05em;
	color: #717071;
	background: url("../img/all/bg-beige.jpg") repeat;
}
p {	padding:0;	margin:0;}

img { margin: 0; padding: 0; /*width:100%;*/ max-width: 100%; border: none; vertical-align:middle;}
img.photo{ width:100%; height: auto;}

a:link,
a:visited {	color: #b40729;	text-decoration: none; word-break: break-all;}

a:focus { outline: none;}
iframe{ vertical-align: middle;}
table {
	width: 100%;
	word-break: break-all;
	vertical-align: middle;
	border-collapse: collapse;
	border: 1px dotted #999;
	}

th {
	padding: 0.3em 1em;
	white-space: nowrap;
	border: 1px dotted #999;
}
td {
	padding: 0.3em 1em;
	vertical-align: middle;
	border: 1px dotted #999;
	text-align: center;
}
table.border, .border th, .border td {
    border: 1px solid #000;
}

.table_w100 th{
	display:block;
	width:100%;
	border: 1px dotted #999;
}
.table_w100 td{
	display:block;
	width:100%;
	border: 1px dotted #999;
	text-align: center;
}
.table_w100 td.border_bottom{
	border-bottom: solid 1px #9a9082;
}
ul { padding: 0; margin: 0; list-style:none;}
div[data-role=navbar] ul li {
	overflow: hidden;
}

dl,dt,dd{ margin:0; padding:0;}

h1,h2,h3,h4,h5,h6{ margin:0; padding:0; font-size:100%; font-weight:normal;}
/*h2 img,h3 img,h4 img,h5 img,h6 img{ width:335px;}*/


/* =========================
	header
========================= */
.subpage .header{ max-width:800px; margin: 0 auto;}

/* =========================
	logo
========================= */
.subpage h1 {
	width: 100%;
	margin: 0;
	padding: 20px 20px;
	line-height: 0;
	text-align: center;
	background: url("../img/all/footer_bg.jpg") bottom center;
	-webkit-background-size: cover;
	background-size: cover;
}

.subpage h1 img {
	width: 100%;
	max-width: 270px;
}

/* =========================
	slider
========================= */
.slider_box {

}
/* =========================
	g_menu
========================= */
.g_menu {
	width: 100%;
	margin: 0;
	text-align: center;
	background: url("../img/all/menu_bg.jpg");
	-webkit-background-size: cover;
	background-size: cover;
}

.g_menu a {
	display: inline-block;
	width: 50%;
	max-width: 320px;
	padding: 20px 0;
}

.g_menu img {
	vertical-align:middle;
	max-width: 160px;
	
}

/* =========================
	menu
========================= */
.menu {
	margin: 0;
	background: url(../img/menu/menu_bg.jpg) no-repeat top left;
	-webkit-background-size: cover;
	background-size: cover;
	padding:10px 0;
}

.menu ul {
	width: 100%;
	max-width: 750px;
	margin: 0 auto;
	padding: 0;
}

.menu ul li {
	line-height: 0;
	list-style: none;
	border-bottom: 2px solid #fff;
	padding: 0 20px;
}
.menu ul .menu_up{
	text-align: center;
	background: #fff;
	border-bottom: none;
	margin-bottom: 2px;
	
}
.menu ul li a {
	display: block;
	padding: 16px 0;
	background: url(../img/all/arrow_02.png) no-repeat 100% 50%;
	background-size: auto 15px;
	text-decoration: none;
}
.menu ul .menu_up a {
	background: url(../img/all/arrow_01.png) no-repeat 100% 50%;
	background-size: auto 15px;
}
.menu ul li a img{ width: 165px;}
.menu ul .menu_up a img{ width: 115px;}

.menu ul li.smenu{ border-bottom: none;}
.menu ul li.smenu a{
	padding: 8px 0;
	background: url(../img/menu/pc.png) no-repeat 100% 50%;
	background-size: 18px auto;
	border-bottom:none;
}

/* =========================
	footer_menu
========================= */

.footer_menu {
	width:100%;
	}
.banner_wp{
	max-width: 670px;
	margin: 0 auto;
	padding: 20px;
	text-align: center;
}
.footer_menu p{ margin-bottom: 10px;}
.footer_menu p:last-child{ margin-bottom: 0;}

/* =========================
	f_menu
========================= */

.f_menu {
	margin: 0;
	padding: 16px 0;
	text-align:center;
}

.f_menu:after {
	content: "";
	display: block;
	clear: both;
}
.f_menu img {
	vertical-align:middle;
	max-width:160px;
}

.f_menu ul {
	max-width: 750px;
	margin: 0 auto;
	padding: 0;
}

.f_menu li {
	float: left;
	width: 50%;
	line-height: 0;
	text-align: center;
	list-style: none;
}

/* =========================
	footer
========================= */

.footer {
	margin: 0;
	padding: 0 0 0;
	background:url("../img/all/footer_bg.jpg");
	-webkit-background-size: cover;
	background-size: cover;
}
.footer .f_logo{ margin: 0 auto 10px auto;}
.footer .f_logo img{ width: 270px; height: auto;}
.footer_inner {
	width: 90%;
	max-width: 750px;
	margin: 0 auto;
	padding-top:20px;
	border-top:2px solid rgba(255,255,255,1);
	color:#fff;
}
.footer_inner span {
	display: inline-block;
	margin-right: 5px;
}

.footer_inner a,.footer_inner a:visited{ color:#fff; font-weight:normal;}

.copyright {
	font-size: 11px;
	color: #fff;
	padding: 0 0.5em;
	}
/* =========================
	Contents
========================= */
.contents {
	width: 100%;
	max-width: 750px;
	margin: 0 auto;
	padding: 40px 20px 0 20px;
}
.contents-nop {
	width: 100%;
	max-width: 750px;
	margin: 0 auto;
	padding: 0 20px 0 20px;
}
.contents-last {
	width: 100%;
	max-width: 750px;
	margin: 0 auto;
	padding: 40px 20px;
}
.contents p,.contents-last p{ margin:0; padding:0;}

.box_inner{
	width: 100%;
	max-width: 750px;
	margin: 0 auto;
	padding: 0 20px;
	}

.link_btn{ text-align:center;}
.link_btn img{ width: 335px;}

.shadow1{ box-shadow: 0px 4px 10px -4px rgba(0,0,0,0.3);}
.shadow2{ box-shadow:0px 4px 8px -4px rgba(0,0,0,0.5) inset;}

/*---ボタン---*/
.btn {
	min-width: 220px;
	width: 100%;
	height: 40px;
	display: inline-table;
	margin-top: 1.5em;
	}
	.btn a {
	font-weight: normal;
	line-height: 1em;
	display: table-cell;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	padding: 0 1em 0 3em;
	opacity: 1;
	color: #fff;
	position: relative;
	background-color: rgba(35,102,206,1.00);
	}
	.btn a::after {
	content: '\203A';
	margin-left: 4em;
	}
	.btn a:hover {
	background-color: #223355;	
	color: #fff;
	}
.btn.wh a {
	border: 2px solid #fff;
	color: #fff;
	background: none;
	}
	.btn.wh a:hover {
	background-color: #fff;	
	color: #000;
	}
/*---lightbox---*/
ul.gallery{
	list-style:none;
	padding:0;
	margin:0;
	text-align:center;
}
ul.gallery li{
	width: 90px;
	display:inline-block;
	margin-bottom:6px;
}
/* =========================
	page
========================= */
.subpage{ }
.subpage .header{ max-width:100%; height:260px; text-align:center; min-height:auto; position:relative;}
.subpage .header .pagetitle{
	width:100%;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translateY(-50%) translateX(-50%);	
	transform: translateY(-50%) translateX(-50%);
	padding: 20px;
	text-align: left;
	}
.subpage .header .pagetitle img{ width:250px; height:auto;}
.subpage .footer_menu{ border-top: 3px solid #073274;}

.subpage .contents { padding: 0 20px 0 20px;}
.subpage .white_box{ background: #fff; font-size: 13px; padding: 1em;}
.subpage h2,.subpage h3,.subpage h2,.subpage h4{ margin:0; padding:0;}
.subpage .caution{ font-size:12px; color:#cba026; line-height: 1.7em;}
.radius{ border-radius:6px;}

.subpage .anchor_list{ list-style-type:none; padding:0;}


@media screen and (max-width: 320px) {
}
/*------------------ index ------------------*/
#index .header{
	width: 100%;
	height: calc(100vh - 80px);
	position: relative;
	display: table;
	overflow: hidden;
	
}
#index .header_left{
	position: absolute;
	top: 0;
	left: 0;
	width: 50%;
	height: 100%;
	background: url("../img/index/cover-c-bg.jpg") no-repeat;
	-webkit-background-size: cover;
	background-size: cover;
	text-align: center;
	z-index: 88;
	display: table-cell;
	vertical-align: middle;
	padding: 30px 20px;
}
#index .slider_box{
	position: absolute;
	top: 0;
	right: 0;
	z-index: 77;
}

#index .header .movie_btn{
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	z-index: 999;
	background: #fff;
}
#index .contents01{
	background: url("../img/index/top.jpg") no-repeat;
	-webkit-background-size: cover;
	background-size: cover;
}
#index .contents01 .contents{ padding: 20px;}
#index .contents01 img{
	width: 110px;
	height: auto;
}

/*------------------ 天草の恵み ------------------*/
#grace .header{ background:url("../img/grace/top.jpg") no-repeat top center; -webkit-background-size:cover; background-size:cover;}

#grace .contents01 .img_wp,
#grace .contents02 .img_wp{
	position: relative;
	margin-top: 20px;
	padding-top: 20px;
}
#grace .contents01 .img_wp h2{
	position: absolute;
	top: 0;
	left: 20px;
	z-index: 99;
}
#grace .contents01 .img_wp h2 img,
#grace .contents02 .img_wp h2 img{
	width: 100px;
	height: auto;
}
#grace .contents01 .contents,
#grace .contents02 .contents{
	position: relative;
	margin-top: -10px;
}
#grace .contents02 .img_wp h2{
	position: absolute;
	top: 0;
	right: 20px;
	z-index: 99;
}
/*------------------ 新鮮魚貝 ------------------*/
#fresh .header{ background:url("../img/fresh/top.jpg") no-repeat top center; -webkit-background-size:cover; background-size:cover;}
#fresh .contents{ padding: 40px 20px 0 20px;}
#fresh .contents02 .contents{ padding: 40px 20px 0 20px;}

#fresh .flick2 .slick-arrow,
#facilities .flick2 .slick-arrow{ bottom: 36px;}
#fresh .flick2 .slick-dots,
#facilities .flick2 .slick-dots { bottom: 30px;}
#fresh h3,
#facilities h3{
    color: #595757;
	border-bottom: 1px solid #595757;
	padding-bottom: 8px;
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 10px;
}
/*------------------ 館内案内 ------------------*/
#facilities .header{ background:url("../img/facilities/top.jpg") no-repeat top center; -webkit-background-size:cover; background-size:cover;}
#facilities .contents{ padding: 40px 20px 0 20px;}
#facilities h4{  color: #595757; font-size: 18px; font-weight: bold; margin-bottom: 10px;}

/*------------------ 交通・周辺 ------------------*/
#access .header{ background:url("../img/access/top.jpg") no-repeat top center; -webkit-background-size:cover; background-size:cover;}
#access .contents{ padding: 30px 20px 0 20px;}
#access dt{
	color: #595757;
	border-bottom: 1px solid #595757;
	padding-bottom: 0.5em;
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 0.5em;
}
#access dd{ margin-bottom: 1.5em;}
#access dd:last-child{ margin-bottom: 0;}
#access .inner{ margin-bottom: 30px;}
#access .inner h3{
	margin-top: 14px;
	color: #595757;
	border-bottom: 1px solid #595757;
	padding-bottom: 8px;
	font-size: 16px;
	font-weight: bold;
}
#access .time{
	margin: 4px 0 14px;
	font-size: 13px;
}
#access .inner p.time a {
    color: #b40729;
    text-decoration: none;
}
/*------------------ 料金・ご予約 ------------------*/
#fee .header{ background:url("../img/fee/top.jpg") no-repeat top center; -webkit-background-size:cover; background-size:cover;}
#fee .contents{ padding: 30px 20px 0 20px;}
#fee .yado_detail span {
	display: inline-block;
	margin-right: 5px;
}
#fee h3{
    color: #595757;
	border-bottom: 1px solid #595757;
	padding-bottom: 8px;
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 10px;
}
#fee h4{ font-weight: bold;}
#fee table{ margin-bottom: 30px;}

/*------------------ English ------------------*/
#english .header{ background:url("../img/english/top.jpg") no-repeat top center; -webkit-background-size:cover; background-size:cover;}
#english .pagetitle{
	text-align: center;
	font-size: 26px;
	color: #fff;
	line-height: 40px;
}
#english .contents{ padding: 30px 20px 0 20px;}
#english h2.serif{
	color: #595757;
	font-size: 26px;
	font-weight: bold;
	margin-bottom: 10px;
	line-height: 30px;
}
#english h3{
	color: #595757;
	border-bottom: 1px solid #595757;
	font-weight: bold;
	padding-bottom: 8px;
	font-size: 18px;
	margin-bottom: 10px;
}
#english dt{ font-weight: bold;}
#english dd{ border-bottom: 1px dotted #999; text-align: right; padding-bottom: 0.5em; margin-bottom: 1em;}
#english dd:last-child{ margin-bottom: 0;}
#english .contents04 ul{
    list-style: circle;
    margin-left: 1.5em;
}
#english .contents04 ul li{
	margin-bottom: 1em;
}
#english .contents04 ul li:last-child{margin-bottom: 0;}
/*------------------ movie ------------------*/
.movie_page h1{ position:relative;}
.movie_page .g_menu{
}
.movie_contents {
	width: 100%;
	margin: 0 auto;
	padding: 20px 20px;
}

.movie_contents p,
.movie_contents h2 {
	margin: 0 0 20px;
	text-align: center;
}

.movie_contents span {
	display: inline-block;
}

.movie_contents strong {
	display: inline-block;
	margin: 0 10px;
}

.movie {
	padding: 0;
}

.movie_box {
	max-width: 750px;
	margin: 0 auto;
}

/* =========================
	add
========================= */

/*------------------ float ------------------*/

.clear { clear: both;}
.float_left { float: left;}
.float_right { float: right;}
.img_left {
	width: 49%;
	float: left;
	margin: 1% 0;
	line-height: 0;
	text-align: left;
}

.img_right {
	width: 49%;
	float: right;
	margin: 1% 0;
	line-height: 0;
	text-align: right;
}


/*------------------ margin ------------------*/

.m0 { margin: 0 !important;}
.mt10 {	margin-top: 10px !important;}
.mt20 { margin-top: 20px !important;}
.mt30 { margin-top: 30px !important;}
.mt40 {	margin-top: 40px !important;}
.mt50 {	margin-top: 50px !important;}

.mb0{ margin-bottom:0px !important;}
.mb1{ margin-bottom:1em !important;}
.mb10{ margin-bottom:10px !important;}
.mb20{ margin-bottom:20px !important;}
.mb30{ margin-bottom:30px !important;}
.mb35{ margin-bottom:35px !important;}
.mb40{ margin-bottom:40px !important;}
.mb50{ margin-bottom:50px !important;}
.mb60{ margin-bottom:60px !important;}
.mb70{ margin-bottom:70px !important;}
.mb80{ margin-bottom:80px !important;}
.mb90{ margin-bottom:90px !important;}
.mb100{ margin-bottom:100px !important;}

.pb0{ padding-bottom:0 !important;}
.pb30{ padding-bottom:30px !important;}
.pb40{ padding-bottom:40px !important;}

/*------------------ text ------------------*/
.center { text-align: center !important;}
.left {	text-align: left !important;}
.right { text-align: right !important;}
.strong{ font-weight:bold;}
.strong_red{ font-size:30px; color:#990000; font-weight:bold;}
.serif{ font-family: 'Noto Serif JP', serif; font-weight: bold;}
.small{ font-size:12px; line-height: 1.5em;}
.big{ font-size:16px;}
.title_text{
	font-size: 16px;
	font-weight: bold;
	padding-bottom: 10px;
	border-bottom: 1px dotted #999;
	margin-bottom: 10px;
	color: #444;
	}
.img_round{ border-radius: 12px; overflow:hidden;}
@media screen and (max-width: 320px) {
	.strong_red{ font-size:20px;}
}