:root {
  --main-beige: rgba(216, 191, 169, 0.46); /* #d8bfa975 */
  --dark-beige: #bfa58d;
  --text-color: #5a544e;
  --bg-light: #fdfcfb;
}

body {
  font-family: "M PLUS Rounded 1c", sans-serif;
  color: var(--text-color);
  background-color: var(--bg-light);
  overflow-x: hidden;
}

a {
  color: rgb(170, 104, 84);
  text-decoration: none;
}


.page h1 {
	font-size: 30px;
	text-align: center;
	padding-bottom: 10px;
	margin-bottom: 25px;
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
  padding: 15px 0;
  background: #eeebe8;
  min-height: 38px;
  margin-top: 0;
  color: #fff;
}
.breadcrumbs h2 {
  font-size: 28px;
  font-weight: 500;
}
.breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}
.breadcrumbs ol a {
  color: #aaaaaa;
}
.breadcrumbs ol a:hover {
  color: #fff;
  transition: 0.3s;
}
.breadcrumbs ol li + li {
  padding-left: 10px;
}
.breadcrumbs ol li + li::before {
  display: inline-block;
  padding-right: 10px;
  color: #2c2424;
  content: "/";
}

.h3,
h3 {
  font-size: 1.35rem;
  margin-top: 15px;
}

/*--------------------------------------------------------------
# Blog
--------------------------------------------------------------*/

.blog .entry {
  padding: 1rem;
  margin-bottom: 60px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  height: 100%;
  position: relative;
}
.blog .entry .entry-img {
  margin: -1rem;
  overflow: hidden;
}
.blog .entry .entry-title {
  font-size: 1.5rem;
  font-weight: bold;
  padding: 0;
  margin: 0 0 20px 0;
  padding-bottom: 10px;
  border-bottom: 2px solid #c7ab94;
  position: relative;
}
.blog .entry .entry-title::before {
  content: " ";
  border-bottom: 2px solid #7e4444;
  display: block;
  width: 3rem;
  position: absolute;
  bottom: -2px;
}

.blog .entry .entry-title a {
  color: #111111;
  transition: 0.3s;
}
.blog .entry .entry-title a:hover {
  color: #e03a3c;
}
.blog .entry .entry-meta {
  margin-bottom: 15px;
  color: #777777;
}
.blog .entry .entry-meta ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  align-items: center;
  padding: 0;
  margin: 0;
}
.blog .entry .entry-meta ul li + li {
  padding-left: 0px;
}
.blog .entry .entry-meta i {
  font-size: 16px;
  margin-right: 8px;
  line-height: 0;
}
.blog .entry .entry-meta a {
  /* color: #c60a0a; */
  /* font-size: 14px; */
  display: inline-block;
  line-height: 1;
  /* border: 1px solid; */
  /* padding: 5px; */
  /* border-radius: 4px; */
}
.blog .entry .entry-content p {
  line-height: 24px;
}
.blog .entry .entry-content .read-more {
  -moz-text-align-last: right;
  text-align-last: right;
  position: absolute;
  bottom: 10px;
}
.blog .entry .entry-content .read-more a {
  display: inline-block;
  background: #e03a3c;
  color: #fff;
  padding: 6px 20px;
  transition: 0.3s;
  font-size: 14px;
  border-radius: 4px;
}
.blog .entry .entry-content .read-more a:hover {
  background: #e35052;
}
.blog .entry .entry-content h3 {
  font-size: 22px;
  margin-top: 30px;
  font-weight: bold;
}
.blog .entry .entry-content blockquote {
  overflow: hidden;
  background-color: #fafafa;
  padding: 60px;
  position: relative;
  text-align: center;
  margin: 20px 0;
}
.blog .entry .entry-content blockquote p {
  color: #444444;
  line-height: 1.6;
  margin-bottom: 0;
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
}
.blog .entry .entry-content blockquote::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background-color: #111111;
  margin-top: 20px;
  margin-bottom: 20px;
}
.blog .entry .entry-footer {
  padding-top: 10px;
  border-top: 1px solid #e6e6e6;
}
.blog .entry .entry-footer i {
  color: #5e5e5e;
  display: inline;
}
.blog .entry .entry-footer a {
  color: #1e1e1e;
  transition: 0.3s;
}
.blog .entry .entry-footer a:hover {
  color: #e03a3c;
}
.blog .entry .entry-footer .cats {
  list-style: none;
  display: inline;
  padding: 0 20px 0 0;
  font-size: 14px;
}
.blog .entry .entry-footer .cats li {
  display: inline-block;
}
.blog .entry .entry-footer .tags {
  list-style: none;
  display: inline;
  padding: 0;
  font-size: 14px;
}
.blog .entry .entry-footer .tags li {
  display: inline-block;
}
.blog .entry .entry-footer .tags li + li::before {
  padding-right: 6px;
  color: #6c757d;
  content: ",";
}
.blog .entry .entry-footer .share {
  font-size: 16px;
}
.blog .entry .entry-footer .share i {
  padding-left: 5px;
}
.blog .entry-single {
  margin-bottom: 30px;
}
.blog .blog-author {
  padding: 20px;
  margin-bottom: 30px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}
