@charset "UTF-8";
/**
*
* 海ナビ
*
*/
/* ==========================================================================
ページごとに変更
========================================================================== */
#umi, #umi-lower {
  /*全体背景色*/
  background-color: #1878cf;
  /*ロゴ横画像*/
  /*タイトル色変更*/
  /*サイドナビ色変更*/
  /*関連コンテンツタイトル色変更*/ }
  /*タイトル位置微調整*/
  @media screen and (max-width: 750px) {
    #umi #main, #umi-lower #main {
      position: inherit; }
    #umi #head-nav-wrap, #umi-lower #head-nav-wrap {
      padding-bottom: 32px; }
    #umi #head-nav-wrap:before, #umi-lower #head-nav-wrap:before {
      background-color: #fff; } }
  #umi #head-nav-wrap, #umi-lower #head-nav-wrap {
    background: url("https://cdn1.n-kishou.co.jp/image/common/bg_header_umi.png") left top no-repeat; }
    #umi #head-nav-wrap .logo-icon, #umi-lower #head-nav-wrap .logo-icon {
      display: none; }
  #umi .page-contents, #umi-lower .page-contents {
    /*全体背景画像*/
    background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/bg_umi.png) repeat-y center top #1878cf;
    background-size: contain;
    /*ヘッダー背景画像*/
    /*下層ヘッダー背景画像*/ }
    #umi .page-contents .page-contents-umi, #umi-lower .page-contents .page-contents-umi {
      background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/main_sp.jpg) no-repeat center top;
      background-size: contain;
      padding-top: 130px;
      margin-top: 2px; }
    #umi .page-contents.lower .page-contents-umi, #umi-lower .page-contents.lower .page-contents-umi {
      background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/main_sp_lower.jpg) no-repeat center top;
      background-size: contain;
      padding-top: 80px;
      margin-top: -2px; }
  #umi #foot, #umi-lower #foot {
    /*フッター帯背景色変更*/ }
    #umi #foot .foot-contents, #umi-lower #foot .foot-contents {
      /*フッター背景画像*/
      background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/footer_sp.png) no-repeat center bottom;
      padding-bottom: 120px;
      border-top: 1px solid #1878cf;
      /*フページトップボタン色変更*/ }
      #umi #foot .foot-contents .page-top a, #umi-lower #foot .foot-contents .page-top a {
        color: #fff; }
        #umi #foot .foot-contents .page-top a:before, #umi-lower #foot .foot-contents .page-top a:before {
          background-color: #fff; }
        #umi #foot .foot-contents .page-top a:after, #umi-lower #foot .foot-contents .page-top a:after {
          border-top: solid 3px #1878cf;
          border-right: solid 3px #1878cf; }
    #umi #foot .inner-foot, #umi-lower #foot .inner-foot {
      background-color: #23386b; }
      #umi #foot .inner-foot .cmn-inner.season, #umi-lower #foot .inner-foot .cmn-inner.season {
        display: none; }
  #umi .wrap-main-ttl .main-ttl, #umi-lower .wrap-main-ttl .main-ttl {
    -webkit-text-shadow: -2px -2px 4px #fff, 2px -2px 4px #fff, 2px 2px 4px #fff, -2px 2px 4px #fff, 0px 0px 15px #85c7db, 0px 0px 15px #85c7db;
    -moz-text-shadow: -2px -2px 4px #fff, 2px -2px 4px #fff, 2px 2px 4px #fff, -2px 2px 4px #fff, 0px 0px 15px #85c7db, 0px 0px 15px #85c7db;
    -ms-text-shadow: -2px -2px 4px #fff, 2px -2px 4px #fff, 2px 2px 4px #fff, -2px 2px 4px #fff, 0px 0px 15px #85c7db, 0px 0px 15px #85c7db;
    -o-text-shadow: -2px -2px 4px #fff, 2px -2px 4px #fff, 2px 2px 4px #fff, -2px 2px 4px #fff, 0px 0px 15px #85c7db, 0px 0px 15px #85c7db;
    text-shadow: -2px -2px 4px #fff, 2px -2px 4px #fff, 2px 2px 4px #fff, -2px 2px 4px #fff, 0px 0px 15px #85c7db, 0px 0px 15px #85c7db; }
  #umi .cmn-sttl2, #umi-lower .cmn-sttl2 {
    color: #fff;
    border-color: #fff; }
  #umi .cmn-sttl2.sct-nimbus-ttl, #umi-lower .cmn-sttl2.sct-nimbus-ttl {
    color: #015db2;
    border-color: #015db2; }
  #umi .sp-side-nav .sp-side-nav-ttl, #umi-lower .sp-side-nav .sp-side-nav-ttl {
    /*サイドナビタイトル背景色*/
    background-color: #a3c9ec;
    /*サイドナビタイトル文字色*/
    color: #015db2; }
  #umi .cmn-sttl, #umi-lower .cmn-sttl {
    /*関連コンテンツ背景色*/
    background-color: #a3c9ec;
    /*関連コンテンツ文字色*/
    color: #015db2; }

/*下層 ロゴ*/
@media screen and (min-width: 751px) {
  #umi-lower #head-logo {
    width: 285px;
    background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/logo_umi_pc.png);
    background-size: 75px auto;
    background-position: 185px 8px;
    background-repeat: no-repeat;
    padding-bottom: 10px; }
    #umi-lower #head-logo img {
      width: 180px; }
  #umi-lower #head-nav-wrap {
    padding-bottom: 30px;
    }
  #umi-lower .page-contents.lower .page-contents-umi {
    padding-top: 0; } }
/*下層 ロゴ*/
@media screen and (max-width: 750px) {
  #umi-lower #head-logo {
    width: 285px;
    background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/logo_umi.png);
    background-size: 95px auto;
    background-position: center 62px;
    background-repeat: no-repeat;
    height: 107px; }
  #umi-lower #head-nav-wrap {
    padding-bottom: 0px;
    }
  #umi-lower .page-contents.lower .page-contents-umi {
    padding-top: 0; }
  #umi-lower .body-inner {
    width: 100%; } }
@media screen and (min-width: 751px) {
  #umi, #umi-lower {
    /*ロゴ横画像*/ }
    #umi #head-nav-wrap, #umi-lower #head-nav-wrap {
      padding-top: 0px;
      padding-bottom: 0px;
      border-bottom: none;
      /* background-image: url("https://cdn1.n-kishou.co.jp/image/common/bg_header_pc01_umi.png"), url("https://cdn1.n-kishou.co.jp/image/common/bg_header_pc02.png"); */
      background-position: center 5px, left 10px;
      background-repeat: no-repeat , repeat-x;
      background-size: auto;
      }
    #umi .gnav:after, #umi-lower .gnav:after {
      background-color: #fff; }
    #umi .page-contents, #umi-lower .page-contents {
      background-image: none;
      /*ヘッダー背景画像*/
      /*下層ヘッダー背景画像*/ }
      #umi .page-contents .page-contents-umi, #umi-lower .page-contents .page-contents-umi {
        background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/main_pc02.png), url(https://cdn1.n-kishou.co.jp/image/charge/tide/main_pc01.jpg);
        background-repeat: no-repeat,repeat-x;
        background-position: center top,center top;
        background-size: auto;
        padding-top: 195px; }
      #umi .page-contents.lower .page-contents-umi, #umi-lower .page-contents.lower .page-contents-umi {
        background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/main_pc01_lower.jpg);
        background-repeat: repeat-x;
        background-position: center top;
        background-size: auto;
        padding-top: 40px; }
  #umi .cmn-sttl2.sct-nimbus-ttl, #umi-lower .cmn-sttl2.sct-nimbus-ttl {
    color: #015db2;
    border-color: #015db2; }

    #umi #foot .foot-contents, #umi-lower #foot .foot-contents {
      /*フッター背景画像*/
      background: url(https://cdn1.n-kishou.co.jp/image/charge/tide/footer_pc02.png), url(https://cdn1.n-kishou.co.jp/image/charge/tide/footer_pc01.png);
      background-repeat: no-repeat,repeat-x;
      background-position: center bottom,center bottom;
      background-size: auto; } }
