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

/* CSS変数定義 */
:root {
    /* カラーパレット tomo skin clinic */
    /* ベース色 */
    --cp-base-01: rgb(97,136,198);
    /* 基本色 */
    --cp-base-02: rgb(244,179,194);
    --cp-base-03: rgb(161,203,237);
    --cp-base-04: rgb(165,162,208);
    /* 定番色 */
    --cp-stap-01: rgb(75, 156, 221);
    --cp-stap-02: rgb(70, 110, 174);
    --cp-stap-03: rgb(102, 183, 127);
    --cp-stap-04: rgb(0,0,0);
    /* 補色 */
    --cp-comp-01: rgb(227, 167, 71);
    --cp-comp-02: rgb(244, 67, 54);
    --cp-comp-03: rgb(0,0,0);
    --cp-comp-04: rgb(0,0,0);
    /* 同系色 */
    --cp-simi-01: rgb(0,0,0);
    --cp-simi-02: rgb(0,0,0);
    --cp-simi-03: rgb(0,0,0);
    --cp-simi-04: rgb(0,0,0);
    /* その他 */
    --cp-etc-01: rgb(51,51,51);
    --cp-etc-02: rgb(102,102,102);
    --cp-etc-03: rgb(109,107,91);
    --cp-etc-04: rgb(221,221,221); /*#e5e5e5*/
    
    --cp-uk-link: #1e87f0;

    /* グラデーション */
    --cp-grad-01: var(--cp-base-03) 40%, var(--cp-base-02) 100%;
    
    /* フォント */
    --fn-jp-01: 'Zen Kaku Gothic New';
    --fn-en-01: 'Urbanist';
    --fn-en-02: 'Josefin Sans';
}

html {
    font-family: var(--fn-jp-01), sans-serif;
}
.uk-h1, .uk-h2, .uk-h3, .uk-h4, .uk-h5, .uk-h6, .uk-heading-2xlarge, .uk-heading-large, .uk-heading-medium, .uk-heading-small, .uk-heading-xlarge, h1, h2, h3, h4, h5, h6 {
    font-family: var(--fn-en-01), var(--fn-jp-01), sans-serif;
    font-size: 200;
}

/* 汎用書体クラス */
.font-uklink {color: var(--cp-uk-link)!important;}

.font-jp-01 {font-family: var(--fn-jp-01), sans-serif!important;}

.font-base-01 {color: var(--cp-base-01)!important;}
.font-base-02 {color: var(--cp-base-02)!important;}
.font-base-03 {color: var(--cp-base-03)!important;}
.font-base-04 {color: var(--cp-base-04)!important;}
.font-stap-01 {color: var(--cp-stap-01)!important;}
.font-stap-02 {color: var(--cp-stap-02)!important;}
.font-stap-03 {color: var(--cp-stap-03)!important;}
.font-stap-04 {color: var(--cp-stap-04)!important;}
.font-comp-01 {color: var(--cp-comp-01)!important;}
.font-comp-02 {color: var(--cp-comp-02)!important;}
.font-comp-03 {color: var(--cp-comp-03)!important;}
.font-comp-04 {color: var(--cp-comp-04)!important;}
.font-simi-01 {color: var(--cp-simi-01)!important;}
.font-simi-02 {color: var(--cp-simi-02)!important;}
.font-simi-03 {color: var(--cp-simi-03)!important;}
.font-simi-04 {color: var(--cp-simi-04)!important;}
.font-etc-01 {color: var(--cp-etc-01)!important;}
.font-etc-02 {color: var(--cp-etc-02)!important;}
.font-etc-03 {color: var(--cp-etc-03)!important;}
.font-etc-04 {color: var(--cp-etc-04)!important;}