.blog .blog-author img {
  width: 120px;
  margin-right: 20px;
}
.blog .blog-author h4 {
  font-weight: 600;
  font-size: 22px;
  margin-bottom: 0px;
  padding: 0;
  color: #111111;
}
.blog .blog-author .social-links {
  margin: 0 10px 10px 0;
}
.blog .blog-author .social-links a {
  color: rgba(17, 17, 17, 0.5);
  margin-right: 5px;
}
.blog .blog-author p {
  font-style: italic;
  color: #b7b7b7;
}
.blog .blog-comments {
  margin-bottom: 30px;
}
.blog .blog-comments .comments-count {
  font-weight: bold;
}
.blog .blog-comments .comment {
  margin-top: 30px;
  position: relative;
}
.blog .blog-comments .comment .comment-img {
  margin-right: 14px;
}
.blog .blog-comments .comment .comment-img img {
  width: 60px;
}
.blog .blog-comments .comment h5 {
  font-size: 16px;
  margin-bottom: 2px;
}
.blog .blog-comments .comment h5 a {
  font-weight: bold;
  color: #444444;
  transition: 0.3s;
}
.blog .blog-comments .comment h5 a:hover {
  color: #e03a3c;
}
.blog .blog-comments .comment h5 .reply {
  padding-left: 10px;
  color: #111111;
}
.blog .blog-comments .comment h5 .reply i {
  font-size: 20px;
}
.blog .blog-comments .comment time {
  display: block;
  font-size: 14px;
  color: #2b2b2b;
  margin-bottom: 5px;
}
.blog .blog-comments .comment.comment-reply {
  padding-left: 40px;
}
.blog .blog-comments .reply-form {
  margin-top: 30px;
  padding: 30px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}
