
@charset "UTF-8";


/* -------------------------------------------
   Main Content Elements
------------------------------------------- */
/* MV */
.mv { position: relative; height: 550px; background-color: #f4ece2; background-size: cover; background-position: center; display: flex; align-items: center; justify-content: center; }
.mv-content { background-color: rgba(255, 255, 255, 0.85); padding: 40px 30px; border-radius: 30px; margin: 0 20px; text-align: center; box-shadow: 0 10px 25px rgba(0,0,0,0.05); max-width: 650px; }
.mv h1 { 
    font-size: clamp(1.4rem, 4vw, 2.4rem); 
    margin-bottom: 15px; 
    color: #5a4a42; 
    line-height: 1.6; 
    font-weight: 700; 
}.mv p { font-size: 1.1rem; color: #e8a798; font-weight: bold; }

/* Concept */
.concept { background-color: #fff; border-radius: 0 0 50px 50px; }
.check-list { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; margin-bottom: 50px; }
.check-item { background-color: #fcf9f4; border: 2px dashed #e8a798; padding: 20px; border-radius: 20px; width: 100%; max-width: 400px; display: flex; align-items: center; }
.check-icon { font-size: 1.8rem; margin-right: 15px; background: #fff; width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; border-radius: 50%; color: #e8a798; }
.concept-message { max-width: 800px; margin: 0 auto; text-align: center; font-size: 1.1rem; line-height: 2; }

/* Menu */
.menu-grid { display: grid; grid-template-columns: 1fr; gap: 40px; }
@media (min-width: 768px) { .menu-grid { grid-template-columns: 1fr 1fr; } }
.menu-card { background-color: #fff; border-radius: 30px; overflow: hidden; box-shadow: 0 5px 20px rgba(90, 74, 66, 0.08); transition: transform 0.3s; }
.menu-card:hover { transform: translateY(-5px); }
.menu-img-area { height: 220px; background-color: #eaddd3; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: bold; background-size: cover; background-position: center; }
.menu-content { padding: 30px; }
.menu-tag { background-color: #fdf2f0; color: #e8a798; font-size: 0.8rem; padding: 5px 12px; border-radius: 20px; display: inline-block; margin-bottom: 15px; font-weight: bold; }
.menu-title { font-size: 1.4rem; margin-bottom: 15px; color: #5a4a42; border-bottom: 3px dotted #e8a798; padding-bottom: 5px; display: inline-block; }
.menu-desc { font-size: 0.95rem; margin-bottom: 20px; }
.menu-card ul { margin-bottom: 20px; }
.menu-card li::before { content: "✔"; color: #e8a798; margin-right: 5px; }

/* Unique Section */
.unique-section { background-color: #fff; border-radius: 50px; padding: 60px 20px; margin: 60px 0; }
.unique-intro { text-align: center; margin-bottom: 50px; font-size: 1.1rem; }
.unique-grid { display: grid; grid-template-columns: 1fr; gap: 30px; max-width: 900px; margin: 0 auto; }
@media (min-width: 768px) { .unique-grid { grid-template-columns: repeat(3, 1fr); } }
.unique-card { background-color: #fcf9f4; border: 2px solid #f4ece2; border-radius: 20px; padding: 30px 20px; text-align: center; transition: 0.3s; }
.unique-card:hover { border-color: #e8a798; transform: translateY(-3px); }
.unique-icon { font-size: 3rem; margin-bottom: 15px; display: block; }
.unique-title { font-size: 1.1rem; color: #5a4a42; margin-bottom: 15px; font-weight: bold; }
.unique-text { font-size: 0.9rem; text-align: left; }

/* Features & Amenity & Access */
.reason-list { display: flex; flex-wrap: wrap; justify-content: center; gap: 30px; }
.reason-item { width: 100%; max-width: 300px; text-align: center; background: #fff; padding: 30px 20px; border-radius: 20px; }
.reason-icon-circle { width: 80px; height: 80px; background-color: #fdf2f0; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 2.5rem; margin: 0 auto 20px; color: #e8a798; }
.amenity-section { text-align: center; margin-bottom: 80px; }
.amenity-box { background-color: #fdf2f0; padding: 40px; border-radius: 30px; display: inline-block; width: 100%; max-width: 900px; }
.amenity-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 15px; margin-top: 20px; }
.amenity-item { background: #fff; padding: 10px 20px; border-radius: 20px; font-size: 0.9rem; color: #5a4a42; box-shadow: 0 2px 5px rgba(0,0,0,0.05); }
/* -------------------------------------------
   スマホ版のみアメニティのテキストを左寄せ
------------------------------------------- */
@media (max-width: 767px) {
    .amenity-box h3,
    .amenity-box p {
        text-align: left;
    }
    
    /* ※もしアメニティのリスト（タグ）も左寄せにしたい場合は以下も追加してください */
    /*
    .amenity-grid {
        justify-content: flex-start;
    }
    */
}

.access-box { background-color: #fff; padding: 40px; border-radius: 30px; box-shadow: 0 5px 20px rgba(0,0,0,0.05); }
.access-dl { display: flex; flex-wrap: wrap; margin-bottom: 30px; }
.access-dl dt { width: 30%; padding: 10px 0; font-weight: bold; border-bottom: 1px dashed #eee; color: #e8a798; }
.access-dl dd { width: 70%; padding: 10px 0; border-bottom: 1px dashed #eee; }
.map-placeholder { width: 100%; height: 300px; background-color: #eaddd3; display: flex; align-items: center; justify-content: center; border-radius: 10px; color: #fff; }

/* お知らせ一覧のテキストリンク */
.link-text-arrow {
    display: inline-block;
    color: #e8a798;
    font-weight: bold;
    text-decoration: none;
    transition: 0.3s;
}
.link-text-arrow:hover {
    color: #eea190;
    transform: translateX(5px); /* ホバー時に少し右へ動く */
}


/* -------------------------------------------
   Amenity Section
------------------------------------------- */
.amenity-section { text-align: center; margin-bottom: 80px; }
.amenity-box { background-color: #fdf2f0; padding: 40px; border-radius: 30px; display: inline-block; width: 100%; max-width: 900px; }

/* アメニティ: リード文と説明文 (修正: 太字解除) */
.amenity-box h3 {
    color: #5a4a42;
    margin-bottom: 15px;
    font-weight: normal; 
    font-size: 1.2rem;
}
.amenity-box p {
    margin-bottom: 20px;
    font-weight: normal;
    font-size: 1rem;
}

/* アメニティリスト */
.amenity-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px; 
    margin-top: 20px;
}
.amenity-item {
    background: #fff;
    padding: 12px 25px; 
    border-radius: 20px;
    font-size: 0.9rem;
    color: #5a4a42;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}
@media (max-width: 767px) {
    .amenity-grid { gap: 15px; }
    .amenity-item { padding: 10px 20px; }
}

/* -------------------------------------------
   Flow & FAQ Section
------------------------------------------- */
.flow-cta .section-title {
    /* タイトルの中央寄せ */
    text-align: center;
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
}


/* -------------------------------------------
   Reason Section (修正)
------------------------------------------- */
.reason-icon-circle img {
    /* 丸い枠内に画像を中央配置 */
    width: auto;
    height: auto;
    max-width: 60%; /* 枠に対して60%くらいのサイズ感 */
    max-height: 60%;
    object-fit: contain;
}