/* 汎用BGクラス */
.bg-base-01 {background: var(--cp-base-01)!important;}
.bg-base-02 {background: var(--cp-base-02)!important;}
.bg-base-03 {background: var(--cp-base-03)!important;}
.bg-base-04 {background: var(--cp-base-04)!important;}
.bg-stap-01 {background: var(--cp-stap-01)!important;}
.bg-stap-02 {background: var(--cp-stap-02)!important;}
.bg-stap-03 {background: var(--cp-stap-03)!important;}
.bg-stap-04 {background: var(--cp-stap-04)!important;}
.bg-comp-01 {background: var(--cp-comp-01)!important;}
.bg-comp-02 {background: var(--cp-comp-02)!important;}
.bg-comp-03 {background: var(--cp-comp-03)!important;}
.bg-comp-04 {background: var(--cp-comp-04)!important;}
.bg-simi-01 {background: var(--cp-simi-01)!important;}
.bg-simi-02 {background: var(--cp-simi-02)!important;}
.bg-simi-03 {background: var(--cp-simi-03)!important;}
.bg-simi-04 {background: var(--cp-simi-04)!important;}

.bg-dot-black {
    background: url("../img/bg_dot_black.png")!important;
    background-size: 4px!important;
}
.bg-dot-white {
    background: url("../img/bg_dot_white.png")!important;
    background-size: 4px!important;
}
.bg-dot-green {
    background: url("../img/bg_dot.png")!important;
    background-size: 4px!important;
}
.bg-transparent {background: rgba(34,34,34,.3)!important;}
.bg-transparent-black {background: rgba(0,0,0,.5)!important;}
.bg-transparent-white {background: rgba(255,255,255,.85)!important;}

.bg-base-gradient-h {
    background: linear-gradient(90deg, var(--cp-grad-01))!important;
}
.bg-base-gradient-v {
    background: linear-gradient(180deg, var(--cp-grad-01))!important;
}

.uk-heading-bullet::before {
    border-left: calc(5px + .1em) solid var(--cp-base-01);
    transition: all .1s ease-out;
}
a:hover .uk-heading-bullet::before {
    border-left: calc(5px + .1em) solid white;
}

.font-header {color: white!important;}
.font-change .font-header {color: var(--cp-etc-02)!important;}
.logo-img {display: none;}
.font-change .logo-img {display: block;}

.uk-divider-small::after {
    border-top-color: white!important;
}

/* メインナビゲーション */
header {
    /* box-shadow: 0 0 5px 3px rgba(0,0,0,0.4); */
}
.uk-navbar-nav>li>a {
    padding-top: 29px;
    font-size: 1rem;
    font-family: var(--fn-jp-01), sans-serif!important;
    color: var(--cp-etc-02);
    font-weight: bold;
	position: relative;
    z-index: 1;
	display: inline-block;
}
.uk-navbar-nav>li:hover>a,
.uk-navbar-nav>li>a.uk-open,
.uk-navbar-nav>li>a:focus {
    color: var(--cp-etc-02)!important;
    transition: all .3s ease-out;
}

.uk-navbar-center ul>li>a {
	position: relative;
}
.uk-navbar-center ul>li>a::before {
	position: absolute;
    z-index: -1;
	bottom: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 10px;
	background: var(--cp-base-03);
	transform: scale(1, 0);
	transform-origin: left bottom;
	transition: transform .3s ease;
    border-radius: 3px 3px 0 0;
}
.uk-navbar-center ul>li>a:hover::before {
	transform-origin: left bottom;
	transform: scale(1, 1);
}

/* ヒーローヘッダー */
#hero-header {
    z-index: -1;
}

/* サイドナビゲーション */
.uk-offcanvas-bar {
    box-shadow: 0 0 5px 3px rgba(0,0,0,0.4);
    padding: 0;
    color: white;
    /* width: 100vw; */
}

.uk-offcanvas-bar .uk-nav-default>li>a {
    color: white;
    font-weight: bold;
}
.uk-offcanvas-bar .uk-nav-default>li:hover>a,
.uk-offcanvas-bar .uk-nav-default>li>a.uk-open,
.uk-accordion-content>ul>li:hover>a {
    padding-left: 10px;
    padding-right: 10px;
    color: var(--cp-etc-02);
    font-weight: bold;
    background: white;
    border-radius: 20px;
    transition: all 0.1s ease-out;
}
.uk-accordion>:nth-child(n+2) {
    margin-top: 15px;
    margin-bottom: 15px;
}
.uk-offcanvas-bar .uk-nav-default, 
.uk-offcanvas-bar .uk-nav-default>li>a.uk-accordion-title {
    font-size: 1rem;
}

.uk-nav-divider {
    border-top-color: var(--cp-etc-04)!important;
}

