/*------------------------------------------------------------------------------------*/
/* style.css                                                                          */
/*------------------------------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");

html {
    position: relative;
    height: 100%;
}

body {
    margin: 0;
    padding: 0;
    font-family: "Noto Sans JP", apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    height: 100%;
    position: relative;
    color: #2e2e2e;
	font-size: 16px;
	font-weight: 300;
	letter-spacing: 0.14em;
	line-height: 180%;
}

ul {
    padding-inline-start: 0px;
    margin: 0;
    padding: 0;
    list-style: none;
}

a {
    text-decoration: none;
}

h1,
h2,
h3,
h4,
h5 {
    margin: 0;
}

.none {
    display: none !important;
}

.center {
    text-align: center !important;
}

.inline-block {
    display: inline-block;
}

.content-inner {
    background-color: #eaeaea;
}

.content-inner-link {
    background-color: #edeff8;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.text-center {
	text-align: center;
}

.vertical-top {
    vertical-align: top;
}

.font-size-48 { 
	font-size: 48px; 
	line-height: 160%; 
	letter-spacing: 0.14em; 
	font-weight: 800;
}

.font-size-44 { 
	font-size: 44px; 
	line-height: 160%; 
	letter-spacing: 0.14em; 
	font-weight: 800;
}

.font-size-40 { 
	font-size: 40px; 
	line-height: 160%; 
	letter-spacing: 0.14em; 
	font-weight: 800;
}

.font-size-32 { 
	font-size: 32px; 
	line-height: 170%; 
	letter-spacing: 0.14em; 
	font-weight: 700;
}

.font-size-28 { 
	font-size: 28px; 
	line-height: 170%; 
	letter-spacing: 0.14em; 
	font-weight: 700;
}

.font-size-24 { 
	font-size: 24px; 
	line-height: 170%; 
	letter-spacing: 0.14em; 
	font-weight: 700;
}

.font-size-20 { 
	font-size: 20px; 
	line-height: 170%; 
	letter-spacing: 0.14em; 
	font-weight: 500;
}

.font-size-18 { 
	font-size: 18px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 500;
}

.font-size-16 { 
	font-size: 16px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-15 { 
	font-size: 15px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-14 { 
	font-size: 14px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-13 { 
	font-size: 13px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-12 { 
	font-size: 12px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-11 { 
	font-size: 11px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-10 { 
	font-size: 10px; 
	line-height: 180%; 
	letter-spacing: 0.14em; 
	font-weight: 300;
}

.font-size-8 { 
		font-size: 8px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
}



@media screen and (max-width: 768px) {
	.font-size-48 { 
		font-size: 32px; 
		line-height: 160%; 
		letter-spacing: 0.1em; 
		font-weight: 800;
	}

	.font-size-44 { 
		font-size: 30px; 
		line-height: 160%; 
		letter-spacing: 0.1em; 
		font-weight: 800;
	}

	.font-size-40 { 
		font-size: 26px; 
		line-height: 160%; 
		letter-spacing: 0.1em; 
		font-weight: 800;
	}

	.font-size-32 { 
		font-size: 22px; 
		line-height: 170%; 
		letter-spacing: 0.1em; 
		font-weight: 700;
	}

	.font-size-28 { 
		font-size: 20px; 
		line-height: 170%; 
		letter-spacing: 0.1em; 
		font-weight: 700;
	}

	.font-size-24 { 
		font-size: 18px; 
		line-height: 170%; 
		letter-spacing: 0.1em; 
		font-weight: 700;
	}

	.font-size-20 { 
		font-size: 16px; 
		line-height: 170%; 
		letter-spacing: 0.1em; 
		font-weight: 500;
	}

	.font-size-18 { 
		font-size: 16px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 500;
	}

	.font-size-16 { 
		font-size: 14px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}

	.font-size-15 { 
		font-size: 14px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}

	.font-size-14 { 
		font-size: 12px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}

	.font-size-13 { 
		font-size: 11px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}

	.font-size-12 { 
		font-size: 10px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}

	.font-size-11 { 
		font-size: 9px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}

	.font-size-10 { 
		font-size: 8px; 
		line-height: 180%; 
		letter-spacing: 0.1em; 
		font-weight: 300;
	}
	
	.font-size-8 { 
			font-size: 8px; 
			line-height: 180%; 
			letter-spacing: 0.1em; 
			font-weight: 300;
		}
}

.font-weight-light { 
	font-weight: 300;
}

.font-weight-middle { 
	font-weight: 500;
}

.font-weight-bold { 
	font-weight: 700;
}

.lt-s-half { 
	letter-spacing: 0.08em;
}

.lt-s-half { 
	letter-spacing: 0.08em;
}

.lt-s-price { 
	letter-spacing: 0;
}

.pc {
    display: block;
    width: 100%;
}
@media screen and (max-width: 768px) {
    .pc {
        display: none;
    }
}

.sp {
    display: none;
}
@media screen and (max-width: 768px) {
    .sp {
        display: block;
        width: 100%;
    }
}





/* button
-------------------------------------------------- */
.button {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    cursor: pointer;
    font-size: 14px;
    border-radius: 4px;
    box-sizing: border-box;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
}

