@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');
@import url('https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanjp_s.css');

/* ========== ========== ==========
	Reset
========== ========== ========== */

html, body {
	margin: 0;
	padding: 0;
}
.l-wrapper, .l-wrapper *,
.l-wrapper *::before, .l-wrapper *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
.l-wrapper h1, .l-wrapper h2, 
.l-wrapper h3, .l-wrapper h4, 
.l-wrapper h5, .l-wrapper h6 {
    margin: 0;
    padding: 0;
}
.l-wrapper a {
    text-decoration: none;
}
.l-wrapper p {
    margin: 0;
    padding: 0;
}
.l-wrapper ul, .l-wrapper li {
    margin: 0;
    padding: 0;
    list-style: none;
}



/* ========== ========== ==========
	Default
========== ========== ========== */

:root {
    --color-primary: #be0125;
    --color-secondary: #003285;
    --color-black: #000000;
    --color-white: #ffffff;
    --color-text: #222222;
    --color-text-link: #003285;
    --color-red: #be0125;
    --color-blue: #003285;

    --color-primary-rgb: 190 1 37;
    --color-secondary-rgb: 0 50 133;
    --color-black-rgb: 0 0 0;
    --color-white-rgb: 255 255 255;
}
.l-wrapper, .l-wrapper * {
	font-family: YakuHanJPs, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-size: 16px;
	line-height: 1.75;
}
.l-wrapper a {
    font-size: inherit;
    text-decoration: none;
    transition: 0.2s;
}
.l-wrapper a:hover {
    opacity: 0.5;
}
.l-wrapper hr {
    margin: 2em 0;
    border: 0;
    border-top: 1px solid #cccccc;
}
.l-wrapper img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}
.l-wrapper p:not(:first-of-type) {
    margin-top: 1em;
}
.l-wrapper span {
    display: inline-block;
    font-size: inherit;
    text-decoration: inherit;
}
.l-wrapper .red {
    color: var(--color-primary);
    font-weight: bold;
}
.l-wrapper .small {
    font-size: 0.9em;
    font-weight: normal;
}
.l-wrapper .wavy {
    text-decoration: underline wavy;
    text-underline-offset: 0.5em;
}
.l-wrapper .sp_view {
    display: none;
}



/* ========== ========== ==========
	Layout
========== ========== ========== */

.l-wrapper {
    width: 100%;
    max-width: 1000px;
    margin: 2em auto 0;
}
.l-wrapper .l-section {
    margin-top: 4em;
}



/* ========== ========== ==========
	Component
========== ========== ========== */

/* Common */

.l-wrapper .c-btn {
    display: block;
    margin-top: 1em;
    padding: 1em;
    background: var(--color-primary) url(../images/icon_arrow02.png) right bottom no-repeat;
    border-radius: 3px;
    color: #ffffff;
    text-align: center;
}
.l-wrapper .c-text-link {
	color: var(--color-text-link);
	text-decoration: underline;
}
.l-wrapper .c-inline-img {
    height: 1.5em;
    vertical-align: middle;
}
.l-wrapper .c-header-yokoku {
    padding: 0.5em 1em;
    background-color: #be0125;
    color: var(--color-white);
    font-size: 1.25em;
    font-weight: bold;
    text-align: center;
}
.l-wrapper .c-home-ttl--h2 {
	margin-bottom: 1em;
	padding-left: 1em;
	background: url(../images/bg_main_h3.png) left center no-repeat;
	border-bottom: 2px solid var(--color-text);
	font-size: 1.5em;
	font-weight: bold;
}
.l-wrapper .c-home-ttl--h3 {
    margin-bottom: 2em;
    font-size: 1.5em;
    font-weight: bold;
    text-align: center;
}
.l-wrapper .c-home-ttl--h3 .inner {
    border-bottom: 2px solid var(--color-primary);
    color: var(--color-primary);
}
.l-wrapper .c-home-lede {
    margin-bottom: 2em;
    font-weight: bold;
}

/* c-header-notice */

.l-wrapper .c-header-notice {
    display: block;
    padding: 1em 4em 1em 2em;
    background: url(../images/bg_common.png) repeat;
    color: var(--color-white);
    text-align: center;
    position: relative;
}
.l-wrapper .c-header-notice::before {
    content: "";
    display: block;
    width: 1em;
    height: 1em;
    border: 0.25em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    color: var(--color-white);
    line-height: 1;
    position: absolute;
    right: 1em;
    top: 50%;
    transform: translate(-25%, -50%) rotate(45deg);
}
.l-wrapper .c-header-notice p {
    font-size: 1.25em;
    font-weight: bold;
}
.l-wrapper .c-header-notice .em {
    background-color: var(--color-white);
    margin: 0 0.25em;
    padding: 0.125em 0.75em;
    border-radius: 100vh;
    color: var(--color-text);
    font-size: 0.8em;
}
.l-wrapper .c-header-notice .em--red {
    color: var(--color-red);
}

