@charset "UTF-8";
/*
Theme Name: Colorful Tails Theme
Theme URI: https://wordpress.org/
Requires at least: WordPress 4.9.6
Text Domain: colorfultails

*/

/* override and utilities */

body {
	position: relative;
	font-family: "Noto Sans JP",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
}

a {
	color: #000; /* bootstrap default black for body copy */
	transition: all .3s ease-out;
}
a:hover {
	color: inherit;
	text-decoration: underline;
}

img {
	max-width: 100%;
	height: auto;
}

p {
	line-height: 1.88;
}

.table td, .table th {
	padding: 25px .75rem;
}

blockquote {
	padding: 15px;
	border: 1px solid #efefef;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.px-5px {
	padding-left: 5px;
	padding-right: 5px;
}
.-mx-5px {
	margin-left: -5px;
	margin-right: -5px;
}

.pl-15 {
	padding-left: 15px;
}
.pr-15 {
	padding-right: 15px;
}
.pt-20 {
	padding-top: 20px;
}
.pb-20 {
	padding-bottom: 20px;
}
.pr-20 {
	padding-right: 20px;
}
.pl-20 {
	padding-left: 20px;
}

.mt-10 {
	margin-top: 10px;
}
.mb-10 {
	margin-bottom: 10px;
}
.mr-10 {
	margin-right: 10px;
}
.ml-10 {
	margin-left: 10px;
}
.mt-20 {
	margin-top: 20px;
}
.mb-20 {
	margin-bottom: 20px;
}
.mr-20 {
	margin-right: 20px;
}
.ml-20 {
	margin-left: 20px;
}
.mt-30 {
	margin-top: 30px;
}
.mb-30 {
	margin-bottom: 30px;
}
.mr-30 {
	margin-right: 30px;
}
.ml-30 {
	margin-left: 30px;
}
.mt-40 {
	margin-top: 40px;
}
.mb-40 {
	margin-bottom: 40px;
}
.mr-40 {
	margin-right: 40px;
}
.ml-40 {
	margin-left: 40px;
}

.h-45 {
	height: 45px;
}

.h1, h1 {
	font-size: 44px;
}

.f-12 {
	font-size: 12px;
}

.f-14 {
	font-size: 14px;
}

.f-15 {
	font-size: 15px;
}

.f-18 {
	font-size: 18px;
}

.f-20 {
	font-size: 20px;
}

.f-22 {
	font-size: 22px;
}

.f-24 {
	font-size: 24px;
}

.f-28 {
	font-size: 28px;
}

.f-34 {
	font-size: 34px;
}

.f-36 {
	font-size: 36px;
}

.f-64 {
	font-size: 64px;
}

.fw-500 {
	font-weight: 500;
} 
.fw-700 {
	font-weight: 700;
} 
.fw-900 {
	font-weight: 900;
} 

.page-header-tint {
	height: 100%;
	width: 100%;
	background: #000;
	opacity: 0.23;
	position: absolute;
	top: 0;
	left: 0;
}

.page-title {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
}
.page-title h1 {
	font-weight: 900;
}
.page-title h6.subtitle {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	text-transform: uppercase;
}

.text-yellow {
	color: #FEC72F; /* yellow */
}

.custom-select,
.input-group-text,
.col-form-label,
.form-control {
	font-size: 15px;
}
.custom-select {
	padding-left: 0.5rem;
}

.custom-select:focus,
.form-control:focus {
	border-color: #FEC72F; /* yellow */
	box-shadow: 0 0 0 .2rem #FEC72F5E;
}

.custom-switch .custom-control-label::after {
	background-color: #fff;
}
.custom-control-label::before {
	background-color: #607D8B; /* dark grey */
	border-color: #607D8B; /* dark grey */
}
.custom-control-input:checked ~ .custom-control-label::before {
	border-color: #FEC72F; /* yellow */
	background-color: #FEC72F; /* yellow */
}
.custom-control-input:focus ~ .custom-control-label::before {
	box-shadow: 0 0 0 .2rem #FEC72F5E;
}

.modal button.close {
	position: absolute;
	top: 10px;
	right: 15px;
}
.modal-body {
	padding: 20px 40px;
}