.blog .blog-comments .reply-form h4 {
  font-weight: bold;
  font-size: 22px;
}
.blog .blog-comments .reply-form p {
  font-size: 14px;
}
.blog .blog-comments .reply-form input {
  border-radius: 4px;
  padding: 10px 10px;
  font-size: 14px;
}
.blog .blog-comments .reply-form input:focus {
  box-shadow: none;
  border-color: #ee9293;
}
.blog .blog-comments .reply-form textarea {
  border-radius: 4px;
  padding: 10px 10px;
  font-size: 14px;
}
.blog .blog-comments .reply-form textarea:focus {
  box-shadow: none;
  border-color: #ee9293;
}
.blog .blog-comments .reply-form .form-group {
  margin-bottom: 25px;
}
.blog .blog-comments .reply-form .btn-primary {
  border-radius: 4px;
  padding: 10px 20px;
  border: 0;
  background-color: #111111;
}
.blog .blog-comments .reply-form .btn-primary:hover {
  background-color: #1e1e1e;
}
.blog .blog-pagination {
  color: #444444;
}
.blog .blog-pagination ul {
  display: flex;
  padding: 0;
  margin: 0;
  list-style: none;
}
.blog .blog-pagination li {
  margin: 0 5px;
  transition: 0.3s;
}
.blog .blog-pagination li a {
  color: #111111;
  padding: 7px 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.blog .blog-pagination li.active,
.blog .blog-pagination li:hover {
  background: #e03a3c;
}
.blog .blog-pagination li.active a,
.blog .blog-pagination li:hover a {
  color: #fff;
}
.blog .sidebar {
  padding: 20px;
  margin: 0 0 0px 0px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}
.blog .sidebar .sidebar-title {
  font-size: 20px;
  font-weight: 700;
  padding: 0 0 0 0;
  margin: 0 0 15px 0;
  color: #111111;
  position: relative;
}
.blog .sidebar .sidebar-item {
  margin-bottom: 30px;
}
.blog .sidebar .search-form form {
  background: #fff;
  border: 1px solid #ddd;
  padding: 3px 10px;
  position: relative;
}
.blog .sidebar .search-form form input[type="text"] {
  border: 0;
  padding: 4px;
  border-radius: 4px;
  width: calc(100% - 40px);
}
.blog .sidebar .search-form form button {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  border: 0;
  background: none;
  font-size: 16px;
  padding: 0 15px;
  margin: -1px;
  background: #e03a3c;
  color: #fff;
  transition: 0.3s;
  border-radius: 0 4px 4px 0;
  line-height: 0;
}
.blog .sidebar .search-form form button i {
  line-height: 0;
}
.blog .sidebar .search-form form button:hover {
  background: #e34c4d;
}
.blog .sidebar .categories ul {
  list-style: none;
  padding: 0;
}
.blog .sidebar .categories ul li + li {
  padding-top: 10px;
}
.blog .sidebar .categories ul a {
  color: #111111;
  transition: 0.3s;
}
.blog .sidebar .categories ul a:hover {
  color: #e03a3c;
}
.blog .sidebar .categories ul a span {
  padding-left: 5px;
  color: #aaaaaa;
  font-size: 14px;
}
.blog .sidebar .recent-posts .post-item + .post-item {
  margin-top: 15px;
}
.blog .sidebar .recent-posts img {
  width: 80px;
  float: left;
}
.blog .sidebar .recent-posts h4 {
  font-size: 15px;
  margin-left: 95px;
  font-weight: bold;
}
.blog .sidebar .recent-posts h4 a {
  color: #111111;
  transition: 0.3s;
}
.blog .sidebar .recent-posts h4 a:hover {
  color: #e03a3c;
}
.blog .sidebar .recent-posts time {
  display: block;
  margin-left: 95px;
  font-size: 14px;
  color: #aaaaaa;
}
.blog .sidebar .tags {
  margin-bottom: -10px;
}
.blog .sidebar .tags ul {
  list-style: none;
  padding: 0;
}
.blog .sidebar .tags ul li {
  display: inline-block;
}
.blog .sidebar .tags ul a {
  color: #515151;
  font-size: 14px;
  padding: 6px 14px;
  margin: 0 6px 8px 0;
  border: 1px solid #c4c4c4;
  display: inline-block;
  transition: 0.3s;
}
.blog .sidebar .tags ul a:hover {
  color: #fff;
  border: 1px solid #e03a3c;
  background: #e03a3c;
}
.blog .sidebar .tags ul a span {
  padding-left: 5px;
  color: #aaaaaa;
  font-size: 14px;
}

/* Header & Nav */
.header {
  background-color: rgba(181, 143, 112, 0.74);
  padding: 15px 0;
  position: sticky;
  top: 0;
  z-index: 1000;
  backdrop-filter: blur(3px);
}
.header-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 4%;
}
.logo {
  font-size: 1.6rem;
  font-weight: 700;
  color: #fff;
  margin: 0;
}
.logo_accent {
  color: #e8d7ca;
  font-style: normal;
}

