/* ============================================================
   ROOMS PAGE — sample/rooms/index.html 準拠 2026-04-29 REBUILT
   ============================================================ */

/* HERO */
.rm-hero{position:relative;height:500px;overflow:hidden;background:#1a2220}
.rm-hero__bg{position:absolute;inset:0;background:center/cover no-repeat;filter:saturate(.95)}
.rm-hero__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,34,32,.55) 0%,rgba(26,34,32,.3) 45%,rgba(26,34,32,.55) 100%)}
.rm-hero__inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 24px}
.rm-hero__label{font-family:"Playfair Display",serif;font-size:14px;letter-spacing:.6em;color:#fff;margin:0 0 22px;padding-left:.6em;text-shadow:0 2px 12px rgba(0,0,0,.5);opacity:.95}
.rm-hero__title{font-family:"Noto Serif JP",serif;font-size:56px;font-weight:500;letter-spacing:.16em;color:#fff;margin:0;text-align:center;text-shadow:0 4px 20px rgba(0,0,0,.55)}
.rm-hero__title em{font-family:"Playfair Display",serif;font-style:italic;font-weight:400;color:#fff;margin-right:.15em}
.rm-hero__wave{position:absolute;left:0;right:0;bottom:-1px;line-height:0;z-index:3}
.rm-hero__wave svg{width:100%;height:90px;display:block;transform:scaleY(-1)}
@media(max-width:640px){.rm-hero{height:340px}.rm-hero__title{font-size:28px}}

/* STAY intro */
.rm-stay{background:#fff;padding:90px 24px 60px;text-align:center}
.rm-stay__label{font-family:"Playfair Display",serif;font-size:13px;letter-spacing:.5em;color:#2d4a4f;margin:0 0 18px}
.rm-stay__h{font-family:"Noto Serif JP",serif;font-size:30px;font-weight:500;color:#1a2e32;letter-spacing:.14em;margin:0 0 28px}
.rm-stay__p{max-width:700px;margin:0 auto;font-size:14px;line-height:2.1;color:#3a4252}

/* BLOCK A / B (rm-block--a / rm-block--b) */
.rm-block{padding:60px 24px;overflow:hidden}
.rm-block--a{background:#f7f4eb}
.rm-block--b{background:#eaf2f5}
.rm-block__panel{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:center;position:relative}
.rm-block--b .rm-block__panel{grid-template-columns:1fr 1.2fr}
.rm-block__photo{position:relative}
.rm-block__photo img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:8px;display:block;box-shadow:0 18px 40px rgba(0,0,0,.15)}
.rm-block__card{background:#fff;border-radius:8px;padding:48px 44px;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.rm-block__letter{font-family:"Playfair Display",serif;font-size:68px;font-weight:400;color:#2d4a4f;line-height:1;margin:0 0 4px;display:flex;align-items:baseline;gap:14px}
.rm-block__letter small{font-family:"Playfair Display",serif;font-size:14px;letter-spacing:.3em;color:#2d4a4f;font-weight:500}
.rm-block__sub{font-family:"Playfair Display",serif;font-size:11px;letter-spacing:.24em;color:#8a9098;margin:0 0 14px}
.rm-block__jp{font-family:"Noto Serif JP",serif;font-size:18px;color:#1a2e32;margin:0 0 20px;letter-spacing:.12em;font-weight:500}
.rm-block__p{font-size:13px;line-height:1.95;color:#3a4252;margin:0 0 26px}
.rm-block__spec{list-style:none;padding:0;margin:0;border-top:1px solid #dfd8c4}
.rm-block__spec li{display:flex;align-items:center;gap:18px;padding:14px 0;border-bottom:1px solid #dfd8c4;font-size:13px;color:#3a4252;padding-left:8px;flex-wrap:wrap;word-break:break-word;overflow-wrap:anywhere}
.rm-block__spec li::before{content:"—";color:#2d4a4f;flex-shrink:0}
.rm-block__spec li strong{font-family:"Noto Serif JP",serif;font-size:13px;color:#1a2e32;font-weight:500;min-width:100px;flex-shrink:0}
.rm-block__strip{max-width:1100px;margin:60px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rm-block__strip img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:8px;box-shadow:0 8px 18px rgba(0,0,0,.1)}
.rm-block__strip figure{margin:0;position:relative}

/* SHOWER */
.rm-shower{background:#f7f4eb;padding:80px 24px 100px;text-align:center}
.rm-shower__label{font-family:"Playfair Display",serif;font-size:13px;letter-spacing:.5em;color:#2d4a4f;margin:0 0 14px}
.rm-shower__title{font-family:"Noto Serif JP",serif;font-size:28px;font-weight:500;color:#1a2e32;letter-spacing:.12em;margin:0 0 10px}
.rm-shower__sub{font-family:"Noto Serif JP",serif;font-size:15px;color:#546069;letter-spacing:.1em;margin:0 0 40px}
.rm-shower__body{max-width:700px;margin:0 auto 48px;text-align:left}
.rm-shower__p{font-size:14px;line-height:2.05;color:#3a4252;margin:0 0 20px}
.rm-shower__list{list-style:none;padding:0;margin:0}
.rm-shower__list li{font-size:13px;line-height:2;color:#3a4252;padding:10px 0;border-bottom:1px solid #e3dcc8;position:relative;padding-left:22px}
.rm-shower__list li::before{content:"—";position:absolute;left:0;color:#b8a57a;font-family:"Playfair Display",serif}
.rm-shower__gal{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rm-shower__gal figure{margin:0}
.rm-shower__gal img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:8px;box-shadow:0 12px 28px rgba(0,0,0,.14)}
.rm-shower__gal figcaption{font-family:"Noto Serif JP",serif;font-size:13px;color:#1a2e32;margin-top:12px;letter-spacing:.08em;line-height:1.55;text-align:center}
@media(max-width:700px){.rm-shower__gal{grid-template-columns:1fr}}

/* AMENITY (in shower section) */
.rm-amenity{max-width:700px;margin:48px auto 0;text-align:left}
.rm-amenity__title{font-family:"Noto Serif JP",serif;font-size:18px;font-weight:500;color:#1a2e32;letter-spacing:.12em;text-align:center;margin:0 0 24px;padding-bottom:14px;border-bottom:1px solid #b8a57a}
.rm-amenity__list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:0 32px}
.rm-amenity__list li{font-family:"Noto Serif JP",serif;font-size:14px;line-height:2;color:#3a4252;padding:10px 0 10px 22px;border-bottom:1px solid #e3dcc8;position:relative;letter-spacing:.04em}
.rm-amenity__list li::before{content:"—";position:absolute;left:0;color:#b8a57a;font-family:"Playfair Display",serif}
@media(max-width:700px){.rm-amenity__list{grid-template-columns:1fr}}

/* SPEC */
.rm-spec{background:#fff;padding:80px 24px;border-top:1px solid #ececec;border-bottom:1px solid #ececec}
.rm-spec__inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center}
.rm-spec__item{position:relative;padding:0 20px}
.rm-spec__item:not(:last-child)::after{content:"";position:absolute;right:-15px;top:12%;height:76%;width:1px;background:#dfd8c4}
.rm-spec__num{font-family:"Playfair Display",serif;font-size:18px;font-style:italic;color:#b8a57a;margin:0 0 6px}
.rm-spec__label{font-size:11px;letter-spacing:.3em;color:#546069;margin:0 0 14px}
.rm-spec__big{font-family:"Playfair Display",serif;font-size:96px;font-style:italic;font-weight:400;color:#2d4a4f;line-height:1;margin:0}
.rm-spec__big small{font-family:"Playfair Display",serif;font-size:22px;letter-spacing:.25em;color:#2d4a4f;margin-left:14px;font-style:italic}

/* GALLERY (rm-gal2) — TOP style organic collage */
.rm-gal2{background:#fff;padding:30px 24px 110px;text-align:center}
.rm-gal2__head{margin-bottom:40px}
.rm-gal2__label{font-family:"Playfair Display",serif;font-size:13px;letter-spacing:.5em;color:#2d4a4f;margin:0 0 12px}
.rm-gal2__title{font-family:"Playfair Display",serif;font-size:22px;letter-spacing:.5em;color:#2d4a4f;margin:0;text-transform:uppercase}
.rm-gal2__wrap{max-width:1360px;margin:0 auto;position:relative}
.rm-gal2__row{display:grid;grid-template-columns:repeat(12,1fr);gap:10px;margin-bottom:-40px;position:relative}
.rm-gal2__row:last-child{margin-bottom:0}
.rm-gal2__cell{overflow:hidden;border-radius:8px;box-shadow:0 12px 28px rgba(0,0,0,.15);transition:transform .4s,box-shadow .4s;border:5px solid #fff;background:#fff;position:relative}
.rm-gal2__cell:hover{transform:scale(1.05) rotate(0deg)!important;box-shadow:0 20px 48px rgba(0,0,0,.25);z-index:10}
.rm-gal2__cell img{width:100%;height:100%;object-fit:cover;display:block}
.rm-gal2__cell--1{grid-column:1 / span 2;aspect-ratio:5/4;transform:rotate(-3deg);z-index:2}
.rm-gal2__cell--2{grid-column:3 / span 2;aspect-ratio:5/4;transform:rotate(2deg) translateY(18px);z-index:1}
.rm-gal2__cell--3{grid-column:5 / span 2;aspect-ratio:1/1;transform:rotate(-1.5deg) translateY(-8px);z-index:3}
.rm-gal2__cell--4{grid-column:7 / span 2;aspect-ratio:5/4;transform:rotate(2.5deg) translateY(12px);z-index:2}
.rm-gal2__cell--5{grid-column:9 / span 2;aspect-ratio:5/4;transform:rotate(-2deg);z-index:1}
.rm-gal2__cell--6{grid-column:11 / span 2;aspect-ratio:5/4;transform:rotate(1.5deg) translateY(20px);z-index:2}
.rm-gal2__cell--7{grid-column:1 / span 2;aspect-ratio:4/3;transform:rotate(1.5deg) translateY(-10px);z-index:4}
.rm-gal2__cell--8{grid-column:3 / span 2;aspect-ratio:4/3;transform:rotate(-2.5deg) translateY(8px);z-index:3}
.rm-gal2__cell--9{grid-column:5 / span 2;aspect-ratio:4/3;transform:rotate(2deg) translateY(-4px);z-index:4}
.rm-gal2__cell--10{grid-column:7 / span 2;aspect-ratio:4/3;transform:rotate(-1.5deg) translateY(14px);z-index:3}
.rm-gal2__cell--11{grid-column:9 / span 2;aspect-ratio:4/3;transform:rotate(2.5deg) translateY(-6px);z-index:4}
.rm-gal2__cell--12{grid-column:11 / span 2;aspect-ratio:5/4;transform:rotate(-2deg) translateY(22px);z-index:5}

/* RESPONSIVE */
@media(max-width:960px){
  .rm-block__panel{grid-template-columns:1fr!important;gap:40px}
  .rm-block__strip{grid-template-columns:repeat(2,1fr)}
  .rm-spec__inner{grid-template-columns:1fr;gap:48px}
  .rm-spec__item:not(:last-child)::after{display:none}
  .rm-gal2__row{grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:-20px}
  .rm-gal2__cell--1,.rm-gal2__cell--2,.rm-gal2__cell--3,.rm-gal2__cell--4,.rm-gal2__cell--5,.rm-gal2__cell--6,
  .rm-gal2__cell--7,.rm-gal2__cell--8,.rm-gal2__cell--9,.rm-gal2__cell--10,.rm-gal2__cell--11,.rm-gal2__cell--12{grid-column:span 2}
}
@media(max-width:640px){
  .rm-block{padding:40px 16px}
  .rm-block__card{padding:32px 24px}
  .rm-spec__big{font-size:70px}
  .rm-gal2__row{grid-template-columns:repeat(4,1fr)}
  .rm-gal2__cell--1,.rm-gal2__cell--2,.rm-gal2__cell--3,.rm-gal2__cell--4,.rm-gal2__cell--5,.rm-gal2__cell--6,
  .rm-gal2__cell--7,.rm-gal2__cell--8,.rm-gal2__cell--9,.rm-gal2__cell--10,.rm-gal2__cell--11,.rm-gal2__cell--12{grid-column:span 2}
}