/* navbar bsnav */
.navbar-toggler {
	position: absolute;
	right: 22px;
	top: 26px;
	width: 36px;
	height: 26px;
}
.navbar-toggler:focus {
	outline: none;
}
.navbar-toggler.toggler-spring .navbar-toggler-icon::before {
	top: 13px;
}
.navbar-toggler.toggler-spring .navbar-toggler-icon::after {
	top: 26px;
}
.navbar-toggler .navbar-toggler-icon,
.navbar-toggler .navbar-toggler-icon::after,
.navbar-toggler .navbar-toggler-icon::before {
	background-color: #fff;
	height: 1px;
}
.bsnav.nav-light:not(.sticked) .navbar-toggler .navbar-toggler-icon,
.bsnav.nav-light:not(.sticked) .navbar-toggler .navbar-toggler-icon::after,
.bsnav.nav-light:not(.sticked) .navbar-toggler .navbar-toggler-icon::before 
{
	background-color: #000;
}
.bsnav-mobile.in + .bsnav
.navbar-toggler .navbar-toggler-icon,
.bsnav-mobile.in + .bsnav
.navbar-toggler .navbar-toggler-icon::after,
.bsnav-mobile.in + .bsnav
.navbar-toggler .navbar-toggler-icon::before {
	background-color: #fff;
}


.bsnav .navbar-brand {
	transition: all .3s ease-out;
}

.bsnav-mobile.in + .bsnav .navbar-brand {
	opacity: 0;
}


.bsnav-sticky {
	top: 0;
}

.navbar-nav .nav-item.active > .nav-link,
.navbar-nav .nav-item:active:focus > .nav-link,
.navbar-nav .nav-item:active > .nav-link,
.navbar-nav .nav-item:focus > .nav-link,
.navbar-nav .nav-item:hover > .nav-link,
.navbar-nav .nav-item.nav-item-double-line.active > .nav-link, 
.navbar-nav .nav-item.nav-item-double-line > .nav-link:active,
.navbar-nav .nav-item.nav-item-double-line > .nav-link:active:focus,
.navbar-nav .nav-item.nav-item-double-line > .nav-link:focus,
.navbar-nav .nav-item.nav-item-double-line > .nav-link:hover,
.navbar-nav .nav-item.nav-item-line.active > .nav-link,
.navbar-nav .nav-item.nav-item-line > .nav-link:active,
.navbar-nav .nav-item.nav-item-line > .nav-link:active:focus,
.navbar-nav .nav-item.nav-item-line > .nav-link:focus,
.navbar-nav .nav-item.nav-item-line > .nav-link:hover {
	color: inherit;
	font-weight: 700;
}

.navbar-nav .nav-item.nav-item-line > .nav-link::after {
	background: #000;
}

.navbar-nav .nav-item {
	color: #fff;
}

.navbar-expand-lg .navbar-nav .nav-link, .navbar-nav .nav-link {
	padding: 0;
	margin: 0px 25px;
	text-transform: uppercase;
	font-weight: 500;
	white-space: nowrap;
}

.bsnav-mobile .navbar {
	width: 100%;
	transform: translate3d(100%,0,0);
	background-image: url('assets/images/mobile-nav-bg.svg');
	background-size: cover;
	background-position: top right;
	padding: 70px 25px;
	justify-content: start;
}

.bsnav-mobile .navbar-nav {
	align-items: start;
	margin-bottom: 15px;
}
.bsnav-mobile .navbar-nav.social-menu  {
	flex-direction: row;
}

.bsnav-mobile .navbar-nav .nav-item .nav-link {
	padding: 0;
	font-size: 24px;
	font-weight: 500;
	margin: 0;
}

.bsnav-mobile .navbar .contact-menu {
	margin-left: 0;
	padding-left: 0;
	border: none;
	margin-top: 70px;
	position: relative;
}
.bsnav-mobile .navbar .contact-menu::before {
	content: '';
	position: absolute;
	width: 30px;
	height: 1px;
	background: #fff;
	display: block;
	top: -32px;
	left: 0;
}
.bsnav-mobile .lang-switcher {
	margin-left: 0;
	flex-direction: row;
	justify-content: center;
	margin-top: 30px;
}