/* Use a serif display font for the site logo only */
.logo {
  font-family: "Playfair Display", serif;
  letter-spacing: 0.5px;
}
.nav ul {
  display: flex;
  list-style: none;
  margin: 0;
}
.nav ul li {
  margin-left: 20px;
}
.nav ul li a {
  text-decoration: none;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 500;
}

/* Hide the raw menu button on desktop; show via the mobile media query below */
.menu-btn {
  display: none;
}

/* Hero */
.hero {
  height: 100vh;
  position: relative;
  overflow: hidden;
}
.hero-overlay {
  height: 100%;
  background: transparent; /* keep photo visible, don't darken entire image */
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 2;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform-origin: center center;
  transform: scale(1);
  transition:
    transform 0.1s linear,
    opacity 0.5s ease;
  z-index: 0;
}
.hero-text-box {
  position: relative;
  z-index: 3;
}
.hero-bg.front {
  z-index: 1;
  opacity: 1;
}
.hero-bg.back {
  z-index: 0;
  opacity: 0;
}
.hero-text-box {
  background: transparent;
  padding: 40px;
  text-align: center;
  border-radius: 10px;
  box-shadow: none;
}
.hero-subtitle {
  font-size: 1.8rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
}
.hero-description {
  color: #fff;
  text-shadow: 0 4px 12px rgba(0, 0, 0, 0.38);
}

.hero::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 150px; /* グラデーションの高さ。お好みで調整してください */
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
  z-index: 5; /* 背景画像(z-index: 1~2)より大きく、テキストより小さい値 */
  pointer-events: none; /* 下にあるボタンなどのクリックを邪魔しない設定 */
}