/* c-header-nav */

.l-wrapper .c-header-nav {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    width: 100%;
    max-width: 1000px;
    background-color: var(--color-white);
}
.l-wrapper .c-header-nav.stuck {
    position: fixed;
    top: 0;
    z-index: 9999;
}
.l-wrapper .c-header-nav__item {
    border-left: 1px solid var(--color-white);
}
.l-wrapper .c-header-nav__item:first-of-type {
    border-left: 0;
}
.l-wrapper .c-header-nav__link {
    display: grid;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 1em;
    background: url(../images/bg_common.png) repeat;
    color: var(--color-white);
    font-size: 0.9em;
    font-weight: bold;
    text-align: center;
}

/* c-header-slider */

.l-wrapper .c-header-slider.slick-dotted.slick-slider {
    margin: 0;
}
.l-wrapper .c-header-slider .slick-slide,
.l-wrapper .c-oseibo-slider .slick-slide {
    height: auto;
}
.l-wrapper .c-header-slider .slick-dots {
    width: auto;
    position: absolute;
    right: 1em;
    bottom: 0.5em;
}
.l-wrapper .c-header-slider .slick-dots li,
.l-wrapper .c-oseibo-slider .slick-dots li {
    width: auto;
    height: auto;
    margin: 0;
    margin: 5px;
}
.l-wrapper .c-header-slider .slick-dots li button,
.l-wrapper .c-oseibo-slider .slick-dots li button {
    width: auto;
    height: auto;
}
.l-wrapper .c-header-slider .slick-dots li button:before,
.l-wrapper .c-oseibo-slider .slick-dots li button:before {
    content: "";
    width: 10px;
    height: 10px;
    background-color: var(--color-text);
    border: 2px solid var(--color-text);
    border-radius: 50%;
}
.l-wrapper .c-header-slider .slick-dots li.slick-active button:before,
.l-wrapper .c-oseibo-slider .slick-dots li.slick-active button:before {
    background-color: transparent;
}
.l-wrapper .c-header-slider.slick-slider .arrow,
.l-wrapper .c-oseibo-slider.slick-slider .arrow {
    content: "";
    display: block;
    width: 25px;
    height: 45px;
    position: absolute;
    top: 50%;
    z-index: 99;
    transform: translateY(-50%);
    transition: 0s;
}
.l-wrapper .c-header-slider.slick-slider .arrow:hover,
.l-wrapper .c-oseibo-slider.slick-slider .arrow:hover {
    cursor: pointer;
}
.l-wrapper .c-header-slider.slick-slider .arrow.prev,
.l-wrapper .c-oseibo-slider.slick-slider .arrow.prev {
    background: url("../images/controls.png") left top no-repeat;
    left: -3em;
}
.l-wrapper .c-header-slider.slick-slider .arrow.prev:hover,
.l-wrapper .c-oseibo-slider.slick-slider .arrow.prev:hover {
    background-position: left bottom;
}
.l-wrapper .c-header-slider.slick-slider .arrow.next,
.l-wrapper .c-oseibo-slider.slick-slider .arrow.next {
    background: url("../images/controls.png") right top no-repeat;
    right: -3em;
}
.l-wrapper .c-header-slider.slick-slider .arrow.next:hover,
.l-wrapper .c-oseibo-slider.slick-slider .arrow.next:hover {
    background-position: right bottom;
}

/* c-home-price */

.l-wrapper .c-home-price {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5em;
}
.l-wrapper .c-home-price__item img {
    width: 100%;
    height: auto;
}

/* c-home-categoryLarge */

.l-wrapper .c-home-categoryLarge {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5em;
    margin-bottom: 2em;
}
.l-wrapper .c-home-categoryLarge__item {
    display: block;
    border: 1px solid #cccccc;
    border-radius: 3px;
    position: relative;
}
.l-wrapper .c-home-categoryLarge__item .txt {
    width: 100%;
    padding: 0.5em 2em 0.5em 0.5em;
    background-color: rgb(64 47 21 / 0.75);
    color: var(--color-white);
    font-size: 1.25em;
    font-weight: bold;
    text-align: center;
    position: absolute;
    left: 0;
    bottom: 0;
}
.l-wrapper .c-home-categoryLarge__item .txt::before {
    content: "";
    display: block;
    width: 1em;
    height: 1em;
    border: 0.25em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    color: var(--color-white);
    line-height: 1;
    position: absolute;
    right: 0.5em;
    top: 50%;
    transform: translate(-25%, -50%) rotate(45deg);
}