/* colorful tails */
.navbar .contact-menu {
	border-left: 1px solid;
	border-left-color: inherit;
	margin-left: 15px;
	padding-left: 15px;
}
.navbar .contact-menu a {
	display: inline-flex;
	align-items: center;
}
.navbar .contact-menu a:before {
	content: '';
	display: inline-block;
	width: 21px;
	height: 21px;
	background-image: url('assets/images/icon-contact-white.svg');
	background-size: contain;
	margin-right: 13px;
}

.bsnav.nav-light .navbar-nav .nav-item,
.bsnav-sticky.sticked.in 
.navbar-nav .nav-item {
	color: #000;
}
.bsnav.nav-light .navbar .contact-menu a:before,
.bsnav-sticky.sticked.in 
.navbar .contact-menu a:before {
	background-image: url('assets/images/icon-contact-color.svg');
}

.custom-logo.logo-color {
	display: none
}
.bsnav.nav-light .custom-logo.logo-color,
.bsnav-sticky.sticked.in 
.custom-logo.logo-color {
	display: block;
}
.bsnav.nav-light .custom-logo.logo-white,
.bsnav-sticky.sticked.in 
.custom-logo.logo-white {
	display: none;
}

/* navbar above this */

.btn {
	font-weight: 500;
	font-size: 15px;
	padding-top: 10px;
	padding-bottom: 10px;
}

.btn-outline-primary:not(:disabled):not(.disabled).active,
.btn-outline-primary:not(:disabled):not(.disabled):active,
.show > .btn-outline-primary.dropdown-toggle,
.btn-outline-primary:hover,
.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show > .btn-primary.dropdown-toggle,
.btn-primary.focus, .btn-primary:focus,
.btn-primary:hover, 
.btn-primary {
	color: #fff;
	background-color: #FEC72F; /* yellow */
	border-color: #FEC72F; /* yellow */
}

.btn.focus, .btn:focus,
.btn-outline-primary.focus, .btn-outline-primary:focus,
.btn-primary.focus, .btn-primary:focus {
	box-shadow: 0 0 0 .2rem #FEC72F5E;
}

.btn-outline-primary {
	color: #FEC72F; /* yellow */
	border-color: #FEC72F; /* yellow */
}

header.page-header {
	position: relative;
	height: 50vh;
	background-image: url('assets/images/header-bg.svg');
	background-size: cover;
	background-position: center center;
}
.page-header.home-header {
	height: 100vh;
}

.page-header.nav-light {
	background: #fff;
	height: 84px; /* 13+13+58 */
}

.page-header.home-header .page-header-tint {
	opacity: 0.35;
}
.page-header.home-header .page-title {
	top: calc(50% - 20px);
}
/* .page-header.home-header .subtitle { */
/* 	font-size: 28px; */
/* } */

.popover {pointer-events: none;}

.swiper-button-next, .swiper-button-prev {
	color: #fff;
	opacity: 0.65;
}

.heateor_sss_horizontal_sharing {
	display: flex;
	align-items: center;
	margin-top: 80px;
}
.heateor_sss_sharing_title {
	font-size: 28px;
	margin-right: 15px;
}
.heateor_sss_horizontal_sharing ul.heateor_sss_sharing_ul li {
	margin: 0 5px !important;
}


.social-menu {
	margin: 0 25px;
}

.social-menu .list-inline-item:not(:last-child) {
	margin-right: 15px;
}

.social-menu-item i {
	display: block;
	height: 36px;
	width: 36px;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
}
.icon-facebook {
	background-image: url('assets/images/icon-facebook-white.svg');
}
.icon-twitter {
	background-image: url('assets/images/icon-twitter-white.svg');
}
.icon-instagram {
	background-image: url('assets/images/icon-instagram-white.svg');
}
.icon-inner-facebook {
	background-image: url('assets/images/icon-facebook-inner.svg');
}
.icon-inner-twitter {
	background-image: url('assets/images/icon-twitter-inner.svg');
}
.icon-inner-instagram {
	background-image: url('assets/images/icon-instagram-inner.svg');
}

.bsnav.nav-light .icon-facebook,
.bsnav-sticky.sticked.in 
.icon-facebook {
	background-image: url('assets/images/icon-facebook-color.svg');
}
.bsnav.nav-light .icon-twitter,
.bsnav-sticky.sticked.in 
.icon-twitter {
	background-image: url('assets/images/icon-twitter-color.svg');
}
.bsnav.nav-light .icon-instagram,
.bsnav-sticky.sticked.in 
.icon-instagram {
	background-image: url('assets/images/icon-instagram-color.svg');
}