.btn-primary {
  background-color: #8cae50;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  border: none;
  padding: 12px 35px;
  border-radius: 30px;
}
/* Decorative backbox for hero text (large centered stripe with subtle gradient highlight) */
.backbox {
  text-transform: uppercase;
  font-size: 3rem;
  color: white;
  width: 75%;
  position: relative;
  left: 0;
  top: 0rem;
  text-align: center;
  padding: 0.0625rem;
  background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuNSIgeDI9IjEuMCIgeTI9IjAuNSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjQwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjMiLz48c3RvcCBvZmZzZXQ9IjYwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjMiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmZmZmZmYiIHN0b3Atb3BhY2l0eT0iMC4wIi8+PC9saW5lYXJHcmFkaWVudD48L2RlZnM+PHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgZmlsbD0idXJsKCNncmFkKSIgLz48L3N2Zz4g");
  background-size: 100%;
  background-image: -webkit-gradient(linear, 0% 50%, 100% 50%, color-stop(0%, rgba(204, 165, 131, 0)), color-stop(40%, rgba(204, 165, 131, 0.3)), color-stop(60%, rgba(204, 165, 131, 0.3)), color-stop(100%, rgba(204, 165, 131, 0)));
  background-image: -moz-linear-gradient(left, rgba(204, 165, 131, 0), rgba(204, 165, 131, 0.3) 40%, rgba(204, 165, 131, 0.3) 60%, rgba(204, 165, 131, 0));
  background-image: -webkit-linear-gradient(left, rgba(204, 165, 131, 0), rgba(204, 165, 131, 0.3) 40%, rgba(204, 165, 131, 0.3) 60%, rgba(204, 165, 131, 0));
  background-image: linear-gradient(90deg, rgba(204, 165, 131, 0) 0%, rgba(204, 165, 131, 0.7) 35%, rgba(204, 165, 131, 0.7) 71%, rgba(204, 165, 131, 0) 100%);
}
.backbox:before {
  width: 100%;
  height: 0.125rem;
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuNSIgeDI9IjEuMCIgeTI9IjAuNSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjQwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjgiLz48c3RvcCBvZmZzZXQ9IjYwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjgiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmZmZmZmYiIHN0b3Atb3BhY2l0eT0iMC4wIi8+PC9saW5lYXJHcmFkaWVudD48L2RlZnM+PHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgZmlsbD0idXJsKCNncmFkKSIgLz48L3N2Zz4g");
  background-size: 100%;
  background-image: -webkit-gradient(linear, 0% 50%, 100% 50%, color-stop(0%, rgba(255, 255, 255, 0)), color-stop(40%, rgba(255, 255, 255, 0.8)), color-stop(60%, rgba(255, 255, 255, 0.8)), color-stop(100%, rgba(255, 255, 255, 0)));
  background-image: -moz-linear-gradient(left, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8) 40%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0));
  background-image: -webkit-linear-gradient(left, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8) 40%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0));
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8) 40%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0));
}
.backbox:after {
  width: 100%;
  height: 0.125rem;
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuNSIgeDI9IjEuMCIgeTI9IjAuNSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjQwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjgiLz48c3RvcCBvZmZzZXQ9IjYwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjgiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmZmZmZmYiIHN0b3Atb3BhY2l0eT0iMC4wIi8+PC9saW5lYXJHcmFkaWVudD48L2RlZnM+PHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgZmlsbD0idXJsKCNncmFkKSIgLz48L3N2Zz4g");
  background-size: 100%;
  background-image: -webkit-gradient(linear, 0% 50%, 100% 50%, color-stop(0%, rgba(255, 255, 255, 0)), color-stop(40%, rgba(255, 255, 255, 0.8)), color-stop(60%, rgba(255, 255, 255, 0.8)), color-stop(100%, rgba(255, 255, 255, 0)));
  background-image: -moz-linear-gradient(left, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8) 40%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0));
  background-image: -webkit-linear-gradient(left, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8) 40%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0));
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8) 40%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0));
}

/* move large heading size to subtitle only, and keep button small & centered */
.backbox .hero-subtitle {
  font-size: 3rem;
  margin: 0 0 6px;
  margin-top: 20px;
}
.backbox .hero-description {
  font-size: 1.52rem;
  margin-bottom: 12px;
}
.backbox .hero-btns {
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}
.backbox .hero-btns .btn-primary {
  font-size: 1.05rem;
  padding: 10px 26px;
  border-radius: 22px;
  display: inline-block;
  min-width: 180px;
  line-height: 1.2;
}

.contact .php-email-form button[type="submit"] {
  background: #e03a3c;
  border: 0;
  padding: 10px 32px;
  color: #fff;
  transition: 0.4s;
  border-radius: 4px;
}

@media (max-width: 768px) {
  .nav ul {
    display: block;
    list-style: none;
    margin: 0;
    width: 100%;
    padding: 0;
  }
  .backbox {
    width: 86%;
    left: 0;
    top: 0rem;
  }
  .backbox .hero-subtitle {
    font-size: 1.6rem;
  }
  .backbox .hero-description {
    font-size: 0.95rem;
  }
  .backbox .hero-btns .btn-primary {
    min-width: 140px;
    padding: 10px 20px;
    font-size: 1rem;
  }
}

/* サブ画像 高さを統一 */
.sub-visuals img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.rounded-15 {
  border-radius: 15px;
}

/* Sections */
.section-padding {
  padding: 80px 0;
}
.bg-beige-light {
  background-color: #f7f3f0;
}
.section-title h1,
.section-title h2 {
  color: var(--dark-beige);
  font-weight: 400;
}
.custom-hr {
  width: 140px;
  height: 12px;
  border: none;
  margin: 14px auto;
  /* repeating decorative diamond pattern using inline SVG so it remains self-contained */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='12' viewBox='0 0 24 12'><polygon points='0,6 6,0 12,6 6,12' fill='%23bfa58d'/><polygon points='12,6 18,0 24,6 18,12' fill='%23d8bfa9' opacity='0.6'/></svg>");
  background-repeat: repeat-x;
  background-position: center;
  background-size: 24px 12px;
  opacity: 1;
}

