@charset "UTF-8";
@import url('https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanjp_s.css');

/* ==========================================================================
	Foundation
========================================================================== */

:root {
	/* コンテンツサイズ */
	--container-width: 910px;

	/* ブレイクポイント */
	--break-point-ta: 910px;
	--break-point-sp: 768px;

	/* カラーパレット */
	--color-primary: #086baf;
	--color-secondary: #bfe4f7;
	--color-base: #e6f0f7;
	--color-text: #231815;
	--color-text-link: #086baf;
	--color-red: #af0828;
	--color-pink: #bf3953;
	--color-black: #231815;
	--color-white: #ffffff;

	/* トランジション */
	--transition-time: 0.2s;
}
.l-wrapper *,
.l-wrapper *::before,
.l-wrapper *::after {
	box-sizing: border-box;
	font-family: YakuHanJPs, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.l-wrapper h1, .l-wrapper h2,
.l-wrapper h3, .l-wrapper h4, 
.l-wrapper h5, .l-wrapper h6 {
	margin: 0;
	color: var(--color-text);
}
.l-wrapper a:hover {
	opacity: 1;
}
.l-wrapper img {
	max-width: 100%;
	vertical-align: bottom;
}
.l-wrapper p {
	margin: 0;
	color: var(--color-text);
	line-height: 1.75;
}
.l-wrapper span {
	display: inline-block;
	font-size: inherit;
}
.l-wrapper ul, .l-wrapper ol {
	margin: 0;
	padding: 0;
}
.l-wrapper .bold {
	font-weight: bold;
}
.l-wrapper .red {
	color: var(--color-pink);
	font-weight: bold;
}
.l-wrapper .small {
	font-size: 80%;
}
.l-wrapper .sp {
	display: none;
}
@media (max-width: 768px) {
	.l-wrapper .sp {
		display: block;
	}
}

/* ==========================================================================
	Layout
========================================================================== */

.l-wrapper {
	max-width: var(--container-width);
	margin: 1em auto 0;
	background-color: #231815;
}
.l-wrapper .l-main {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2em;
	padding: 2em;
}
.l-wrapper .l-nav {
	position: sticky;
	top: 0;
	z-index: 1000;
}
.l-wrapper .l-section {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2em;
}
@media (max-width: 960px) {
	.tec16-mainframe-header_bread-list {
		display: none;
	}
	.l-wrapper {
		margin: 10px auto 0;
	}
	.l-wrapper .l-main {
		padding: 1em;
	}
}

/* ==========================================================================
	Object
========================================================================== */

/* -----------------------------------------------------------------
	Component
----------------------------------------------------------------- */

/* c-header */
.l-wrapper .c-header-yokoku {
	padding: 0.5em 1em;
	background-color: var(--color-red);
	color: var(--color-white);
	font-size: 1.25em;
	font-weight: bold;
	text-align: center;
}

/* c-btn */
.l-wrapper .c-btn {
	display: inline-block;
	padding: 1em 2.5em 1em 1em;
	background-color: var(--color-primary);
	border: 2px solid var(--color-primary);
	border-radius: 5px;
	color: var(--color-white);
	font-size: 1.25em;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	transition: var(--transition-time);
	position: relative;
}
.l-wrapper .c-btn:hover {
	background-color: var(--color-white);
	color: var(--color-primary);
}
.l-wrapper .c-btn::after {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    border-top: 4px solid var(--color-white);
    border-right: 4px solid var(--color-white);
	transition: var(--transition-time);
    position: absolute;
    right: 1em;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
}
.l-wrapper .c-btn:hover::after {
	border-color: var(--color-primary);
}
@media (max-width: 768px) {
	.l-wrapper .c-btn {
		font-size: 1.125em;
	}
}

/* -----------------------------------------------------------------
	Project
----------------------------------------------------------------- */

/* p-iinfo */
.l-wrapper .p-info {
	gap: 2em;
	padding: 2em;
	background-color: var(--color-white);
	border-radius: 3px;
}
.l-wrapper .p-info__ttl {
	padding: 0.5em;
	border-top: 2px solid var(--color-text);
	border-bottom: 2px solid var(--color-text);
	font-size: 1.5em;
	font-weight: bold;
	text-align: center;
}
.l-wrapper .p-info__lede {
	font-weight: bold;
	text-align: center;
}
.l-wrapper .p-info__lede .period {
	padding: 0 0.5em;
	margin-top: 0.5em;
	background-color: var(--color-red);
	border-radius: 3px;
	color: var(--color-white);
}
.l-wrapper .p-info__list {
	display: grid;
	gap: 0.5em;
	margin-left: 1.5em;
	color: var(--color-text);
	list-style: disc;
}
@media (max-width: 768px) {
	.l-wrapper .p-info {
		padding: 2em 1em;
	}
}

/* p-category */
.l-wrapper .p-category__list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1em;
	list-style: none;
}
.l-wrapper .c-category-card {
	display: block;
	background-color: var(--color-white);
	border-radius: 5px;
	color: var(--color-text);
	text-decoration: none;
	overflow: hidden;
	transition: 0.2s;
}
.l-wrapper .c-category-card--zonin {
	background-color: var(--color-white);
}
.l-wrapper .c-category-card:hover {
	opacity: 0.5;
}
.l-wrapper .c-category-card__img {
	aspect-ratio: 1 / 1;
}
.l-wrapper .c-category-card__txt {
	padding: 2em;
}
.l-wrapper .c-category-card__txt .main {
	display: block;
	margin-top: 0.5em;
	font-size: 1.5em;
	font-weight: bold;
}
.l-wrapper .c-category-card__txt .small {
	margin-left: 0.5em;
	font-size: 0.5em;
}
@media (max-width: 480px) {
	.l-wrapper .p-category__list {
		grid-template-columns: 1fr;
	}
}

/* -----------------------------------------------------------------
	Utility
----------------------------------------------------------------- */