/* リンク・ボタンなど */
.uk-button {
    border-radius: 50px;
}
.uk-button-like {
    display: inline-block;
    border-radius: 50px;
    border: 1px var(--cp-base-01) solid;
    color: var(--cp-base-01);
}

/* ページトップへ戻るボタン */
.scroll2view .btn-pagetop {
    display: none;
}
.btn-pagetop {
    width: 60px;
    height: 60px;
    position: fixed;
    right: 0;
    bottom: 0;
    padding: 0;
    background: #fff;
    border-radius: 50%;
    -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
    box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
    margin: 0 10px 10px 0;
}
@media (max-width: 639px) {
    .btn-pagetop {
        margin: 0 10px 55px 0;
    }
}
.btn-pagetop i {
    font-size: 150%;
    line-height: 60px;
    -webkit-transition: all .3s;
    transition: all .3s;
    letter-spacing: 0;
}
.btn-pagetop:hover i {
    line-height: 55px;
}

.uk-accordion-title.uk-card-header {
    transition: all .2s;
}

.uk-accordion-title.uk-card-header:hover {
    background-color: var(--cp-base-03);
}

.breadcrumb {
    text-align: center;
    background: linear-gradient(0deg, var(--cp-stap-01) -20%, rgb(129,170,218) 30%, var(--cp-base-03) 90%)!important;
    padding: 10px 0 5px;
}
.uk-breadcrumb * {
    color: white!important;
}
.uk-breadcrumb>:nth-child(n+2):not(.uk-first-column)::before {
    content: ">";
    color: white!important;
}

/* フッター */
/* footer {
    border-top: 1px var(--cp-base-01) solid;
    margin-top: 40px;
} */
address {
    margin: 0;
    padding: 0;
	font-style: normal;
}
.copyright {
	font-size: 0.8em;
	text-align: center;
}


/* アニメーション */
.obj-fluid {
    width: 60vh;
    height: 60vh;
    max-width: 600px;
    max-height: 600px;
    background: rgba(255,255,255,.9);
    animation: fluidrotate 30s ease 0s infinite;
}
@media (max-width: 639px) {
    .obj-fluid {
        width: 80vw;
        height: 80vw;
    }
}
@keyframes fluidrotate {  
    0%, 100% {
        border-radius: 63% 37% 54% 46%/55% 48% 52% 45%;
    }
    14% {
        border-radius: 40% 60% 54% 46%/49% 60% 40% 51%;
    }
    28% {
        border-radius: 54% 46% 38% 62%/49% 70% 30% 51%;
    }
    42% {
        border-radius: 61% 39% 55% 45%/61% 38% 62% 39%;
    }
    56% {
        border-radius: 61% 39% 67% 33%/70% 50% 50% 30%;
    }
    70% {
        border-radius: 50% 50% 34% 66%/56% 68% 32% 44%;
    }
    84% {
        border-radius: 46% 54% 50% 50%/35% 61% 39% 65%;
    } 
}

.obj-waves {
    position:relative;
    width: 100%;
    height: 60px;
    margin-bottom:-7px; /*Fix for safari gap*/
}
.parallax > use {
    animation: move-forever 25s cubic-bezier(.55,.5,.45,.5) infinite;
}
.parallax > use:nth-child(1) {
    animation-delay: -2s;
    animation-duration: 7s;
}
.parallax > use:nth-child(2) {
    animation-delay: -3s;
    animation-duration: 10s;
}
.parallax > use:nth-child(3) {
    animation-delay: -4s;
    animation-duration: 13s;
}
.parallax > use:nth-child(4) {
    animation-delay: -5s;
    animation-duration: 20s;
}
@keyframes move-forever {
    0% {
        transform: translate3d(-90px,0,0);
    }
    100% { 
        transform: translate3d(85px,0,0);
    }
}
@media (max-width: 959px) {
    .obj-waves {
        height: 40px;
    }
}

