@charset "UTF-8";
/* ---------------------------------------------
*   container
--------------------------------------------- */
/*  l-container
--------------------------------------------- */
.l-container {
    max-width: 990px;
    margin-inline: auto;
    padding-inline: 15px;
}
@media screen and (max-width: 768px) {
    .l-container {
        max-width: initial;
        padding-inline: calc(24 / 390 * 100vw);
    }
    .l-container--sp-none {
        padding-inline: 0;
    }
}

/*  l-container-sp
--------------------------------------------- */
@media screen and (max-width: 768px) {
    .l-container-sp {
        padding-inline: calc(24 / 390 * 100vw);
    }
}

/*  l-container-pc
--------------------------------------------- */
@media screen and (min-width: 769px) {
    .l-container-pc {
		max-width: 990px;
		margin-inline: auto;
		padding-inline: 15px;
    }
}

/*  .l-container-sm-sp
--------------------------------------------- */
@media screen and (max-width: 768px) {
    .l-container-sm-sp {
        max-width: calc(326 / 390 * 100vw);
        margin-inline: auto;
		padding-inline: 0;
    }
}

/******************************************************************
layout - footer-html-igniture
******************************************************************/
#footer * {
	line-height: 1.6;
	box-sizing: content-box;
}

.l-footer {
	background: #F5F5F6;
}

