@charset "utf-8";
:root {
--fontfamily:"source-han-sans-japanese", sans-serif;
--fontfamilym:"dnp-shuei-mincho-pr6", sans-serif;
--fontcolor: #000000;
--mainecolor:#3551a2;
--subcolor:#81cbd6;
--anime:all 0.5s 0s ease-out;
--animemovie:all 1s 0.5s ease-out;
--maxcontent:80rem;
}
* {
	margin:0;
	padding:0;
	box-sizing:border-box;
	outline:none;
	word-break: auto-phrase;
}
#container {
	overflow:hidden;
}
.en_blod, .tp_concept .ttl_catch, .catch, h3.ttl, ul.list_recruit li a {
	font-family: "arial", sans-serif;
	font-weight: 900;
	font-style: normal;
}
body {
	font-family: var(--fontfamily);
	font-size:18px;
	line-height:180%;
	font-weight:400;
}
a {
	color:var(--fontcolor);
	text-decoration:none;
}
a:hover {
	color:var(--fontcolor);
	text-decoration:underline;
}
a, a:hover {
	transition:var(--anime);
}
ul, li {
	list-style:none;
}
ul#menu, ul.btn_cl2, .flex_box {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
img {
	border:0;
	max-width:100%;
	height:auto;
	vertical-align: bottom;
}
table {
	border-collapse: collapse;
	width:98%;
	margin:auto;
}
table tr {
	background-color:#FFFFFF;
}
table tr:nth-child(even) {
background-color:#EEEEEE70;
}
table th, table td {
	padding:15px 20px;
	box-sizing:border-box;
	text-align:left;
	vertical-align:top;
}
table th {
	font-weight:normal;
	width:250px;
	font-family: "arial", sans-serif;
	font-weight: 900;
}
#header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 99;
	padding-left:450px;
	transition:var(--anime);
}
#header.fixed, .subpage #header {
	transition:var(--anime);
	background: #FFFFFF;
}
#header h1.logo {
	position:absolute;
	top:55px;
	left:63px;
	width: 260px;
	aspect-ratio: 260 / 140;
	transition:var(--anime);
}
#header.fixed h1.logo, .subpage #header h1.logo {
	top: 7px;
	left: 20px;
	width: 150px;
	transition:var(--anime);
}
ul#menu {
	justify-content:flex-end;
	padding-top:30px;
	transition:var(--anime);
}
.fixed ul#menu, .subpage ul#menu {
	padding-top:0px;
	transition:var(--anime);
}
ul#menu li a {
	display:block;
	font-weight:bold;
	padding:110px 0.5rem 10px 0.5rem;
	color:var(--mainecolor);
	text-decoration:none;
	transition:var(--anime);
	width:160px;
font-size:.875rem;
	line-height:110%;
	text-align:center;
}
ul#menu li a.icon001 {
	background-image:url(https://www.paradi.net/images25/header_logo_n001.png);
	background-size:110px 110px;
	background-repeat:no-repeat;
	background-position:center top;
}
ul#menu li a.icon002 {
	background-image:url(https://www.paradi.net/images25/header_logo_n002.png);
	background-size:110px 110px;
	background-repeat:no-repeat;
	background-position:center top;
}
ul#menu li a.icon003 {
	background-image:url(https://www.paradi.net/images25/header_logo_n003.png);
	background-size:110px 110px;
	background-repeat:no-repeat;
	background-position:center top;
}
ul#menu li a.icon004 {
	background-image:url(https://www.paradi.net/images25/header_logo_n004.png);
	background-size:110px 110px;
	background-repeat:no-repeat;
	background-position:center top;
}
ul#menu li a.icon005 {
	background-image:url(https://www.paradi.net/images25/header_logo_n005.png);
	background-size:110px 110px;
	background-repeat:no-repeat;
	background-position:center top;
}
ul#menu li a.icon006 {
	background-image:url(https://www.paradi.net/images25/header_logo_n006.png);
	background-size:110px 110px;
	background-repeat:no-repeat;
	background-position:center top;
}
.subpage ul#menu li a.icon001, .subpage ul#menu li a.icon002, .subpage ul#menu li a.icon003, .subpage ul#menu li a.icon004, .subpage ul#menu li a.icon005, .subpage ul#menu li a.icon006,
.fixed ul#menu li a.icon001, .fixed ul#menu li a.icon002, .fixed ul#menu li a.icon003, .fixed ul#menu li a.icon004, .fixed ul#menu li a.icon005, .fixed ul#menu li a.icon006 {
	background-size:65px 65px;
}
.fixed ul#menu li a, .subpage ul#menu li a {
	width:auto;
	padding:60px 2rem 10px 2rem;
	color:var(--mainecolor);
	transition:var(--anime);
}
ul#menu li a:hover {
	transition:var(--anime);
	color:#000;
}
.subpage #wrapper {
	padding-top:100px;
}
.tp_images {
	position:relative;
	padding-bottom:130px;
	z-index:1;
	clip-path: inset(0);
}
.text {
	font-family:var(--fontfamilym);
	position: fixed;
	bottom: 50px; /* 画面下からの距離 */
	left: 50px;
	color: white; /* 初期カラーは白 */
	font-size: 5rem;
	width:11.5em;
	z-index: 1000;
	text-shadow: 2px 2px 9px #000;
	opacity: 1;
	transition: opacity 0.8s ease, color 0.3s ease;
}
.text.hidden {
	opacity: 1;
	position:absolute;
	pointer-events: none;
    bottom: 160px;
}
.text h2 {
	line-height:130%;
	font-size: 5rem;
	width:100%;
}
.white-bg {
	background-color: white;
}
.white-bg h3 {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.8s ease, transform 0.8s ease;
}
.white-bg h3.visible {
	opacity: 1;
	transform: translateY(0);
}
.photo-bg {
	height: 100vh;
	background-image: url('https://www.paradi.net/images25/top_maine_ph.jpg');
	background-size: cover;
	background-position: center;
}
#scrollEndTrigger {
  height: 1px;
}
#trigger h3{
font-weight: normal;
margin-left: 50%;
padding-top: 90px;
padding-bottom: 170px;
padding-right:100px;
}
.tp_best_shot {
width:100%;
margin:auto auto 160px 0;
max-width:1300px;
position:relative;
}
.flex_best_tp {
display: flex;
flex-direction: row;
flex-wrap: wrap;
align-items:flex-end;
}
.in_box.best_ph {
width:calc(100% - 450px);
}
.in_box.best_ph img {
	width:100%;
	max-width:auto;
}
.in_box.best_title {
width:450px;
padding-left:80px;
font-size:18px;
}
.in_box.best_ph .best_date {
    text-align: right;
    width: 100%;
    margin-bottom: 15px;
    padding-right: 0;
}
.in_box.best_ph .best_date span {
	margin-left:3rem;
	display:inline-block;
}
h3.img_ttl {
	position:relative;
	z-index:3;
	margin-left:100px;
	text-align:left;
}
h3.img_ttl img {
	position:absolute;
	max-width: none;
	z-index:1;
	top:0;
	left:0;
}

