@charset "UTF-8";

.facilities-main{
  padding-bottom:96px;
  background:
/*
    radial-gradient(circle at top right, rgba(242,106,33,.08), transparent 28%),
*/
    linear-gradient(180deg, #fbfcfe 0%, #f5f7fa 100%);
}
.facilities-hero{
  position:relative;
  overflow:hidden;
  min-height:min(76vh, 760px);
  display:grid;
  align-items:end;
  background:#0f1723;
}
.facilities-hero__media,
.facilities-hero__media::after{ position:absolute; inset:0; }
.facilities-hero__media img{
  width:100%; height:100%; object-fit:cover;
  filter:saturate(1.02) contrast(1.02);
}
.facilities-hero__media::after{
  content:"";
  background:
    linear-gradient(90deg, rgba(9,16,30,.78) 0%, rgba(9,16,30,.42) 44%, rgba(9,16,30,.14) 100%),
    linear-gradient(180deg, rgba(9,16,30,.06) 0%, rgba(9,16,30,.48) 100%);
}
.facilities-hero__inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(260px, 340px);
  gap:32px;
  align-items:end;
  padding:clamp(96px, 14vw, 148px) 0 56px;
}
.facilities-eyebrow{display:inline-flex; align-items:center; gap:0; margin-bottom:18px; color:rgba(255,255,255,.90); letter-spacing:.18em; font-size:.78rem; font-weight:800; text-transform:uppercase;}
.facilities-eyebrow::before{content:none; display:none;}
.facilities-hero h1{margin:0 0 18px; color:#fff; font-size:clamp(2.4rem, 5.2vw, 4.8rem); letter-spacing:.05em; line-height:1.04;}
.facilities-hero p{margin:0; max-width:720px; color:rgba(255,255,255,.88); font-size:clamp(1rem, 1.4vw, 1.12rem); line-height:1.95;}
.facilities-hero__panel{justify-self:end; width:min(100%, 340px); padding:22px 22px 20px; border-radius:26px; background:rgba(255,255,255,.90); border:1px solid rgba(255,255,255,.34); box-shadow:0 18px 56px rgba(9,16,30,.16); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);}
.facilities-hero__panelLabel{display:block; margin-bottom:12px; color:var(--ss-accent); font-size:.76rem; font-weight:800; letter-spacing:.18em;}
.facilities-hero__panel ul{margin:0; padding:0; list-style:none; display:grid; gap:10px;}
.facilities-hero__panel li{display:flex; align-items:center; gap:10px; color:var(--ss-text); font-weight:700;}
.facilities-hero__panel li::before{content:""; width:8px; height:8px; border-radius:999px; background:var(--ss-accent); box-shadow:0 0 0 6px rgba(242,106,33,.12); flex:0 0 auto;}


.facilities-intro{padding:34px 0 8px;}
.facilities-intro__panel{display:grid; grid-template-columns:minmax(0, 1.2fr) minmax(260px, .8fr); gap:22px; padding:26px; border-radius:30px; background:linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.88) 100%); border:1px solid rgba(24,33,47,.08); box-shadow:0 18px 46px rgba(18,24,39,.06);}
.facilities-intro__panel p{margin:0; font-size:1rem; line-height:2; color:var(--ss-muted);}
.facilities-intro__points{display:grid; gap:10px; align-content:start;}
.facilities-intro__points span{display:flex; gap:10px; align-items:flex-start; color:var(--ss-text); font-weight:700; line-height:1.7;}
.facilities-intro__points span::before{content:""; margin-top:.45em; width:8px; height:8px; border-radius:999px; background:var(--ss-accent); box-shadow:0 0 0 6px rgba(242,106,33,.12); flex:0 0 auto;}

.facilities-main .shell{width:var(--ss-container);}