/* ==========================================================================
Twitterボタン 白に変更する場合
========================================================================== */
.btn-twitter.btn-shadow.shadow03 a {
  background-color: #fff;
  color: #015db2;
  -webkit-box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  -moz-box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  -ms-box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  -o-box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5); }
  .btn-twitter.btn-shadow.shadow03 a:before {
    background: url(https://cdn1.n-kishou.co.jp/image/common/icon_twitter2.png) left top no-repeat;
    background-size: 100%; }
  .btn-twitter.btn-shadow.shadow03 a.touch, .btn-twitter.btn-shadow.shadow03 a.hover {
    -webkit-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
    -moz-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
    -ms-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
    -o-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
    box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5); }

/* ==========================================================================
以下海ナビ用css
========================================================================== */
.inner-box {
  margin-bottom: 50px; }

.sub-sttl3-umi {
  color: #fff;
  line-height: 1;
  margin-bottom: 8px; }

.cmn-sttl3-umi {
  margin-bottom: 14px;
  color: #fff;
  font-size: 32px;
  font-size: 3.2rem;
  line-height: 1; }
  .cmn-sttl3-umi:after, .cmn-sttl3-umi:before {
    display: inline-block;
    content: "/";
    font-size: 34px;
    font-size: 3.4rem; }
  .cmn-sttl3-umi:before {
    margin-right: 15px;
    -webkit-transform: scale(-1, 1);
    -ms-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  .cmn-sttl3-umi:after {
    margin-left: 15px; }

.search-btn-wrap {
  background-color: #e7e7e7;
  margin-top: 40px;
  padding: 30px 30px 20px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  -ms-border-radius: 10px;
  -o-border-radius: 10px;
  border-radius: 10px; }
  .search-btn-wrap h3 {
    margin-bottom: 20px; }
  .search-btn-wrap .btn-cmn a {
    width: 100%;
    box-sizing: border-box; }

.service-list {
  overflow: hidden;
  margin: 50px 0;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  -ms-border-radius: 10px;
  -o-border-radius: 10px;
  border-radius: 10px; }
  .service-list li {
    box-sizing: border-box;
    width: 33.3%;
    padding: 0;
    text-align: center;
    border-top: 2px solid #efefef;
    border-right: 2px solid #efefef; }
    .service-list li:nth-child(1), .service-list li:nth-child(2), .service-list li:nth-child(3) {
      border-top: none; }
    .service-list li:nth-child(3n) {
      border-right: none; }
    .service-list li span {
      display: block;
      height: 80px;
      line-height: 1; }
      .service-list li span img {
        width: auto;
        height: 80px; }
    .service-list li a {
      display: block;
      text-decoration: none;
      color: #015db2;
      background-color: #fff;
      font-size: 28px;
      font-size: 2.8rem;
      font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
      font-style: normal;
      font-weight: 700; }

.link-list li {
  background-color: #fff; }
  .link-list li a {
    background-color: #fff; }
    .link-list li a span {
      color: #585858;
      font-size: 28px;
      font-size: 2.8rem; }

@media screen and (min-width: 751px) {
  .cmn-sttl3-umi {
    font-size: 22px;
    font-size: 2.2rem; }
    .cmn-sttl3-umi:after, .cmn-sttl3-umi:before {
      font-size: 22px;
      font-size: 2.2rem; }

  .link-list li a span {
    font-size: 14px;
    font-size: 1.4rem; }

  .service-list li a {
    font-size: 16px;
    font-size: 1.6rem; } }
/* ==========================================================================
釣果ボタン
========================================================================== */
.btn-choka {
  position: relative;
  border: 10px solid #62ceff;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  -ms-border-radius: 10px;
  -o-border-radius: 10px;
  border-radius: 10px;
  margin-top: 20px;
  margin-bottom: 50px;
  background-color: #fff; }
  .btn-choka .tenavin {
    position: absolute;
    left: 0;
    top: -91px; }
  .btn-choka a {
    display: block;
    overflow: hidden;
    padding: 25px 60px 20px 120px;
    line-height: 1.4;
    text-decoration: none;
    color: #1878cf;
    background-image: url("https://cdn1.n-kishou.co.jp/image/charge/tide/img_navu01.gif");
    background-repeat: no-repeat;
    background-position: 20px center;
    background-size: 82px auto;
    background-color: #fff;
    font-size: 46px;
    font-size: 4.6rem;
    font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
    font-style: normal;
    font-weight: 700; }
    .btn-choka a:after {
      right: 30px; }
  .btn-choka span {
    line-height: 1; }
    .btn-choka span.subttl01 {
      font-size: 22px;
      font-size: 2.2rem;
      display: block;
      background-color: #fff; }
    .btn-choka span.subttl02 {
      font-size: 32px;
      font-size: 3.2rem;
      background-color: #fff;
      display: inline-block; }

@media screen and (min-width: 751px) {
  .btn-choka {
    border-color: #62ceff; }
    .btn-choka a {
      padding: 25px 60px 20px 100px;
      color: #015db2;
      background-position: 20px center;
      background-size: 62px auto;
      background-color: #fff;
      font-size: 22px;
      font-size: 2.2rem; }
      .btn-choka a:after {
        right: 30px; }
    .btn-choka span {
      line-height: 1; }
      .btn-choka span.subttl01 {
        font-size: 16px;
        font-size: 1.6rem;
        display: block; }
      .btn-choka span.subttl02 {
        font-size: 18px;
        font-size: 1.8rem; } }

/* ==========================================================================
  ボタン色
========================================================================== */
/* メイン色
.btn-cmn a, .page-control .btn-prev a, .page-control .btn-next a,
.btn-cmn input {
  color: #fff;
  background: #0f58b1; }*/

/* 影色(海背景の上にボタンを置くときのみ使用) */
  .btn-shadow.shadow03_umi > * {
    -webkit-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(27, 46, 87, 0.6);
    -moz-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(27, 46, 87, 0.6);
    -ms-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(27, 46, 87, 0.6);
    -o-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(27, 46, 87, 0.6);
    box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(27, 46, 87, 0.6);
    }
  .btn-shadow.shadow03_umi > *.hover, .btn-shadow.shadow03_umi > *.touch {
    -webkit-box-shadow: inset 0 -1px 0 2px rgba(27, 46, 87, 0.6);
    -moz-box-shadow: inset 0 -1px 0 2px rgba(27, 46, 87, 0.6);
    -ms-box-shadow: inset 0 -1px 0 2px rgba(27, 46, 87, 0.6);
    -o-box-shadow: inset 0 -1px 0 2px rgba(27, 46, 87, 0.6);
    box-shadow: inset 0 -1px 0 2px rgba(27, 46, 87, 0.6); }
/* ==========================================================================
	マップ紹介
========================================================================== */
	.area-nowcast {
		position: relative;
		margin-bottom: 50px;
		padding: 25px 20px 20px 20px;
		border: 10px solid #fff;
		background-image: url("https://cdn1.n-kishou.co.jp/image/charge/tide/map_img.png"), url("https://cdn1.n-kishou.co.jp/image/charge/tide/bg_oceanmap.png");
		background-repeat: no-repeat , repeat;
		background-position: 480px 25px , center;
		background-size: 180px auto , 20px auto;
		-webkit-border-radius: 10px;
		-moz-border-radius: 10px;
		-ms-border-radius: 10px;
		-o-border-radius: 10px;
		border-radius: 10px; }
		.area-nowcast .nowcast-ttl {
			margin-bottom: 26px; }
			.area-nowcast .nowcast-ttl img {
				width: 426px;}
		.area-nowcast .txt-nowcast {
			margin-top:-20px;
			margin-bottom: 20px;
			padding-right: 160px;
			line-height: 1.4;
			color: #fff;
			font-size: 30px;
			font-size: 3.0rem;
			font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
			font-style: normal;
			font-weight: 700;
			padding-left:20px; }
		.area-nowcast .nowcast-list {
			top:-0px;
			margin: 0 -8px; }
			.area-nowcast .nowcast-list li {
				box-sizing: border-box;
				width: 33.3%;
				padding: 0 8px;
				text-align: center;
				}
				.area-nowcast .nowcast-list li a {
					/* display: block; */
					margin:0px 0px 0px 0px;
					padding: 16px 20px 20px 20px;
					text-decoration: none;
					color: #015db2;
					background-color: #fff;
					font-size: 32px;
					font-size: 3.2rem;
					font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
					font-style: normal;
					font-weight: 700;
					}
					.area-nowcast .nowcast-list li a span {
						font-size: 24px;
						font-size: 2.4rem; }


@media screen and (min-width: 751px) {

		.area-nowcast {
		position: relative;
		margin-bottom: 50px;
		padding: 15px 20px 15px 20px;
		border: 10px solid #fff;
		background-image: url("https://cdn1.n-kishou.co.jp/image/charge/tide/map_img.png"), url("https://cdn1.n-kishou.co.jp/image/charge/tide/bg_oceanmap.png");
		background-repeat: no-repeat , repeat;
		background-position: 430px 15px , center;
		background-size: 170px auto , 20px auto;
		-webkit-border-radius: 10px;
		-moz-border-radius: 10px;
		-ms-border-radius: 10px;
		-o-border-radius: 10px;
		border-radius: 10px; }
		.area-nowcast .nowcast-ttl {
			margin-bottom: 26px; }
			.area-nowcast .nowcast-ttl img {
				width: 380px;}

	
			.area-nowcast .nowcast-list li {
				box-sizing: border-box;
				width: 33.3%;
				padding: 0 8px;
				margin-top: -15px;
				text-align: center;
				}

				.area-nowcast .nowcast-list li a {
					/* display: block; */
					padding: 5px 20px;
					text-decoration: none;
					color: #015db2;
					background-color: #fff;
					font-size: 25px;
					font-size: 2.5rem;
					font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
					font-style: normal;
					font-weight: 700;
					}

			.area-nowcast .txt-nowcast {
				margin-bottom: 26px;
				padding-right: 160px;
				line-height: 1.4;
				color: #fff;
				font-size:21px;
				font-size: 2.2rem;
				font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
				font-style: normal;
				font-weight: 700; }
}
/* ==========================================================================
sct-service
========================================================================== */
.wrap-sct-service {
	position: relative;
}


.sct-service .service-list li:nth-child(1), .sct-service .service-list li:nth-child(2), .sct-service .service-list li:nth-child(3) {
	border-top: none;
}

.sct-service .service-list li:nth-child(3n) {
	border-right: none;
}

.sct-service .service-list li span {
	display: block;
	height: 80px;
	line-height: 1;
}

.sct-service .service-list li span img {
	width: auto;
	height: 80px;
}

.sct-service .service-list li a {
	display: block;
	text-decoration: none;
	color: #015db2;
	background-color: #fff;
	font-size: 28px;
	font-size: 2.8rem;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}

@media screen and (min-width: 751px) {
	.wrap-sct-service:before {
		top: 105px;
		left: 10px;
	}
	.wrap-sct-service:after {
		top: 70px;
		right: 10px;
	}
	.sct-service .sct-service-ttl img {
		width: 260px;
		height: auto;
	}
	.sct-service .sct-service-sttl {
		margin-bottom: 20px;
	}
	.sct-service .service-list {
		margin: 0 0 50px;
	}
	.sct-service .service-list li {
		text-align: left;
	}
	.sct-service .service-list li span {
		display: inline-block;
		margin-bottom: 0;
		line-height: 1;
		vertical-align: middle;
	}
	.sct-service .service-list li span img {
		height: 70px;
	}
	.sct-service .service-list li a {
/*		padding: 5px 0 5px 80px;*/
		padding: 6px 0 4px 80px;
		font-size: 18px;
		font-size: 1.8rem;
	}
	.sct-service .service-list li a.hover, .sct-service .service-list li a.touch {
		padding-top: 7px;
		padding-bottom: 3px;
	}
}


@media screen and (min-width: 751px) {
.area-tidegraph {
  position: relative;
  margin-top: 0px;
  margin-bottom: 20px;
  border: 10px solid #fff;
  border-radius: 10px;
  padding-top:0px;
}
}
/* ==========================================================================
sct-service
========================================================================== */
.wrap-sct-service {
	position: relative;
}

.sct-service .service-list li:nth-child(1), .sct-service .service-list li:nth-child(2), .sct-service .service-list li:nth-child(3) {
	border-top: none;
}

.sct-service .service-list li:nth-child(3n) {
	border-right: none;
}

.sct-service .service-list li span {
	display: block;
	height: 80px;
	line-height: 1;
}

.sct-service .service-list li span img {
	width: auto;
	height: 80px;
}

.sct-service .service-list li a {
	display: block;
	text-decoration: none;
	color: #015db2;
	background-color: #fff;
	font-size: 28px;
	font-size: 2.8rem;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}

@media screen and (min-width: 751px) {
	.wrap-sct-service:before {
		top: 105px;
		left: 10px;
	}
	.wrap-sct-service:after {
		top: 70px;
		right: 10px;
	}
	.sct-service .sct-service-ttl img {
		width: 260px;
		height: auto;
	}
	.sct-service .sct-service-sttl {
		margin-bottom: 20px;
	}
	.sct-service .service-list {
		margin: 0 0 50px;
	}
	.sct-service .service-list li {
		text-align: left;
	}
	.sct-service .service-list li span {
		display: inline-block;
		margin-bottom: 0;
		line-height: 1;
		vertical-align: middle;
	}
	.sct-service .service-list li span img {
		height: 70px;
	}
	.sct-service .service-list li a {
/*		padding: 5px 0 5px 80px;*/
		padding: 6px 0 4px 80px;
		font-size: 18px;
		font-size: 1.8rem;
	}
	.sct-service .service-list li a.hover, .sct-service .service-list li a.touch {
		padding-top: 7px;
		padding-bottom: 3px;
	}
}
/* ==========================================================================
		service-list ナビ
========================================================================== */
/*スマホの表示ここから*/
@media screen and (max-width: 750px) {
	/* 全体設定 */
	/*  {*/
	/* 	box-sizing: border-box;*/
	/*	}*/

	/* ポップアップウインドウの設定 */
	.popup {
		background-color: #082a48;
		box-shadow: 0 0 0 9999px rgba(0, 0, 0, .8);
		display: none;
		position: relative;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 1;

	}
	/* チェックボックスの初期設定 */
	#popup-on{
		display: none;
	}
	/* チェックされたらポップアップウインドウを開く */
	#popup-on:checked + .popup{
		display: block;
	}

	/* 開くボタン */
	.btn-open{
		background: #fff;
		border-radius: 10px;
		color: #fff;
		padding: 10px;
		cursor: pointer;
		margin: 10px auto;
		width: 95%;
		text-align: center;
	}

	/* ポップアップの内容 */
	.popup-content{
		margin: 40px auto 40px auto;
		width: 100%;
		border-radius: 10px;

	}
	.popup-content:before {
		content: "";
		position: absolute;
		top: -48px;
		left: 50%;
		border: 20px solid transparent;
		border-bottom: 30px solid #fff;
		margin-left: -21px;
	}

}
/*スマホの表示ここまで*/

/*PC表示ここから*/
/*調査中*/
@media screen and (min-width: 751px) {
	/* 全体設定 */
	/* {*/
	/* box-sizing: border-box;*/
	/*	}*/

	/* ポップアップウインドウの設定 */
	.sct-service .popup {
		background-color: #082a48;
		box-shadow:	0 0 0 9999px	rgba(0, 0, 0, 0.65);
		display: none;
		position: relative;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 1;
	}
	/* チェックボックスの初期設定 */
	.sct-service #popup-on{
		display: none;
	}
	/* チェックされたらポップアップウインドウを開く */
	.sct-service #popup-on:checked + .popup{
		display: block;
	}

	/* 開くボタン */
	.sct-service .btn-open{
		background: #fff;
		border-radius: 10px;
		color: #fff;
		padding: 10px;
		cursor: pointer;
		margin: 10px auto;
		width: 95%;
		text-align: center;
	}

	/* ポップアップの内容 */
	.sct-service .popup-content {
		background: transparent;
		margin: 40px auto 40px auto;
		width: 100%;
		border-radius: 10px;
	}
	.sct-service .popup-content:nth-of-type(3n + 2):before {
		left: 50%;
	}
	.sct-service .popup-content:before {
			content: "";
			position: absolute;
			top: -48px;
			left: 50%;
			border: 20px solid transparent;
			border-bottom: 30px solid #fff;
			margin-left: -20px;
	}
}

/*PC表示ここまで*/

/* ==========================================================================
		文字色
========================================================================== */

.white01 {
	color: #fff;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}

/* btn-cam02（海ナビパワーアップ予告の表示）
------------------------------------------------------*/
.btn-cam02 {
	box-sizing: border-box;
}

.btn-cam02 a {
	display: block;
	margin: 0px 0px 30px 0px;
	padding: 8px 88px 8px 25px;
	text-decoration: none;
	color: #015db2;
	border-radius: 8px;
	background: #d9f3ff;
	font-size: 24px;
	font-size: 2.4rem;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}


@media screen and (min-width: 751px) {
	.btn-cam02 a {
		margin: -20px 0px 40px 0px;
		padding: 8px 90px 8px 25px;
		font-size: 16px;
		font-size: 1.6rem;
	}
}

/* btn-umi（海洋マップ用の海ナビパワーアップ予告の表示）
------------------------------------------------------*/
.btn-umi {
	box-sizing: border-box;
}

.btn-umi a {
	display: block;
	margin: 0px 0px 40px 0px;
	padding: 8px 88px 8px 25px;
	text-decoration: none;
	color: #015db2;
	border-radius: 8px;
	background: #d9f3ff;
	font-size: 24px;
	font-size: 2.4rem;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}


@media screen and (min-width: 751px) {
	.btn-umi a {
		margin: 20px 0px 40px 0px;
		padding: 8px 90px 8px 25px;
		font-size: 16px;
		font-size: 1.6rem;
	}
}
.overlay{
	background-color: #082a48;
	box-shadow:	0 0 0 9999px	rgba(0, 0, 0, 0.65);
	position: relative;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
.btn_area{
		width:300px;
		height:150px;
		position:absolute;
		top:50%;
		left:50%;
		margin-top:-75px;
		margin-left:-150px;
		background-color:#fff;
		z-index:2;
}
.btn_area p{
		padding:15px;
}
.btn_area button{
		display:block;
		margin:0 auto;
}


/* ==========================================================================
    service-list ナビ
    ========================================================================== */
.body-inner #main,
.body-inner .sct-service {
  z-index: 9999;
}


.body-inner.service-overlay .wrap-overlay {
  position: fixed;
  z-index: 9997;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.65);
}

.body-inner .service-list.active {
  z-index: auto;
}

.body-inner .service-list.active > li.active {
  background: #fff;
  position: relative;
  z-index: 9999;
}

.body-inner .wrap-service-list-lvl2 {
  background: #e5eaee;
  position: absolute;
  z-index: 9999;
  width: 710px;
  box-sizing: border-box;
  padding: 0 30px;
  border-radius: 10px;
  display: none;
}

.body-inner .wrap-service-list-lvl2 .service-list-lvl2 {
  background: #e5eaee;
  margin-bottom: 0;
  position: absolute;
}

.body-inner .wrap-service-list-lvl2 .service-list-lvl2 li {
  border-color: #d3d6d8;
}

.body-inner .wrap-service-list-lvl2:before {
  content: "";
  position: absolute;
  top: -48px;
  left: 50%;
  border: 20px solid transparent;
  border-bottom: 30px solid #e5eaee;
  margin-left: -20px;
}

.body-inner .wrap-service-list-lvl2:nth-of-type(3n + 1):before {
  left: 16%;
}

.body-inner .wrap-service-list-lvl2:nth-of-type(3n + 2):before {
  left: 50%;
}

.body-inner .wrap-service-list-lvl2:nth-of-type(3n + 3):before {
  left: 84%;
}

@media screen and (max-width: 750px) {
  .body-inner .wrap-service-list-lvl2 {
    padding: 0;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2 {
    display: block;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2:after {
    content: "";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li {
    width: 50%;
    float: left;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li span, .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li a {
    font-size: 24px;
    font-size: 2.4rem;
    padding-right: 30px;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li .icon-arrow-s:after {
    right: 20px;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li:nth-child(odd) {
    border-right: 2px solid #d3d6d8;
  }
}

@media screen and (min-width: 751px) {
  .body-inner .wrap-service-list-lvl2 {
    padding: 0 0px;
    position: absolute;
  }
  .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li:nth-last-child(1), .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li:nth-last-child(2), .body-inner .wrap-service-list-lvl2 .service-list-lvl2 li:nth-last-child(3) {
    border-bottom: 2px solid #d3d6d8;
  }
}


/* ==========================================================================
 マップ
========================================================================== */
/* 拡大縮小ボタン（スマホ） */
.leaflet-touch .leaflet-bar a {
	width: 60px;
	height: 60px;
	line-height: 50px;
}
.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out	{
	font-size: 40px;
}

/* マーカー吹き出し（スマホ）*/
	/* 吹き出しの大きさ*/
	.leaflet-popup-content {
		margin: 22px 36px;
		line-height: 1.6;
		}
	/* 吹き出しの文字サイズ*/
	.leaflet-popup-content span {
		border-bottom: solid 1px;
		}

@media screen and (min-width: 751px) {
	/* 拡大縮小ボタン（PC） */
	.leaflet-touch .leaflet-bar a {
			width: 40px;
			height: 40px;
			line-height: 40px;
	}
	.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out	{
		font-size: 22px;
	}
	/* マーカー吹き出し（PC）*/
	/* 吹き出しの大きさ*/
	.leaflet-popup-content {
		margin: 13px 19px;
		line-height: 1.4;
	}
	/* 吹き出しの文字サイズ*/
	.leaflet-popup-content span {
		font-size: 1.6em;
		border-bottom: solid 1px;
	}
}

/* ==========================================================================
タイドグラフPROバナー
========================================================================== */
.area-tidegraph {
  position: relative;
  margin-top: 0px;
  margin-bottom: 20px;
  border: 10px solid #fff;
  border-radius: 10px;
  padding-top:0px;
}

/* ==========================================================================
キャンペーンの背景
========================================================================== */
#campaign{
 background-color: #77d4ff;
 width:100%;
 padding-top:10px;
 padding-bottom:30px;
}

/* ==========================================================================
サンプルページを見てみるのボタン配置
========================================================================== */
.sample_attend{
	padding-right:20px;
}

@media screen and (min-width: 751px) {
	.sample_attend{
		padding-right:85px;
	}

	.wind-btn{
	    padding-right:20px;
    }
}

/* ==========================================================================
//ボタン
========================================================================== */

.btn-shadow-tide > *,
.btn-shadow-menu > * {
  display: block;
  border-radius: 10px;
  width:100%;
  -ms-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  -o-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
}

.btn-shadow-tide > *.btn-shadow-img,
.btn-shadow-menu > *.btn-shadow-img {
  -ms-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3);
  -o-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3);
  box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3);
}

.btn-shadow-tide > *.btn-shadow-img a,
.btn-shadow-menu > *.btn-shadow-img a {
  position: relative;
  display: block;
}

.btn-shadow-tide > *.btn-shadow-img a:before,
.btn-shadow-menu > *.btn-shadow-img a:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  overflow: hidden;
  width: 100%;
  height: 100%;
  content: "";
  border-radius: 10px;
  -ms-box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  -o-box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
  box-shadow: inset 0 -4px 0 2px rgba(195, 195, 195, 0.5);
}

.btn-shadow-tide > *.hover, .btn-shadow-tide > *.touch,
.btn-shadow-menu > *.hover, .btn-shadow-menu > *.touch {
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  -ms-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
  -o-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
  box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
}

.btn-shadow-tide > *.hover.btn-shadow-img a:before, .btn-shadow-tide > *.touch.btn-shadow-img a:before,
.btn-shadow-menu > *.hover.btn-shadow-img a:before, .btn-shadow-menu > *.touch.btn-shadow-img a:before {
  -ms-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
  -o-box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
  box-shadow: inset 0 -1px 0 2px rgba(195, 195, 195, 0.5);
}

.btn-shadow-tide.shadow04 > * {
  -ms-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(130, 130, 130, 0.3);
  -o-box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(130, 130, 130, 0.3);
  box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.3), inset 0 -4px 0 2px rgba(130, 130, 130, 0.3);
}

.btn-shadow-tide.shadow04 > *.btn-shadow-img a:before {
  -ms-box-shadow: inset 0 -4px 0 2px rgba(130, 130, 130, 0.3);
  -o-box-shadow: inset 0 -4px 0 2px rgba(130, 130, 130, 0.3);
  box-shadow: inset 0 -4px 0 2px rgba(130, 130, 130, 0.3);
}

.btn-shadow-tide.shadow04 > *.hover, .btn-shadow.shadow04 > *.touch {
  -ms-box-shadow: inset 0 -1px 0 2px rgba(130, 130, 130, 0.3);
  -o-box-shadow: inset 0 -1px 0 2px rgba(130, 130, 130, 0.3);
  box-shadow: inset 0 -1px 0 2px rgba(130, 130, 130, 0.3);
}

.btn-shadow-tide.shadow04 > *.hover.btn-shadow-img a:before, .btn-shadow.shadow04 > *.touch.btn-shadow-img a:before {
  -ms-box-shadow: inset 0 -1px 0 2px rgba(130, 130, 130, 0.3);
  -o-box-shadow: inset 0 -1px 0 2px rgba(130, 130, 130, 0.3);
  box-shadow: inset 0 -1px 0 2px rgba(130, 130, 130, 0.3);
}


.image{
float:left;
width:30%;
margin:12px;
}

.image02{
float:left;
width:30%;
margin:12px;
margin-bottom:50px;
}

/* ==========================================================================
//2023_lp変更
========================================================================== */

html {
  scroll-behavior: smooth;
}

body {
  color: #585858;
  overflow-y:hidden;
}

.b_fixed {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  /* overflow-y: scroll; */
}
/* 
body.ad_modal-content {
  height: 100vh;
  overflow-y: hidden;
} */

h2 {
  font-style: normal;
  font-weight: 600;
  font-size: 9rem;
  color:#6d6d6d;
}

h3{
  line-height: 1.3;
  font-size: 4.5rem;
  font-weight:100;
}

.em1 {
  letter-spacing: -1em;
  display: inline-block;
}

.em04 {
  letter-spacing: -0.4em;
  display: inline-block;
}
.em01 {
  letter-spacing: -0.1em;
  display: inline-block;
}

.ad_keyvisual {
  position: relative;
}

.ad_logo {
  position:absolute;
  top:20px;
  left:20px;
}

.ad_main {
  margin: 0 20px;
}

.ad_navi{    
  list-style: none;
  display:flex;
  background: #f7f5f1; 
  font-size: 2.8rem;
  padding: 25px 0;
  border-radius: 10px 10px 0px 0px;
  justify-content: space-around;
}

.ad_section {
  background-color: #fff;
  border-bottom: 10px solid #fff;
}

.ad_section-gray {
  background-color: #f7f5f1;
}

.ad_section-white {
  background-color: #fff;
}

.ad_container {
  text-align: center;
  padding-top: 85px;
  padding-bottom: 85px;
  margin-left: auto;
  margin-right: auto;
  width: 87.5%;
}

.ad_container-gray {
  text-align: center;
  padding-top: 85px;
  padding-bottom: 85px;
  margin-left: auto;
  margin-right: auto;
  width: 87.5%;
}

.flex-item {
  flex: 1;
  text-align: center;
}

.icon-arrow-s:after {
  position: absolute;
  content: "";
  border: 0;
  border-top: solid 4px #015db2;
  border-right: solid 4px #015db2;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  border-radius: 1px 1px 1px 100%;
}

li a {
  padding: 15px 30px 15px 20px;
}

.ad_title{
  display: flex;
  justify-content: center;
}

.ad_subtitle {
  font-size: 4rem;
}

.ad_flex {
  display: flex;
  gap: 6%;
}

.ad_flexitem {
  flex: 1;  
}

.ad_image {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 53px;
  margin-top: 53px;
  flex: 1;
}

.ad_text {
  flex: 1;
  display: block;
  padding-top: 34px;
  text-align: left;
 }

 .fade-over a {
  -webkit-opacity: 1;
  -moz-opacity: 1;
  -ms-opacity: 1;
  -o-opacity: 1;
  opacity: 1;
  transition: opacity 0.3s;
  -webkit-font-smoothing: antialiased;
}

.fade-over a.hover, .fade-over a.touch {
  -webkit-opacity: 0.5;
  -moz-opacity: 0.5;
  -ms-opacity: 0.5;
  -o-opacity: 0.5;
  opacity: 0.5;
}

.Link {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  position:relative;
}

.Link::before {
  content: '';
}
.Link::after {
  position: absolute;
  content: '';
  border: 0;
  border-top: solid 2px #015db2;
  border-right: solid 2px #015db2;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width:8px;
  height:8px;
  right: 30px;
}

.ad_button {
  border-radius: 50px;
  background: #D9F3FF;
  display: block; /*inline-block*/
  padding: 10px;
  margin-top: 30px;
  width: 100%;
  position:relative;
  cursor: pointer;
  /* -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease; */
}

.ad_button_small {
  border-radius: 5cqh;
  background: #D9F3FF;
  display: block;
  font-size: 2.5rem;
  margin-top: 10px;
  text-align: right;
}

.ad_content {
  display: flex;
  flex-direction: column;
  color:#696969;
}

.ad_custom_lower {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.ad_btnarea {
  margin-bottom: 100px;
}

.ad_btnarea_lower {
  flex-grow: 1;  
} 

.ad_detailTxt {
  font-weight: 700;
  font-size: 4.5rem;
  line-height: 1.4;
  text-align: left;
}

.ad_usage_txt {
  flex: 1;
  text-align: left;
  font-size: 3rem;
  width:85%;
}

.ad_explanation {
    width:80%;
}

.ad_pay_txt{
  line-height: 1.3;
}

.ad_custom_txt {
  line-height: 1.3;
  font-size: 8rem;
}

.ad_button a, .ad_button_small a, button a {
  color: #015DB2;
  font-weight: 500;
  font-size:3rem;
}

.ad_detail {
  width: 85%;
  text-align: left;
  margin: 0 auto;
}

.ad_content_row {
  display: flex;
  gap: 6%;
  flex-direction: row;
  width: 85%;
  margin: 0 auto;
 }

.ad_content_inner {
  display: flex;
  flex-direction:column;
  flex: 1;
  width: 500px;
  align-items: center;
}

.ad_usage {
  text-align: center;
  margin: 0 auto;
}

.ad_custom_inner {
  background: #F4F4F4;
  border-radius: 20px;
  height: 100%;
}

.ad_category {
  display: flex;
  padding: 15px 0;
}

.ad_icon {
  font-size: 2.5rem;
  border-radius: 20px;
  padding: 5px 20px;
  background: #F2F2F2;
}

.ad_custom-list {
  padding:2rem;
  width:450px;
}

.ad_carriers {
  font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
  font-style: normal;
  font-weight: 700;
}

.carriers_list_adj{
  font-size: 4rem;
  font-weight: 200;
  margin: 0 10px;
} 

.ad_voice_box {
  margin-top: 20px;
  border-radius: 10px;
  border: 3px solid #0095db;
  display: flex;
  padding: 10px;
}

.ad_voice_box .ad_profile {
  border-radius: 10px;
  background: #D9F3FF;
  font-size: 2rem;
  margin: 10px 0;
  color: #015DB2;
}

.ad_voice_txt {
  text-align: left;
  margin-left: 20px;
  font-size: 2.5rem;
  font-weight: 700;
  flex:2;
}

.ad_voice_title {
  font-size: 3rem;
  line-height: 1.2;
  font-weight: 700;
  color: #ffffff;
  background-color: #015DB2;
  border-radius:50px;
  padding: 15px 0;
  margin-top: 60px;
}

.ad_voice_why {
  line-height: 1.2;
}

.ad_voice_box_img {
  width: 100%;
  flex:1;
}

/* ==========================================================================
スライダー
========================================================================== */
.ad_nav {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hscroll {
	width:650px;
	height:650px;/*slick*/
	position:relative;
}

ul.hscroll_inner {
	padding:0;
	margin:0;
  width:100%;
	height:100%;
	white-space:nowrap;
  scroll-snap-type:x mandatory;
	scroll-behavior:smooth;
  /* overflow-x:auto; * slick用に削除/
  /*IE(Internet Explorer)・Microsoft Edgeへの対応*/
  -ms-overflow-style: none;
  /*Firefoxへの対応*/
  scrollbar-width: none;
}
  /*Google Chrome、Safariへの対応*/
.hscroll ul::-webkit-scrollbar{
  display: none;
}

.hscroll img {
	/* width:100%;
	height:100%;
	object-fit:contain; */
}

.hscroll li {
	list-style:none;
	scroll-snap-align:center;
  margin: 30px;
}

.hscroll_inner {
  display: flex;
}

li .ad_custom_item {
	height:100%;
  object-fit:contain;
  gap: 8%;
  display: flex;
  flex-direction: column;
}

.slide_arrow {
	top:0;
	position:absolute;
	width:8%;
	height:100%;
	cursor: pointer;
}

.slide_arrow:before {
	content:'';
	position:absolute;
	width:10px;
	height:10px;
	border-left:solid 4px #333333;
	border-bottom:solid 4px #333333;
}

.left {
	left:0px;
}
.left:before {
	top:calc(50% - 10px);
	left:calc(-50% - 6px);
	transform:rotate(45deg);
}
.right {
	right:0;
}
.right:before {
	top:calc(50% - 10px);
	right:calc(-50% - 4px);
	transform:rotate(-135deg);
}

.ad_custom_txt {
  margin: 20px;
}
.ad_detailTxt {
white-space: normal;
}

.ad_payment_detail {
  margin-top: 28px;
}

.ad_carriers {
  font-size: 4rem;
}

.hscroll_inner-list {
  width:100%;
  height:100%;
  background-color: #F4F4F4;
  border-radius: 20%;
}
.ad_button_biz {
  border: 1px solid #008cd6;
  background-color: #008cd6;;
  color:#fff;
  margin-right: 20px;
}
.ad_button_re {
  border: 1px solid #008cd6;
  background-color: #008cd6;
  color:#fff;
}

.slide_pager {
  position:absolute;
  bottom:-60px;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

li.ad_circle {
  position:relative;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  position: relative;
  list-style: none;
  border: 1px #000 solid;
  margin-left: 10px;
  margin-right: 10px;
  cursor: pointer;
}

li.ad_circle:after {
  content: "";
  width: 20px;
  height: 20px;
  border: 1px #000 solid;
  border-radius: 50%;
  position: absolute;
  top: -4px;
  left: -4px;
}

#ad_list1{
  background-color: #000;
}

.slide_pager{
  z-index:10000;
}
/* ==========================================================================
支払い方法
========================================================================== */

.ad_carriers_row {
  display: flex;
  justify-content: center;
  gap: 2%;
}

.color_docomo {
  color:#cc0033; 
}
.color_au {
  color:#eb5505; 
}
.color_povo {
  color:#767778; 
}
.color_uq {
  color:#0099ff; 
}
.color_softbank {
  color:#bbbcbe; 
}
.color_softbank {
  color:#bbbcbe; 
}
.color_ymobile {
  color:#ff0033;
}

.fw_700 {
  font-weight: 700;
}

.ad_point_title {
  font-size:5rem;
  color:#015db2;
  line-height: 2;
  width:100px;
  height:100px;
  background-color: #fff;
  border-radius: 50%;
  margin: 0 auto 20px;
  border:3px solid;
}

.ad_attention_box {
  margin: 50px 0 10px;
  text-align: center;
}

.ad_payment_txt {
  font-size: 2rem;
  margin-top: 15px;
  color: white;
}

.ad_amazon {
  margin: 15px 0 0;
}

.ad_amazon img {
  width: 40%;
}

/* ==========================================================================
スクロール矢印
========================================================================== */

/*====== 9-1-1 縦線が動いてスクロールを促す =======*/


/*スクロールダウン全体の場所*/
.scrolldown4{
  /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:1%;
  right:50%;
  /*矢印の動き1秒かけて永遠にループ*/
  animation: arrowmove 1s ease-in-out infinite;
}

/*下からの距離が変化して全体が下→上→下に動く*/
@keyframes arrowmove{
    0%{bottom:1%;}
    50%{bottom:3%;}
   100%{bottom:1%;}
}

/*Scrollテキストの描写*/
.scrolldown4 span{
  /*描画位置*/
  position: absolute;
  left:-60px;
  bottom:10px;
  /*テキストの形状*/
  color: #eee;
  font-size: 3rem;
  letter-spacing: 0.05em;
  /*縦書き設定*/
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}

/* 矢印の描写 */
.scrolldown4:before {
  content: "";
  /*描画位置*/
  position: absolute;
  bottom: 15px;
  right: -6px;
  /*矢印の形状*/
  width: 4px;
  height: 20px;
  background: #eee;
  transform: skewX(-31deg);
}

.scrolldown4:after{
  content:"";
    /*描画位置*/
  position: absolute;
  bottom:15px;
  right:0;
    /*矢印の形状*/
  width:4px;
  height: 80px;
  background:#eee;
}

/* ==========================================================================
スクロール
========================================================================== */
.nscroll {
	width:200px;
	height:200px;
	position:relative;
	border:1px solid lightgray;
}

.nshscroll ul {
	padding:0;
	margin:0;
	width:100%;
	height:100%;
	overflow:hidden;
	white-space:nowrap;
	scroll-snap-type:x mandatory;
	scroll-behavior:smooth;
}

.nscroll li {
	list-style:none;
	display:inline-block;
	scroll-snap-align:center;
	width:100%;
	height:100%;
}

.box-parent{
  width:100%;height:auto;
  display:flex;
  justify-content:space-between;
  padding:20px;box-sizing:border-box;
 }

 .box-child{
  width:100%;height:auto;
  display:flex;/*子要素に追加*/
  flex-direction:column;/*子要素に追加*/
  margin: 40px;
 }
 .box-child-title{
  width:100%;height:auto;
 }
 .box-child img{
  display:block;/*画像下の余白を消す*/
  width:100%;
  height:180px;/*高さを指定*/
  object-fit:cover;/*画像をコンテナいっぱいに表示*/
 }
 .box-child-text{
  width:100%;height:auto;
  flex-grow:1;/*空きスペースの伸びる倍率を指定*/
  white-space: normal;
  font-weight: 700;
  font-size: 4.5rem;
  line-height: 1.2;
  text-align: left;
 }

 .ad_btnarea_lower2 {
  /* flex-grow: 1;   */
  display: block;
} 

.hscroll_inner-list2 {
  width:100%;
  display: flex;
 }

.ad_box_inner {
  display: flex;
  box-sizing:border-box;
  background:#fff;
  border-radius: 20px;
  width: 550px;
  height: 550px;
  text-align: center;
  margin:0 auto;
 }

 @media screen and (min-width: 751px) {
 .box-child-text{
  font-size: 2.5rem;
 }
 .ad_box_inner {
  width: auto;
 }
}

/* ==========================================================================
モーダルウインドウ
========================================================================== */
.ad_modal{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0,0,0,0.5);
  /* padding: 40px 20px; 背景のばす用*/
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  /**/
  box-sizing: border-box;
  z-index: 10;
  /*20231023追記*/
  display: flex;
  justify-content: center;
  align-items: center;
}

.ad_modal:before{
  content: "";
}

.ad_modal.is-active{
  opacity: 1;
  visibility: visible;
}

.ad_modal-container {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  /*20231023モーダル背景固定のため追記
   max-width: 600px;
  width: 90%; */
  width: 100%;
}

.ad_modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  /* top: 110px;
  right: 45px; */
  top: 5px;
  right: 45px;
  width: 50px;
  height: 50px;
  color: #fff;
  background: #000;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
}

.ad_modal-content{
  /* background: #666; */
  text-align: left;
  line-height: 1.8;
  padding: 20px;/* 背景伸ばす用*/
  /* padding: 140px 0; */
  padding: 40px 0 30px;
  margin: 0px auto;
  text-align: center;
  width: 90%;
}

.ad_modal-content p{
  margin: 1em 0;
}

button {
  padding: 0;
  border: none;
  outline: none;
  font: inherit;
  color: inherit;
  background: none;
  cursor: pointer;
}

.btn-movie {
  color: #015DB2;
  font-weight: 500;
  text-align: center;
  margin: 0 auto;
  display: block;
  font-size:3rem;
}
.btn-movie:after{
  content: '';
  border: 0;
  border-top: solid 1px #015db2;
  border-right: solid 1px #015db2;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 8px;
  height: 8px; 
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 40px;
}
@media screen and (min-width: 751px) {
.ad_modal {
  z-index: 10001;
 }

.ad_mdal-container {
  position: relative;
 }

   /* 背景スクロール止める追加 
  .ad_modal {

  overscroll-behavior: contain;
  overflow-y: scroll;
  scrollbar-width: none;
  -ms-overflow-style: none;
  touch-action: none;
  }

  .ad_modal-content:before,
  .ad_modal-content:after {
    content: "";
    width: 1px;
    height: calc(100vh + 1px);
    display: flex;
  }
  .ad_modal:-webkit-scrollbar {
    display: none;
  }
*/

.ad_modal-content {
    /*2023102modal背景固定のため変更
     padding: 80px 0px;
    width: 430px;
    margin: 30px auto; */
    text-align: center;
    border-radius: 20px;
    position: relative;
    padding: 15px 0px 0px;
    width: 390px;
    margin: 0px auto;
 }

 .ad_modal-close {
  top: -10px;
  right: -10px;
 }
}
/* ==========================================================================
ビデオ部分
========================================================================== */
.video {
  position: relative;
}
.video-btn {
  content: "";
  position: absolute;
  top:50px;
  left:0;
  right:0;
  bottom:90px; /*コントローラー分下部に余白を*/
  cursor: pointer;
}

.video_size {
 width: 600px;
}
@media screen and (min-width: 751px) {
  .video_size {
    width: 360px;
   }
  }
/* ==========================================================================
表
========================================================================== */
.wrap-tbl {
  border: 8px solid #0095db;
}
/* ==========================================================================
footer
========================================================================== */
.footer_fix_btn {
	width:100%;
	position:fixed;
	bottom:0;
	margin: 0 auto;
	justify-content: center;
	text-align:center;
	background-color: rgba(255, 2255, 255, 0.8);
	z-index: 10000;
}
.footer_fix_btn_inner {
	display: flex;
	display:-webkit-box;
	display:-moz-box;
	display:-ms-flexbox;
	display:-webkit-flex;
	display:-moz-flex;
	display:flex;
	-webkit-box-pack:center;
	-moz-box-pack:center;
	-webkit-flex-pack:center;
	-moz-flex-pack:center;
	-ms-flex-pack:center;
	-webkit-justify-content:center;
	-moz-justify-content:center;
	justify-content:center;
  font-size:2.5rem;
}
.footer_fix_btn .inner_btn{
	margin-right: 10px;
	width: 500px;
}
.footer_fix_btn .active{
	opacity: 1;
}
.footer_fix_btn a {
	text-decoration:none;
	align-items: center;
}
.footer_fix_btn a:hover {
	opacity:0.8;
}
.btn-cmn a,
.btn-cmn input, .btn-cmn span.inactive {
	display: inline-block;
	font-weight: bold;
	text-decoration: none;
	color: #fff;
	background: #015db2;
}
.inner-btn .btn-free {
	width: 332px;
}
.catch_inner_btn {
	display: flex;
	justify-content: space-around;
}
.btn-cmn-catch a {
  display: inline-block;
  padding: 30px 50px;
  font-weight: bold;
  text-decoration: none;
  color: #fff;
  background: #015db2;
}
.fix_btn_exercise {
	width: 40%;
  text-align: center;
  margin: 0 auto;
  padding: 8px 25px 8px 25px;
  text-decoration: none;
  color: #015db2;
  border-radius: 40px;
  background: #d9f3ff;
  font-size: 24px;
  font-size: 1.4rem;
  font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
  font-style: normal;
  font-weight: 700;
}
	
.fix_btn_user {
	width: 60%;
	text-align: center;
	margin: 0 auto;
	padding: 8px 25px 8px 25px;
	text-decoration: none;
	color: #015db2;
	border-radius: 40px;
	background: #ffba17cc;
	font-size: 24px;
	font-size: 1.4rem;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}
.fix_btn_register {
	width: 50%;
	text-align: center;
	margin: 0 auto;
	padding: 8px 25px 8px 25px;
	text-decoration: none;
	color: #015db2;
	border-radius: 40px;
	background: #ffba17cc;
	font-size: 24px;
	font-size: 1.4rem;
	font-family: "ヒラギノ角ゴ Pro W6","HiraKakuPro-W6","メイリオ", sans-serif;
	font-style: normal;
	font-weight: 700;
}

@media screen and (min-width: 751px) {
    .inner_btn{
        font-size: 1.5rem;
    }
}

.ad_section-gray:last-child {
  border-bottom-right-radius:10px;
  border-bottom-left-radius: 10px;
}


@media screen and (min-width: 751px) {
  h2 {
    font-size: 5rem;
    }
  
  h3{
    font-size: 4rem;
    }
      
  .Link::after {
    border-top: solid 1px #015db2;
    border-right: solid 1px #015db2;
  }

  .ad_logo {
    top:60px;
    left:60px;
  }

  .ad_keyvisual {
    margin-top: 30px;
  }

  .ad_navi{    
    font-size: 1.5rem;
  }

  .icon-arrow-s:after {
    border-top: solid 2px #015db2;
    border-right: solid 2px #015db2;
  }
   
  .ad_txt_box {
    width:80%;
    text-align: center;
    margin: 0 auto;
  }

  .ad_point_title {
    display: flex;
    justify-content: space-around;
  }

  .ad_voice_box .ad_profile {
    font-size: 1.5rem;
  }

  .ad_button a, .ad_button_small a, button a {
    font-size:1.5rem;
  }

  .ad_content {
    gap: 6%;
  }

  .ad_content:nth-of-type(2n) { flex-direction: row; }  
  .ad_content:nth-of-type(2n+1) { flex-direction: row-reverse; }  

  .ad_text {
    border-radius: 20px;
    margin-top: 53px;
  }

  .ad_icon {
    font-size: 1.4rem;
  }
  
   .ad_button {
    margin: 10px auto;
    width: 85%;
  }

  .ad_subtitle {
    margin: 0px 25px 10px;
  }

  .ad_content_inner {
    align-items: center;
  }

  .ad_btnarea_movie {
    text-align: center;
    margin: 90px auto;
    width: 50%;
  }

  .ad_usage_txt {
    font-size: 1.5rem;
  }

  .ad_payment_txt {
    font-size: 1rem;
  }

  .ad_voice_inner {
    display:flex;
    gap: 2%;
    align-items: stretch;
  }

  .hscroll {
    width: 880px;
    height: 430px;
  }

  .hscroll_inner {
    gap:0%;
  }

  .hscroll ul {
  overflow:hidden;
  }

  .ad_detailTxt {
    font-size: 2.5rem;
  }

  .ad_amazon {
    margin: 20px auto 0;
    width: 50%;
  }
  
  .ad_amazon img {
    width: 50%;
  }

  .hscroll li {
    margin-right: 20px;
  }

  li a {
    padding: 5px 30px 5px 20px;
  }

  .ad_box_inner {
    height: 320px;
  }

  .box-child {
    margin: 10px;
  }
  .ad_custom_inner {
    width: 280px;
   }

  .ad_custom_lower {
    margin: 20px;
    gap: 3%;
  }

  .ad_button_small {
    font-size: 1.5rem;
  }

  .ad_voice_title {
    font-size: 2rem;
}

.ad_voice_inner_box {
  flex: 1;
  display:flex;
  align-items: stretch;
  flex-direction: column;
}

.ad_voice_txt {
  font-size: 2rem;
  font-weight: 400;
}

.lh24{
  line-height: 2.4;
}

  .btn-movie {
    font-size:1.5rem;
}

  .pc-fl {
    padding-right: 0;
  }

  .ad_custom-list {
    width:100%;
  }

  .ad_custom_txt {
    font-size: 4rem;
  }

  .ad_attention_box {
    margin: 50px 0 50px;
    text-align: center;
  }

  .ad_payment_txt {
    font-size: 1.5rem;
  }

}