.lang-switcher {
	margin-left: 25px;
}

.lang-switcher .lang-item {
	color: #fff;
}
.bsnav.nav-light .lang-switcher .lang-item,
.bsnav-sticky.sticked.in 
.lang-switcher .lang-item {
	color: #000;
}

.lang-switcher a {
	text-transform: uppercase;
	font-weight: 500;
	color: inherit;
}
.lang-switcher a:hover {
	text-decoration: underline;
}

.lang-switcher .lang-item:not(:first-child) {
	margin-left: 15px;
}
.lang-switcher .lang-item:not(:first-child):before {
	content: '/';
	color: inherit;
	position: relative;
	top: -2px;
	margin-right: 15px;
}

.lang-switcher .lang-item.current-lang a {
	padding: 2px 10px;
	background: #fff;
	color: #000;
	border-radius: 2px;
	margin-right: 3px;
}
.bsnav.nav-light .lang-switcher .lang-item.current-lang a,
.bsnav-sticky.sticked.in 
.lang-switcher .lang-item.current-lang a {
	background: #000;
	color: #fff;
}

.breadcrumbs {
	padding: 13px 15px;
	white-space: nowrap;
}

.breadcrumbs li {
	font-size: 12px;
	text-transform: uppercase;
}

.breadcrumbs li:last-child {
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
}
.breadcrumbs li:not(:last-child) {
	margin-right: 10px;
}
.breadcrumbs li:not(:last-child):after {
	content: '＞';
	margin-left: 10px;
}

.breadcrumbs .icon-home {
	display: inline-block;
	width: 15px;
	height: 15px;
	background-image: url('assets/images/icon-home.svg');
	background-size: contain;
	margin-right: 20px;
}

.home-header .scroll-indicator {
	font-size: 14px;
	color: #fff;
	position: absolute;
	text-align: center;
	height: 20%;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	letter-spacing: 1px;
}
.home-header .scroll-indicator:before {
	content: '';
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 1px;
	height: calc(100% - 35px);
	background: #fff;
}

.contact-section {
	padding: 170px 0;
	background-image: url('assets/images/footer-contact-bg.jpg');
	background-size: cover;
	background-position: center center;
	position: relative;
	color: #fff;
}

.contact-section:before {
	content: '';
	height: 100%;
	width: 100%;
	background: #484848;
	opacity: 0.38;
	position: absolute;
	top: 0;
	left: 0;
}

.btn-transparent {
	display: flex;
	height: 70px;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.22);
	border: 1px solid #fff;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	border-radius: 70px;
	color: #fff;
	transition: all .3s ease-out;
}
.btn-transparent.btn-outline {
	box-shadow: none;
	background: none;
	border-color: #707070;
	color: #000;
}
.btn-grey-pill {
	display: flex;
	height: 70px;
	align-items: center;
	justify-content: center;
	background: #575757;
	border-radius: 70px;
	color: #fff;
	transition: all .3s ease-out;
}

.contact-section .btn-transparent {
	margin-top: 50px;
	margin-bottom: 20px;
}

.btn-transparent:hover {
	background: #575757;
	border: none;
	text-decoration: none;
	color: #fff;
}
.btn-grey-pill:hover {
	background: #000;
	color: #fff;
	text-decoration: none;
}

.icon-contact {
	display: inline-block;
	width: 21px;
	height: 21px;
	background-image: url('assets/images/icon-contact-white.svg');
	background-size: contain;
	margin-right: 13px;
}

.sns-section {
	padding: 80px 0 90px;
}
.sns-section .social-menu-item {
	margin: 0 30px;
	height: 70px;
	border-radius: 70px; 
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
}
.sns-section .social-menu-item.facebook {
	background-color: #1c2595;
}
.sns-section .social-menu-item.twitter {
	background-color: #7acddd;
}
.sns-section .social-menu-item.instagram {
	background-image: linear-gradient(to left, #7835a8, #de1237 44%, #f4d405);
}
.sns-section .social-menu-item:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #575757;
	opacity: 0;
	transition: all .3s ease-out;
}

.sns-section .social-menu-item i {
	position: relative;
}

.sns-section .social-menu-item:hover:before {
	opacity: 1;
}