/* utility for a thinner decorative separator (useful in other spots) */
.fancy-hr {
  width: 100%;
  height: 8px;
  border: none;
  margin: 18px 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='8' viewBox='0 0 16 8'><polygon points='0,4 4,0 8,4 4,8' fill='%23bfa58d'/></svg>");
  background-repeat: repeat-x;
  background-size: 16px 8px;
}

/* News & Tabs Styles */
.news-box {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}
.sample_img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 50%;
  border: 3px solid var(--main-beige);
}
.custom-tab h4 {
  font-size: 1rem;
  margin-top: 10px;
  color: var(--text-color);
}

/* Tabs - nicer grid, circular thumbs, active card style */
.nav.nav-tabs.row.d-flex {
  gap: 0.7rem 0.9rem;
  justify-content: center;
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(200px, 340px));
  align-items: start;
}
.nav.nav-tabs .nav-item {
  display: flex;
  justify-content: center;
}
.nav.nav-tabs .nav-link {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border-radius: 12px;
  color: var(--text-color);
  background: #fff0;
  /* border: 1px solid rgba(0,0,0,0.035); */
  /* box-shadow: 0 3px 10px rgba(0,0,0,0.03); */
  text-decoration: none;
  width: 100%;
  max-width: 340px;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease;
}
.nav.nav-tabs .nav-link .sample_img {
  width: 125px;
  height: 125px;
  object-fit: cover;
  border-radius: 50%;
  border: 3px solid rgba(216, 191, 169, 0.5);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04);
}
.nav.nav-tabs .nav-link h4 {
  color: var(--text-color);
  margin: 0;
  font-weight: 700;
  font-size: 1.05rem;
}
.nav.nav-tabs .nav-link:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.055);
}
.nav.nav-tabs .nav-link.active,
.nav.nav-tabs .nav-link.show.active {
  background: #fff;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.055);
  border-color: rgba(189, 150, 120, 0.12);
  transform: none;
}
.nav.nav-tabs .nav-link.active h4 {
  color: var(--text-color);
}

/* Make layout tighter on medium screens */
@media (min-width: 992px) {
  .nav.nav-tabs.row.d-flex {
    grid-template-columns: repeat(2, 360px);
  }
}