/* c-home-categorySmall */

.l-wrapper .c-home-categorySmall {
    display: grid;
    /* grid-template-columns: repeat(5, 1fr); */
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.5em;
    margin-bottom: 2em;
}
.l-wrapper .c-home-categorySmall__item {
    display: block;
    border: 1px solid #cccccc;
    border-radius: 3px;
    color: var(--color-text);
    position: relative;
}
.l-wrapper .c-home-categorySmall__item img {
    width: 100%;
    height: auto;
}
.l-wrapper .c-home-categorySmall__item .txt {
    width: 75%;
    padding: 1em;
    font-size: 0.9em;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

/* c-home-topics */

.l-wrapper .c-home-topics {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1em;
}
.l-wrapper .c-home-topics__item {
    display: grid;
    grid-template-columns: 2fr 3fr;
    border: 2px solid var(--color-text);
    border-radius: 0.5em;
    overflow: hidden;
}
.l-wrapper .c-home-topics__img img {
    height: 100%;
    object-fit: cover;
    object-position: center center;
}
.l-wrapper .c-home-topics__txt {
    padding: 2em;
}
.l-wrapper .c-home-topics__ttl {
    margin-bottom: 1em;
    font-size: 1.25em;
    font-weight: bold;
}
.l-wrapper .c-home-topics__ttl::before {
    content: "■";
    margin-right: 0.5em;
    color: var(--color-primary);
}
.l-wrapper .c-home-topics__list .item {
    display: block;
    color: var(--color-text-link);
    text-decoration: underline;
}
.l-wrapper .c-home-topics__list .item:not(:first-of-type) {
    margin-top: 0.5em;
}

/* c-info */

.l-wrapper .c-info-container {
    margin-top: 2em;
}
.l-wrapper .c-info-ttl {
    margin-bottom: 1.5em;
    font-size: 1.5em;
    font-weight: bold;
}
.l-wrapper .c-info-ttl::before {
    content: "■";
    margin-right: 0.5em;
    color: var(--color-primary);
}



/* ========== ========== ==========
	Project
========== ========== ========== */

/* p-home-news */

.l-wrapper .p-home-news {
    padding: 2em;
    background-color: #eeeeee;
}
.l-wrapper .c-home-news__item {
    margin-top: 0.5em;
    font-size: 0.9em;
}
.l-wrapper .c-home-news__date {
    margin-right: 1em;
    padding: 0 1em;
    background-color: var(--color-primary);
    border-radius: 3px;
    color: var(--color-white);
    font-size: 0.75em;
}

/* p-home-info */

.l-wrapper .c-home-info-accordion {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5em;
    margin-bottom: 2em;
}
.l-wrapper .c-home-info-accordion__item {
    display: flex;
    flex-direction: column;
    padding: 1px;
    border: 1px solid #665b2a;
}
.l-wrapper .c-home-info-accordion__head {
    display: flex;
    gap: 0.5em;
    padding: 1em;
    background-color: #bfb899;
}
.l-wrapper .c-home-info-accordion__head .ttl {
    flex-grow: 1;
    padding-left: 0.5em;
    border-left: 4px solid #665b2a;
    color: #665b2a;
    font-weight: bold;
}
.l-wrapper .c-home-info-accordion__head img {
    flex-grow: 0;
}
.l-wrapper .c-home-info-accordion__main {
    display: flex;
    flex-grow: 1;
    flex-direction: column;
    justify-content: space-between;
    padding: 1em;
}
.l-wrapper .c-home-info-accordion__main .txt {
    font-size: 0.9em;
}
.l-wrapper .c-home-info-accordion__main .c-btn {
    font-size: 0.9em;
}
.l-wrapper .c-home-info-btn {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5em;
}
.l-wrapper .c-home-info-btn__item {
    display: flex;
    align-items: center;
    gap: 1em;
    padding: 1em 2em;
    background: url(../images/icon_arrow02.png) right bottom no-repeat;
    background-color: var(--color-text);
    border-radius: 3px;
    color: var(--color-white);
}
.l-wrapper .c-home-info-btn__item--beginner {
    background-color: #4d799e;
}
.l-wrapper .c-home-info-btn__item--carriage {
    background-color: #d99b34;
}
.l-wrapper .c-home-info-btn__icon {
    flex-grow: 0;
}
.l-wrapper .c-home-info-btn__txt {
    flex-shrink: 1;
}
.l-wrapper .c-home-info-btn__txt .main {
    display: block;
    font-size: 1.5em;
    font-weight: bold;
}

/* p-oseibo-slider */

.l-wrapper .c-oseibo-slider {
    margin-bottom: 2em;
    padding: 1em 0.58em;
    background: url(../images/bg_content01.png) repeat;
}
.l-wrapper .c-oseibo-slider .slick-track {
    display: flex;
}
.l-wrapper .c-oseibo-slider .slick-dots {
    width: auto;
    position: absolute;
    left: 50%;
    bottom: -2em;
    transform: translateX(-50%);
}
.l-wrapper .c-oseibo-slider__item {
    display: block;
    margin: 0 0.5em;
    background: var(--color-white);
    border-radius: 0.5em;
    color: var(--color-text);
    overflow: hidden;
    position: relative;
}
.l-wrapper .c-oseibo-slider__item:hover {
    opacity: 1;
}
.l-wrapper .c-oseibo-slider__head {
    overflow: hidden;
}
.l-wrapper .c-oseibo-slider__head .img {
    transition: 0.2s;
}
.l-wrapper .c-oseibo-slider__item:hover .c-oseibo-slider__head .img {
    transform: scale(1.2);
}
.l-wrapper .c-oseibo-slider__main {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 1em;
}
.l-wrapper .c-oseibo-slider__main p {
    font-size: 0.9em;
}
.l-wrapper .c-oseibo-slider__main .price {
    margin-top: 0.5em;
    text-align: right;
}
.l-wrapper .c-oseibo-slider__main .price::before {
    content: "……";
    margin-right: 0.5em;
}
.l-wrapper .c-oseibo-slider__item .absolute {
    display: grid;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: rgb(var(--color-black-rgb) / 0.5);
    opacity: 0;
    transition: 0.2s;
    position: absolute;
    left: 0;
    top: 0;
}
.l-wrapper .c-oseibo-slider__item:hover .absolute {
    opacity: 1;
}
.l-wrapper .c-oseibo-slider__item .absolute .inner {
    padding: 0.5em;
    border: 2px solid var(--color-white);
    color: var(--color-white);
    font-weight: bold;
    line-height: 1;
}

/* p-oseibo-feature */

.l-wrapper .c-oseibo-feature {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5em;
}
.l-wrapper .c-oseibo-feature__item {
    display: block;
    border: 1px solid #cccccc;
    border-radius: 3px;
    overflow: hidden;
    position: relative;
}
.l-wrapper .c-oseibo-feature__item .txt {
    width: 100%;
    padding: 0.5em 2em 0.5em 0.5em;
    background-color: rgb(var(--color-primary-rgb) / 0.75);
    color: var(--color-white);
    font-size: 1.25em;
    font-weight: bold;
    text-align: center;
    position: absolute;
    left: 0;
    bottom: 0;
}
.l-wrapper .c-oseibo-feature__item .txt::before {
    content: "";
    display: block;
    width: 1em;
    height: 1em;
    border: 0.25em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    color: var(--color-white);
    line-height: 1;
    position: absolute;
    right: 0.5em;
    top: 50%;
    transform: translate(-25%, -50%) rotate(45deg);
}

/* p-oseibo-feature */

.l-wrapper .p-oseibo-feature {
    margin-top: 4em;
}
.l-wrapper .c-kumamoto-feature {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2em 0.5em;
}
.l-wrapper .c-kumamoto-feature__item {
    color: var(--color-text);
}
.l-wrapper .c-kumamoto-feature__item--story {
    grid-column: span 3;
}
.l-wrapper .c-kumamoto-feature__item:hover {
    color: var(--color-primary);
    opacity: 1;
}
.l-wrapper .c-kumamoto-feature__item .img {
    display: block;
    margin-bottom: 1em;
    border: 1px solid #cccccc;
    border-radius: 3px;
    overflow: hidden;
    transition: 0.2s;
}
.l-wrapper .c-kumamoto-feature__item:hover .img {
    opacity: 0.5;
}
.l-wrapper .c-kumamoto-feature__item .txt {
    font-size: 1.25em;
    font-weight: bold;
    text-align: center;
    transition: 0.2s;
}
.l-wrapper .c-kumamoto-feature__item:hover .txt {
    text-decoration: underline wavy;
    text-underline-offset: 0.5em;
}

/* p-home-special */

.l-wrapper .p-home-special {
    padding: 1em;
    background: url(../images/bg_content01.png);
}
.l-wrapper .p-home-special__item {
    border: 2px solid var(--color-primary);
    border-radius: 3px;
    overflow: hidden;
}
.l-wrapper .p-home-special__item:not(:first-of-type) {
    margin-top: 1em;
}
.l-wrapper .p-home-special__ttl {
    padding: 1em;
    background-color: var(--color-primary);
    color: var(--color-white);
    font-size: 1.25em;
    font-weight: bold;
    text-align: center;
}
.l-wrapper .p-home-special__inner {
    padding: 2em;
    background-color: var(--color-white);
}
.l-wrapper .p-home-special__container:not(:first-of-type) {
    margin-top: 2em;
}
.l-wrapper .p-home-special__lede {
    margin-bottom: 1em;
    font-size: 1.125em;
    font-weight: bold;
    text-align: center;
}
.l-wrapper .c-special-period {
    display: flex;
    border: 2px solid var(--color-secondary);
    border-radius: 100vh;
    overflow: hidden;
}
.l-wrapper .c-special-period:not(:first-of-type) {
    margin-top: 1em;
}
.l-wrapper .c-special-period__head {
    display: flex;
    align-items: center;
    flex-grow: 0;
    min-width: 16em;
    padding: 1em 2em;
    background-color: var(--color-secondary);
    color: var(--color-white);
    font-weight: bold;
    text-align: center;
}
.l-wrapper .c-special-period__main {
    display: flex;
    align-items: center;
    gap: 0.5em;
    padding: 0.5em 1em;
    flex-shrink: 1;
}
.l-wrapper .c-special-period__main .txt {
    font-size: 1.125em;
    font-weight: bold;
}
.l-wrapper .c-special-period__main .rate {
    color: var(--color-primary);
    font-size: 2em;
    font-weight: bold;
}
.l-wrapper .c-members-flex {
    display: flex;
    gap: 2em;
}
.l-wrapper .c-members-flex__img {
    flex-grow: 0;
}
.l-wrapper .c-members-flex__txt {
    flex-shrink: 1;
}
.l-wrapper .c-members-flex__txt p:not(:first-of-type) {
    margin-top: 0;
}
.l-wrapper .c-members-lede {
    color: var(--color-primary);
    font-size: 1.125em;
    font-weight: bold;
}
.l-wrapper .c-members-img {
    display: block;
    margin-top: 1em;
}

/* p-oseibo-campaign */

.l-wrapper .p-oseibo-campaign {
    padding: 4em;
    border: 4px solid var(--color-primary);
    position: relative;
}
.l-wrapper .p-oseibo-campaign__ttl {
    display: inline-block;
    width: 100%;
    background-color: var(--color-white);
    color: var(--color-primary);
    font-size: 1.75em;
    font-style: italic;
    font-weight: bold;
    text-align: center;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.75, 1);
}
.l-wrapper .p-oseibo-campaign__lede {
    margin-bottom: 2em;
    font-size: 1.25em;
    font-weight: bold;
}
.l-wrapper .p-oseibo-campaign .finish {
    margin-bottom: 2em;
    padding: 0.5em 1em;
    background-color: var(--color-primary);
    color: var(--color-white);
    font-weight: bold;
    text-align: center;
}
.l-wrapper .c-campaign-info {
    display: grid;
    grid-template-columns: 1fr 6fr;
    gap: 1em;
}
.l-wrapper .c-campaign-info__dt .inner {
    display: block;
    padding: 0.5em 1em;
    background-color: var(--color-primary);
    border-radius: 100vh;
    color: var(--color-white);
    font-size: 0.9em;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}
.l-wrapper .c-campaign-info__icon {
    height: 3em;
    vertical-align: middle;
}
.l-wrapper .c-campaign-prize {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: 2em;
}
.l-wrapper .c-campaign-prize__img {
    display: grid;
    align-items: center;
    background-color: #d4edf7;
}
.l-wrapper .c-campaign-prize__txt {
    flex-shrink: 0;
}
.l-wrapper .c-prize-info:not(:first-of-type) {
    margin-top: 2em;
}
.l-wrapper .c-prize-info__ttl {
    margin-bottom: 0.5em;
    color: var(--color-primary);
    font-size: 1.125em;
    font-weight: bold;
}
.l-wrapper .c-prize-info__list {
    display: grid;
    grid-template-columns: 1fr 5fr;
    font-size: 1.125em;
    font-weight: bold;
}