.button-margin {
    margin: 0 8px;
}

.button-square {
    display: inline-block;
    cursor: pointer;
    width: 200px;
    padding: 8px 20px;
    text-align: center;
    font-size: 14px;
    text-decoration: none;
    border-radius: 8px;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
}

.button_reg-login {
    display: inline-block;
    cursor: pointer;
    width: calc(100% - 80px);
    height: 42px;
    padding: 0 20px;
    margin: 0 40px;
    text-align: center;
    font-size: 16px;
    font-family: inherit;
    color: #ffffff;
    text-decoration: none;
    border: none;
    border-radius: 30px;
    background-color: #5e6cef;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
}

@media screen and (max-width: 768px) {
    .button_reg-login {
        width: 100%;
        margin: 0;
    }
}

.button .button_flex {
    display: flex;
    justify-content: center;
    align-items: center;
}

.button .button_flex img {
    width: 16px;
    padding: 0 6px 2px 0;
}

.button .button_flex .p_button {
    margin: 0;
}

.button-small {
    cursor: pointer;
    padding: 0px 10px;
    font-size: 13px;
    width: auto;
}

.button-mini {
    cursor: pointer;
    padding: 3px 10px;
    font-size: 13px;
    width: auto;
}

.width-80 {
    width: 80px;
}

.width-120 {
    width: 120px;
}

.width-180 {
    width: 180px;
}

.width-240 {
    width: 240px;
}

.width-360 {
    width: 360px;
}

.height-40 {
    height: 40px;
}

.height-60 {
    height: 60px;
}

@media screen and (max-width: 768px) {
    .width-100-sp {
        width: 100px;
    }
}

@media screen and (max-width: 768px) {
    .button-delete {
        line-height: 1.2;
    }
}

