@charset "utf-8";

/*一時的な設定*/
/*Oliveバナー2025.3まで、クリスマスケーキ*/
.xmas {
	background-color: #9D1C1E;
	padding: 0;
}

.xmas h2 {
	padding: 0px;
}

.cafe_olive,
.cafe_xmas_img {
	display: block;
	max-width: 1000px;
	height: 100%;
	position: relative;
	/*left: -50%;
	transform: translateX(50%);*/
	left: 0;
}

.disc_xmas {
	width: 100%;
	margin: 20px;
	padding: 30px;
	background-color: white;
	right: 100%;
	box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.4);
}


.list_xmas {
	padding: 5px 30px 0;
	line-height: 1.5rem;
	list-style-type: square;
}

.list_xmas li {
	margin-top: 5px;
}

.txt_disc_xmas {
	padding: 5px 0px 5px 5px;
	text-align: left;
}

.ttl_min_round {
	color: white;
	display: block;
	width: 100px;
	text-align: center;
	font-size: 13px;
	padding: 5px 10px;
	border-radius: 20px;
	margin: 0px;
}

.txt_xmaslist {
	padding: 5px 20px;
}

.txt_xmaslist p {
	padding-bottom: 10px;
}

.txt_xmaslist span {
	padding-left: 30px;
}

.txt_xmas_how {
	font-size: 14px;
	line-height: 1.2em;
	padding: 0 5px;
}

.cafe_xmas_leaf {
	display: block;
	width: 200px;
	height: auto;
	margin: 0 auto 0 0;

}

@media (max-width: 798px) {
	.xmas {
		padding-bottom: 10px;
	}

	.cafe_xmas_img {
		max-width: 100%;
	}

	.disc_xmas {
		width: 96%;
		margin: 10px auto;
	}

	.cafe_xmas_leaf {
		margin: 0 auto;
	}
}

/* CSS Document */
.topimg {
	width: 100%;
	min-width: 1400px;
	background-image: url("../original_img/ttl_cafe.webp");
	background-position-y: 35%;
	background-repeat: no-repeat;
	background-size: cover;
	height: 250px;
	box-shadow: 2px 2px 4px -2px black inset;
}

h1 {
	font-size: 18px;
	font-weight: bold;
	margin: 0px auto;
}

h3,
h2 {
	color: #F96C84;
	font-weight: bold;
	font-size: 18px;
	margin: 0px auto;
	position: relative;
	width: 300px;
	padding-left: 20px;
	text-align: center;
}

/*
h3::before {
	content: "";
	position: absolute;
	background: #F96C84;
	top: 0;
	left: -5px;
	height: 32px;
	width: 9px;

}*/


h4 {
	color: #F96C84;
	font-weight: bold;
	text-align: center;
	font-size: 15px;
	margin: 0px auto 20px;
}

section {
	width: 100%;
	padding: 50px;
}

.container_ttl {
	background-color: white;
	padding: 20px 0 50px;
	text-align: center;
}

.container_ttl>h2 {
	position: relative;
}

.ttl_fa {
	font-size: 30px;
	color: #F96C84;
	margin: 10px auto 0;
}

.deco_line {
	display: block;
	width: 400px;
	height: auto;
	aspect-ratio: 400/35;
	margin: 0 auto;
	transform: translate(0, -30px);
}

.image_circle {
	width: 800px;
	padding: 0 78px;
	margin: 0 auto;
}

.cafeimage_circle {
	width: 180px;
	height: 180px;
	border-radius: 50%;
	margin: 10px 0;
	background-position-x: 50%;
	background-position-y: 50%;
	background-repeat: no-repeat;
	background-size: contain;
}

.cicle1 {
	background-image: url("../original_img/cafe_image1.png");
}

.cicle2 {
	background-image: url("../original_img/cafe_image2.png");
	margin: 10px 52px;
}

.cicle3 {
	background-image: url("../original_img/cafe_image3.png");
}

.bg_menu {
	background-image: url("../original_img/bg_cafemenu.webp");
}

.bg_about {
	background-image: url("../original_img/bg_cafeabout.webp");
}

.bg_link {
	background-color: #F9F8F9;
}

.container_1000 {
	width: 1000px;
	margin: 0 auto;
}

.container_800 {
	width: 800px;
	margin: 0 auto;
}

.container_menuimg {
	width: 1000px;
}

.img_menu {
	width: 250px;
	height: auto;
	aspect-ratio: 5/7;
	margin: 10px;
}