.facility-section{scroll-margin-top:calc(var(--ss-header-h) + 82px); padding:72px 0 0;}
.facility-section__head{display:grid; grid-template-columns:minmax(0, 1fr) minmax(260px, 340px); gap:28px; align-items:end; margin-bottom:28px;}
.facility-kicker{display:inline-flex; margin-bottom:16px; color:var(--ss-accent); font-size:.82rem; font-weight:800; letter-spacing:.17em;}
.facility-section h2{margin:0 0 16px; font-size:clamp(2rem, 3.2vw, 3rem); line-height:1.08; letter-spacing:.04em;}
.facility-section__lead{margin:0; max-width:760px; color:var(--ss-muted); font-size:1rem; line-height:2;}
/*削除
.facility-section__summary{padding:18px 20px; border-radius:24px; background:rgba(242,106,33,.08); color:var(--ss-text);}
.facility-section__summary strong{display:block; margin-bottom:6px; font-size:.8rem; letter-spacing:.14em; color:var(--ss-accent);}
.facility-section__summary p{margin:0; line-height:1.85; font-size:.96rem;}
*/
.facility-layout{display:grid; grid-template-columns:minmax(0, 1fr) minmax(280px, 300px); gap:clamp(16px, 1.8vw, 22px); align-items:start;}
.facility-gallery{display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:clamp(14px, 1.4vw, 18px); align-items:stretch;}
.facility-gallery.is-odd .facility-figure:last-child{grid-column:1 / 2; width:100%; max-width:none; justify-self:stretch;}
/*
.facility-figure{overflow:hidden; border-radius:28px; background:#fff; border:1px solid rgba(24,33,47,.08); box-shadow:0 18px 46px rgba(18,24,39,.06);}
*/
.facility-figure{
	margin: 10px;				  /* 追加 */
	overflow:hidden;
	border-radius:12px;		/* 変更 */
	background:#fff;
	border:1px solid rgba(24,33,47,.08);
	box-shadow:0 18px 46px rgba(18,24,39,.06);
}
/*
.facility-figure__media{display:grid; place-items:center; aspect-ratio:4 / 3; padding:14px; background:linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%);}
*/
.facility-figure__media{
	display:grid;
	place-items:center;
	aspect-ratio:4 / 3;
	padding:16px;					/* 変更 */
	background:linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%);
}
.facility-figure img{width:100%; height:100%; object-fit:contain; object-position:center;}
.facility-figure figcaption{padding:16px 18px 18px; color:var(--ss-muted); font-size:.95rem; line-height:1.75;}
.facility-figure figcaption strong{display:block; margin-bottom:6px; color:var(--ss-text); font-size:1rem;}

