@charset "UTF-8";
/*文字色*/
.blue{
	color: #52C4BF;
	font-weight: bold;
}

@media (min-width: 1025px) {
.br-sp{
	display: none;
}
}

/*画像レイアウト設定*/
#main img {
	border-radius: 12px;
}

@media (min-width: 1025px) {
    .headerimg-img img {
        height: auto;
    }
}

   [data-header][data-header="col2"] #logo img:hover {
       opacity: 0.7;
      transition:0.3s;
    }

@media (max-width: 1024px) {
#logo img.pc-image{
	display: none;
}
}
@media (max-width: 1024px) {
#headerimg img.pc-image {
    display: none !important;
　}
}
@media (min-width: 1025px) {
#logo img.sp-image{
	display: none;
　}
}
@media (min-width: 1025px) {
#headerimg img.sp-image{
	display: none !important;
　}
}


/*装飾*/
.nmlbox {
    border: 2px solid #E0E0E0;
    border-radius: 20px;
}


.topmenu_ul a:hover {
    color: #ffe697;
    opacity:1;
}

/*ヘッダーテキストデザイン*/
.headerimg-title {
    font-size: clamp(2.4rem, 5.55555vw, 4rem);
    font-weight: 700;
    line-height: 1.5;
    margin: 0;
}
@media (max-width: 1440px) {
.headerimg-title {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.5;
    margin: 0;
}
}

@media (min-width: 1025px) {
    [data-headerimg-title="center"][data-main-header*="wide"] .headerimg-txt {
        margin-left: auto;
        margin-right: auto;
        max-width: 45%;
    }
}
@media (min-width: 1025px) {
        [data-main-header*="wide"] .headerimg-txt {
        background: rgba(255, 255, 255, 0);
        border-radius: 32px;
        margin-left: auto;
        margin-right: auto;
        width: 94%;
　}
}

@media (max-width: 1024px) {
    [data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt {
       background: rgba(255, 255, 255, 0); 
        border-radius: 32px;
        flex-shrink: 0;
    }
}
@media (max-width: 1024px) {
        [data-headerimg-type="header"][data-headerimg-img-sp="true"] .headerimg-desc {
        overflow: hidden;
        display: none !important;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 4;
    }
}

/*ヘッダー見た目崩れ調整*/
@media (min-width: 1025px) {
.headerimg-desc {
    display: none;
}
}
@media (min-width: 1025px) {
[data-headerimg-type="header"] #headerimg {
    display: flex;
    flex-direction: column;
}
}

@media (min-width: 1025px) {
    [data-main-header*="wide"] .headerimg-inner {
        position: absolute;
                height: 100%;
    }
}

@media (min-width: 1025px) {
[data-main-header*="header"] #main-header::before {
    background-color: var(--clr-header-bg1, var(--clr-accent, #ffd400));
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 50%;
    margin: 0;
}
}


/*見出しデザイン*/
h2:not([class*="topic"]) {
    margin-top:0;
    color:#52C4BF ;
}
[data-column="col1"][data-main="wide"] h2:not([class*="topic"]) {
    background: transparent;
    border-radius: 0;
    font-size: clamp(2.2rem, 6.11111vw, 3rem);
    padding: 0;
    text-align: center;
    color: #52c4bf;
    margin-top:0;
}

h3:not([class*="topic"]) {
display: inline-block;
    position: relative;
    padding: .5em .7em .5em 2em;
    border-radius: 50px 5px 5px 50px;
    background-color: #52C4BF;
    color: #fff;
  margin:0;
}
h3:not([class*="topic"])::before {
    content: '';
        background: #ffffff;
        border-radius: 50%;
        position: absolute;
        left: 18px;
        height: 15px;
        margin-right: 13px;
        display: inline-block;
        width: 15px;
        top: 40%;
        right: 0;
        bottom: 0;
}

h4:not([class*="topic"]) {
  position: relative;
  z-index: 1;
  padding: 1rem 20px;
  font-weight: bold;
  color: #333333;
}
h4:not([class*="topic"])::before {
content: '';
  background: #8ADBD7;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 0;
    bottom: 0;
  width: 40px;
  height: 40px;
  transform: translateY(-50%);
  z-index: -1;
  opacity: 0.7;
}

/*横並びのフォントサイズ*/
.figcaption p{
    font-size: 1.6rem;
    line-height: 2;
}
@media (max-width: 1024px) {
.figcaption p{
    font-size: 1.4rem;
    line-height: 1.7;
}
}
@media (max-width: 1024px) {
    .layout_box .float_item {
        display: table-cell;
        vertical-align: top;
        font-size: 1.4rem;
        line-height: 1.7;
        border-radius: 20px;
    }
}

@media (max-width: 1024px) {
    .layout_box .float_item {
        display: table-cell;
        vertical-align: top;
        font-size: 1.4rem !important;
        line-height: 1.7 !important;
        border-radius: 20px;
    }
}

@media screen and (max-width: 640px) {
    .figure[data-figure-responsive*="true"] .figcaption .figcaption-title {
        text-align: left;
    }
}

.layout_box .float_item {
    display: table-cell;
    vertical-align: top;
    font-size: 1.6rem;
    line-height: 2;
}
 .layout_box .float_item {
        display: table-cell;
        vertical-align: top;
        font-size: 1.6rem;
        line-height: 2;
        border-radius: 20px;
    }

.topmenu_ul a {
    color: #fff;
}

.float_item img.image-center{
    margin: 10px auto 20px auto;
    display: block;
}

.nmlbox, .dottbox, .ylwbox, .graybg, .grnbox, .pnkbox, .blubox, .brwbox, .cynbox {
    padding: 0 1.5em;
    margin-top: 1em;
    margin-bottom: 1em;
    clear: both;
    overflow: hidden;
}

/*横並び*/
.original-box{
display: flex;
justify-content: space-between;	
}
.original-box .table-wrap{
	width:55%;
}
.original-box .rnd1{
	width: 40%;
}

@media (max-width: 1024px) {
.original-box{
	display: flex;
	flex-direction: column;
	}
}

@media (max-width: 1024px) {
	.original-box .table-wrap{
	width:100%;
	}
}
@media (max-width: 1024px) {
.original-box .rnd1{
	width: 100%;
}
}

/*サイトマップ位置*/
.footer-menu_ul {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 1.5em 3em;
    align-items: center;
}

.footer-menu_ul a:hover {
    opacity: 0.7;
   transition:0.3s;
}

#sitemaps > ul > li > a::before {
    background:#52C4BF;
    border-radius: .15em;
    content: '';
    position: absolute;
    top: .45em;
    left: 0;
    width: .6em;
    height: .6em;
}

/*メニューBox非表示*/
nav.menuboxlist {
    display: none;
}

/*コピーライト*/
@media (max-width: 1024px) {
#copy {
    font-size: 1.1rem;
    text-align: center;
    width: 70%;
    margin-left: auto;
    margin-right: auto;
}
｝


@media screen and (max-width: 480px) {
    .figcaption {
        margin-top:0;
    }
}