/*About*/
.contain_about {
	width: 1000px;
	margin: 20px auto;
}

.about_point {
	width: 320px;
	height: 450px;
	padding: 14px;
	background-color: white;
	margin: 20px;
	box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .16);
}

.about_point>h5 {
	font-weight: bold;
	font-size: 18px;
	margin: 5px auto;
	text-align: center;
}

.img_about {
	width: 100%;
	aspect-ratio: 292/223;
	height: auto;
}

.img_about_1 {
	background-image: url("../original_img/about1.png");
}

.img_about_2 {
	background-image: url("../original_img/about2.png");
}

.img_about_3 {
	background-image: url("../original_img/about3.png");
}

/*カレンダーby ChatGPT*/
/* カレンダーのスタイル */
.calendar {
	padding: 10px 0;
	display: grid;
	grid-template-columns: repeat(7, 40px);
	grid-template-rows: 40px repeat(6, 40px);
	gap: 15px;
	text-align: center;
	border-collapse: collapse;
	border-top: 2px solid black;
}

/* 営業日のピンクの円のスタイル */
.pink {
	background-color: #FFDADA;
}

/* 営業日の黄色の円のスタイル */
.yellow {
	background-color: #FDF1A0;
}

/* 営業日の水色の円のスタイル */
.blue {
	background-color: #C1EAFF;
}

/* 営業日の緑色の円のスタイル */
.green {
	background-color: #DAF97F;
}

/* 休業日のスタイル */
.empty {
	width: 40px;
	height: 40px;
	margin: auto;
}

.day {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	margin: auto;
}

.day::before {
	content: attr(data-day);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 16px;
	color: #605B4D;
}

.container_calender {
	width: 370px;
	/*40*7+12*6*/
	margin: 10px auto;
}

.div_calender {
	width: 1000px;
	margin: 20px auto;
}

.container_calender>h5 {
	font-weight: bold;
	font-size: 15px;
	text-align: center;
	margin: 0px auto;
}

/*カレンダー数字強調*/
.month {
	font-size: 30px;
}

.disc_calender {
	width: fit-content;
	text-align: center;
	margin: 0px auto;
}

.circle_calender {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	margin: 0 10px 0 30px;
}

.div_cafe_osusume {
	width: 734px;
	margin: 0 auto;
}

.cafe_osusume>a {
	display: block;
}

.cafe_osusume {
	width: 352px;
	height: 277px;
	margin: 15px;
	border-radius: 10px;
}

.obento {
	background-image: url("../original_img/bg_ttl_daymenu.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}

.cafe_insta {
	background-image: url("../original_img/cafe_insta.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}

.btn_title {
	width: 210px;
	padding: 20px;
	background-color: rgba(255, 255, 255, 0.9);
	font-weight: bold;
	text-align: center;
	margin: 0px auto;
	transform: translateY(50%);
}

.link_ttl {
	border-bottom: solid 2px;
	width: 120px;
	text-align: center;
	margin: 0 auto;
}

.link_ttlesub>i {
	font-size: 30px;
}

.sns {
	margin: auto;
}

@media screen and (max-width : 1038px) {
	section {
		padding: 50px 0;
	}

	.topimg {
		min-width: 310px;
		height: 150px;
		background-position-x: 50%;
	}

	h3 {
		width: 95%;
	}

	.deco_line {
		width: 80%;
	}

	.image_circle {
		width: 90%;
		padding: 0;
		margin: 10px auto;
	}

	.cafeimage_circle {
		width: 33%;
		height: auto;
		aspect-ratio: 1;
		margin: 3px;
	}

	.container_800 {
		width: 98%;
	}

	.container_1000 {
		width: 98%;
	}

	.container_menuimg {
		width: 100%;
	}

	.img_menu {
		width: 100%;
		margin: 5px;
	}

	.cicle2 {
		margin: 3px 10px;
	}

	.contain_about {
		width: 100%
	}

	.about_point {
		margin: 10px auto;
	}

	.calendar {
		gap: 5px;
	}

	.container_calender {
		width: 310px;
		/*40*7+5*6*/
		margin: 10px auto;
	}

	.div_calender {
		width: 100%;
	}

	.disc_calender {
		width: 100%;
	}


	.div_cafe_osusume {
		width: 100%;
	}

	.cafe_osusume {
		width: 94%;
		margin: 0 auto;
	}

	.cafe_osusume:first-child {
		margin-bottom: 30px;
	}

	.cafe_olive {
		width: 100%;
	}
}