/* ============================================
   style_dailylife.css
   光の郷での生活 ページ専用スタイル
   ============================================ */

/* ============================================
   現在地ナビリンクのスタイル
   ============================================ */
.gnav__link--current {
	color: var(--color-main);
}

/* ============================================
   日常の生活
   ============================================ */
.daily__intro {
	margin-bottom: 40px;
}
.daily__intro p {
	margin-bottom: 20px;
	line-height: 1.8;
}
.daily__intro p:last-child {
	margin-bottom: 0;
}

/* h3：光の郷のとある1日 */
.daily .section-heading-sub {
	margin-bottom: 16px;
}

/* 箇条書きリスト */
.daily__note-list {
	list-style: disc;
	padding-left: 1.5em;
	margin-bottom: 50px;
}
.daily__note-list li {
	margin-bottom: 8px;
	line-height: 1.8;
}
.daily__note-list li:last-child {
	margin-bottom: 0;
}

/* ============================================
   タイムフロー＋画像 横並び
   ============================================ */
.daily__body {
	display: flex;
	align-items: flex-start;
	gap: 40px;
}

/* --- タイムフロー --- */
.daily__timeline {
	flex: 0 1 360px;
	min-width: 0;
}

.timeline__list {
	display: flex;
	flex-direction: column;
	position: relative;
	/* 縦線：●の中心（9px）に合わせて左端から引く */
	padding-left: 34px; /* dot幅18px + 右余白16px */
}

/* 縦線：リスト全体を貫く1本線 */
.timeline__list::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 8px; /* (18px dot - 2px line) / 2 = 8px で中心に */
	width: 2px;
	background-color: #CD7E8C;
}

.timeline__item {
	display: flex;
	align-items: flex-start;
	position: relative;
	padding-bottom: 28px;
}

.timeline__item--last {
	padding-bottom: 0;
}

/* ●ドット：縦線の上に重ねる */
.timeline__dot {
	position: absolute;
	left: -34px; /* padding-left分だけ戻す */
	top: calc(1.8em / 2 - 9px); /* テキスト行の中央に合わせる */
	display: block;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background-color: #CD7E8C;
	flex-shrink: 0;
	z-index: 1;
}

/* テキスト部分 */
.timeline__content {
	display: flex;
	align-items: baseline;
	gap: 12px;
	min-height: 18px;
}

.timeline__time {
	font-size: 1rem;
	color: var(--color-text);
	white-space: nowrap;
	min-width: 3.8em;
	line-height: 1.8;
}

.timeline__label {
	font-size: 1rem;
	color: var(--color-text);
	line-height: 1.8;
}

/* 注記テキスト */
.daily__timeline-note {
	margin-top: 20px;
	font-size: 0.875rem;
	color: var(--color-text);
	line-height: 1.8;
}

/* --- 画像グリッド --- */
.daily__images {
	flex: 1 1 0;
	min-width: 0;
}

.daily__img-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
}

.daily__img-item {
	min-width: 0;
}

.daily__img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 12px;
}

/* ============================================
   レスポンシブ
   ============================================ */
@media (max-width: 768px) {

	.daily__body {
		flex-direction: column;
		gap: 40px;
	}

	.daily__timeline {
		flex: none;
		width: 100%;
		order: 1;
	}

	.daily__images {
		flex: none;
		width: 100%;
		order: 2;
	}

	.daily__img-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	.daily__img {
		max-width: 100%;
	}
}

/* ============================================
   共通：テキスト＋画像 横並びレイアウト
   （お食事・レクリエーション等で流用）
   ============================================ */
.content-with-img {
	display: flex;
	align-items: flex-start;
	gap: 40px;
	margin-bottom: 50px;
}
.content-with-img__text {
	flex: 1 1 0;
	min-width: 0;
	max-width: 540px;
}
.content-with-img__text p {
	margin-bottom: 20px;
	line-height: 1.8;
}
.content-with-img__text p:last-child {
	margin-bottom: 0;
}
.content-with-img__img-wrap {
	flex: 1 1 0;
	min-width: 0;
	max-width: 560px;
}
.content-with-img__img {
	width: 100%;
	height: auto;
	border-radius: 12px;
	display: block;
}

@media (max-width: 768px) {
	.content-with-img {
		flex-direction: column;
		margin-bottom: 40px;
	}
	.content-with-img__img-wrap {
		max-width: 100%;
		order: -1;
	}
	.content-with-img__text {
		max-width: 100%;
	}
}

/* ============================================
   お食事について
   ============================================ */

/* 食事画像3枚グリッド */
.meal__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-bottom: 60px;
}
.meal__grid-item {
	min-width: 0;
}
.meal__img {
	width: 100%;
	max-width: 360px;
	height: auto;
	border-radius: 12px;
	display: block;
}

/* 季節の特別メニュー見出し */
.meal__sub-heading {
	margin-top: 0;
}

/* 季節の特別メニュー3枚グリッド */
.meal__kisetsu-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	width: 100%;
  max-width: 1000px;
}
.meal__kisetsu-item {
	min-width: 0;
}
.meal__kisetsu-img {
	width: 100%;
	max-width: 300px;
	height: auto;
	border-radius: 12px;
	display: block;
}

@media (max-width: 768px) {
	.meal__grid {
		grid-template-columns: 1fr;
		gap: 24px;
		margin-bottom: 40px;
	}
	.meal__img {
		max-width: 100%;
	}
	.meal__kisetsu-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.meal__kisetsu-img {
		max-width: 100%;
	}
}

/* ============================================
   レクリエーション
   ============================================ */

/* 「その他〜」テキスト */
.recreation__note {
	margin: 40px 0;
	line-height: 1.8;
}

/* ============================================
   共通：4列テキスト群（クラブ活動・各種行事で流用）
   ============================================ */
.info-columns {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px 16px;
	margin-bottom: 0;
}
.info-columns__item {
	max-width: 280px;
	font-size: 1rem;
	line-height: 1.8;
	color: var(--color-text);
}
.info-columns__title {
	display: block;
	color: #A61C4B;
	font-weight: 700;
}

/* 区切り線 */
.info-columns__divider {
	border-top: 1px solid #CCCCCC;
	margin: 40px 0;
}

/* 下段（行事ごと）は上余白なし・下余白あり */
.info-columns--bottom {
	padding-bottom: 60px;
}

@media (max-width: 768px) {
	.info-columns {
		grid-template-columns: 1fr;
		gap: 20px 0;
	}
	.info-columns__item {
		max-width: 100%;
	}
	.info-columns--bottom {
		padding-bottom: 40px;
	}
}

/* ============================================
   共通：画像＋キャプション グリッド（3列）
   ============================================ */
.photo-grid--3col {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px 20px;
	padding-bottom: 80px;
}
.photo-grid__item {
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.photo-grid__img {
	width: 100%;
	max-width: 360px;
	height: auto;
	border-radius: 12px;
	display: block;
}
.photo-grid__caption {
	margin-top: 10px;
	font-size: 1rem;
	color: var(--color-text);
	text-align: center;
	line-height: 1.8;
}

@media (max-width: 768px) {
	.photo-grid--3col {
		grid-template-columns: 1fr;
		gap: 24px 0;
		padding-bottom: 30px;
	}
	.photo-grid__img {
		max-width: 100%;
	}
}

/* ============================================
   お問い合わせ：上余白
   ============================================ */
.contact {
	margin-top: 80px;
}

@media (max-width: 768px) {
	.contact {
		margin-top: 40px;
	}
}
