/* ============================================================
   BBQ PAGE — page-specific overrides (patterns.css handles layout)
   ============================================================ */

/* --- Spec table compact (inside pt-2col__body) --- */
.bbq-spec-compact { margin-top: 24px; }
.bbq-spec-compact th { width: 120px; }

/* === extracted from page-bbq.php === */
/* BQ hero - post-spec */
.bq-hero{position:relative;height:500px;overflow:hidden;background:#1a2220}
.bq-hero__bg{position:absolute;inset:0;background:center/cover no-repeat;filter:saturate(.95)}
.bq-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%)}
.bq-hero__inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 24px}
.bq-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}
.bq-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)}
.bq-hero__wave{position:absolute;left:0;right:0;bottom:-1px;line-height:0;z-index:3}
.bq-hero__wave svg{width:100%;height:90px;display:block;transform:scaleY(-1)}
@media(max-width:640px){.bq-hero{height:340px}.bq-hero__title{font-size:28px}}

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

.bq-block{padding:60px 24px;overflow:hidden}
.bq-block--a{background:#f7f4eb}
.bq-block--b{background:#eaf2f5}
.bq-block--c{background:#f7f4eb}
.bq-block__panel{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:center;position:relative}
.bq-block--b .bq-block__panel{grid-template-columns:1fr 1.2fr}
.bq-block__photo{position:relative}
.bq-suika-badge{position:absolute;top:-18px;right:-10px;z-index:4;background:#ff4d5e;color:#fff;width:130px;height:130px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:rotate(-12deg);box-shadow:0 10px 20px rgba(0,0,0,.22);border:3px dashed #fff;font-family:"Noto Serif JP",serif;letter-spacing:.05em;text-align:center;line-height:1.3;animation:suikaWobble 2.4s ease-in-out infinite}
.bq-suika-badge em{font-style:normal;font-size:20px;font-weight:700;margin-bottom:4px;text-shadow:0 1px 2px rgba(0,0,0,.25)}
.bq-suika-badge>span{font-size:11px;letter-spacing:.08em;opacity:.95}
@keyframes suikaWobble{0%,100%{transform:rotate(-12deg) scale(1)}50%{transform:rotate(-8deg) scale(1.04)}}
@media(max-width:700px){.bq-suika-badge{width:100px;height:100px;top:-12px;right:-6px}.bq-suika-badge em{font-size:15px}.bq-suika-badge>span{font-size:9px}}
.bq-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)}
.bq-block__label-file{position:absolute;left:16px;bottom:14px;background:rgba(0,0,0,.55);color:#fff;font-family:"Playfair Display",serif;font-size:11px;padding:4px 10px;border-radius:2px;letter-spacing:.1em}
.bq-block__thumb{position:absolute;right:-60px;bottom:-40px;width:38%;z-index:2}
.bq-block--b .bq-block__thumb{right:auto;left:-60px}
.bq-block__thumb img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:8px;border:6px solid #fff;box-shadow:0 10px 24px rgba(0,0,0,.2)}
.bq-block__card{background:#fff;border-radius:8px;padding:48px 44px;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.bq-block__letter{font-family:"Playfair Display",serif;font-size:60px;font-weight:400;color:#2d4a4f;line-height:1;margin:0 0 6px;display:flex;align-items:baseline;gap:12px}
.bq-block__letter small{font-family:"Playfair Display",serif;font-size:14px;letter-spacing:.3em;color:#2d4a4f;font-weight:500}
.bq-block__jp{font-family:"Noto Serif JP",serif;font-size:18px;color:#1a2e32;margin:0 0 20px;letter-spacing:.12em;font-weight:500}
.bq-block__p{font-size:13px;line-height:1.95;color:#3a4252;margin:0 0 26px}
.bq-block__spec{list-style:none;padding:0;margin:0 0 28px;border:1px solid #dfd8c4;border-radius:4px;overflow:hidden}
.bq-block__spec li{display:grid;grid-template-columns:130px 1fr;align-items:stretch;border-bottom:1px solid #dfd8c4;font-size:13px;color:#3a4252}
.bq-block__spec li:last-child{border-bottom:none}
.bq-block__spec li::before{content:none}
.bq-block__spec li strong{font-family:"Playfair Display",serif;font-size:12px;letter-spacing:.2em;color:#2d4a4f;font-weight:500;text-transform:uppercase;background:#f7f4eb;padding:14px 20px;border-right:1px solid #dfd8c4;display:flex;align-items:center}
.bq-block__spec li span.val{padding:14px 20px;display:flex;align-items:center;font-size:13px;color:#3a4252;background:#fff}
.bq-block__more{font-family:"Playfair Display",serif;font-size:11px;letter-spacing:.3em;color:#2d4a4f;padding-bottom:6px;border-bottom:1px solid #2d4a4f;text-decoration:none}
.bq-block__more::after{content:"→"}
.bq-block__strip{max-width:1100px;margin:60px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.bq-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)}
.bq-block__strip figure{margin:0;position:relative}
.bq-block__strip figcaption{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.55);color:#fff;font-family:"Playfair Display",serif;font-size:10px;padding:3px 8px;border-radius:2px;letter-spacing:.08em}

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

.bq-each{background:#fff;padding:60px 24px 80px;text-align:center}
.bq-each__label{font-family:"Playfair Display",serif;font-size:13px;letter-spacing:.5em;color:#2d4a4f;margin:0 0 14px}
.bq-each__title{font-family:"Noto Serif JP",serif;font-size:26px;font-weight:500;color:#1a2e32;letter-spacing:.14em;margin:0 0 44px}
.bq-each__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.bq-each__item{}
.bq-each__item img{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:8px;box-shadow:0 10px 24px rgba(0,0,0,.08);position:relative}
.bq-each__item figure{margin:0;position:relative}
.bq-each__item figcaption{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.55);color:#fff;font-family:"Playfair Display",serif;font-size:10px;padding:3px 8px;border-radius:2px}
.bq-each__cap{font-family:"Noto Serif JP",serif;font-size:13px;color:#1a2e32;margin:14px 0 0;letter-spacing:.06em}

.bq-gal{background:#fff;padding:30px 24px 100px;text-align:center}
.bq-gal__label{font-family:"Playfair Display",serif;font-size:13px;letter-spacing:.5em;color:#2d4a4f;margin:0 0 12px}
.bq-gal__title{font-family:"Noto Serif JP",serif;font-size:22px;letter-spacing:.12em;color:#1a2e32;margin:0 0 40px}
.bq-gal__wrap{max-width:1320px;margin:0 auto}
.bq-gal__row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:10px}
.bq-gal__cell{overflow:hidden;border-radius:8px;box-shadow:0 10px 24px rgba(0,0,0,.15);border:5px solid #fff;background:#fff;transition:transform .4s}
.bq-gal__cell:hover{transform:scale(1.04)}
.bq-gal__cell img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.bq-gal__cell:nth-child(1){transform:rotate(-2deg)}
.bq-gal__cell:nth-child(3){transform:rotate(1.5deg)}
.bq-gal__cell:nth-child(5){transform:rotate(-1deg)}
.bq-gal__cell:nth-child(8){transform:rotate(2deg) translateY(-8px)}
.bq-gal__cell:nth-child(10){transform:rotate(-1.5deg) translateY(6px)}
.bq-gal__cell:nth-child(12){transform:rotate(1deg)}

@media(max-width:960px){
  .bq-block__panel{grid-template-columns:1fr!important;gap:40px}
  .bq-block__thumb{display:none}
  .bq-block__strip{grid-template-columns:repeat(2,1fr)}
  .bq-spec__inner{grid-template-columns:1fr;gap:48px}
  .bq-spec__item:not(:last-child)::after{display:none}
  .bq-each__grid{grid-template-columns:repeat(2,1fr)}
  .bq-gal__row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:640px){
  .bq-block{padding:40px 16px}
  .bq-block__card{padding:32px 24px}
  .bq-spec__big{font-size:70px}
  .bq-each__grid{grid-template-columns:1fr}
}

/* BBQ gallery - TOP style */
.bq-gal2{background:#fff;padding:30px 24px 110px;text-align:center}
.bq-gal2__head{margin-bottom:40px}
.bq-gal2__label{font-family:"Playfair Display",serif;font-size:13px;letter-spacing:.5em;color:#2d4a4f;margin:0 0 12px}
.bq-gal2__title{font-family:"Noto Serif JP",serif;font-size:22px;letter-spacing:.12em;color:#1a2e32;margin:0}
.bq-gal2__wrap{max-width:1360px;margin:0 auto;position:relative}
.bq-gal2__row{display:grid;grid-template-columns:repeat(12,1fr);gap:10px;margin-bottom:-40px;position:relative}
.bq-gal2__row:last-child{margin-bottom:0}
.bq-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}
.bq-gal2__cell:hover{transform:scale(1.05) rotate(0deg)!important;box-shadow:0 20px 48px rgba(0,0,0,.25);z-index:10}
.bq-gal2__cell img{width:100%;height:100%;object-fit:cover;display:block}
.bq-gal2__cell figcaption{position:absolute;left:6px;bottom:6px;background:rgba(0,0,0,.55);color:#fff;font-family:"Playfair Display",serif;font-size:10px;padding:2px 7px;border-radius:2px}

.bq-gal2__cell--1{grid-column:1 / span 2;aspect-ratio:5/4;transform:rotate(-3deg);z-index:2}
.bq-gal2__cell--2{grid-column:3 / span 2;aspect-ratio:5/4;transform:rotate(2deg) translateY(18px);z-index:1}
.bq-gal2__cell--3{grid-column:5 / span 2;aspect-ratio:1/1;transform:rotate(-1.5deg) translateY(-8px);z-index:3}
.bq-gal2__cell--4{grid-column:7 / span 2;aspect-ratio:5/4;transform:rotate(2.5deg) translateY(12px);z-index:2}
.bq-gal2__cell--5{grid-column:9 / span 2;aspect-ratio:5/4;transform:rotate(-2deg);z-index:1}
.bq-gal2__cell--6{grid-column:11 / span 2;aspect-ratio:5/4;transform:rotate(1.5deg) translateY(20px);z-index:2}
.bq-gal2__cell--7{grid-column:1 / span 2;aspect-ratio:4/3;transform:rotate(1.5deg) translateY(-10px);z-index:4}
.bq-gal2__cell--8{grid-column:3 / span 2;aspect-ratio:4/3;transform:rotate(-2.5deg) translateY(8px);z-index:3}
.bq-gal2__cell--9{grid-column:5 / span 2;aspect-ratio:4/3;transform:rotate(2deg) translateY(-4px);z-index:4}
.bq-gal2__cell--10{grid-column:7 / span 2;aspect-ratio:4/3;transform:rotate(-1.5deg) translateY(14px);z-index:3}
.bq-gal2__cell--11{grid-column:9 / span 2;aspect-ratio:4/3;transform:rotate(2.5deg) translateY(-6px);z-index:4}
.bq-gal2__cell--12{grid-column:11 / span 2;aspect-ratio:5/4;transform:rotate(-2deg) translateY(22px);z-index:5}

@media(max-width:960px){
  .bq-gal2__row{grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:-20px}
  .bq-gal2__cell--1,.bq-gal2__cell--2,.bq-gal2__cell--3,.bq-gal2__cell--4,.bq-gal2__cell--5,.bq-gal2__cell--6{grid-column:span 2}
  .bq-gal2__cell--7,.bq-gal2__cell--8,.bq-gal2__cell--9,.bq-gal2__cell--10,.bq-gal2__cell--11,.bq-gal2__cell--12{grid-column:span 2}
}
@media(max-width:640px){
  .bq-gal2__row{grid-template-columns:repeat(4,1fr)}
  .bq-gal2__cell{grid-column:span 2!important}
}