/* Googleカスタム検索 */
#cse-search-box {
  box-sizing: border-box;
  position: relative;
  border: 1px solid #999;
  padding: 3px 10px;
  border-radius: 20px;
  height: 2.3em;
  width: 200px;
  overflow: hidden;
}
@media (max-width: 640px) {
    #cse-search-box {
        width: 200px;
        background-color: white;
      }
} 
#cse-search-box input[type="text"] {
  border: none;
  height: 2.0em;
  position: absolute;
  top: 1px;
}
#cse-search-box input[type="text"]:focus {
  outline: 0;
}
#cse-search-box input[type="submit"] {
  cursor: pointer;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 1.3em;
  border: none;
  background: none;
  color: var(--cp-base-01);
  position: absolute;
  width: 2.5em;
  height: 2.5em;
  right: 0;
  top: -8px;
  outline : none;
}

/* トピックス */
.sidepanel {
    width: 280px;
}

.sidepanel ul>li>a {
    color: var(--cp-stap-01);
}
.sidepanel ul>li.sel>a {
    padding-left: 10px;
    background: var(--cp-base-01);
    transition: all 0.1s ease-out;
    color: white;
    border-radius: 20px;
}
.sidepanel ul>li:hover>a,
.sidepanel ul>li.sel:hover>a,
.sidepanel ul>li>a.uk-open,
.sidepanel ul>li>a:focus {
    padding-left: 10px;
    color: white;
    background: var(--cp-base-02);
    transition: all 0.1s ease-out;
    border-radius: 20px;
}

.midhead {
    box-sizing: border-box;
    width: 100%;
    padding: 5px 10px;
    color: white!important;
    background: linear-gradient(90deg, var(--cp-grad-01));
}

.inp-date>select {
    text-transform: none;
    border: 0 none;
    padding: 0 10px 3px;
    margin-right: 5px;
    background: #fff;
    color: #666;
    border: 1px solid #e5e5e5;
    transition: .2s ease-in-out;
    transition-property: color,background-color,border;
}
.inp-date>select:not([multiple]):not([size]) {
    height: 40px;
    vertical-align: middle;
    display: inline-block;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 20px;
    background-image: url(data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D%2224%22%20height%3D%2216%22%20viewBox%3D%220%200%2024%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%0A%20%20%20%20%3Cpolygon%20fill%3D%22%23666%22%20points%3D%2212%201%209%206%2015%206%22%20%2F%3E%0A%20%20%20%20%3Cpolygon%20fill%3D%22%23666%22%20points%3D%2212%2013%209%208%2015%208%22%20%2F%3E%0A%3C%2Fsvg%3E%0A);
    background-repeat: no-repeat;
    background-position: 100% 50%;
}

.uk-datepicker {
    width: auto;
}
.uk-datepicker-nav {
    margin-bottom: 15px;
    text-align: center;
    line-height: 20px;
}
.uk-datepicker-nav:after,
.uk-datepicker-nav:before {
    content: "";
    display: table;
}
.uk-datepicker-nav:after {
    clear: both;
}
.uk-datepicker-nav a {
    color: var(--cp-etc-01);
    text-decoration: none;
}
.uk-datepicker-nav a:hover {
    color: var(--cp-base-03);
}
.uk-datepicker-previous {
    float: left;
    margin-left: 12px;
}
.uk-datepicker-next {
    float: right;
    margin-right: 12px;
}
.uk-datepicker-table {
    width: 100%;
}
.uk-datepicker-table td,
.uk-datepicker-table th {
    padding: 2px;
}
.uk-datepicker-table th {
    font-size: 12px;
}
.uk-datepicker-table span {
    display: block;
    width: 26px;
    line-height: 24px;
    text-align: center;
    color: var(--cp-etc-02);
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: 4px;
    background-origin: border-box;
}
.uk-datepicker-table span a {
    color: var(--cp-base-01);
    text-decoration: none;
}
.uk-datepicker-table span:focus,
.uk-datepicker-table span:hover,
.uk-datepicker-table span:active {
    background-color: var(--cp-base-04);
    outline: 0;
    border-color: rgba(0,0,0,.1);
    border-bottom-color: rgba(0,0,0,.2);
    cursor: pointer;
}
.uk-datepicker-table span.uk-active {
    background: var(--cp-base-01);
    border:1px solid rgba(0,0,0,.1);
    border-bottom-color:rgba(0,0,0,.2);
}
.uk-datepicker-table span.uk-active a,
.uk-datepicker-table span.uk-active strong,
.uk-datepicker-table span.uk-active {
    background: var(--cp-base-01);
    color: white;
}