.l-footer-html-igniture { text-align: center; border-bottom: 0.6px solid #B3B1D5;}

@media print, screen and (min-width: 768px) { .l-footer-html-igniture { min-height: 329px; display: flex; align-items: center; justify-content: center; }
  .l-footer-html-igniture--w { background: url(/common_v2/img/logo_igniture-bgleft-w.svg) left top/auto 60% no-repeat, url(/common_v2/img/logo_igniture-bgright-w.svg) right bottom/auto 30% no-repeat, linear-gradient(90deg, #424d99 20%, #5185c5 100%); } }

@media screen and (max-width: 767px) { .l-footer-html-igniture:not(.l-footer-html-igniture--w) { background-color: #F6F6FA; }
  .l-footer-html-igniture--w { background: linear-gradient(90deg, #424d99 20%, #5185c5 100%); } }

@media print, screen and (min-width: 768px) { .l-footer-html-igniture__inner { margin-bottom: 22px; } .l-footer-html-igniture h2 img { width: auto; } }

@media screen and (max-width: 767px) { .l-footer-html-igniture h2 img { width: 100%; } }

@media print, screen and (min-width: 768px) { .l-footer-html-igniture--w h2 img { filter: brightness(0) invert(1); } }

@media screen and (max-width: 375px) { .l-footer-html-igniture p { font-size: 3.73333vw; } }

.l-footer-html-igniture p a { text-decoration: underline; }

.l-footer-html-igniture p a:hover { text-decoration: none; }

.l-footer-html-igniture--w p { color: #fff; font-size: 0.866666rem;}

.l-footer-html-igniture--w a { color: #fff; transition-property: opacity; transition-duration: 0.3s; }

.l-footer-html-igniture--w a:hover { opacity: .7; }

.l-footer-html-igniture__foot { margin-top: 16px; }

@media screen and (max-width: 767px) { .l-footer-html-igniture__foot img { width: 100%; } }

/******************************************************************
layout - footer2
******************************************************************/
.l-footer2 { color: #fff; background: #004098; font-size: 14px; }

.l-footer2 a { color: #fff; text-decoration: none; }

.l-footer2 a:hover { text-decoration: underline; }

@media print, screen and (min-width: 768px) { 
  .l-footer2__inner { line-height: 1.6; max-width: 960px; margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; padding-top: 40px; padding-bottom: 30px; display: flex; align-items: center; }
  .l-footer2__nav { flex-grow: 1; display: flex; font-size: 12px; }
  .l-footer2__nav ul { margin-right: 60px; } }

@media print, screen and (min-width: 768px) and (max-width: 980px) { .l-footer2__nav ul { margin-right: 3.06122vw; } }

@media print, screen and (min-width: 768px) { .l-footer2__nav li:not(:last-child) { margin-bottom: 5px; }
  .l-footer2__sns-outer { text-align: center; }
  .l-footer2__sns { display: flex; justify-content: center; margin-right: -18px; }
  .l-footer2__sns li { margin-right: 18px; }
  .l-footer2__sns a { transition-property: opacity; transition-duration: 0.3s; }
  .l-footer2__sns a:hover { opacity: 0.7; }
  .l-footer2__sns-list { margin-top: 15px; }
  .l-footer2__sns-list a { position: relative; padding-right: 5.5px; padding-right: 20px; }
  .l-footer2__sns-list a::after { position: absolute; content: ""; margin: auto; box-sizing: border-box; vertical-align: middle; top: 0; bottom: 0; right: 0; transform: translate(0px, 2.5px) rotate(45deg); transform-origin: top right; border-top: 1px solid #fff; border-right: 1px solid #fff; width: 7px; height: 7px; transition-property: top, right, bottom, left; transition-duration: 0.3s; }
  .l-footer2__sns-list a::after { top: 2px; } }

@media screen and (max-width: 767px) { 
  .l-footer2__inner { padding: 30px 24px; display: flex; flex-direction: column; }
  .l-footer2__nav { order: 3; margin-top: 30px; font-size: 12px; }
  .l-footer2__nav ul:not(:last-child) { margin-bottom: 24px; }
  .l-footer2__nav li:not(:last-child) { margin-bottom: 8px; }
  .l-footer2__sns { display: flex; justify-content: center; }
  .l-footer2__sns li { padding: 0 10px; }
  .l-footer2__sns li img { width: 40px; }
  .l-footer2__sns-list { margin-top: 12px; text-align: center; }
  .l-footer2__sns-list a { position: relative; padding-right: 5.5px; padding-right: 20px; }
  .l-footer2__sns-list a::after { position: absolute; content: ""; margin: auto; box-sizing: border-box; vertical-align: middle; top: 0; bottom: 0; right: 0; transform: translate(0px, 2.5px) rotate(45deg); transform-origin: top right; border-top: 1px solid #fff; border-right: 1px solid #fff; width: 7px; height: 7px; transition-property: top, right, bottom, left; transition-duration: 0.3s; }
  .l-footer2__sns-list a::after { top: 2px; } }

/******************************************************************
layout - footer-group
******************************************************************/
@media print, screen and (min-width: 768px) { .l-footer-group__inner { max-width: 960px; margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; display: flex; justify-content: space-between; align-items: center; padding-top: 12px; padding-bottom: 15px; } }

@media screen and (max-width: 767px) { .l-footer-group__inner { box-sizing: border-box; padding-inline: 15px; display: flex; flex-direction: column; min-height: 134px; justify-content: center; } }

@media print, screen and (min-width: 768px) { .l-footer-group__logo img { width: 421px; transform: translateX(-10.175px);} }

@media screen and (max-width: 767px) { .l-footer-group__logo img { width: 360px; transform:} }

.l-footer-group__copy { font-size: 12px; color: #B9BABD; }

@media screen and (max-width: 767px) { .l-footer-group__copy { display: block; padding-top: 10px; padding-left: 9px; } }

@media screen and (max-width: 767px) and (max-width: 320px) { .l-footer-group__copy { font-size: 10px; } }


/* ---------------------------------------------
*   header
--------------------------------------------- */
header *, header *::before, header *::after {
    box-sizing: content-box;
}

/*  .header-group
--------------------------------------------- */
.l-header-group { background-color: #F5F5F6; line-height: 1; }

.l-header-group__inner { max-width: 960px; margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; display: flex; flex-direction: row-reverse; justify-content: space-between; align-items: center; min-height: 40px; }

.l-header-group__logo img { width: 331px; vertical-align: baseline; transform: translateX(8px);}
.l-header-group__nav { display: flex; flex-wrap: wrap; font-size: 0.75rem; margin-bottom: -5px; }

.l-header-group__nav li { margin-right: 30px; margin-bottom: 5px; }

.l-header-group__nav a { color: var(--main-text-color); position: relative; padding-right: 5px; padding-right: 10px; }

.l-header-group__nav a::after { position: absolute; content: ""; margin: auto; box-sizing: border-box; vertical-align: middle; top: 0; bottom: 0; right: 0; transform: translate(0px, 2px) rotate(45deg); transform-origin: top right; border-top: 1px solid var(--main-text-color); border-right: 1px solid var(--main-text-color); width: 6px; height: 6px; transition-property: top, right, bottom, left; transition-duration: 0.3s; }

.l-header-group__nav a::after { top: 3px; }

.l-header-group__nav a:hover { color: var(--fc-theme-2); text-decoration: none; }

@media screen and (max-width: 767px) { .l-header-group { display: none; } }

/*  .l-header
--------------------------------------------- */
.l-header {
    background-color: #fff;
}
@media screen and (max-width: 768px) {
    .l-header {
        position: sticky;
        top: 0;
        z-index: 99;
    }
}

@media print, screen and (min-width: 768px) {
	.l-header__inner { 
		max-width: 960px;
		margin-right: auto;
		margin-left: auto;
		padding-right: 30px;
		padding-left: 30px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding-top: 5px;
		padding-bottom: 5px;
	}
	.l-header__logo {
		max-width: 130px;
		width: 100%;
		transform: translateX(-4px);
	}

}

@media screen and (max-width: 768px) {
	.l-header__inner {
		box-sizing: border-box;
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 10px 15px 7px;
	}
    .l-header__logo {
        max-width: 111px;
    }
}

@media print, screen and (min-width: 768px) {
	.l-header__body-pc { 
	}
	.l-header__body-pc-inner {
		display: flex;
		align-items: center;
	}
}
@media screen and (max-width: 768px) {
	.l-header__body-pc {
		display: none;
	}
}

@media print, screen and (min-width: 768px) {
	.l-header__search2 { position: relative; margin-left: 20px; }
	.l-header__search2-trigger a { display: flex; align-items: center; line-height: 1; background: url(/common_v2/img/icn_search2.svg) center center no-repeat; }
	.l-header__search2-trigger a img { 10px; opacity: 0; }
	.l-header__search2-trigger a:hover, .l-header__search2-trigger a[aria-expanded="true"] { background: none; }
	.l-header__search2-trigger a:hover img, .l-header__search2-trigger a[aria-expanded="true"] img { opacity: 1; }
	.l-header__search2-form { position: absolute; z-index: 1000; display: none; right: -3px; margin-top: 5px;}
	.l-header__search2-form form { display: flex; background: #fff; border: 1px solid var(--fc-theme-2); border-radius: 4px; padding: 6px; }
	.l-header__search2-form form input[type="text"] { outline: 0; border: 0 !important; width: 200px; padding: 6px 12px; line-height: 1.8; font-size: 1rem; }
	.l-header__search2-form form button { box-sizing: border-box; display: flex; align-items: center; padding: 0 10px; width: 40px; transition-property: background; transition-duration: 0.3s; }
	.l-header__search2-form form button:hover { background-color: #F5F5F6; }
	.l-header__search2-form form button img { width: 20px; }
	.l-header__body-sp { display: none; }
	
	.l-header__faq2 a { position: relative; color: var(--main-text-color); display: inline-block; font-size: 0.6875rem; line-height: 1.6; letter-spacing: 0.02em; background: url(/common_v2/img/icn_faq2.svg) left center no-repeat; padding: 5px 0 5px 22px; transition-property: color; transition-duration: 0.3s; }
	.l-header__faq2 a::before { position: absolute; content: ""; margin: auto; box-sizing: border-box; vertical-align: middle; top: 0; bottom: 0; left: 0; width: 20px; height: 20px; background: url(/common_v2/img/icn_faq2_o.svg) left center no-repeat; opacity: 0; }
	.l-header__faq2 a:hover, .l-header__faq2 a[aria-expanded="true"] { color: var(--fc-theme-2); background: none; }
	.l-header__faq2 a:hover::before, .l-header__faq2 a[aria-expanded="true"]::before { opacity: 1; }
}

@media print, screen and (min-width: 768px) {
	.l-header__htmllp-head-igniture {
		background: linear-gradient(90deg, #424d99 20%, #5185c5 100%);
	}
	.l-header__htmllp-head-igniture span {
		display: flex;
		align-items: center;
		max-width: 960px;
		margin-inline: auto;
		height: 64px;
		padding: 0 30px;
	}
	.l-header__htmllp-head-igniture img {
		width: auto;
		height: 24px;
		vertical-align: top;
		transform: translateY(-1px);
	}
}

@media screen and (max-width: 768px) {
	.l-header__htmllp-head-igniture {
		background: linear-gradient(90deg, #424d99 20%, #5185c5 100%);
		height: 48px;
		padding-left: 23.86px;
		padding-right: 10px;
		display: flex;
		align-items: center;
	}
	.l-header__htmllp-head-igniture img {
		height: 21px;
		vertical-align: top;
	}
	.l-header__htmllp-head-igniture span img {
		transform: translateY(1px);
	}
}

/*  header-menu-button
--------------------------------------------- */
.header-menu-button {
    position: relative;
    display: none;
    padding: 12px 11px;
    border: 0;
    border-radius: 0;
    background: none;
    margin: 0;
    margin-left: auto;
    box-shadow: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
}
@media screen and (max-width: 768px) {
    .header-menu-button {
        display: block;
    }
}
.header-menu-button img {
    display: block;
    width: 22px;
    height: 20px;
}

/*  header-menu
--------------------------------------------- */
.header-menu {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    display: none;
    width: 100%;
    height: 100dvh;
    color: #fff;
}
@media screen and (min-width: 769px) {
    .header-menu {
        display: none !important;
    }
}

.header-menu.is-menu-opened {
	height: 100dvh;
}

.header-menu__overlay {
    position: absolute;
    inset: 0;
	background: rgba(35, 24, 21, 0.5);
}

.header-menu__inner {
    position: relative;
    width: calc(330 / 390 * 100vw);
    height: auto;
    overflow-y: auto;
	margin-left: auto;
	margin-right: 0;
    padding-top: 45px;
    background-color: var(--fc-theme-1);
	
}
@media screen and (max-width: 768px) and (orientation: landscape) {
	.header-menu__inner {
		height: calc(100dvh - 36px);
	}
}

.header-menu__btn {
    position: absolute;
	top: 56px;
    right: 12px;
	padding: 12px;
	width: 20px;
}
@media (hover: hover) and (pointer: fine) {
    .header-menu__btn {
        transition: opacity 300ms;
    }
    .header-menu__btn:hover {
        opacity: 0.8;
    }
}
.header-menu__btn img {
    width: 100%;
}

.header-menu__nav {
	width: calc(258 / 375 *100vw);
	margin-inline: auto;
	padding-top: 80px;
	padding-bottom: 104px;
}

.header-menu__nav-lv1-item {
    font-size: 1rem;
	font-weight: 400;
}
.header-menu__nav-lv1-link {
    display: block;
    padding: 27.5px 10px 28.5px 10px;
    border-bottom: 0.66px solid #B3B1D5;
}
@media (hover: hover) and (pointer: fine) {
    .header-menu__nav-lv1-link, .header-menu__nav-lv2-link {
        transition: opacity 300ms;
    }
    .header-menu__nav-lv1-link:hover, .header-menu__nav-lv2-link:hover {
        opacity: 0.8;
    }
}

/*  l-header__search--sp
--------------------------------------------- */
.l-header__search--sp {
	background-color: #D9D8EB;
	padding: 36px 32px;
}

.l-header__search--sp-form {
	background-color: #ffffff;
}

.l-header__search--sp-form form {
	display: flex;
	align-items: center;
	gap: 14px;
	background: #FFFFFF;
	padding: 6px 15px;
}
 .l-header__search--sp-form form input[type="text"] {
	 outline: 0;
	 border: 0 !important;
	 width: 100%;
	 padding: 7px 0;
	 font-size: 1rem;
}

.l-header__search--sp-form form img {
	width: 20px;
}

.l-header__search--sp > *:not(:last-child) {
	margin-bottom: 16px;
}

.l-header__search--sp .l-header__faq2 a {
	position: relative;
	color: var(--main-text-color);
	display: inline-block;
	font-size: 0.733rem;
	background: url(/common_v2/img/icn_faq2_o.svg) left center no-repeat;
	background-size: 20px 20px;
	padding: 16px 0 16px 24px;
}

/* ---------------------------------------------
*   l-wrapper
--------------------------------------------- */

/* ---------------------------------------------
*   btn
--------------------------------------------- */
/*  c-btn
--------------------------------------------- */
.c-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 380px;
	min-height: 56px;
    border: 1px solid var(--fc-theme-1);
	padding: .75em 36px;
	color: var(--fc-theme-1);
    font-size: 1rem;
    font-weight: 500;
	line-height: 1.5;
    letter-spacing: 0.02em;
    text-align: center;
	background: #FFFFFF url(/common_v2/img/icn_arrow_right.svg) right 22px center / 6px 11px no-repeat;
	background-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
    .c-btn {
        transition: opacity 300ms;
    }
    .c-btn:hover {
        text-decoration: none;
		color: var(--fc-theme-1);
		border: 1px solid  var(--fc-theme-1);
		background-color: var(--fc-theme-4);
    }
}
@media screen and (max-width: 768px) {
    .c-btn {
		width:  calc(342 / 390 * 100vw);
		min-height: 50px;
		padding: .75em 1em;
		background: #FFFFFF url(/common_v2/img/icn_arrow_right.svg) right 20px center / 6px 11px no-repeat;
    }
}

/* ---------------------------------------------
*   card
--------------------------------------------- */
.c-card-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    -moz-gap: min(5%, 48px);
         gap: min(5%, 48px);
}
@media screen and (max-width: 768px) {
    .c-card-list {
        display: block;
    }
}
.c-card-list__item {
    --delay: .2s;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 0;
    /* animation */
}
@media screen and (max-width: 768px) {
    .c-card-list__item:not(:last-child) {
        padding-bottom: calc(64 / 390 * 100vw);
    }
}
@media screen and (min-width: 769px) {
    .c-card-list__item {
        opacity: 0;
        transform: translateY(50px);
    }
    .is-active-2 .c-card-list__item {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}
.c-card-list__item:nth-of-type(1) {
    transition-delay: 0s;
}
.c-card-list__item:nth-of-type(2) {
    transition-delay: var(--delay);
}
.c-card-list__item:nth-of-type(3) {
    transition-delay: calc(var(--delay) * 2);
}
.c-card-list__img img {
    width: 100%;
	display: block;
}
.c-card-list__txt-wrap {
	padding-inline: 4px;
}
@media screen and (max-width: 768px) {
    .c-card-list__txt-wrap {
        max-width: calc(326 / 390 * 100vw);
        margin-inline: auto;
		padding-inline: 0;
    }
}
.c-card-list__ttl {
    margin-top: 28px;
	font-size: 1.125rem;
    font-weight: 500;
    letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .c-card-list__ttl {
        margin-top: min(calc(32 / 390 * 100vw), 32px);
        font-size: 1.06666666rem;
		letter-spacing: 0.04em;
    }
}

@media screen and (min-width: 769px) {
    .p-top-solution-cassette--03 .c-card-list__item:nth-of-type(1) .c-card-list__ttl {
        letter-spacing: 0;
    }
}

.c-card-list__txt {
    margin-top: 16px;
    font-size: 0.9375rem;
    line-height: 1.75;
	letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
    .c-card-list__txt {
        font-size: 0.933333rem;
    }
}
@media screen and (min-width: 769px) {
    .c-card-list__ttl, .c-card-list__txt {
        opacity: 0;
        transform: translateY(50px);
    }
    .is-active-2 .c-card-list__ttl, .is-active-2 .c-card-list__txt {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
    .c-card-list__item:nth-of-type(1) .c-card-list__ttl, .c-card-list__item:nth-of-type(1) .c-card-list__txt {
        transition-delay: calc(var(--delay) * 1);
    }
    .c-card-list__item:nth-of-type(2) .c-card-list__ttl, .c-card-list__item:nth-of-type(2) .c-card-list__txt {
        transition-delay: calc(var(--delay) * 2);
    }
    .c-card-list__item:nth-of-type(3) .c-card-list__ttl, .c-card-list__item:nth-of-type(3) .c-card-list__txt {
        transition-delay: calc(var(--delay) * 3);
    }
}

/* ---------------------------------------------
*   l-main
--------------------------------------------- */
.l-main {
	display: grid;
	grid-template-areas:
		"keyvisual"
		"breadcrumb"
		"contents";
}

.l-keyvisual { grid-area: keyvisual; }
.l-breadcrumb { grid-area: breadcrumb; }
.l-contents { grid-area: contents; }

@media (max-width: 768px) {
	.l-main {
		grid-template-areas:
			"keyvisual"
			"contents"
			"breadcrumb"
	}	
}

/******************************************************************
html - visual-img-text
******************************************************************/
.html-visual-img-text { position: relative; }

.html-visual-img-text img { object-fit: cover; width: 100%; height: 420px; }

@media screen and (max-width: 768px) { .html-visual-img-text img { height: auto; aspect-ratio: 375 / 188; } }

.html-visual-img-text__body { position: relative; z-index: +1; box-sizing: border-box; }

@media print, screen and (min-width: 769px) { .html-visual-img-text__body { position: absolute; top: 50%; transform: translateY(-50%); background-color: rgba(217, 216, 235, 0.9); width: 54%; min-height: 223px; padding-block: 24px; display: flex; flex-direction: column; justify-content: center; } }

@media screen and (max-width: 767px) { .html-visual-img-text__body { background-color: #D9DBEB; margin-top: -12%; width: 93%; } }

@media print, screen and (min-width: 768px) { .html-visual-img-text__body-inner { box-sizing: border-box; margin-left: calc((100vw - (960px + 30px + 30px)) / 2); padding-inline: 30px; } }

@media print, screen and (max-width: 980px) { .html-visual-img-text__body-inner { margin-left: 0; } }

@media screen and (max-width: 768px) { .html-visual-img-text__body-inner { padding: 24px; } }

.html-visual-img-text__body-inner > *:not(:last-child) { margin-bottom: 16px; }

.html-visual-img-text__body-inner h1 { 
	color: #424D99;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.4;
}
@media screen and (max-width: 768px) { 
	.html-visual-img-text__body-inner h1 {
		font-size: 1.8666666rem;
		font-weight: 500;
		line-height: 1.5;
	}
}

.html-visual-img-text__body-inner h1 > p { 
	font-weight: 400;
	letter-spacing: 0.02em;
	line-height: 1.75;
}
@media screen and (max-width: 768px) { 
	.html-visual-img-text__body-inner h1 > p {
		line-height: 1.5;
	}
}

/* ---------------------------------------------
*   l-breadcrumb
--------------------------------------------- */
.l-breadcrumb {
	width: 100%;
	justify-self: stretch;
}

.l-breadcrumb__inner {
	max-width: 960px;
	min-height: 80px;
    margin-inline: auto;
	padding-top: 26px;
}
@media screen and (max-width: 768px) {
    .l-breadcrumb__inner {
        min-height: calc(48 / 390 * 100vw);
		margin-left: calc(12 / 390 * 100vw);
		margin-right: calc(24 / 390 * 100vw);
		padding-top: 0;
		padding-left: calc(4 / 390 * 100vw); 
    }
}

.l-breadcrumb ul {
	display: flex;
	align-items: center;
}

.l-breadcrumb li {
	font-size: 0.8125rem;
	line-height: 1;
}
@media screen and (max-width: 768px) {
    .l-breadcrumb li {
        font-size: 0.8rem;
    }
}


.l-breadcrumb li:not(:last-child)::after {
	content: "";
	display: inline-block;
	width: 12px;
	height: 12px;
	background: url(/common_v2/img/icn_arrow_breadcrumb.svg) right center no-repeat;
	vertical-align: middle;
}

.l-breadcrumb span {
	padding: 10px 12px 12px 12px;
}

.l-breadcrumb a {
	text-decoration: underline 0.8px;
	text-underline-offset: 3px;
	box-sizing: border-box;
	outline: 2px solid transparent;
	padding: 10px 12px 12px 12px;
}

.l-breadcrumb a:focus-visible {
	outline-color: #0099D9;
	border-radius: 8px;
}

@media screen and (max-width: 768px) {
    .l-breadcrumb a {
        text-underline-offset: 2px;
		line-height: 1.5;
		padding: 10px 8px 12px 8px;
    }
}

/* ---------------------------------------------
*   SP コンテンツ幅以上のパンくず対応
--------------------------------------------- */
@media screen and (max-width: 768px) {
	.l-breadcrumb ul {
		overflow: hidden;
	}
	.l-breadcrumb.is-overflow li:first-child a {
		font-size: 0;
		padding: 0;
		display: inline-block;
		min-width: 1rem;
		position: relative;
	}
	.l-breadcrumb.is-overflow li:first-child a::before {
		content: "…";
		color: var(--main-text-color);
		font-size: 0.666rem;
		min-width: 1.5em;
		position: absolute;
		left: 0;
		top: 60%;
		transform: translateY(-50%);
	}
	.l-breadcrumb.is-overflow .l-breadcrumb__inner {
		padding-left: calc(12 / 390 * 100vw);
		margin-right: calc(8 / 390 * 100vw);
		margin-left: calc(8 / 390 * 100vw);;
	}
}
@media screen and (max-width: 356px) {
	.l-breadcrumb.is-overflow .l-breadcrumb__inner {
		padding-left: calc(8 / 390 * 100vw);
		margin-right: 0;
		margin-left: 0;
	}
    .l-breadcrumb li {
        font-size: 0.7rem;
    }
}

/* ---------------------------------------------
*   list
--------------------------------------------- */
/*  c-list-news
--------------------------------------------- */
.c-list-news {
	margin-top: 40px;
}
@media screen and (max-width: 768px) {
    .c-list-news {
        margin-top: calc(32 / 390 * 100vw);
    }
}

.c-list-news__item {
    border-bottom: 0.6px solid #CCCCCC;
	padding-inline: 8px;
}
@media screen and (max-width: 768px) {
    .c-list-news__item {
        padding-inline: 4px;
    }
}

.c-list-news__link {
    display: grid;
    grid-template-columns: 138px auto;
    padding-block: 33px;
}
@media screen and (max-width: 768px) {
    .c-list-news__link {
        display: block;
        padding-block: 23px;
    }
}
.c-list-news__date {
    color: #666;
    font-weight: 500;
    letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
    .c-list-news__date {
		line-height: 1;
    }
}

@media screen and (min-width: 769px) {
    .c-list-news__ttl {
        padding-inline: 32px 8px;
    }
}
@media screen and (max-width: 768px) {
    .c-list-news__ttl {
        margin-top: 12px;
		letter-spacing: 0.02em;
    }
}
@media (hover: hover) and (pointer: fine) {
    .c-list-news__link:hover .c-list-news__ttl {
		text-decoration: underline 0.8px;
		text-underline-offset: 3px;
    }
}

.p-top-news__btn {
	margin-top: 64px;
    margin-inline: auto;
}
@media screen and (max-width: 768px) {
	.p-top-news__btn {
		margin-top: calc(56 / 390 * 100vw);
	}
}

/*  c-list-topics
--------------------------------------------- */
.c-list-topics__item {
    border-bottom: 0.6px solid #CCCCCC;
    display: grid;
    grid-template-columns: 138px 126px 1fr;
	align-items: center;
    padding: 1rem;
    font-size: 1rem;
}
@media (max-width: 768px) {
  .c-list-topics__item {
	  grid-template-columns: 128px 1fr;
	  grid-template-areas:
		  "col1 col2"
		  "col3 col3";
	  row-gap: 12px;
	  padding: 1rem 0 1.5rem 4px;
  }
  .c-list-topics__item > :nth-child(1) {
	  grid-area: col1;
  }
  .c-list-topics__item > :nth-child(2) {
	  grid-area: col2;
  }
  .c-list-topics__item > :nth-child(3) {
	  grid-area: col3;
  }
}

.c-list-topics__date {
	color: #666666;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
    .c-list-topics__date {
    }
}

.c-list-topics__label {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 8px;
	
	font-size: 0.875rem;
	line-height: 1;
	letter-spacing: 0.02rem
}
@media screen and (max-width: 768px) {
    .c-list-topics__label {
		font-size: 0.933333rem;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: flex-start;
	}
}

.p-topics-label-area .c-list-topics__label {
	flex-direction: row;
	justify-content: flex-start;
}
@media screen and (max-width: 768px) {
    .p-topics-label-area .c-list-topics__label {
		justify-content: flex-end;
	}
}


.c-list-topics__label span {
	background-color: #fff;
	border: 1px solid;
	border-left-width: 8px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 114px;
	height: 36px;
}
@media screen and (max-width: 768px) {
    .c-list-topics__label span {
		width: clamp(90px, calc(101 / 390 * 100vw), 101px);
		height: 32px;
  }
}

.c-list-topics__label .label-01 {
	border-color: #0094A3!important;
}
.c-list-topics__label .label-02 {
	border-color: var(--fc-theme-2)!important;
}
.c-list-topics__label .label-03 {
	border-color: var(--fc-theme-3)!important;
}

.c-list-topics__ttl {
	padding: 1rem
	
}
@media screen and (max-width: 768px) {
    .c-list-topics__ttl {
		padding: 0;
    }
}
@media (hover: hover) and (pointer: fine) {
    .c-list-topics__ttl a:hover {
        text-decoration: underline 0.8px;
		text-underline-offset: 3px;
    }
}

.c-heading-title.p-topics .c-list-topics__label {
	gap: 12px;
}
@media screen and (max-width: 768px) {
    .c-heading-title.p-topics .c-list-topics__label {
		gap: 10px;
    }
}
@media screen and (max-width: 768px) {
    .c-list-topics__label {
		font-size: 0.8293333rem;
	}
}

/* ---------------------------------------------
*   html-anker
--------------------------------------------- */
/*  html-anker
--------------------------------------------- */
.html-anker {
	padding-top: 80px;
}
@media screen and (max-width: 768px) {
    .html-anker {
        padding-block: calc(40 / 390 *100vw) calc(16 / 390 *100vw);
    }
}

.html-anker__item:not(:last-child) {
	margin-bottom: 16px;
}

@media screen and (max-width: 767px) { 
	.html-anker__item:not(:last-child) { 
		margin-bottom: 24px; 
	}
}

.html-anker__item ul {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(228px, 1fr));
	gap: 16px min(calc(30 / 960 * 100vw), 30px);
}
@media screen and (max-width: 767px) {
	.html-anker__item ul {
		grid-template-columns: repeat(1, 1fr);
		gap: 0;
	}
}

.html-anker__item li {
	display: flex;
}

.html-anker__item a {
	flex-grow: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	border: var(--fc-theme-1) 1px solid;
	text-align: center;
	font-size: 0.8125rem;
	line-height: 1.5;
	letter-spacing: 0.02em;
	color: var(--fc-theme-1);
	padding: .75em 30px;
	transition-property: all;
	transition-duration: 0.3s;
	background: url(/common_v2/img/icn_arrow.svg) right 15px center/11px 6px no-repeat;
}

@media print, screen and (min-width: 768px) {
	.html-anker__item a:hover {
		text-decoration: none;
		color: var(--fc-theme-1);
		border: 1px solid  var(--fc-theme-1);
		background-color: var(--fc-theme-4); 
	}
}

@media screen and (max-width: 767px) {
	.html-anker__item a {
		border: none;
		border-bottom: 1px solid #E8E8E8;
		justify-content: flex-start;
		text-align: left;
		font-size: 0.866666666rem;
		min-height: 51px;
		padding-left: 4px;
		background-position: right 9px center;
	}
}

/* トップページ anker */
.html-anker.top-page {
	padding-top: 80px;
	transition-delay: 0.6s !important;
}
@media screen and (max-width: 768px) {
    .html-anker.top-page {
        padding-block: calc(40 / 390 *100vw) calc(16 / 390 *100vw);
		transition-delay: 1.2s !important;
    }
}

.html-anker.top-page .html-anker__item:not(:last-child) {
	margin-bottom: 16px;
}

@media screen and (max-width: 767px) { 
	.html-anker.top-page .html-anker__item:not(:last-child) { 
		margin-bottom: 24px; 
	}
}

.html-anker.top-page .html-anker__item ul {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(228px, 1fr));
	gap: 16px;
}
@media screen and (max-width: 767px) {
	.html-anker.top-page .html-anker__item ul {
		grid-template-columns: repeat(1, 1fr);
		gap: 0;
	}
}

.html-anker.top-page .html-anker__item li {
	display: flex;
}

.html-anker.top-page .html-anker__item a {
	flex-grow: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 49px;
	border: var(--fc-theme-1) 1px solid;
	text-align: center;
	font-size: 0.8125rem;
	line-height: 1.5;
	letter-spacing: 0.02em;
	color: var(--fc-theme-1);
	padding: .75em 30px;
	transition-property: all;
	transition-duration: 0.3s;
	background: url(/common_v2/img/icn_arrow.svg) right 15px center/11px 6px no-repeat;
}

@media print, screen and (min-width: 768px) {
	.html-anker.top-page .html-anker__item a:hover {
		text-decoration: none;
		color: var(--fc-theme-1);
		border: 1px solid  var(--fc-theme-1);
		background-color: var(--fc-theme-4); 
	}
}

@media screen and (max-width: 767px) {
	.html-anker.top-page .html-anker__item a {
		border: none;
		border-bottom: 1px solid #E8E8E8;
		justify-content: flex-start;
		text-align: left;
		font-size: 0.866666666rem;
		min-height: 51px;
		padding-left: 4px;
		background-position: right 9px center;
	}
}


/* ---------------------------------------------
*   Top Page
--------------------------------------------- */
/*  p-top-kv
--------------------------------------------- */
.p-top-kv {
    max-width: 1200px;
    display: grid;
    place-content: center;
    margin-inline: auto;
	padding-block: 80px;
    overflow: hidden;
    transition: background-color 0.3s;
    transition-delay: 0.8s !important;
}
.js-top-fv.is-fv-anime-start .p-top-kv {
    background-color: #fff;
}

@media screen and (max-width: 768px) {
    .p-top-kv {
		padding-block: calc(80 / 390 * 100vw) calc(40 / 390 * 100vw);
    }
}
.p-top-kv video {
    display: block;
    width: 100%;
}
.js-top-fv .p-top-kv video {
    opacity: 0;
    transform: translateY(50px);
    transition-delay: 0.8s !important;
}
.js-top-fv.is-fv-anime-start .p-top-kv video {
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.8s, opacity 1s;
}

@media screen and (min-width: 769px) {
	.p-top-kv + .html-anker {
		padding-top: 0;
    }
}

/*  p-top-statement
--------------------------------------------- */
.p-top-statement {
	padding-top: 216px;
    padding-bottom: 136px;
    opacity: 0;
    transition-delay: 0.8s !important;
}
@media screen and (max-width: 768px) {
    .p-top-statement {
        padding-block: calc(64 / 390 * 100vw) calc(100 / 390 * 100vw);
    }
}
@media screen and (max-width: 768px) {
    .p-top-statement {
        transition-delay: 1s !important;
    }
}
.js-top-fv.is-fv-anime-start .p-top-statement {
    opacity: 1;
    transition: opacity 0.3s;
}

.p-top-statement__container {
    display: grid;
    grid-template-columns: calc(374 / 960 * 100%) auto;
	justify-content: space-between;
	gap: calc(58 / 960 * 100%);
}
@media screen and (max-width: 768px) {
    .p-top-statement__container {
        grid-template-columns: auto;
		gap: calc(48 / 390 * 100vw);
		justify-content: center;
    }
}

.p-top-statement__head {
    color: var(--fc-theme-1);
}
@media screen and (max-width: 768px) {
    .p-top-statement__head {
        text-align: center;
    }
}
.p-top-statement__ttl-sub {
    display: block;
    font-size: 1.125rem;
    font-weight: 700;
	line-height: 1.5;
    letter-spacing: 1.8px;
    opacity: 0;
    transform: translateY(50px);
    transition-delay: 0.4s !important;
}
@media screen and (max-width: 768px) {
    .p-top-statement__ttl-sub {
        font-size: 0.8666666rem;
		line-height: 1;
		letter-spacing: 0.49px;
    }
}
@media screen and (max-width: 768px) {
    .p-top-statement__ttl-sub {
        transition-delay: 1s !important;
    }
}
.js-anime-statement.is-active .p-top-statement__ttl-sub {
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.8s, opacity 1s;
}

.p-top-statement__ttl {
    margin-top: min(174px, calc(174 / 1200 * 100vw));
    opacity: 0;
    transform: translateY(50px);
    transition-delay: 0.6s !important;
}
@media screen and (max-width: 768px) {
    .p-top-statement__ttl {
        margin-top: calc(40 / 390 * 100vw);
		transition-delay: 1.2s !important;
		width: calc(250 / 390 * 100vw);
		margin-inline: auto;
    }
}

.js-anime-statement.is-active .p-top-statement__ttl {
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.8s, opacity 1s;
}

.p-top-statement__body {
    opacity: 0;
    transform: translateY(50px);
    transition-delay: 1s !important;
}
@media screen and (max-width: 768px) {
    .p-top-statement__body {
        transition-delay: 1.4s !important;
    }
}
.js-anime-statement.is-active .p-top-statement__body {
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.8s, opacity 1s;
}

.p-top-statement__txt {
	max-width: 470px;
}
@media screen and (max-width: 768px) {
    .p-top-statement__txt {
    }
}

/*  p-top-about
--------------------------------------------- */
.p-top-about {
    position: relative;
    z-index: 1;
    background: linear-gradient(90deg, rgb(66, 77, 153) 20%, rgb(81, 133, 197) 100%);
    color: #fff;
    padding-block: 136px 160px;
}
@media screen and (max-width: 768px) {
    .p-top-about {
        background: linear-gradient(90deg, rgb(63, 77, 158) 20%, rgb(81, 133, 197) 100%);
        padding-block: calc(64 / 390 *100vw) calc(100 / 390 *100vw);
    }
}
.p-top-about__ttl-sub {
    display: block;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 1.8px;
}
@media screen and (max-width: 768px) {
    .p-top-about__ttl-sub {
        font-size: 0.933333rem;
        text-align: center;
    }
}
@media screen and (min-width: 769px) {
    .p-top-about__ttl-sub {
        opacity: 0;
        transform: translateY(50px);
    }
    .js-anime-brand-pc.is-active .p-top-about__ttl-sub {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}
.p-top-about__ttl {
    margin-top: 72px;
	margin-bottom: 40px;
	max-width: 263px
}
@media screen and (max-width: 768px) {
    .p-top-about__ttl {
        margin-top: calc(40 / 390 *100vw);
		margin-bottom: calc(32 / 390 *100vw);
		max-width: calc(182 / 390 *100vw);
		margin-inline: auto;
    }
}
@media screen and (min-width: 769px) {
    .p-top-about__ttl {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 0.2s !important;
    }
    .js-anime-brand-pc.is-active .p-top-about__ttl {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}

.p-top-about__col {
    display: grid;
    grid-template-columns: calc(498 / 960 *100%) auto;
    -moz-column-gap: calc(40 /960 *100%);
         column-gap: calc(40 /960 *100%);
    align-items: flex-start;
    margin-top: 50px;
}
@media screen and (max-width: 768px) {
    .p-top-about__col {
       grid-template-columns: auto;
    }
}

.p-top-about__lead {
    line-height: 1.75;
    letter-spacing: 0.04em;
    text-align: justify;
}
@media screen and (min-width: 769px) {
    .p-top-about__lead {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 0.4s !important;
    }
    .js-anime-brand-pc.is-active .p-top-about__lead {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}

.p-top-about__box {
}
@media screen and (max-width: 768px) {
    .p-top-about__box {
        margin-top: calc(44 /390 * 100vw);
    }
}
@media screen and (min-width: 769px) {
    .p-top-about__box {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 0.6s !important;
    }
    .js-anime-brand-pc.is-active .p-top-about__box {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}

/*  p-top-promise
--------------------------------------------- */
.p-top-promise {
    margin-top: 88px;
}
@media screen and (max-width: 768px) {
    .p-top-promise {
        margin-top: calc(56 / 390 * 100vw);
    }
}
.p-top-promise__ttl {
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
    .p-top-promise__ttl {
        font-size: 0.866666rem;
		letter-spacing: 1.6px;
        text-align: center;
		line-height: 1.84615;
    }
}
@media screen and (min-width: 769px) {
    .p-top-promise__ttl {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 0.8s !important;
    }
    .js-anime-brand-pc.is-active .p-top-promise__ttl {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}
.p-top-promise__lead {
    margin-top: 20px;
    line-height: 1.75;
	letter-spacing: 0.04em;
	text-align: justify;
}
@media screen and (max-width: 768px) {
    .p-top-promise__lead {
        margin-top: calc(24 / 390 * 100vw);
    }
}
@media screen and (min-width: 769px) {
    .p-top-promise__lead {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 1s !important;
    }
    .js-anime-brand-pc.is-active .p-top-promise__lead {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}
.p-top-promise__video {
    margin-top: 48px;
}
@media screen and (max-width: 768px) {
    .p-top-promise__video {
        margin-top: calc(32 / 390 * 100vw);
    }
}
@media screen and (min-width: 769px) {
    .p-top-promise__video {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 1.2s !important;
    }
    .js-anime-brand-pc.is-active .p-top-promise__video {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}
.p-top-promise__video iframe {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: 16/9;
}

/*  p-top-solution
--------------------------------------------- */
.p-top-solution {
    --delay: .2s;
    padding-block: 136px;
    /* animation */
}
@media screen and (max-width: 768px) {
    .p-top-solution {
        padding-block: calc(64 / 390 *100vw) calc(100 / 390 *100vw);
    }
}
@media screen and (min-width: 769px) {
    .p-top-solution__anime-target-pc {
        opacity: 0;
        transform: translateY(50px);
    }
    .js-anime-solution-pc.is-active .p-top-solution__anime-target-pc {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}
.p-top-solution__head {
}
@media screen and (max-width: 768px) {
    .p-top-solution__head {
    }
}
.p-top-solution__ttl-sub {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--fc-theme-1);
	letter-spacing: 1.8px;
}
@media screen and (max-width: 768px) {
    .p-top-solution__ttl-sub {
        font-size: 0.933333rem;
        text-align: center;
		line-height: 1.92857;
    }
}
.p-top-solution__ttl {
	margin-top: 72px;
	max-width: 674px;
    /* animation */
}
@media screen and (max-width: 768px) {
    .p-top-solution__ttl {
        margin-top: calc(40 / 390 *100vw);
		max-width: calc(252.34 / 390 *100vw);
		margin-inline: auto;
    }
}
@media screen and (min-width: 769px) {
    .p-top-solution__ttl {
        transition-delay: calc(var(--delay) * 2) !important;
    }
}
.p-top-solution__lead {
    margin-top: 40px;
	font-size: 1rem;
    line-height: 1.75;
	letter-spacing: 0.04em;
	text-align: justify;
    /* animation */
}
@media screen and (max-width: 768px) {
    .p-top-solution__lead {
        margin-top: calc(32 / 390 *100vw);
	}
	.letter-spacing-ajust-1 {
		letter-spacing: -0.01em;
	}
}
@media screen and (min-width: 769px) {
    .p-top-solution__lead {
        transition-delay: calc(var(--delay) * 3) !important;
    }
}
.p-top-solution__head-graph {
	max-width: 687.54px;
	margin-inline: auto;
    margin-top: 80px;
    /* animation */
}
@media screen and (max-width: 768px) {
    .p-top-solution__head-graph {
		max-width: calc(326 / 390 *100vw);
        margin-block: calc(48 / 390 *100vw);
	}
}
@media screen and (min-width: 769px) {
    .p-top-solution__head-graph {
        transition-delay: calc(var(--delay) * 5) !important;
    }
}

@media screen and (max-width: 768px) {
	.p-top-solution__head-graph_sp-text dt {
		margin-bottom: min(calc(20 / 390 *100vw), 20px);
		line-height: 1;
	}
	.p-top-solution__head-graph_sp-text dt img {
		width: auto;
		max-height: calc(20 / 390 *100vw);
	}
	.p-top-solution__head-graph_sp-text dd {
		line-height: 1.75;
		letter-spacing: 0.02em;
	}

	.p-top-solution__head-graph_sp-text dd:not(:last-of-type) {
		margin-bottom: min(calc(48 / 390 *100vw), 48px);
	}
}

/*  p-top-solution__body
--------------------------------------------- */
.p-top-solution__body {
    padding-top: 120px;
}
@media screen and (max-width: 768px) {
    .p-top-solution__body {
        padding-top: calc(100 / 390 *100vw);
    }
}
@media screen and (min-width: 769px) {
    .p-top-solution__btn-wrap {
        opacity: 0;
        transform: translateY(50px);
        transition-delay: 0.8s !important;
    }
    .is-active-2 .p-top-solution__btn-wrap {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}

.p-top-solution__btn {
    margin-top: 64px;
    margin-inline: auto;
}
@media screen and (max-width: 768px) {
    .p-top-solution__btn {
        margin-top: calc(64 / 390 *100vw);
        margin-bottom: calc(36 / 390 *100vw);
    }
    .p-top-solution-cassette--03 .p-top-solution__btn {
        margin-bottom: 0;
    }
}

/*  p-top-solution-cassette
--------------------------------------------- */
.p-top-solution-cassette:not(:last-of-type) {
	margin-bottom: 120px;
}
@media screen and (max-width: 768px) {
    .p-top-solution-cassette:not(:last-of-type) {
        margin-bottom: calc(36 / 390 *100vw);
    }
}

.p-top-solution-cassette--01 {
    --base-color: var(--fc-theme-2);
}
.p-top-solution-cassette--02 {
    --base-color: var(--fc-theme-3);
}
.p-top-solution-cassette--03 {
    --base-color: #0094a3;
}
.p-top-solution-cassette__ttl {
    padding-block: 8px;
    padding-left: 24px;
    font-size: 1.375rem;
    font-weight: 500;
    border-left: 2px solid var(--base-color);
    letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .p-top-solution-cassette__ttl {
        font-size: 1.2rem;
    }
}
.p-top-solution-cassette__body {
    padding-top: 40px;
}
@media screen and (max-width: 768px) {
    .p-top-solution-cassette__body {
        padding-top: calc(40 / 390 *100vw);
    }
}

/*  p-top-movie
--------------------------------------------- */
.p-top-movie {
	padding-bottom: 136px;
}
@media screen and (max-width: 768px) {
    .p-top-movie {
        padding-bottom: calc(100 / 390 *100vw);
    }
}

.p-top-movie__ttl-sub {
    font-size: 1.125rem;
    font-weight: 700;
	line-height: 1.5;
    color: var(--fc-theme-1);
	letter-spacing: 1.8px;
}
@media screen and (max-width: 768px) {
    .p-top-movie__ttl-sub {
        font-size: 0.8333333rem;
		line-height: 1.92857;
        text-align: center;
    }
}

.p-top-movie__ttl {
	margin-top: 56px;
	max-width: 242.32px;
	line-height: 1;
}
@media screen and (max-width: 768px) {
    .p-top-movie__ttl {
		margin-top: calc(40 / 390 *100vw);
		max-width: calc(166.19 / 390 *100vw);
		margin-inline: auto;
    }
}

/*  p-movie-list
--------------------------------------------- */
.p-movie-list {
	margin-top: 40px;
}
@media screen and (max-width: 768px) {
	.p-movie-list {
		margin-top: calc(40 / 390 *100vw);
	}
}

/*   c-card-list__body
--------------------------------------------- */
.c-card-list__body {
	display: block;
	font-size: 0.9375rem;
	line-height: 1.75;
	letter-spacing: 0.02em;
	padding-inline: 4px;
	margin-top: 1rem;
}

@media screen and (max-width: 767px) {
	.c-card-list__body {
		padding-inline: calc(24 / 390 *100vw);
		font-size: 1rem;
	}
}

.p-movie-list .c-card-list__item a:hover {
	text-decoration: underline 0.8px;
	text-underline-offset: 3px;	
}

@media screen and (max-width: 767px) {
	.p-movie-list .c-card-list__item:not(:last-child) {
		padding-bottom: calc(40 / 390 * 100vw);
	}
}

/*   u-over-scale-img
--------------------------------------------- */
.u-over-scale-img {
	display: block;
	overflow: hidden;
}

.u-over-scale-img img {
	width: 100%;
	transition-property: transform;
	transition-duration: 0.3s;
}

@media screen and (min-width: 768px) { 
	a:hover .u-over-scale-img img { transform: scale(1.1);
	}
}

/* ---------------------------------------------
*  p-top-news
--------------------------------------------- */
.p-top-news {
    background-color: #F5F5F6;
    padding-block: 120px;
}
@media screen and (max-width: 768px) {
    .p-top-news {
        padding-block: calc(64 / 390 *100vw) calc(100 / 390 *100vw);
    }
}

.p-top-news__ttl-sub {
    font-size: 1.125rem;
    font-weight: 700;
	line-height: 1.5;
    color: var(--fc-theme-1);
	letter-spacing: 1.8px;
}
@media screen and (max-width: 768px) {
    .p-top-news__ttl-sub {
        font-size: 0.933333rem;
        text-align: center;
    }
}

.p-top-news__ttl {
	margin-top: 56px;
	max-width: 114.96px;
	line-height: 1;
}
@media screen and (max-width: 768px) {
    .p-top-news__ttl {
		margin-top: calc(40 / 390 *100vw);
		max-width: calc(79.51 / 390 *100vw);
		margin-inline: auto;
    }
}

/*---------------------------------------------
*  p-region-topics
--------------------------------------------- */
.p-region-topics {
    padding-block: 80px 100px;
}
@media screen and (max-width: 768px) {
    .p-region-topics {
        padding-block: calc(48 / 390 *100vw) calc(100 / 390 *100vw);
    }
}
.p-region-topics__ttl {
    font-size: 1.75rem;
    font-weight: 500;
	line-height: 1.5;
    letter-spacing: 0.05em;
	margin-bottom: 16px;
}
@media screen and (max-width: 768px) {
    .p-region-topics__ttl {
        font-size: 1.466666rem;
		margin-bottom: 18px;
    }
}

/*  p-region-topics__btn
--------------------------------------------- */
.p-region-topics__btn {
	margin-top: 64px;
}
@media screen and (max-width: 767px) { 
	.p-region-topics__btn {
		margin-top: calc(64 / 390 * 100vw);
	}
}

.p-region-topics__btn .c-btn {
	margin-inline: auto;
}

/*  p-region-sec
--------------------------------------------- */
.p-region-sec {
    padding-block: 80px 100px;
}
@media screen and (max-width: 768px) {
    .p-region-sec {
        padding-block: calc(64 / 390 * 100vw) calc(100 / 390 * 100vw);
    }
}

@media screen and (max-width: 768px) {
    .p-region-sec--02 {
        padding-bottom: calc(100 / 390 * 100vw);
    }
}

.p-region-sec__ttl {
    font-size: 	1.75rem;
    font-weight: 500;
	line-height: 1.5;
    letter-spacing: 0.05em;
	margin-bottom: 24px;
	padding-inline: 8px;
}
@media screen and (max-width: 768px) {
    .p-region-sec__ttl {
        font-size: 1.466666rem;
		padding-inline: 0;
    }
}

.p-region-sec__lead {
	line-height: 1.75;
	letter-spacing: 0.04em;
	text-align: justify;
	padding-inline: 8px;
}

@media screen and (max-width: 768px) {
    .p-region-sec__lead {
        letter-spacing: 0.02em;
		padding-inline: 0;
    }
}


/*  p-region-solution
--------------------------------------------- */
.p-region-solution {
    margin-top: 40px;
    padding: 64px 48px 80px;
    background-color: #fff;
}
@media screen and (max-width: 768px) {
    .p-region-solution {
        margin-top: calc(40 / 390 * 100vw);
		width: calc(370 / 390 * 100vw);
		margin-inline: auto;
        padding: calc(30 / 390 * 100vw) 0 calc(34 / 390 * 100vw);
    }
}

.p-region-solution__ttl {
    font-size: 1.375rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .p-region-solution__ttl {
        font-size: 1.0666666rem;
		letter-spacing: 0.04em;
    }
}

.p-region-solution__img {
    margin-top: 64px;
	max-width: 810px;
	margin-inline: auto;
}
@media screen and (max-width: 768px) {
    .p-region-solution__img {
        margin-top: calc(22 / 390 * 100vw);
    }
}

.p-region-solution__img img {
    width: 100%;
}

/*  p-region-values
--------------------------------------------- */
.p-region-values__img {
	margin-top: 44px;
	max-width: 820px;
	margin-inline: auto;
}
@media screen and (max-width: 768px) {
    .p-region-values__img {
		margin-top: calc(40 / 390 * 100vw);
        max-width: calc(290 / 390 * 100vw);
    }
}

/*  p-region-cassette
--------------------------------------------- */
.p-region-cassette-wrap {
    margin-top: 80px;
}
@media screen and (max-width: 768px) {
    .p-region-cassette-wrap {
		margin-top: calc(64 / 390 * 100vw);
    }
}

.p-region-cassette:not(:first-of-type) {
    margin-top: 80px;
}
@media screen and (max-width: 768px) {
    .p-region-cassette:not(:first-of-type) {
        margin-top: calc(48 / 390 * 100vw);
    }
}

.p-region-cassette__col {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
@media screen and (max-width: 768px) {
    .p-region-cassette__col {
        display: block;
    }
}

.p-region-cassette--01 .p-region-cassette__col {
    background-color: #D2D3EA;
}
.p-region-cassette--02 .p-region-cassette__col {
    background-color: #B8D3D9;
}
.p-region-cassette--03 .p-region-cassette__col {
    background-color: #B6D6F1;
}

.p-region-cassette__col-img {
    max-height: 720px;
}
.p-region-cassette__col-img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
}

.p-region-cassette__col-head {
	padding-inline: clamp(32px, 5.83333vw, 56px);
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	overflow: hidden;
}

.p-region-cassette__col-head:after {
	content: "";
	position: absolute;
	top: -40px;
	right: -30px;
	width: clamp(206px, 26.38vw, 380px);
	height: clamp(206px, 26.38vw, 380px);
}
.p-region-cassette--01 .p-region-cassette__col-head:after {
	background: url(/region/img/icn_value_cassette01.svg) no-repeat center / contain;
}
.p-region-cassette--02 .p-region-cassette__col-head:after {
	background: url(/region/img/icn_value_cassette02.svg) no-repeat center / contain;
}
.p-region-cassette--03 .p-region-cassette__col-head:after {
	background: url(/region/img/icn_value_cassette03.svg) no-repeat center / contain;
}
@media screen and (max-width: 768px) {
	.p-region-cassette__col-head {
		padding: calc(34 / 390 * 100vw) calc(32 / 390 * 100vw);
	}
    .p-region-cassette__col-head:after {
        top: -20px;
		right: -10px;
		width: clamp(140px, calc(206 / 390 * 100vw), 206px);
		height: clamp(140px, calc(206 / 390 * 100vw), 206px);
    }
}

.p-region-cassette__col-ttl {
    font-size: 1.375rem;
    font-weight: 500;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .p-region-cassette__col-ttl {
        font-size: 1.2rem;
    }
}

.p-region-cassette__col-txt {
    padding-top: 1.5rem;
    line-height: 1.75;
	letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
    .p-region-cassette__col-txt {
		letter-spacing: 0.02em;
    }
}

/* ---------------------------------------------
*   background-color
--------------------------------------------- */
.bg-white {
    background-color: #fff !important;
}

.bg-gray {
    background-color: #F5F5F6 !important;
}

/* ---------------------------------------------
*   font-wight
--------------------------------------------- */
.fw-normal {
    font-weight: 500 !important;
}

.fw-bold {
    font-weight: 700 !important;
}

/* ---------------------------------------------
*   font
--------------------------------------------- */
.ff-serif {
    font-family: "Noto Serif JP", serif !important;
}

/* ---------------------------------------------
*   text-align
--------------------------------------------- */
.txt-al-center {
    text-align: center !important;
}

.txt-al-right {
    text-align: right !important;
}

.txt-al-left {
    text-align: left !important;
}

/* ---------------------------------------------
*   block-align
--------------------------------------------- */
.block-align-right {
    margin-left: auto !important;
}

/* ---------------------------------------------
*   scroll animation
--------------------------------------------- */
/* フェードインアップ */
.js-fadein-up {
    opacity: 0;
    transform: translateY(50px);
}
.js-fadein-up.is-active {
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.8s, opacity 1s;
}

@media screen and (max-width: 768px) {
    .js-fadein-up-sp {
        opacity: 0;
        transform: translateY(50px);
    }
    .js-fadein-up-sp.is-active {
        transform: translateY(0);
        opacity: 1;
        transition: transform 0.8s, opacity 1s;
    }
}

.js-fadein-up-2 {
    opacity: 0;
    transform: translateY(50px);
}
.js-fadein-up-2.is-active {
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.8s, opacity 1s;
}

@media print and (min-width: 769px), screen and (min-width: 769px) {
    .pc-hide {
        display: none !important;
    }
}
@media print and (max-width: 768px), screen and (max-width: 768px) {
    .sp-hide {
        display: none !important;
    }
}

/* ---------------------------------------------
*   error PAGE
--------------------------------------------- */
.c-box-error {
    background-color: #F5F5F6;
}

.c-box-error__inner {
    max-width: 990px;
    margin-inline: auto;
	padding-inline: 15px;
	padding-block: 80px 100px;
}

@media screen and (max-width: 768px) {
    .c-box-error__inner {
        width: calc(350 / 390 * 100vw);
		padding-inline: 0;
		padding-block: calc(32 / 390 * 100vw);
    }
}

.c-block-error {
    background-color: #fff;
    border-radius: 12px;
	padding: clamp(48px, 7.55208vw, 72.5px) clamp(48px, 7.5vw, 72px);
}

@media screen and (max-width: 768px) {
    .c-block-error {
        border-radius: 8px;
		padding: calc(40 / 390 * 100vw) calc(24 / 390 * 100vw) calc(56 / 390 * 100vw); 
    }
}

.c-block-error__inner {
	min-height: 325px;
}
@media screen and (max-width: 768px) {
    .c-block-error__inner {
        min-height: auto;
    }
}

.c-block-error__ttl {
    font-size: 1.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--fc-theme-1);
}

@media screen and (max-width: 768px) {
    .c-block-error__ttl {
        font-size: 1.466666rem;
    }
}

.c-block-error__txt {
    margin-top: 32px;
    line-height: 2;
	letter-spacing: 0.04em;
}

@media screen and (max-width: 768px) {
    .c-block-error__txt {
		margin-top: 28px;
		letter-spacing: 0.02em;
    }
}

.c-block-error__note {
	color: #666666;
    line-height: 2;
	letter-spacing: 0.04em;
    margin-top: 56px;
}

@media screen and (max-width: 768px) {
    .c-block-error__note {
		margin-top: 32px;
		letter-spacing: 0.02em;
	}
}

.c-block-error__note-txt {
    line-height: 2;
	letter-spacing: 0.04em;
}

@media screen and (max-width: 768px) {
    .c-block-error__note-txt {
		letter-spacing: 0.02em;
    }
}


/* ---------------------------------------------
*   news-sec
--------------------------------------------- */
.news-sec:nth-child(n+2)  {
    margin-top: 80px;
}
@media screen and (max-width: 768px) {
    .news-sec:nth-child(n+2)  {
        margin-top: calc(64 / 390 * 100vw);
    }
	.html-anker + .news-sec  {
        margin-top: calc(48 / 390 * 100vw);
    }

}

.news-block {
}

.news-year {
	width: 100%;
    font-size: 1.75rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.05em;
	margin-bottom: 56px;
	padding-left: 8px;
}
@media screen and (max-width: 768px) {
    .news-year {
        font-size: 1.466666rem;
		margin-bottom: calc(18 / 390 * 100vw);
		padding-left: 0;
    }
}

.news__group {
	display: grid;
	grid-template-columns: 156px 1fr;
	border-top: 0.6px solid #ccc;
	margin-bottom: 24px;
}
@media (max-width: 768px) {
	.news__group {
		grid-template-columns: 1fr;
		border-top: 0;
		margin-bottom: 8px;
	}
}
.news__group:last-of-type {
	margin-bottom: 0;
}

.news-month {
    font-size: 1.375rem;
	font-weight: 400;
	line-height: 1.2;
	letter-spacing: 0.02em;	
	padding: 2rem 1rem 1rem;
}
@media screen and (max-width: 768px) {
    .news-month {
        font-size: 1.2rem;
		font-weight: 500;
		line-height: 1;
		letter-spacing: 0.04em;
		border-bottom: 0.6px solid #ccc;
		padding: 22px 4px 24px 4px;
    }
}


/*  news__list
--------------------------------------------- */
.news__list {}

.news__item {
	display: grid;
	grid-template-columns: 166px 1fr;
	align-items: flex-start;
	padding-block: 1rem;
}
@media screen and (max-width: 768px) {
    .news__item {
		grid-template-columns: 1fr;
		padding: 23px 4px;
    }
    .news__item:last-child {
		border-bottom: 0;
    }
}

.news__item + .news__item {
	border-top: 0.6px solid #ccc;
}

.news-date {
	color: #666;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.04em;
	padding: 1rem;
	padding-right: 0;
}
@media screen and (max-width: 768px) {
    .news-date {
		line-height: 1;
		padding: 0;
    }
}

.news-title {
	padding: 1rem;
}
@media screen and (max-width: 768px) {
    .news-title {
		padding: 0;
		padding-top: 12px;		
    }
}

.news-title a:hover {
	text-decoration: underline 0.8px;
	text-underline-offset: 3px;	
}

/*  p-news__btn
--------------------------------------------- */
.p-news__btn .c-btn {
    margin-inline: auto;
	margin-block: clamp(64px, 8.3333vw, 80px) clamp(80px, 10.041666vw, 100px);
}


/* ---------------------------------------------
*   p-topics　トピックスページ
--------------------------------------------- */

/*   l-main__lowerlayer
--------------------------------------------- */
.l-main__lowerlayer {
	display: grid;
	grid-template-areas:
		"breadcrumb"
		"pagetitle"
		"contents";
}

.l-breadcrumb { grid-area: breadcrumb; }
.c-heading-title { grid-area: pagetitle; }
.l-contents { grid-area: contents; }

@media (max-width: 768px) {
	.l-main__lowerlayer {
		grid-template-areas:
			"pagetitle"
			"contents"
			"breadcrumb"
	}	
}

@media (min-width: 769px) {
	.l-main__lowerlayer .l-breadcrumb__inner {
		padding-top: 20px;
	}
}

/*  c-heading-title
--------------------------------------------- */
.c-heading-title {
	background-color: #F5F5F6;
}
.c-heading-title__inner {
	max-width: 960px;
	margin-inline: auto;
	min-height: 238px;
	display: flex;
	justify-content: flex-end;
	flex-direction: column;
	gap: 24px;
	padding: 40px 15px 56px 0;
}
@media screen and (max-width: 768px) {
    .c-heading-title__inner {
		max-width: calc(342 / 390 * 100vw);
		min-height: calc(143 / 390 * 100vw);
		gap: calc(16 / 390 * 100vw); 
        padding: 20px 0 28px;
	}
}
@media screen and (max-width: 975px) and (min-width: 767px) {
    .c-heading-title__inner {
        padding-inline: 15px;
	}
}

.c-heading-title__txt {
	font-weight: 500;
    font-size: 2.5em;
    line-height: 1.6;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .c-heading-title__txt {
        font-size: 1.733333rem;
		line-height: 1.5;
    }
}

/* ---------------------------------------------
*   topics-sec
--------------------------------------------- */
.topics-sec {
    margin-top: 80px;
}
@media screen and (max-width: 768px) {
    .topics-sec {
        margin-top: calc(64 / 390 * 100vw);
    }
}

.topics-year {
	width: 100%;
    font-size: 1.75rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.05em;
	margin-bottom: 56px;
	padding-left: 8px;
}
@media screen and (max-width: 768px) {
    .topics-year {
        font-size: 1.466666rem;
		margin-bottom: calc(18 / 390 * 100vw);
		padding-left: 0;
    }
}

.topics__group {
	display: grid;
	grid-template-columns: clamp(80px, 10.5vw, 156px) 1fr;
	border-top: 0.6px solid #ccc;
	margin-bottom: 24px;
}
@media (max-width: 768px) {
	.topics__group {
		grid-template-columns: 1fr;
		border-top: 0;
		margin-bottom: 8px;
	}
}
.topics__group:last-of-type {
	margin-bottom: 0;
}

.topics-month {
    font-size: 1.375rem;
	font-weight: 400;
	line-height: 1.2;
	letter-spacing: 0.02em;	
	padding: 2rem 1rem 1rem;
}
@media screen and (max-width: 768px) {
    .topics-month {
        font-size: 1.2rem;
		font-weight: 500;
		line-height: 1;
		letter-spacing: 0.04em;
		border-bottom: 0.6px solid #ccc;
		padding: 22px 4px 24px 4px;
    }
}

/*  topics__list
--------------------------------------------- */
.topics__list {}

.topics__item {
	display: grid;
	grid-template-columns: 150px 116px 1fr;
	align-items: center;
	column-gap: 16px;
	padding: 16px;
}
@media (max-width: 768px) {
	.topics__item {
		grid-template-columns: 120px 1fr;
		grid-template-areas:
			"col1 col2"
			"col3 col3";
		gap: 12px 8px;
		padding: 16px 4px 24px;
		padding-right: 0;
	}
	.topics__item > :nth-child(1) {
    	grid-area: col1;
	}
	.topics__item > :nth-child(2) {
    	grid-area: col2;
	}
	.topics__item > :nth-child(3) {
		grid-area: col3;
	}
	.topics__item:last-child {
    	border-bottom: 0;
  	}
}

.topics__item + .topics__item {
	border-top: 0.6px solid #ccc;
}

.topics-date {
	color: #666;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
    .topics-date {
		line-height: 1;
    }
}

.topics-title {
	padding-block: 1rem;
}
@media screen and (max-width: 768px) {
    .topics-title {
		padding: 0;
		padding-right: 4px;
    }
}

.topics-title a:hover {
	text-decoration: underline 0.8px;
	text-underline-offset: 3px;	
}

/*  p-topics__btn
--------------------------------------------- */
.p-topics__btn .c-btn {
    margin-inline: auto;
	margin-block: clamp(64px, 8.3333vw, 80px) clamp(80px, 12.5vw, 120px);
}
@media screen and (max-width: 768px) {
    .p-topics__btn .c-btn {
		margin-block: calc(64 / 390 * 100vw) calc(100 / 390 * 100vw);
    }
}


/* ---------------------------------------------
*   topics-sec-detail
--------------------------------------------- */
.topics-sec-detail {
    margin-top: 48px;
}
@media screen and (max-width: 768px) {
    .topics-sec-detail {
        margin-top: calc(36 / 390 * 100vw);
    }
}

/*  p-topics-detail__btn
--------------------------------------------- */
.p-topics-detail__btn {
	margin-block: clamp(64px, 8.3333vw, 80px) clamp(80px, 12.5vw, 120px);
}
.p-topics-detail__btn .c-btn + .c-btn {
    margin-top: 24px;
}
.p-topics-detail__btn .c-btn {
	margin-inline: auto;
}

@media screen and (max-width: 768px) {
    .p-topics-detail__btn {
		margin-block: calc(52 / 390 * 100vw) calc(100 / 390 * 100vw);
    }
}

/*   p-topics-data
--------------------------------------------- */
.p-topics-data {
	text-align: right;
	letter-spacing: 0.02em;
	margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
    .p-topics-data {
        margin-bottom: calc(24 / 390 * 100vw);
    }
}

/*   p-topics__body
--------------------------------------------- */
.p-topics__body:not(:last-of-type) {
	margin-bottom: 160px;
}
@media screen and (max-width: 768px) {
    .p-topics__body:not(:last-of-type) {
        margin-bottom: calc(100 / 390 * 100vw);
    }
}

.p-topics__body > p:not(:first-of-type) {
	padding-top: 1.625em;
}

.p-topics__body p {
	font-size: 1rem;
	line-height: 1.75;
	letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
    .p-topics__body p {
		letter-spacing: 0.02em;
    }
}

/*   c-topics_title__lv2
--------------------------------------------- */
.c-topics_title__lv2 {
	font-size: 1.75rem;
	font-weight: 500;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .c-topics_title__lv2 {
        font-size: 1.466666rem;
    }
}

/*   c-topics_title__lv3
--------------------------------------------- */
.c-topics_title__lv3 {
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
    .c-topics_title__lv3 {
        font-size: 1.066666rem;
    }
}

/*   c-topics_title__line
--------------------------------------------- */
.c-topics_title__line {
	font-size: 1.375rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.05em;
	padding-bottom: 20px;
	border-bottom: 1px solid #CCCCCC;
	margin-bottom: 24px;
}
@media screen and (max-width: 768px) {
    .c-topics_title__line {
        font-size: 1.2rem;
		padding-bottom: 16px;
		margin-bottom: calc(20 / 390 * 100vw);
    }
}

/*   p-topics-figure
--------------------------------------------- */
.p-topics-figure {
}

.p-topics-figure .p-topics__img {
	max-width: 650px;
	margin-inline: auto;
}

@media (max-width: 768px) {
	.p-topics-figure .p-topics__img {
		max-width: 264px;
		margin-top: 8px;
	}
}

.p-topics__img figcaption {
	font-size: 0.875rem;
	letter-spacing: 0.02em;
	margin-top: 16px;
}
@media screen and (max-width: 768px) {
    .p-topics__img figcaption {
        font-size: 0.86666rem;
		margin-top: 8px;
    }
}

/*   p-topics-figure__2columns
--------------------------------------------- */
.p-topics-figure__2columns {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	justify-content: center;
	gap: 80px;
}
.p-topics-figure__2columns .p-topics__img {
	max-width: 328px;
	display: flex;
	flex-direction: column;
}

@media screen and (max-width: 768px) {
    .p-topics-figure__2columns {
        grid-template-columns: 100%;
		gap: calc(48 / 390 * 100vw);
    }
    .p-topics-figure__2columns .p-topics__img {
		max-width: 280.53px;
        margin-inline: auto;
    }
}

.p-topics-figure__2columns > :nth-child(1) {
	justify-self: end;
}
.p-topics-figure__2columns > :nth-child(2) {
	justify-self: start;
}

.p-topics__img picture {
	margin-top: auto;
}

.p-topics__img img {
	max-width: 100%;
	width: auto;
	height: auto;
	display: block;
}

/*   p-topics__c-list-notes
--------------------------------------------- */
.p-topics__c-list-notes {
	font-size: 0.875rem;
	letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
    .p-topics__c-list-notes {
        font-size: 0.86666rem;
		line-height: 1.75;
    }
}

.p-topics__c-list-notes-item {
	display: grid;
	grid-template-columns: auto 1fr;
	column-gap: 0.5em;
}

.notes-mark {
	white-space: nowrap;
}

.p-topics__c-list-notes-item:not(:first-of-type) {
	margin-top: 16px;
}
@media screen and (max-width: 768px) {
    .p-topics__c-list-notes-item:not(:first-of-type) {
		margin-top: calc(24 / 390 * 100vw);
    }
}
	
@media screen and (max-width: 768px) {
    .p-topics__c-list-notes-item span > a {
		display: inline-block;
    }
	.p-topics__c-list-notes-item span > a:not(:first-of-type) {
		padding-top: 8px;
	}
}

/*   p-topics-text-link
--------------------------------------------- */
.p-topics-text-link {
	text-decoration: underline 0.8px;
	text-underline-offset: 3px;
}

.p-topics-text-link:hover {
	text-decoration: none;
}

/*   table-data-list
--------------------------------------------- */
.table-data-list dl {
	display: grid;
	grid-template-columns: 130px 1fr;
	border-bottom: 0.6px solid #cccccc;
}

.table-data-list dt {
	color: #666666;
	letter-spacing: 0.04em;
	padding: 32px 0 32px 8px;
}
.table-data-list dd {
	letter-spacing: 0.02em;
	padding: 32px 0 32px 32px;
}

@media screen and (max-width: 768px) {
    .table-data-list dl {
		grid-template-columns: 100%;
		gap: 12px;
    }
    .table-data-list dt {
		line-height: 1;
		padding: 20px 0 0 4px;
    }
    .table-data-list dd {
		padding: 0 0 24px 4px;
		
    }
}

/*   table-type-1
--------------------------------------------- */
.table-type-1 {}

.table-type-1 th {
	letter-spacing: 0.04em;
}
.table-type-1 td {
	letter-spacing: 0.02em;
}

@media (min-width: 767px) {
	.table-type-1 th.head-title {
		background: var(--fc-theme-1);
		color: #fff;
		text-align: center;
		padding: 16px;
	}
	.table-type-1 th {
		background: var(--fc-theme-4);
		padding: 32px 20px;
		width: calc(160 / 960 * 100%);
	}
	.table-type-1 td {
		padding: 32px 20px;
	}
	.table-type-1 tbody tr {
		border-bottom: 0.6px solid #ccc;
	}
	.table-type-1 th.head-title:not(:first-of-type) {
		border-left: 1px solid #ffffff;
	}
}

@media (max-width: 768px) {
	.table-type-1 table,
	.table-type-1 thead,
	.table-type-1 tbody,
	.table-type-1 tr,
	.table-type-1 th,
	.table-type-1 td {
		display: block;
		width: 100%;
	}
	.table-type-1 thead tr {
		display: none;
	}
	
	.table-type-1 tbody th {
		background: var(--fc-theme-1);
		color: #ffffff;
		text-align: center;
		padding: 8px 12px;
	}

	.table-type-1 tbody td {
		display: grid;
		grid-template-columns: calc(126 / 342 * 100%) 1fr;
		align-items: center;
	}
	
	.table-type-1 tbody td::before {
		content: attr(data-label);
		background: var(--fc-theme-4);
		padding: 12px;
	}
	.table-type-1 tbody td span {
		padding: 12px;
	}
	.table-type-1 tbody td {
		border-bottom: 0.6px solid #ccc;
	}
}

/*   table-type-2
--------------------------------------------- */
@media (min-width: 767px) {
	.table-type-2 {
		border-top: 0.6px solid #ccc;
	}

	.table-type-2 th {
		letter-spacing: 0.04em;
	}
	.table-type-2 td {
		letter-spacing: 0.02em;
	}

	.table-type-2 th {
		background: var(--fc-theme-4);
		padding: 24px 20px;
		width: calc(160 / 960 * 100%);
	}
	.table-type-2 td {
		padding: 24px 20px;
	}
	.table-type-2 tbody tr {
		border-bottom: 0.6px solid #ccc;
	}
}

@media (max-width: 768px) {
	.table-type-2 table,
	.table-type-2 tbody,
	.table-type-2 tr,
	.table-type-2 th,
	.table-type-2 td {
		display: block;
		width: 100%;
	}
	.table-type-2 th {
		background: var(--fc-theme-4);
		padding: 8px 12px;
		letter-spacing: 0.02em;
	}
	.table-type-2 td {
		padding: 12px;
		letter-spacing: 0.02em;
	}
}


/* ---------------------------------------------
*   sup , sub (topics)
--------------------------------------------- */
.p-topics__body sup {
    font-size: 75%;
	top: -0.5em;
}

.p-topics__body sub {
    font-size: 75%;
}

/* ---------------------------------------------
*   line-height
--------------------------------------------- */
.lineheight175 {
	line-height: 1.75!important;
}

/* ---------------------------------------------
*   margin-top
--------------------------------------------- */
.mgt-pc--0 {
    margin-top: 0 !important;
}

.mgt-pc--4 {
    margin-top: 4 !important;
}

.mgt-pc--8 {
    margin-top: 8px !important;
}

.mgt-pc--16 {
    margin-top: 16px !important;
}

.mgt-pc--24 {
    margin-top: 24px !important;
}

.mgt-pc--32 {
    margin-top: 32px !important;
}

.mgt-pc--40 {
    margin-top: 40px !important;
}

.mgt-pc--48 {
    margin-top: 48px !important;
}

.mgt-pc--56 {
    margin-top: 56px !important;
}

.mgt-pc--64 {
    margin-top: 64px !important;
}

.mgt-pc--72 {
    margin-top: 72px !important;
}

.mgt-pc--80 {
    margin-top: 80px !important;
}

.mgt-pc--100 {
    margin-top: 100px !important;
}

.mgt-pc--120 {
    margin-top: 120px !important;
}

.mgt-pc--160 {
    margin-top: 160px !important;
}

@media screen and (max-width: 768px) {
    .mgt-sp--0 {
        margin-top: 0 !important;
    }
    .mgt-sp--4 {
        margin-top: calc(4 / 390 * 100vw) !important;
    }
    .mgt-sp--8 {
        margin-top: calc(8 / 390 * 100vw) !important;
    }
    .mgt-sp--16 {
        margin-top: calc(16 / 390 * 100vw) !important;
    }
    .mgt-sp--24 {
        margin-top: calc(24 / 390 * 100vw) !important;
    }
    .mgt-sp--32 {
        margin-top: calc(32 / 390 * 100vw) !important;
    }
    .mgt-sp--40 {
        margin-top: calc(40 / 390 * 100vw) !important;
    }
    .mgt-sp--48 {
        margin-top: calc(48 / 390 * 100vw) !important;
    }
    .mgt-sp--56 {
        margin-top: calc(56 / 390 * 100vw) !important;
    }
    .mgt-sp--64 {
        margin-top: calc(64 / 390 * 100vw) !important;
    }
    .mgt-sp--72 {
        margin-top: calc(72 / 390 * 100vw) !important;
    }
    .mgt-sp--80 {
        margin-top: calc(80 / 390 * 100vw) !important;
    }
    .mgt-sp--100 {
        margin-top: calc(100 / 390 * 100vw) !important;
    }
    .mgt-sp--120 {
        margin-top: calc(120 / 390 * 100vw) !important;
    }
    .mgt-sp--160 {
        margin-top: calc(160 / 390 * 100vw) !important;
    }
}
/* ---------------------------------------------
*   margin-bottom
--------------------------------------------- */
.mgb-pc--0 {
    margin-bottom: 0 !important;
}

.mgb-pc--4 {
    margin-bottom: 4px !important;
}

.mgb-pc--8 {
    margin-bottom: 8px !important;
}

.mgb-pc--16 {
    margin-bottom: 16px !important;
}

.mgb-pc--24 {
    margin-bottom: 24px !important;
}

.mgb-pc--32 {
    margin-bottom: 32px !important;
}

.mgb-pc--40 {
    margin-bottom: 40px !important;
}

.mgb-pc--48 {
    margin-bottom: 48px !important;
}

.mgb-pc--56 {
    margin-bottom: 56px !important;
}

.mgb-pc--64 {
    margin-bottom: 64px !important;
}

.mgb-pc--72 {
    margin-bottom: 72px !important;
}

.mgb-pc--80 {
    margin-bottom: 80px !important;
}

.mgb-pc--100 {
    margin-bottom: 100px !important;
}

.mgb-pc--120 {
    margin-bottom: 120px !important;
}

.mgb-pc--160 {
    margin-bottom: 160px !important;
}

@media screen and (max-width: 768px) {
    .mgb-sp--0 {
        margin-bottom: 0 !important;
    }
    .mgb-sp--4 {
        margin-bottom: calc(4 / 390 * 100vw) !important;
    }
    .mgb-sp--8 {
        margin-bottom: calc(8 / 390 * 100vw) !important;
    }
    .mgb-sp--16 {
        margin-bottom: calc(16 / 390 * 100vw) !important;
    }
    .mgb-sp--24 {
        margin-bottom: calc(24 / 390 * 100vw) !important;
    }
    .mgb-sp--32 {
        margin-bottom: calc(32 / 390 * 100vw) !important;
    }
    .mgb-sp--40 {
        margin-bottom: calc(40 / 390 * 100vw) !important;
    }
    .mgb-sp--48 {
        margin-bottom: calc(48 / 390 * 100vw) !important;
    }
    .mgb-sp--56 {
        margin-bottom: calc(56 / 390 * 100vw) !important;
    }
    .mgb-sp--64 {
        margin-bottom: calc(64 / 390 * 100vw) !important;
    }
    .mgb-sp--72 {
        margin-bottom: calc(72 / 390 * 100vw) !important;
    }
    .mgb-sp--80 {
        margin-bottom: calc(80 / 390 * 100vw) !important;
    }
    .mgb-sp--100 {
        margin-bottom: calc(100 / 390 * 100vw) !important;
    }
    .mgb-sp--120 {
        margin-bottom: calc(120 / 390 * 100vw) !important;
    }
    .mgb-sp--160 {
        margin-bottom: calc(160 / 390 * 100vw) !important;
    }
}