/* button color
-------------------------------------------------- */
/* main color */
.button-color-main {
    background-color: #5e6cef;
    color: #ffffff;
    border: 3px solid #5e6cef;
}
.button-color-main:hover {
    background-position: right center;
    background-color: #8ca5ff;
    border: 3px solid #8ca5ff;
}
/* invert */
.button-color-sub {
    border: 3px solid #5e6cef;
    background-color: #ffffff;
    color: #5e6cef;
}
.button-color-sub:hover {
    background-position: right center;
    border: 3px solid #8ca5ff;
    color: #8ca5ff;
}
/* yellow */
.button-color-yellow {
    background-color: #ffcd00;
    color: #2e2e2e;
    border: 3px solid #ffcd00;
}
.button-color-yellow:hover {
    background-position: right center;
    background-color: #ffdc4d;
    border: 3px solid #ffdc4d;
}
/* green */
.button-color-green {
    background-color: #3eccb6;
    color: #ffffff;
    border: 3px solid #3eccb6;
}
.button-color-green:hover {
    background-position: right center;
    background-color: #6ce2cf;
    border: 3px solid #6ce2cf;
}
.button-color-green-sub {
    background-color: #ffffff;
    color: #3eccb6;
    border: 3px solid #3eccb6;
}
.button-color-green-sub:hover {
    background-position: right center;
    color: #6ce2cf;
    border: 3px solid #6ce2cf;
}
/* red */
.button-color-red {
    background-color: #ff4671;
    color: #ffffff;
    border: 3px solid #ff4671;
}
.button-color-red:hover {
    background-position: right center;
    background-color: #ff7494;
    border: 3px solid #ff7494;
}
/* gray */
.button-color-gray {
    background-color: #b1b1b1;
    color: #ffffff;
    border: 3px solid #b1b1b1;
}
.button-color-gray:hover {
    background-position: right center;
    background-color: #cecece;
    border: 3px solid #cecece;
}

/* gray invert*/
.button-color-gray-sub {
    background-color: #ffffff;
    color: #b1b1b1;
    border: 3px solid #b1b1b1;
}
.button-color-gray-sub:hover {
    background-position: right center;
    color: #cecece;
    border: 3px solid #cecece;
}

/* unclickable */
.button-color-unclickable {
    background-color: #b1b1b1 !important;
    color: #ffffff !important;
    border: 3px solid #b1b1b1 !important;
    pointer-events: none !important;
}

/* fab
-------------------------------------------------- */
.fab {
    display: inline-block;
    width: 28px;
    height: 28px;
    background: #03a9f4;
    text-align: center;
    border-radius: 50%;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.12), 0 2px 2px 0 rgba(0, 0, 0, 0.24);
}

.fab:hover {
    box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
}

.fab i {
    color: white;
    line-height: 28px;
    font-size: 18px;
}

/* text
-------------------------------------------------- */

/* breadcrumb
-------------------------------------------------- */
#breadcrumbs-one {
    background: #eee;
    border-color: #f5f5f5 #e5e5e5 #ccc;
    overflow: hidden;
    width: 100%;
    font-size: 14px;
    border-radius: 8px 8px 0 0;
}

#breadcrumbs-one li {
    float: left;
}

#breadcrumbs-one a {
    padding: 0.7em 1em 0.7em 2em;
    float: left;
    text-decoration: none;
    color: #444;
    position: relative;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
    background-color: #ddd;
    background-image: linear-gradient(to right, #f5f5f5, #ddd);
}

#breadcrumbs-one li:first-child a {
    padding-left: 1em;
    border-radius: 5px 0 0 5px;
}

#breadcrumbs-one a:hover {
    background: #fff;
}

#breadcrumbs-one a::after,
#breadcrumbs-one a::before {
    content: "";
    position: absolute;
    top: 50%;
    margin-top: -1.5em;
    border-top: 1.5em solid transparent;
    border-bottom: 1.5em solid transparent;
    border-left: 1em solid;
    right: -1em;
}

#breadcrumbs-one a::after {
    z-index: 2;
    border-left-color: #ddd;
}

#breadcrumbs-one a::before {
    border-left-color: #ccc;
    right: -1.1em;
    z-index: 1;
}

#breadcrumbs-one a:hover::after {
    border-left-color: #fff;
}

#breadcrumbs-one .current,
#breadcrumbs-one .current:hover {
    font-weight: bold;
    background: none;
}

#breadcrumbs-one .current::after,
#breadcrumbs-one .current::before {
    content: normal;
}

/* flexbox
-------------------------------------------------- */
.flexbox {
    display: flex;
}

.space-between {
    justify-content: space-between;
}

.flex-cemter {
    align-items: center;
}

.flex-start {
    align-items: flex-start;
}

.fa-check-circle {
    color: #2ecc71;
}

.fa-exclamation-triangle {
    color: #ffbf00;
}