h3.img_ttl big {
	position:relative;
	z-index:2;
	font-weight:700;
	font-size:35px;
	line-height:110%;
}
.tp_best_shot h3.img_ttl {
    max-width: 545px;
    padding-top: 75px;
}
.tp_best_shot h3.img_ttl img {
	top:15px;
	width:545px;
	aspect-ratio:545 / 181;
}

.tp_divinglog_flex h3.img_ttl {
    max-width: 725px;
    padding-top: 0px;
	margin-left:0px;
	margin-bottom: 60px;
	z-index:-1;
}
.tp_divinglog_flex h3.img_ttl img {
top: -65px;
width: 725px;
aspect-ratio: 725 / 175;
left: -100px;
}

.tp_divinglog_flex h3.img_ttl.topics img {
top: -45px;
width: 345px;
aspect-ratio: 345 / 190;
}
a .post-meta .hiduke,
.in_box .hiduke {
	color:#00b3cd;
	letter-spacing:0.05rem;
}

.tp_best_shot h3.img_ttl big {
	font-size:40px;
	line-height:110%;
}
ul.best_list li{
width:100%;
margin-bottom:1.25rem;
text-align:left;
}
ul.best_list li a {
display:block;
width:100%;
}
ul.best_list li a .date {
display:inline-block;
padding-right:1rem;
}
.tp_divinglog_flex {
display: flex;
flex-direction: row;
flex-wrap: wrap;
width:100%;
margin-bottom:200px;
}
.tp_divinglog_flex .in_box.news_ttl {
width:430px;
position:relative;
z-index:1;
padding-left:140px;
padding-right:0px;
border-right:6px solid #b5b5b6;
}
.tp_divinglog_flex .in_box.news_log {
	width:calc(100% - 430px);
	position:relative;
	z-index:2;
	overflow-y: auto;
}
.tp_divinglog_flex .in_box.news_log #tab-body {
padding:25px 45px;
}
.more_btn {
	text-align:left;
	padding-top:30px;
	position:relative;
	z-index:3;
}
.more_btn a {
display:table;
margin-left:0;
margin-right:auto;
padding-right:70px;
background-image:url(https://www.paradi.net/images25/icon_prev.png);
background-size:45px auto;
background-repeat:no-repeat;
background-position:right top;
font-size : 18px;
line-height:57px;
letter-spacing : 3.6px;
color : #231815;
text-decoration:none;
font-weight:900;
}
.more_btn a:hover {
color:var(--mainecolor);
background-image:url(https://www.paradi.net/images25/icon_prev_n.png);
}

.more_btn.right a {
margin-left:auto;
margin-right:0;
}
.flex_log_tp {
display: flex;
overflow-x: auto;
-webkit-overflow-scrolling: touch;
scroll-snap-type: x mandatory;
gap: 1rem;
padding: 1rem;
margin-left:40px;
scroll-behavior: smooth;
}
.flex_log_tp::-webkit-scrollbar {
  display: none;
}
.flex_log_tp .in_box {
flex: 0 0 auto;
scroll-snap-align: start;
width:330px;
margin-left:25px;
margin-right:25px;
transition: transform 0.3s;
}
.flex_log_tp .in_box a img {
object-fit:cover;
aspect-ratio: 330 / 230;
width: 100%;
transition: transform 0.3s;
}
.flex_log_tp .in_box a .images_box {
	overflow:hidden;
	display:block;
}
.flex_log_tp .in_box:hover .images_box img {
transform: scale(1.05);
transition: transform 0.3s;
}
.flex_topics_tp{
	width:100%;
}
.flex_topics_tp .in_box a .ttx {
	display:block;
	text-align:left;
	font-size:1rem;
	line-height:130%;
}
.in_box a {
	text-decoration:none;
}
.flex_topics_tp .in_box a{
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
	width:100%;
	margin-bottom:40px;
}
.flex_topics_tp .in_box a img {
	object-fit:cover;
    aspect-ratio: 170 / 120;
    width: 170px;
	margin-right:40px;
}

.post-meta {
  margin-top: 0.5rem;
  color: #333;
}

.scroll-buttons {
  text-align: center;
  margin-bottom: 0.5rem;
}

.scroll-buttons button {
  padding: 0.5rem 1rem;
  margin: 0 0.5rem;
  font-size: 1rem;
  cursor: pointer;
}
.scroll-buttons button#scrollLeft,
.scroll-buttons button#scrollRight {
    background-color: #FFF;
    border: 0;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    width: 45px;
    height: 57px;
    z-index: 999;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.scroll-buttons button#scrollLeft {
    background-image: url(https://www.paradi.net/images25/icon_next.png);
    left: 2px;
}
.scroll-buttons button#scrollRight {
	background-image:url(https://www.paradi.net/images25/icon_prev.png);
    right: 2px;
}
#tab-head li {
	width:100%;
	margin-bottom:13px;
	position:relative;
}
#tab-head li a {
	display:block;
	width:calc(100% + 20px);
	padding:1rem;
    cursor: pointer;
	margin-right:-20px;
}
#tab-head li a.tab1 {
	background-color:none;
	color:#000;
} 
#tab-head li a.tab2 {
	background-color:#00b3cd95;
	/*mix-blend-mode:multiply;*/
	color:#FFF;
}
.tp_diving_kosyu {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
	max-width:1360px;
	width:100%;
	margin:auto;
	padding:0 0 280px 0;
}
.tp_diving_kosyu .in_box {
	width:calc(33.33% - 50px);
	margin-left:25px;
	margin-right:25px;
}
.tp_diving_kosyu .in_box a {
display:block;
width:100%;
transition: transform 0.3s;
position:relative;
	
}
.tp_diving_kosyu .in_box a img {
display:block;
padding:30px;
border:1px solid #b5b5b6;
margin-bottom:36px;
position:relative;
transition: transform 0.3s;
}
.tp_diving_kosyu .in_box a:hover img {
transform: scale(1.05);
transition: transform 0.3s;
}
.tp_diving_kosyu .in_box a .ttx_link {
display: table;
width:100%;
margin-left: auto;
margin-right: auto;
padding-right: 150px;
background-image: url(https://www.paradi.net/images25/icon_prev.png);
background-size: 45px auto;
background-repeat: no-repeat;
background-position: right top;
font-size: 28px;
line-height: 57px;
color: #231815;
text-decoration: none;
font-weight: 900;
position:relative;
z-index:2;
}
.tp_diving_kosyu .in_box a .ttx_link::after {
	content:"More";
	position:absolute;
    right: 70px;
    font-size: 18px;
    line-height: 57px;
	letter-spacing:0.1rem;
}
.tp_diving_kosyu .in_box a .ttx_link::before {
	content:"";
	position:absolute;
    left:40px;
	top:-80px;
	width:1px;
	height:80px;
	background-color:#b5b5b6;
}
.tp_column2 {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
width:100%;
margin:auto;
align-items:flex-start;
}
.tp_column2.rev {
flex-direction: row-reverse;
}
.tp_column2 .in_box {
	position:relative;
}
.tp_column2 .in_box.ph {
	position:relative;
	z-index:1;
	width:52.6%;
}
.tp_column2 .in_box.ph img {
	object-fit:cover;
	min-height:390px;
	height:100%;
	width:100%;
}
.tp_column2 .in_box.txt {
position:relative;
z-index:2;
width:47.4%;
padding-left:7.69%;
padding-right:7.69%;
}
.tp_column2 .in_box.txt p {
	position:relative;
	z-index:4;
}
.tp_column2 .in_box.txt h3.img_ttl {
margin-left: 0px;
padding-top:60px;
padding-bottom:25px;
}
.tp_column2 .in_box.txt h3.img_ttl img {
top:30px;
}
.tp_column2 .in_box.txt h3.img_ttl.divinginfo img {
left: -310px;
right:auto;
}
.tp_column2 .in_box.txt h3.img_ttl.price img {
left: auto;
right:-250px;
}
.tp_column2 .in_box.txt h3.img_ttl.reservation img {
left: -170px;
right:auto;
}
.tp_column2 .in_box.txt h3.img_ttl.shop img {
left: auto;
right:0;
}
.tp_column2 .in_box.txt h3.img_ttl.access img {
top: auto;
bottom: -200px;
left: -50px;
right: auto;
}
.tp_map {
	position: relative;
	overflow: hidden;
	width:100%;
	margin:auto auto 0px auto;
	height: 390px;
}
.tp_map iframe,
.tp_map object,
.tp_map embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
footer {
background-color:#bce2e8;
}
.footer_flex {
width:100%;
max-width:1180px;
margin:auto;
padding:90px 1rem;
display: flex;
flex-direction: row;
flex-wrap: nowrap;
justify-content: space-between;
}
.footer_flex .in_box.address {
padding-left:30px;
padding-right:80px;
}
.cp_name {
font-weight:700;
font-size:22px;
line-height:100%;
margin-bottom:20px;
}
.cp_name big {
font-size:30px;
line-height:100%;
}
.cp_address {
line-height:120%;
margin-bottom:15px;
letter-spacing:0.15rem;
}
.cp_tel {
background-image:url(https://www.paradi.net/images25/icon_tel.png);
background-size:26px auto;
background-position:left top;
background-repeat:no-repeat;
padding-left:32px;
font-size:20px;
line-height:26px;
margin-bottom:10px;
letter-spacing:0.15rem;
}
.cp_fax {
background-image:url(https://www.paradi.net/images25/icon_fax.png);
background-size:26px auto;
background-position:left top;
background-repeat:no-repeat;
padding-left:32px;
font-size:20px;
line-height:26px;
letter-spacing:0.15rem;
}
#copyright {
text-align:center;
max-width:1400px;
margin:auto;
width:100&;
font-size:12px;
line-height:130%;
padding:1rem 0;
color:#898989;
letter-spacing:0.1em;
border-top:1px solid #898989;
}
#copyright a {
color:#898989;
text-decoration:none;
}
.post-password-required .entry-content {
    max-width: 720px;
    margin: auto;
    padding: 160px 0;
}
.flex_maine_p {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
	position:relative;
	align-items:center;
	padding-bottom:50px;
	margin-bottom:75px;
	max-width:1440px;
	margin-left:auto;
	margin-right:auto;
	width:100%;
}
.flex_maine_p::after {
	content:"";
	position:absolute;
	z-index:0;
	background-color:var(--mainecolor);
	display:block;
	aspect-ratio:1000 / 414;
	width:calc(100% - 435px);
	right:0;
	top:50px;
}
.flex_maine_p .in_box.ph {
	width:calc(100% - 435px);
	z-index:1;
	position:relative;
}
.flex_maine_p .in_box.ph img {
	object-fit:cover;
	width:100%;
	aspect-ratio:1000 / 414;
}
.flex_maine_p .in_box.ttl {
	width:435px;
	padding-left:1rem;
	padding-right:1rem;
	z-index:1;
	position:relative;
}
.flex_maine_p .in_box.ttl h1 {
  font-weight : bold;
  font-size : 37px;
  color : #FFFFFF;
	text-align:center;
	z-index:2;
	position:relative;
}
.flex_maine_p .in_box.ttl img {
    width: 100%;
    z-index: 1;
    position: absolute;
    max-width: 50%;
    margin: auto;
    left: 0;
    right: 0;
    top: 70px;
    bottom: 0;	
}
.inner {
max-width:1300px;
margin-left:auto;
margin-right:auto;
width:100%;
}
.qa_box dl {
background : #f1f9fa;
border-radius: 30px;
-webkit-border-radius: 30px;
-moz-border-radius: 30px;
padding:35px 45px 50px 35px;
margin-bottom:50px;
}
.qa_box dl dt,
.qa_box dl dd {
padding-left:93px;
padding-top:13px;
position:relative;
min-height:63px;
word-break: auto-phrase;

}
.qa_box dl dt {
font-weight : bold;
font-size : 22px;
margin-bottom:20px;
}
.qa_box dl dd {
width:calc(100% - 93px);
font-size : 18px;
line-height:170%;
margin-left:93px;
}

.qa_box dl dt::before {
content:"Q";
color : #FFFFFF;
background-color:var(--mainecolor);
}
.qa_box dl dd::before {
content:"A";
color :var(--mainecolor);
background-color:#bbe1e7;
}
.qa_box dl dt::before,
.qa_box dl dd::before {
font-size : 31px;
line-height:56px;
font-weight:bold;
width:63px;
height:63px;
display:block;
border-radius: 99px;
-webkit-border-radius: 99px;
-moz-border-radius: 99px;
position:absolute;
top:0;
left:0;
text-align:center;
}

.ttx_red {
	color:#d23636;
}
.bus-schedule, .time-schedule {
	font-size:18px;
	background: #fff;
	border-radius: 12px;
	padding: 30px 60px;
	box-sizing:border-box;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	max-width: 1000px;
	margin: 0 auto 40px;
	font-family: 'Helvetica Neue', sans-serif;
	color: #333;
}
.box-s.access-section {
	max-width: 1000px;
}
.provider {
	font-size: 0.95em;
	color: #666;
	margin-bottom: 20px;
}
.access-steps {
	list-style: none;
	counter-reset: step;
	padding-left: 0;
	width: 100%;
	padding: 0 2em 1em 3em;
	margin: auto;
	margin-bottom: 30px;
}
.access-steps li {
	position: relative;
	padding-left: 40px;
	padding-bottom: 20px;
	border-left: 3px solid #3551a1;
	box-sizing:border-box;
}
.access-steps li:last-of-type {
	border-left: 3px solid #FFF;
}
.access-steps li::before {
 counter-increment: step;
 content: counter(step);
 position: absolute;
 left: -16px;
 top: 0;
 background: #3551a1;
 color: #fff;
 width: 30px;
 height: 30px;
 border-radius: 50%;
 text-align: center;
 line-height: 27px;
 font-weight: bold;
}
.time {
	display: inline-block;
	margin-left: 10px;
	color: #666;
	font-size: 0.9em;
}
.access-note, .access-recommend {
	margin-top: 20px;
	width: 100%;
	padding: 0 2em 0 2em;
}
.box-s .access-note p {
	padding-left:0;
	padding-right:0;
}
.access-note h3, .access-recommend h3 {
	font-size: 1.2em;
	margin-bottom: 10px;
	color: #D40000;
}
.access-recommend ul {
	padding-left: 20px;
	list-style: disc;
}
.provider {
	display: flex;
	gap: 12px;
	flex-wrap: wrap; /* スマホでも折り返し可能に */
	margin-bottom: 20px;
	justify-content: flex-end;
}
.provider.center {
	justify-content: center;
}
.link-button {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 20px;
	background: linear-gradient(135deg, #0078D4, #005A9E);
	color: #fff;
	text-decoration: none;
	border-radius: 8px;
	font-weight: bold;
	font-size: 1em;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.link-button.big {
	display: inline-flex;
	padding: 20px 60px;
	font-size: 20px;
	flex-direction: column;
	gap: 0;
}
.link-button.icon_car::before {
 content:"";
 display:block;
 width:100%;
 height:80px;
 background-image:url(https://www.paradi.net/images25/icon_car.png);
 background-position:center center;
 background-repeat:no-repeat;
 background-size:contain;
}
.link-button.icon_bus::before {
 content:"";
 display:block;
 width:100%;
 height:80px;
 background-image:url(https://www.paradi.net/images25/icon_bus.png);
 background-position:center center;
 background-repeat:no-repeat;
 background-size:contain;
}
.link-button.icon_airport::before {
 content:"";
 display:block;
 width:100%;
 height:80px;
 background-image:url(https://www.paradi.net/images25/icon_airport.png);
 background-position:center center;
 background-repeat:no-repeat;
 background-size:contain;
}
.link-button.icon_ferry::before {
 content:"";
 display:block;
 width:100%;
 height:80px;
 background-image:url(https://www.paradi.net/images25/icon_ferry.png);
 background-position:center center;
 background-repeat:no-repeat;
 background-size:contain;
}
.link-button small {
	font-size:16px;
	line-height:100%;
}
.link-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2);
	background: linear-gradient(135deg, #005A9E, #003E7E);
}
.bus-schedule_wrap {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	max-width:1300px;
	width:100%;
	margin:auto;
}
.bus-schedule {
	width:calc(100% / 2);
	margin: 0 auto 40px;
	font-family: 'Helvetica Neue', sans-serif;
	color: #333;
	padding: 30px;
}
.bus-schedule h2 {
	text-align: center;
	font-size: 1.5em;
	color: #3551a1;
	margin-bottom: 20px;
}
.bus-stop, .bus-arrival {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: #F9F9F9;
	padding: 12px 16px;
	margin-bottom: 10px;
	border-radius: 8px;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}
 .bus-stop:nth-child(even), .bus-arrival {
 background: #EFF3F7;
}
.bus-stop.departure {
	background: #DFF0D8;
	font-weight: bold;
}
.stop-name {
	font-weight: bold;
	font-size: 1em;
	word-break: auto-phrase;
}
.stop-time {
	font-size: 0.95em;
	color: #666;
}
.bus-arrival {
	background: #DFF0D8;
	font-weight: bold;
}
.arrival-label {
	margin-right: 10px;
	font-size: 1.2em;
	color: #3551a1;
}
/* プレミアム */
.elegant-details {
	max-width: 600px;
	margin: 3rem auto;
	font-family: 'Helvetica Neue', 'Segoe UI', sans-serif;
	color: #333;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}
.elegant-header, h3.sub-header {
	background-color: #3551a1;
	color: #fff;
	padding: 1rem 1.5rem;
	font-size: 1.4rem;
	font-weight: bold;
	letter-spacing: 0.5px;
	max-width:1300px;
	width:100%;
	margin:auto;
	border-radius: 12px 12px 0 0;
	box-sizing:border-box;
}
h3.sub-header {
	margin-bottom: 2rem;
}
.elegant-row {
	display: flex;
	padding: 1rem 1.5rem;
	border-bottom: 1px solid #eee;
	transition: background 0.3s ease;
}
.elegant-row:hover {
	background-color: #f9f9ff;
}
.elegant-label {
	flex: 0 0 165px;
	font-weight: bold;
	color: #3551a1;
	padding-right: 1rem;
}
.elegant-value {
	flex: 1;
	line-height: 1.6;
}
.elegant-value strong {
	font-size: 1.4em;
	color: #d23636;
}
.elegant-value a.pdf {
	color: #3551a1;
	text-decoration: underline;
}
.schedule-box {
	max-width: 600px;
	margin: 3rem auto;
	font-family: 'Helvetica Neue', 'Segoe UI', sans-serif;
	color: #333;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}
.schedule-header {
	background-color: #3551a1;
	color: #fff;
	padding: 1rem 1.5rem;
	font-size: 1.4rem;
	font-weight: bold;
	letter-spacing: 0.5px;
}
.schedule-row {
	display: flex;
	align-items: center;
	padding: 1rem 1.5rem;
	border-bottom: 1px solid #eee;
	transition: background 0.3s ease;
}
.schedule-row:hover {
	background-color: #f9f9ff;
}
.schedule-label {
	flex: 0 0 33%;
	font-weight: bold;
	color: #3551a1;
	text-align: center;
}
.schedule-time {
	flex: 1;
	display: flex;
	justify-content:space-around;
	font-size: 1rem;
	color: #333;
}
.box-s {
	max-width: 1300px;
	margin: 3rem auto;
	font-family: 'Helvetica Neue', 'Segoe UI', sans-serif;
	color: #333;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
	padding-bottom:30px;
}
.box-s p {
	width:100%;
	padding:0 2em 1em 2em;
	margin:auto;
}
iframe.calender {
	max-width: 100%;
	width: 90%;
	height: 260px;
	margin: auto auto 30px auto;
	display: block;
}
ul.col2.res_status {
	display: flex;
	flex-wrap: wrap;
	list-style: none!important;
	margin-bottom:30px!important;
	width:90%;
	margin:auto;
}
ul.col2.res_status li {
	position: relative;
	width: calc(100% / 4);
	text-indent: 2.5em;
}
 ul.col2.res_status li::before {
 content: "";
 position: absolute;
 width: 25px;
 height: 25px;
 top: 0;
 bottom: 0;
 margin: auto;
 background-color: #DDDDDD;
 left: 0;
}
 ul.col2.res_status li.green::before {
 background-color: #99FF99;
}
 ul.col2.res_status li.blue::before {
 background-color: #66CCFF;
}
 ul.col2.res_status li.yellow::before {
 background-color: #FFFF99;
}
 ul.col2.res_status li.red::before {
 background-color: #FF7C80;
}
 ul.col2.res_status li.orange::before {
 background-color: #FFCC66;
}
ul.col2.res_status li.purple::before {
 background-color: #993399;
}
.tel_link a {
	font-size: 40px;
	line-height: 100%;
	font-weight:bold;
	color: #d23636;
	text-decoration:none;
	display:table;
	margin:auto auto 1em;
	text-align:center;
}
.tel_link a small {
	font-size: 19px;
	line-height: 100%;
	display:block;
	margin-top:5px;
}
.tel_link a::before {
 content:"";
 background-image:url(https://www.paradi.net/images25/icon_tel_red.png);
 background-repeat:no-repeat;
 background-position:center center;
 background-size:contain;
 width:26px;
 height:26px;
 display:inline-block;
 margin-right:5px;
}
/* テーブル */
table.enrich {
	width: 100%;
	max-width:600px;
	margin: 0 auto 50px;
	border-collapse: collapse;
	background-color: #ffffff;
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
table.enrich thead {
	background-color: #3551a1;
	color: #ffffff;
}
table.enrich th, table.enrich td {
	padding: 16px;
	text-align: center;
	border-bottom: 1px solid #e0e6f2;
	width:33.33%;
}
table.enrich tbody tr, table.enrich tbody tr:hover {
	transition: background 0.3s ease;
}
table.enrich tbody tr:hover {
	background-color: #f9f9ff;
}
table.enrich th {
	font-weight: bold;
}
table.enrich td {
	color: #2c3e50;
}
/* アクセス */
.access_flex {
	display: flex;
	flex-direction: row;
	gap: 80px;
	width: calc(100% - 60px);
	margin-left: auto;
	margin-right: auto;
	margin-bottom:100px;
	flex-wrap: wrap;
	justify-content: center;
	max-width:1300px;
}
.access_flex .access_in {
	width:calc(33.33% - 80px);
}
.access_wrap_flow {
	display: flex;
	flex-direction: column;
	margin: auto;
}
.access-value {
	width: 100%;
	border: 1px solid #3551a1;
 padding: .8rem 1rem;
	text-align: center;
	color:var(--mainecolor);
	font-weight:bold;
	background:#F8F8F8;
	font-size:1.25rem;
}
.access-value.start {
	background:var(--mainecolor);
	color:#FFF;
	border-radius: 5px 5px 0 0;
	-webkit-border-radius: 5px 5px 0 0;
	-moz-border-radius: 5px 5px 0 0;
}
.access-value.goal {
	background:var(--subcolor);
	border: 1px solid var(--subcolor);
	color:#FFF;
}
.access-time {
	position: relative;
 padding: .8rem 1rem .8rem 3rem;
	font-weight: bold;
	color: #2c3e50;
	text-align:left;
}
 .access-time::after {
 content: '';
 position: absolute;
 left: 20px;
 top: 0;
 width: 2px;
 height: 100%;
 background-color: #bdc3c7;
}
.bg_bluegreen {
	background-color:#f6fafa;
	padding:100px 0;
}
/* 科目紹介 */
h2 {
	color:var(--mainecolor);
	font-size: 1.4em;
	margin-bottom: 30px;
}
.inner {
	max-width:1300px;
	width:100%;
	margin:auto auto 100px;
}
.section-title {
	font-size: 1.2em;
	font-weight: bold;
	margin: 30px 0 10px;
	color: var(--mainecolor);
	border-left: 4px solid var(--mainecolor);
	padding-left: 10px;
	padding-top:.5rem;
	padding-bottom:.5rem;
}
.card-container {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}
.card {
	background-color: #fff;
	border-radius: 10px;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
	width: calc(50% - 20px);
	padding: 15px;
	display: flex;
	align-items: flex-start;
	transition: transform 0.2s ease;
}
.card:hover {
	transform: translateY(-5px);
}
.card img {
	border-radius: 8px;
	margin-right: 15px;
	width: 130px;
	height: 130px;
	object-fit: cover;
}
.card-content {
	flex: 1;
}
.card-content strong {
	color:var(--mainecolor);
	font-size: 1.1em;
	display: block;
	margin-bottom: 5px;
}
@media screen and (max-width: 1440px) {
#header h1.logo {
top: 20px;
left: 20px;
}
ul#menu li a.icon001,
ul#menu li a.icon002,
ul#menu li a.icon003,
ul#menu li a.icon004,
ul#menu li a.icon005,
ul#menu li a.icon006 {
background-size: 65px 65px;
}
ul#menu li a {
width: auto;
padding: 60px 2rem 10px 2rem;
}
.tp_diving_kosyu .in_box a .ttx_link {
padding-right: 140px;
font-size: 23px;
}
}
@media screen and (max-width: 1330px) {
.inner {
padding-left:1rem;
padding-right:1rem;
}
.qa_box dl dd {
width:100%;
margin-left: 0;
}
}
@media screen and (max-width: 1279px) {
#header {
position: absolute;
}
}
@media screen and (max-width: 1200px) {
#trigger h3 {
margin-left: 55px;
padding-bottom: 270px;
padding-right: 55px;
}
h3.img_ttl {
margin-left: 1rem;
}
.tp_divinglog_flex .in_box.news_ttl {
width: 100%;
padding-left: 140px;
padding-right: 30px;
display: flex;
justify-content: space-between;
}
.tp_divinglog_flex .in_box.news_ttl .more_btn a {
    margin-left: auto;
    margin-right: 0;
}
.tp_divinglog_flex .in_box.news_log {
    width: 100%;
}
.flex_log_tp {
    margin-left: 26px;
}
.flex_log_tp .in_box {
    width: calc(33.33% - 26px);
    margin-left: 13px;
    margin-right: 13px;
}
#tab.tp_divinglog_flex .in_box.news_ttl {
flex-wrap:wrap;
padding-right: 140px;
}
ul#tab-head {
width:100%;
display:flex;
flex-wrap:nowrap;
justify-content:flex-start;
}
#tab-head li a {
width:calc(100% - 6px);
margin-right: 3px;
margin-left:3px;
text-align:center;
border:1px solid #00b3cd95;
}
.tp_diving_kosyu .in_box {
width: calc(100% - 50px);
margin-bottom:30px;
}
.tp_diving_kosyu .in_box a {
display: flex;
align-items: center;
border: 1px solid #b5b5b6;
padding-right:30px;
}
.tp_diving_kosyu .in_box a img {
    padding: 20px;
    width: 300px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
border: 0;
margin-bottom:0;
}
.tp_diving_kosyu .in_box a .ttx_link {
 font-size: 27px;
padding-left: 70px;
}
.tp_diving_kosyu .in_box a .ttx_link::before {
    left:-40px;
    top: 0;
    width: 80px;
    height: 1px;
    bottom: 0;
    margin: auto;
}
}

@media screen and (max-width: 1028px) {
.text {
width:100%;
}
.text h2 {
    line-height: 130%;
    font-size: 3.75rem;
}
.flex_best_tp {
    justify-content: center;
}
.in_box.best_ph {
    width:100%;
	max-width:700px;
	margin-bottom:60px;
}
.in_box.best_title {
    padding-left: 1rem;
	padding-right:1rem;
    width:100%;
	max-width:700px;
}
.in_box.best_title .more_btn a {
	margin-left:auto;
	margin-right:0;
}
.tp_column2 {
flex-wrap:wrap;
}
.tp_column2 .in_box.ph,
.tp_column2 .in_box.txt{
	width:100%;
}
.tp_column2 .in_box.txt {
margin-bottom:100px;
padding-left:80px;
padding-right:80px;
}
.tp_column2 .in_box.txt h3.img_ttl.divinginfo img,
.tp_column2 .in_box.txt h3.img_ttl.price img,
.tp_column2 .in_box.txt h3.img_ttl.reservation img,
.tp_column2 .in_box.txt h3.img_ttl.shop img,
.tp_column2 .in_box.txt h3.img_ttl.access img{
left: -70px;
right:auto;
	max-width:100%;
}
.tp_divinglog_flex {
    margin-bottom: 150px;
}
.tp_diving_kosyu {
 padding-bottom: 100px;	
}
.footer_flex {
flex-direction: column;
align-items: center;
}
.footer_flex .in_box.logo,
.footer_flex .in_box.address{
margin-bottom:50px;
}
.flex_maine_p {
flex-direction:column-reverse;
padding-bottom: 0;
}
.flex_maine_p .in_box.ph,
.flex_maine_p::after{
    width: 90vw;
}
.flex_maine_p .in_box.ph {
margin-left:0;
margin-right:auto;
}
.flex_maine_p .in_box.ph img {
    aspect-ratio: 4 / 3;
}
.flex_maine_p::after{
	top:0;
	bottom:auto;
    height: 90%;
}
.flex_maine_p .in_box.ttl {
width: 100%;
padding: 3rem 0 3rem 0;
}
.flex_maine_p .in_box.ttl img {
    width: auto;
    top: 70px;
    max-height: 100%;
}
.qa_box dl dt::before, .qa_box dl dd::before {
    font-size: 24px;
    line-height: 40px;
    width: 43px;
    height: 43px;
}
.qa_box dl dt, .qa_box dl dd {
    padding-left: 63px;
    min-height: 43px;
	padding-top: 3px;
}
}

@media screen and (max-width: 840px) {
.tp_diving_kosyu .in_box a img {
        width: 33%;
 }
.tp_diving_kosyu .in_box a .ttx_link {
padding-right: 0;
padding-bottom: 60px;
background-position: right bottom;
}
.tp_diving_kosyu .in_box a .ttx_link::after {
bottom: 0;
}
.flex_log_tp .in_box {
width: calc(50% - 26px);
}
#tab.tp_divinglog_flex .in_box.news_ttl,
.tp_divinglog_flex .in_box.news_ttl{
padding-right: 30px;
padding-left: 30px;
}
.tp_divinglog_flex h3.img_ttl img {
left: -30px;
}
.tp_divinglog_flex h3.img_ttl img {
width: 464px;
}
.tp_best_shot h3.img_ttl img {
top: 0;
max-width: 545px;
width:100%;
aspect-ratio: 545 / 181;
}
}
@media screen and (max-width: 766px) {
.text {
width: calc(100% - 25px);
left: 25px;
transition:var(--anime);
}
#trigger h3 {
 margin-left: 25px;
padding-right: 25px;
padding-bottom: 200px;
}
.text h2 {
font-size: 3.25rem;
}
.flex_log_tp {
gap: 0;
padding:0;
margin-left: 0;
}
.flex_log_tp .in_box {
width:100%;
margin-left: 0;
margin-right: 0;
padding-left: 13px;
padding-right: 13px;
}
	
.tp_diving_kosyu .in_box a img {
width: 140px;
padding: 10px;
 }
.tp_diving_kosyu .in_box a .ttx_link::before {
left: -20px;
width: 40px;
}
.tp_diving_kosyu .in_box a .ttx_link {
padding-left: 20px;
}
.text.hidden {
    bottom: 160px;
	transition:var(--anime);
}
#tab-head li a {
padding: 0.5rem 0.2rem;
font-size: 1rem;
}
.flex_topics_tp .in_box a img {
margin-right: 20px;
}
.tp_divinglog_flex .in_box.news_log #tab-body {
padding: 25px 1rem;
}

.tp_column2 .in_box.txt {
padding-left:40px;
padding-right:40px;
}
.tp_column2 .in_box.txt h3.img_ttl.divinginfo img,
.tp_column2 .in_box.txt h3.img_ttl.price img,
.tp_column2 .in_box.txt h3.img_ttl.reservation img,
.tp_column2 .in_box.txt h3.img_ttl.shop img,
.tp_column2 .in_box.txt h3.img_ttl.access img{
left: -30px;
}
}

@media screen and (max-width:620px) {
#trigger h3 {
padding-bottom: 270px;
}
}