.facility-listCard{align-self:start; justify-self:stretch; position:sticky; top:calc(var(--ss-header-h) + 88px); max-width:300px; width:100%; margin:0; padding:24px 20px; border-radius:28px; background:#fff; border:1px solid rgba(24,33,47,.08); box-shadow:0 18px 46px rgba(18,24,39,.06);}
.facility-listCard__title{margin:0 0 16px; color:var(--ss-text); font-size:1.08rem; font-weight:800;}
.facility-list{margin:0; padding:0; list-style:none; display:grid; gap:10px;}
.facility-list li{display:flex; justify-content:space-between; gap:14px; padding:12px 14px; border-radius:18px; background:#f8fafc; border:1px solid rgba(24,33,47,.06); color:var(--ss-text); font-size:.95rem; line-height:1.55;}
.facility-list li span:last-child{color:var(--ss-muted); white-space:nowrap;}
.facility-note{margin-top:14px; padding:14px 16px; border-radius:18px; background:rgba(255,247,239,.96); color:var(--ss-muted); font-size:.9rem; line-height:1.7; border:1px solid rgba(242,106,33,.14);}

.facilities-cta{padding:78px 0 0;}
.facilities-cta__box{position:relative; overflow:hidden; padding:34px 32px; border-radius:34px; background:linear-gradient(135deg, rgba(255,251,247,.98) 0%, rgba(255,243,234,.98) 100%); border:1px solid rgba(242,106,33,.14); box-shadow:0 18px 50px rgba(18,24,39,.08);}
.facilities-cta__box::after{content:""; position:absolute; right:-36px; bottom:-38px; width:min(220px, 40vw); aspect-ratio:1/1; background:url("../images/footer-gasket.png") no-repeat center / contain; opacity:.16;}
.facilities-cta__inner{position:relative; z-index:1; display:flex; gap:24px; justify-content:space-between; align-items:center;}
.facilities-cta h2{margin:0 0 10px; font-size:clamp(1.5rem, 2.2vw, 2.2rem);}
.facilities-cta p{margin:0; color:var(--ss-muted); line-height:1.9;}
.facilities-btn{flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center; min-height:54px; padding:0 22px; border-radius:999px; background:var(--ss-accent); color:#fff; font-weight:800; letter-spacing:.04em; box-shadow:0 14px 26px rgba(242,106,33,.24);}
.facilities-btn:hover{opacity:.94;}

@media (max-width: 980px){
  .facilities-hero__inner,
  .facilities-intro__panel,
  .facility-section__head,
  .facility-layout{grid-template-columns:1fr;}
  .facilities-hero__panel{justify-self:start;}
  .facility-listCard{position:static;}
}
@media (max-width: 900px){
  .facilities-main{padding-bottom:72px;}
  .facilities-hero{min-height:auto;}
  .facilities-hero__inner{padding:112px 0 34px; gap:24px;}
  .facilities-hero h1{font-size:clamp(2.1rem, 10vw, 3rem);}
  .facilities-hero__panel{width:100%;}
  .facilities-intro__panel{padding:22px; border-radius:24px;}
  .facility-section{padding-top:58px;}
  .facility-gallery{grid-template-columns:1fr;}
  .facility-gallery.is-odd .facility-figure:last-child{grid-column:auto; width:100%;}
  .facility-figure__media{padding:14px;}
  .facilities-cta__inner{flex-direction:column; align-items:flex-start;}
}


/* ===== facilities layout tuning only / append at end ===== */

.facility-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 300px;
  gap:20px;
  align-items:start;
}

.facility-gallery{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.facility-gallery.is-odd{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.facility-gallery.is-odd .facility-figure:nth-child(3){
  grid-column:1 / 2;
}

.facility-figure{
  height:100%;
}

.facility-figure__media{
  aspect-ratio:4 / 3;
  display:flex;
  align-items:center;
  justify-content:center;
}

.facility-figure__media img{
  width:100%;
  height:100%;
  object-fit:contain;
}

.facility-listCard{
  align-self:start;
}

@media (max-width: 1024px){
  .facility-layout{
    grid-template-columns:minmax(0, 1fr) 280px;
    gap:18px;
  }

  .facility-gallery{
    gap:10px;
  }
}

@media (max-width: 900px){
  .facility-layout{
    grid-template-columns:1fr;
  }

  .facility-gallery,
  .facility-gallery.is-odd{
    grid-template-columns:1fr;
  }

  .facility-gallery.is-odd .facility-figure:nth-child(3){
    grid-column:auto;
  }

  .facility-listCard{
    width:100%;
  }
}


/* ===== facilities stacked list width fix ===== */
@media (max-width: 980px){
  .facility-listCard{
    position:static;
    max-width:none;
    width:100%;
    justify-self:stretch;
  }
}

@media (max-width: 900px){
  .facility-listCard{
    max-width:none;
    width:100%;
    justify-self:stretch;
  }

  /* サブナビ端の余白を増やし、右側項目も中央寄せしやすくする */
  .facilities-anchorNav__inner{
    padding-left: max(16px, calc(50vw - 110px));
    padding-right: max(16px, calc(50vw - 110px));
  }
}


/* ===== disable sticky hover on touch for facilities nav ===== */
@media (hover: none){
  .facilities-anchorNav a:hover{
    border-color:rgba(24,33,47,.10);
    color:rgba(24,33,47,.72);
    background:rgba(255,255,255,.92);
  }
}