footer {
	padding: 30px 0;
	background-image: url('assets/images/footer-bg.svg');
	background-size: cover;
	background-position: center center;
}

footer .footer-menu .nav-link {
	text-transform: uppercase;
	color: #fff;
	padding: 0 30px;
}
footer .footer-menu .nav-link:hover {
	text-decoration: underline;
}
footer .footer-menu li:not(:last-child) {
	margin-right: 0;
}
footer .footer-menu li:not(:last-child) .nav-link {
	border-right: 1px solid #fff;
}
footer .footer-menu li:last-child .nav-link {
	padding-right: 0;
}

.page-section {
	padding-top: 50px;
	padding-bottom: 50px;
}

.page-section .section-subtitle {
	margin-bottom: 35px;
}
.games-section .section-subtitle {
	margin-bottom: 45px;
}

.games-wrapper div[class^="col-"] {
	margin-top: 10px;
	margin-bottom: 10px;
}
.news-wrapper div[class^="col-"] {
	margin-top: 10px;
	margin-bottom: 10px;
}

.news-item {
	position: relative;
	border-radius: 10px;
	overflow: hidden;
	background: #efefef;
	transition: all .3s ease-out;
}
.news-item .news-thumb {
	transition: all .3s ease-out;
}

.news-item .news-detail {
	padding: 25px;
}
.news-paper .news-cat,
.news-item .news-cat {
	background: #000;
	padding: 3px 12px;
	border-radius: 99px;
	color: #fff;
	margin-right: 13px;
	font-size: 12px;
}
.news-item .news-date {
	font-size: 14px;
}
.news-item .news-title {
	margin-top: 15px;
}
.news-item:hover {
	background: #575757;
}
.news-item:hover 
.news-thumb {
	transform: scale(1.25);
}
.news-item:hover .news-date,
.news-item:hover .news-title a
{
	color: #fff;
	text-decoration: none;
}
.news-item:hover .news-cat {
	background: #fff;
	color: #000;
}

.news-list .button-wrapper,
.news-section .button-wrapper {
	margin-top: 50px;
}

.about-section {
	background-image: url('assets/images/about-section-bg.svg');
	background-size: cover;
	background-position: center center;
	padding-top: 60px;
	padding-bottom: 60px;
}

.games-item {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
}

.games-item .games-detail {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.7);
	opacity: 0;
	transition: all .3s ease-out;
} 

.games-item .games-thumb {
	transition: all .3s ease-out;
}
.games-item:hover .games-detail {
	opacity: 1;
}
.games-item:hover .games-thumb {
	transform: scale(1.25);
}

.games-detail .games-title {
	flex-grow: 1;
}
.games-detail .games-title h2 {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
}
.games-detail .games-meta {
	justify-content: space-between;
}
.games-detail .games-meta a {
	margin: 0 auto;
}
.games-detail .games-meta a:not(:first-child) {
	margin-left: 10px;
}

.games-section .button-wrapper {
	margin-top: 30px;
}
.page-template-page_service .games-section .button-wrapper {
	margin-bottom: 60px;
}

.pagination {
	justify-content: center;
}
.pagination .screen-reader-text {
	display: none;
}

.pagination .nav-links {
	display: flex;
	align-items: center;
}
.pagination .page-numbers:not(.prev):not(.next) {
	display: flex;
	width: 52px;
	height: 52px;
	justify-content: center;
	align-items: center;
	border-radius: 52px;
	border: 1px solid #707070;
	margin: 0 10px;
}
.pagination .prev {
	margin-right: 25px;
}
.pagination .next {
	margin-left: 25px;
}
.pagination .page-numbers.current,
.pagination .page-numbers:not(.prev):not(.next):hover {
	background: #bd0080;
	color: #fff;
	border-width: 0px !important;
	text-decoration: none;
}

.news-container {
	background: #efefef;
	padding: 60px 0;
}

.news-paper {
	padding: 80px;
}

.news-paper .news-meta {
	margin-top: 40px;
	margin-bottom: 80px;
}

.news-paper .news-content {
	margin-top: 80px;
}
.news-paper .news-title {
	font-size: 34px;
}

.single-post .news-section .section-title:before {
	content: '';
	width: 30px;
	height: 2px;
	background: #575757;
	margin-right: 20px;
	display: inline-block;
	vertical-align: top;
	margin-top: 7px;
}