.fa-times-circle {
    color: #de3163;
}

/* banner
-------------------------------------------------- */
.notification-banner a {
    text-decoration: none;
}

.wrapper-banner {
    padding: 16px 0;
    background-color: #ffcd00;
    color: #2e2e2e;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
}

.wrapper-banner .inner-banner {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    width: 1000px;
}

@media screen and (max-width: 768px) {
    .wrapper-banner {
        padding: 10px 20px;
    }

    .wrapper-banner .inner-banner {
        width: 100%;
    }
}

.wrapper-banner .inner-banner .image img {
    width: 42px;
    height: 42px;
}

.wrapper-banner .inner-banner .paragraph p {
    margin: 0 10px;
    font-size: 18px;
    line-height: 1.4;
}

@media screen and (max-width: 768px) {
    .wrapper-banner .inner-banner .paragraph p {
        font-size: 14px;
        margin: 0 10px 0 15px;
    }
}

.wrapper-banner .inner-banner .button-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px;
    border-radius: 4px;
    background-color: #ffffff;
}

.wrapper-banner .inner-banner .button-icon span {
    font-size: 14px;
    margin: 0 4px 0 0;
}

.wrapper-banner .inner-banner .button-icon img {
    width: 16px;
    height: 16px;
}

@media screen and (max-width: 768px) {
    .wrapper-banner .inner-banner .button-icon {
        display: inline-block;
        padding: 4px 4px 8px 8px;
        width: 94px;
        line-height: 1;
    }

    .wrapper-banner .inner-banner .button-icon span {
        font-size: 12px;
        margin: 0;
    }

    .wrapper-banner .inner-banner .button-icon img {
        margin: 0 -2px -2px;
        width: 14px;
        height: 14px;
    }
}

/* banner bottom */
.wrapper-banner-bottom {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    padding: 16px;
    width: 768px;
    height: 100px;
    background-color: #ffcd00;
    color: #2e2e2e;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
}

.wrapper-banner-bottom .inner-banner-bottom {
    display: flex;
    justify-content: center;
    align-items: center;
}

@media screen and (max-width: 768px) {
    .wrapper-banner-bottom {
        padding: 10px 20px;
        width: calc(100% - 40px);
    }

    .wrapper-banner-bottom .inner-banner-bottom {
        width: 100%;
        height: auto;
        justify-content: space-between;
        flex-wrap: wrap;
    }
}

.wrapper-banner-bottom .inner-banner-bottom .image img {
    width: 42px;
    height: 42px;
}

.wrapper-banner-bottom .inner-banner-bottom .paragraph p {
    margin: 0 10px;
    font-size: 18px;
    line-height: 1.4;
}

@media screen and (max-width: 768px) {
    .wrapper-banner-bottom .inner-banner-bottom .paragraph {
        width: calc(100% - 48px);
    }

    .wrapper-banner-bottom .inner-banner-bottom .paragraph p {
        font-size: 16px;
        margin: 0 0 0 10px;
    }
}

.wrapper-banner-bottom .inner-banner-bottom .button-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px;
    border-radius: 4px;
    background-color: #ffffff;
}

.wrapper-banner-bottom .inner-banner-bottom .button-icon span {
    font-size: 14px;
    margin: 0 4px 0 0;
}

.wrapper-banner-bottom .inner-banner-bottom .button-icon img {
    width: 16px;
    height: 16px;
}

@media screen and (max-width: 768px) {
    .wrapper-banner-bottom .inner-banner-bottom .button-icon {
        display: block;
        margin: 8px 0 0 0;
        padding: 4px 4px 8px 8px;
        width: 100%;
        line-height: 1;
        text-align: center;
    }

    .wrapper-banner-bottom .inner-banner-bottom .button-icon span {
        font-size: 12px;
        margin: 0;
    }

    .wrapper-banner-bottom .inner-banner-bottom .button-icon img {
        margin: 0 -2px -2px;
        width: 14px;
        height: 14px;
    }
}