/* Stack to single column on small screens */
@media (max-width: 767px) {
  .nav.nav-tabs.row.d-flex {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .nav.nav-tabs .nav-link {
    flex-direction: row;
    max-width: none;
  }
}

/* News links: use theme color instead of default blue */
.news-box a,
.news-box a:link,
.news-box a:visited {
  color: var(--text-color);
  text-decoration: none;
}
.news-box a:hover {
  color: var(--dark-beige);
  text-decoration: underline;
}

/* Small tweak: ensure sample_img in other contexts keeps circular appearance */
.sample_img {
  display: inline-block;
}

/* 店舗案内 */
.count-box {
  background: #fff;
  border-radius: 20px;
  border: 2px solid var(--main-beige);
  overflow: hidden;
}
.btn-detail {
  background-color: var(--dark-beige);
  color: #fff;
  border-radius: 25px;
}

/* Responsive */
@media (max-width: 768px) {
  /* shrink the top-right hamburger to ~80% of previous size */
  .menu-btn {
    display: block;
    background: none;
    border: none;
    width: 24px;
    height: 19px;
    position: relative;
    z-index: 1300;
  }
  .menu-btn span {
    display: block;
    width: 100%;
    height: 2px;
    background: #fff;
    position: absolute;
    transition: 0.3s;
  }
  .menu-btn span:nth-child(1) {
    top: 0;
  }
  .menu-btn span:nth-child(2) {
    top: 8px;
  }
  .menu-btn span:nth-child(3) {
    bottom: 0;
  }
  .menu-btn.open span:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
  }
  .menu-btn.open span:nth-child(2) {
    opacity: 0;
  }
  .menu-btn.open span:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
  }

  /* scope mobile header nav to avoid matching other .nav usages (e.g. tabs) */
  .header .nav {
    position: fixed;
    top: 0;
    right: -100%;
    width: 70%;
    height: 100vh;
    background: var(--dark-beige);
    transition: 0.4s;
    padding-top: 80px;
    z-index: 1200;
  }
  .header .nav.open {
    right: 0;
  }
  .header .nav ul {
    flex-direction: column;
    align-items: center;
  }
  .header .nav ul li {
    margin: 15px 0;
  }
  /* center the menu text inside the mobile side panel */
  .header .nav ul li a {
    display: block;
    width: 100%;
    text-align: center;
    padding: 12px 0;
    color: #fff;
    font-weight: 600;
  }
  .header .nav ul li a:hover {
    color: #fff;
    opacity: 0.95;
  }

  /* News list on mobile: image left, text right (like PC) */
  .news-box li {
    flex-direction: row;
    text-align: left;
    align-items: center;
    gap: 12px;
  }
  .news-box .w-25 {
    width: 30% !important;
    margin: 0 !important;
  }
  .news-box .w-75 {
    width: 70% !important;
    margin: 0 !important;
  }
  .news-box .w-25 img {
    width: 100%;
    height: auto;
    border-radius: 8px;
  }
  /* Center news list items and tabs on small screens */
  .news-box ul {
    padding: 0 8px;
  }
  .news-box li {
    width: 100%;
    max-width: 520px;
    margin: 0 auto 8px;
  }

  /* hero box taller on mobile - fill full viewport height */
  .hero {
    height: 100vh;
  }
  .hero-text-box {
    padding: 16px;
    margin: 0 8px;
  }
  .hero-subtitle {
    font-size: 1.2rem;
  }
  .hero-description {
    font-size: 0.95rem;
  }

  /* Mobile: force two-column grid and tighten spacing (override bootstrap .row) */
  .nav.nav-tabs.row.d-flex {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(140px, 1fr));
    gap: 8px;
    align-items: start;
    padding: 0 8px;
    margin-left: 0;
    margin-right: 0;
  }
  .nav.nav-tabs.row.d-flex .nav-item {
    width: 100%;
  }
  .nav.nav-tabs .nav-link {
    width: 100%;
    max-width: none;
    margin: 0;
    box-sizing: border-box;
    padding: 8px 10px;
  }
  .nav.nav-tabs .nav-link {
    display: flex;
    align-items: center;
  }
  .nav.nav-tabs {
    justify-items: center;
  }
  .nav.nav-tabs .nav-link h4 {
    text-align: left;
  }
  .section-title {
    padding-left: 8px;
    padding-right: 8px;
  }
}

.footer {
  background: rgba(216, 191, 169, 0.77);
  color: #fff;
  padding: 8px 0;
}

.footer p {
  font-size: 11px;
}
.btn-success {
  --bs-btn-bg: #40c135;
  --bs-btn-border-color: #56a480;
}

/* 背景の共通設定 */
.hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  z-index: 1;
}

/* ズームアニメーション本体 */
@keyframes zoomAnimation {
  0% {
    transform: scale(1);
    opacity: 0;
  }
  5% {
    opacity: 1;
  } /* 最初の5%でフェードイン */
  95% {
    opacity: 1;
  } /* 95%まで表示維持 */
  100% {
    transform: scale(1.1);
    opacity: 0;
  } /* 最後までズームしながらフェードアウト */
}

