@charset "UTF-8";

/* ===== Theme (White base) ===== */
:root{
  --bg:#ffffff;
  --ink:#1f1f1f;
  --muted:#6f6f6f;
  --gold:#c2a661;     /* ??style.css?̃S?[???h???C???Ɋｹ */
  --line:#e9e6df;
  --card:#ffffff;
  --card2:#faf8f2;    /* ?????a???F */
  --shadow:0 6px 14px rgba(0,0,0,.07);
}

html,body{height:100%;margin:0;background:var(--bg);color:var(--ink);font-family:"Noto Sans JP",sans-serif;line-height:1.8}
*{box-sizing:border-box}
a{color:inherit;text-decoration:none}
a:hover{color:#a67c00}
img{max-width:100%;height:auto;display:block}
.container{width:min(1100px,92vw);margin-inline:auto}

/* ===== Header ===== */
header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);z-index:10}
.nav{display:flex;justify-content:space-between;align-items:center;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand__logo{width:34px;height:34px;border-radius:10px;background:var(--gold)}
.brand__name{font-family:"Noto Serif JP";font-weight:700;letter-spacing:.02em}
.nav__links{display:flex;gap:18px;flex-wrap:wrap}
.nav__links a{color:var(--muted)}
.nav__links a:hover{color:var(--ink)}
@media(max-width:780px){.nav__links{gap:12px;font-size:.95rem}}

/* ===== Sections ===== */
section{padding:46px 0;border-bottom:1px solid var(--line)}
h1,h2{font-family:"Noto Serif JP"}
h2{font-size:1.5rem;margin:0 0 18px}
.center{text-align:center}

/* ===== Hero ===== */
.hero{position:relative;padding-top:26px}
.hero__media{position:relative;height:48vh;min-height:340px;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero__media::after{
  content:"";
  position:absolute;inset:0;
  /* ??style.css?́u???ɗn???驕v?v?z?𓥏P */
  background:linear-gradient(180deg,rgba(255,255,255,0) 55%,rgba(255,255,255,.85) 92%,#fff 100%);
}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:left center}
.hero__copy{margin-top:-34px;position:relative;padding:0 18px}
.badge{display:inline-block;padding:6px 10px;font-size:.8rem;color:#fff;background:rgba(31,31,31,.88);border-radius:999px;font-weight:700;letter-spacing:.06em}
.hero__title{font-size:clamp(1.6rem,4.5vw,2.6rem);margin:.55rem 0 0}
.hero__lead{color:var(--muted);margin:.35rem 0 0}

/* ===== Buttons ===== */
.reserve-links{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:12px;margin-top:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 18px;border-radius:999px;border:1px solid var(--gold);background:#fff;color:var(--ink);white-space:nowrap}
.btn:hover{background:rgba(194,166,97,.12)}
.btn-gold{background:var(--gold);border-color:var(--gold);color:#111;font-weight:700}
.btn-gold:hover{opacity:.88}
.btn-line{background:#06C755;border-color:#06C755;color:#fff}
.btn-line:hover{opacity:.88}

/* ===== Layout ===== */
.grid{display:grid;gap:20px}
.grid--2{grid-template-columns:1.1fr .9fr}
.grid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.grid--2,.grid--3{grid-template-columns:1fr}}

/* ===== Cards ===== */
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.card__body{padding:18px}
.card__media{aspect-ratio:16/9;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover}

/* ===== Info boxes ===== */
.info{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.info__box{background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:14px}
@media(max-width:780px){.info{grid-template-columns:1fr}}

/* ===== Tags ===== */
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{border:1px solid var(--line);color:var(--muted);padding:6px 10px;border-radius:999px;font-size:.85rem;background:#fff}

/* ===== Access ===== */
.access__map{aspect-ratio:16/9;border:0;width:100%;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.addr{font-style:normal}

/* ===== Button group (PC???ﾑ / SP?ܕԂ?) ===== */
.btn-group{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
@media(min-width:820px){
  .btn-group{flex-wrap:nowrap}
  .btn-group .btn{flex:1 1 0;text-align:center;padding:10px 12px;font-size:.95rem}
}

/* ===== Footer ===== */
footer{background:#f7f7f7;color:#555;border-top:1px solid var(--line);padding:30px 0 50px;font-size:.9rem}
.footerRow{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