/* このクラスがついた時に動く */
.hero-bg.is-active {
  animation: zoomAnimation 8s linear forwards;
  z-index: 2;
}

#map {
  height: 650px;
}
#map p {
  padding: 0;
  margin: 0;
}
#map2 {
  height: 650px;
}
#map2 p {
  padding: 0;
  margin: 0;
}

.swiper-slide img {
  width: 100%;
  height: auto;
}
button,
input,
optgroup,
select,
textarea {
  font-family: arial;
  padding: 5px;
}
select#language option[value="?language=portuguese"] {
  background-image: url(../images/flags/portuguese.png);
}
select#language option[value="?language=japanese"] {
  background-image: url(../images/flags/japanese.png);
}

.news li {
  border-bottom: 1px dotted;
}

.news_date {
  /* width: 180px; */
}
.news_tag {
  /* width: 180px; */
}

.btn-success {
  background-color: #4dbf5a;
}
.footer_logo {
  max-width: 100%;
}

.btn {
  box-shadow: 0px 4px #ccc;
}

#language {
  background: white;
}
.blog h1 {
  padding-bottom: 20px;
  border-bottom: 1px solid;
}

th {
  vertical-align: middle;
}
.blog .entry .entry-meta ul li + li + li::before {
  content: ",";
  padding-right: 10px;
}
.box_image {
  height: 300px;
  width: 100%;
  /* content: " "; */
  background-size: cover !important;
}

.woman {
  top: -195px;
}

.sample_img {
  width: 140px;
  height: auto;
  border-radius: 0px;
  margin: 0 10px 0 3px;
}

.today {
  background: #066dc8 !important;
  color: white;
}
.today a {
  color: white;
}
.day a::after {
  content: "●";
  font-size: smaller;
  /* vertical-align: super; */
  position: absolute;
}
.week {
  background-color: #f4efefde !important;
}

#footer a {
  color: #fff;
}
.page .h2::before {
  border-bottom: 2px solid #e03a3c;
  content: " ";
  width: 2rem;
  position: absolute;
  bottom: -2px;
}
.page .h2 {
  position: relative;
  font-size: 1.5rem;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid;
  font-weight: bold;
}

.post-item p {
  margin-bottom: 0rem;
  margin-left: 95px;
  font-size: small;
}

.non_home .img {
  padding: 20px;
}

.tags {
  list-style: none;
  display: inline;
  padding: 0;
  font-size: 14px;
}
.tags li {
  display: inline-block;
}
.tags li + li::before {
  padding-right: 6px;
  color: #6c757d;
  content: ",";
}
.badge {
  line-height: inherit !important;
  height: fit-content;
}

.swiper {
  padding: 0;
}

.h3,
h3 {
  font-size: 1.35rem;
  font-weight: bold;
}

figure.image {
  margin: 3px;
  padding: 10px;
  background-color: #f7f7f7;
  /* border: 1px solid #ccc; */
  border-radius: 5px;
  display: inline-block;
  max-width: 100%;
}
figure.image img {
  max-width: 100%;
  height: auto;
}
.counts .count-box {
  height: 100%;
}

.blog_list_img {
  max-height: 180px;
}
.blog img {
  max-width: 100%;
  height: auto;
}
.sr-only {
  display: none;
}
.page-item.active .page-link {
  z-index: 3;
  color: #fff;
  background-color: #e65d5f;
  border-color: #e65d5f;
}
/* a {
  color: #e03a3c;
  text-decoration: none;
} */
.page-link {
  position: relative;
  display: block;
  color: #e03a3c;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #dee2e6;
  transition:
    color 0.15s ease-in-out,
    background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
}

.nagare_right_arrow {
  position: absolute;
  right: -12px;
  top: 50%;
  font-size: 25px;
  color: #bf0001;
}
.nagare_bottom_arrow {
  font-size: 25px;
  position: absolute;
  bottom: -35px;
  left: 50%;
}

.counts {
  padding-top: 25px;
}
