/* ============================================================
   THE SANCTUARY — inner pages
   loaded AFTER styles.css
   ============================================================ */

/* inner header: solid from the top (no hero behind it) */
body.inner{background:var(--ink)}
body.inner .header{
  background:rgba(7,11,20,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
  padding-top:18px;padding-bottom:18px;
}

/* ---------- PAGE BANNER ---------- */
.pbanner{position:relative;height:62vh;min-height:440px;overflow:hidden;display:flex;align-items:flex-end}
.pbanner .pb-bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;z-index:-2;will-change:transform}
.pbanner .pb-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(7,11,20,.6) 0%,transparent 36%,transparent 50%,rgba(7,11,20,.94) 100%)}
.pbanner .pb-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(40px,6vw,72px)}
.pbanner .crumb{display:flex;gap:12px;align-items:center;font-size:11px;letter-spacing:.22em;color:var(--faint);margin-bottom:24px}
.pbanner .crumb a{color:var(--dim);transition:color .4s}
.pbanner .crumb a:hover{color:var(--gold-soft)}
.pbanner .crumb .sep{color:var(--gold);opacity:.6}
.pbanner .eyebrow{display:block;margin-bottom:18px}
.pbanner h1{font-family:var(--serif-en);font-weight:400;font-size:clamp(40px,7vw,88px);letter-spacing:.12em;text-transform:uppercase;line-height:1;text-shadow:0 2px 40px rgba(0,0,0,.5)}
.pbanner .pb-jp{font-family:var(--mincho);font-size:clamp(14px,1.4vw,18px);letter-spacing:.24em;color:var(--gold-soft);margin-top:18px}

/* ---------- PAGE INTRO ---------- */
.pintro{max-width:780px;margin:0 auto;text-align:center;padding:clamp(70px,9vw,120px) var(--pad) 0}
.pintro .lead{font-size:clamp(15px,1.2vw,18px)}

/* ---------- ROOM ROWS (listing) ---------- */
.room-rows{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,8vw,110px) var(--pad)}
.rroom{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,5vw,84px);align-items:center;margin-bottom:clamp(70px,9vw,128px)}
.rroom:last-child{margin-bottom:0}
.rroom:nth-child(even) .rr-media{order:2}
.rr-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.rr-media .swap-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.6s var(--ease);will-change:transform}
.rroom:hover .rr-media .swap-img{transform:scale(1.05)}
.rr-media::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 100px rgba(7,11,20,.5)}
.rr-media .rr-index{position:absolute;top:18px;left:18px;z-index:3;font-family:var(--serif-en);font-size:13px;letter-spacing:.3em;color:var(--text);background:rgba(7,11,20,.55);padding:7px 13px;backdrop-filter:blur(4px)}
.rr-body .eyebrow{display:block;margin-bottom:14px}
.rr-body h2{font-family:var(--serif-en);font-weight:400;font-size:clamp(30px,3.8vw,50px);letter-spacing:.12em;text-transform:uppercase;line-height:1.05}
.rr-body .rr-jp{font-family:var(--mincho);font-size:15px;letter-spacing:.18em;color:var(--gold-soft);margin:10px 0 24px}
.rr-body p{font-family:var(--mincho);font-size:15px;line-height:2.1;color:var(--dim);margin-bottom:30px;max-width:480px}
.rr-specs{display:flex;gap:30px;flex-wrap:wrap;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:22px 0;margin-bottom:28px}
.rr-specs .sp{display:flex;flex-direction:column;gap:5px}
.rr-specs .sp b{font-family:var(--serif-en);font-size:24px;font-weight:400;color:var(--text);line-height:1}
.rr-specs .sp span{font-size:10px;letter-spacing:.2em;color:var(--faint)}
.rr-amen{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px}
.rr-amen li{list-style:none;font-size:11.5px;letter-spacing:.12em;color:var(--dim);border:1px solid var(--line);padding:7px 13px}
.rr-foot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.rr-foot .rr-price{font-family:var(--serif-en);font-size:30px;color:var(--text)}
.rr-foot .rr-price small{font-size:13px;color:var(--faint);letter-spacing:.06em;margin-left:4px}
.rr-foot .rr-price .pre{display:block;font-family:var(--sans-jp);font-size:10px;letter-spacing:.24em;color:var(--gold);margin-bottom:4px}

/* ---------- generic inner CTA reuse from .fcta (already in styles.css) ---------- */

/* ============================================================
   SHARED INNER PIECES
   ============================================================ */
/* active nav state */
.nav a[aria-current="page"]{color:var(--text)}
.nav a[aria-current="page"]::after{transform:scaleX(1)}
.mnav a[aria-current="page"]{color:var(--gold-soft)}

/* generic inner section + centered heading */
.isec{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,8vw,118px) var(--pad)}
.isec.tight{padding-top:clamp(40px,5vw,72px)}
.isec-head{text-align:center;max-width:720px;margin:0 auto clamp(48px,6vw,76px)}
.isec-head .eyebrow{display:block;margin-bottom:18px}
.isec-head h2{font-family:var(--mincho);font-weight:500;font-size:clamp(24px,3vw,40px);line-height:1.6;letter-spacing:.05em}
.isec-head h2 em{font-style:normal;color:var(--gold-soft)}
.isec-head p{font-family:var(--mincho);color:var(--dim);line-height:2.1;margin-top:22px;font-size:15px}

/* big centered statement band */
.cstate{background:var(--ink-soft);text-align:center;padding:clamp(84px,11vw,156px) var(--pad);position:relative;overflow:hidden}
.cstate .q{font-family:var(--mincho);font-weight:400;font-size:clamp(21px,2.7vw,38px);line-height:1.95;letter-spacing:.05em;max-width:920px;margin:0 auto}
.cstate .q em{font-style:normal;color:var(--gold-soft)}
.cstate .by{display:block;margin-top:38px;font-family:var(--serif-en);font-size:13px;letter-spacing:.28em;color:var(--gold)}

/* ---------- CONCEPT: pillars ---------- */
.cpillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.cpillar{background:var(--ink);padding:clamp(34px,3.4vw,54px) clamp(26px,2.6vw,42px)}
.cpillar .cp-i{font-family:var(--serif-en);font-size:13px;letter-spacing:.3em;color:var(--gold)}
.cpillar h3{font-family:var(--serif-en);font-size:23px;letter-spacing:.16em;text-transform:uppercase;margin:18px 0 4px}
.cpillar .cp-jp{font-size:12px;letter-spacing:.3em;color:var(--faint);margin-bottom:20px}
.cpillar p{font-family:var(--mincho);font-size:14px;line-height:2.05;color:var(--dim)}

/* ---------- EXPERIENCE row footer note (reuses .rroom) ---------- */
.rr-foot .rr-note{font-family:var(--mincho);font-size:13px;letter-spacing:.04em;color:var(--gold-soft)}
.rr-foot .rr-note small{display:block;font-family:var(--sans-jp);font-size:10px;letter-spacing:.24em;color:var(--gold);margin-bottom:5px}

/* ---------- ACCESS page ---------- */
.acc-map{position:relative;aspect-ratio:21/9;overflow:hidden;border:1px solid var(--line-soft);margin-bottom:clamp(40px,5vw,70px)}
.acc-map .swap-img{position:absolute;inset:0;background-size:cover;background-position:center}
.acc-map::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 120px rgba(7,11,20,.55);pointer-events:none}
.acc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.acc-grid .a-rows{margin-top:8px}
.acc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);margin-top:clamp(50px,6vw,80px)}
.acc-card{background:var(--ink);padding:clamp(30px,3vw,46px) clamp(24px,2.4vw,38px)}
.acc-card .ac-en{font-family:var(--serif-en);font-size:13px;letter-spacing:.3em;color:var(--gold);text-transform:uppercase}
.acc-card h3{font-family:var(--mincho);font-weight:500;font-size:19px;letter-spacing:.08em;margin:14px 0 14px}
.acc-card ul{list-style:none}
.acc-card li{font-family:var(--mincho);font-size:13.5px;color:var(--dim);line-height:1.9;padding:10px 0;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;gap:16px}
.acc-card li b{font-weight:400;color:var(--text);white-space:nowrap}

/* ---------- NEWS page ---------- */
.nfilter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:clamp(40px,5vw,64px)}
.nfilter button{font-family:var(--sans-jp);font-size:11px;letter-spacing:.22em;color:var(--dim);background:transparent;border:1px solid var(--line);padding:.75em 1.5em;cursor:pointer;transition:color .4s,border-color .4s,background .4s}
.nfilter button:hover{color:var(--text);border-color:var(--gold)}
.nfilter button.active{color:var(--ink);background:var(--gold);border-color:var(--gold)}
.nlist{border-top:1px solid var(--line-soft);max-width:980px;margin:0 auto}
.nlist .n-item{display:grid;grid-template-columns:132px 96px 1fr auto;gap:24px;align-items:center;padding:26px 4px;border-bottom:1px solid var(--line-soft);transition:padding-left .5s var(--ease);cursor:pointer}
.nlist .n-item:hover{padding-left:14px}
.nlist .n-date{font-family:var(--serif-en);font-size:14px;letter-spacing:.14em;color:var(--gold-soft)}
.nlist .n-cat{font-size:10px;letter-spacing:.2em;color:var(--faint);border:1px solid var(--line);padding:5px 0;text-align:center}
.nlist .n-txt{font-family:var(--mincho);font-size:15px;color:var(--dim);transition:color .4s}
.nlist .n-item:hover .n-txt{color:var(--text)}
.nlist .n-arr{color:var(--faint);transition:transform .5s var(--ease),color .4s}
.nlist .n-item:hover .n-arr{transform:translateX(6px);color:var(--gold)}
.npage{display:flex;gap:10px;justify-content:center;margin-top:clamp(48px,6vw,72px)}
.npage a{width:46px;height:46px;display:grid;place-items:center;font-family:var(--serif-en);font-size:15px;color:var(--dim);border:1px solid var(--line-soft);transition:color .4s,border-color .4s,background .4s}
.npage a:hover{color:var(--text);border-color:var(--gold)}
.npage a.active{color:var(--ink);background:var(--gold);border-color:var(--gold)}

/* ---------- RESERVATION page ---------- */
.resv{display:grid;grid-template-columns:1.5fr .85fr;gap:clamp(40px,5vw,80px);align-items:start;max-width:var(--maxw);margin:0 auto;padding:clamp(60px,8vw,108px) var(--pad)}
.resv-form{display:grid;grid-template-columns:1fr 1fr;gap:26px 24px}
.field{display:flex;flex-direction:column;gap:9px}
.field.full{grid-column:1/-1}
.field label{font-size:11px;letter-spacing:.22em;color:var(--gold);text-transform:uppercase}
.field input,.field select,.field textarea{
  font-family:var(--mincho);font-size:15px;color:var(--text);background:var(--ink-soft);
  border:1px solid var(--line);padding:14px 16px;width:100%;transition:border-color .4s,background .4s}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:var(--panel)}
.field textarea{resize:vertical;min-height:120px;line-height:1.9}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 20px) 21px,calc(100% - 14px) 21px;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.resv-form .submit-row{grid-column:1/-1;display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:6px}
.resv-form .submit-row .note{font-family:var(--mincho);font-size:12px;color:var(--faint);line-height:1.7}
.resv-aside{background:var(--ink-soft);border:1px solid var(--line-soft);padding:clamp(30px,3vw,44px)}
.resv-aside h3{font-family:var(--mincho);font-weight:500;font-size:20px;letter-spacing:.06em;margin-bottom:8px}
.resv-aside .ra-jp{font-size:11px;letter-spacing:.28em;color:var(--gold);margin-bottom:24px}
.resv-aside .ra-row{padding:18px 0;border-top:1px solid var(--line-soft)}
.resv-aside .ra-row:first-of-type{border-top:none}
.resv-aside .ra-k{font-size:10px;letter-spacing:.24em;color:var(--faint);margin-bottom:7px}
.resv-aside .ra-v{font-family:var(--mincho);font-size:15px;color:var(--dim);line-height:1.8}
.resv-aside .ra-tel{font-family:var(--serif-en);font-size:30px;letter-spacing:.06em;color:var(--gold-soft)}
.resv-steps{display:flex;justify-content:center;gap:clamp(20px,4vw,56px);flex-wrap:wrap;max-width:var(--maxw);margin:0 auto;padding:clamp(40px,5vw,60px) var(--pad) 0}
.resv-step{display:flex;align-items:baseline;gap:14px}
.resv-step .rs-n{font-family:var(--serif-en);font-size:15px;color:var(--gold);letter-spacing:.2em}
.resv-step .rs-t{font-family:var(--mincho);font-size:14px;color:var(--dim);letter-spacing:.06em}
.resv-step.done .rs-t{color:var(--text)}

/* ---------- ARTICLE / detail typography (for news/about later) ---------- */
.prose{max-width:760px;margin:0 auto;padding:clamp(60px,8vw,100px) var(--pad)}
.prose p{font-family:var(--mincho);font-size:16px;line-height:2.3;color:var(--dim);margin-bottom:1.8em}
.prose h3{font-family:var(--mincho);font-weight:500;font-size:24px;letter-spacing:.05em;margin:1.4em 0 .7em}

/* responsive */
@media(max-width:980px){
  .cpillars,.acc-cards{grid-template-columns:1fr}
  .acc-grid{grid-template-columns:1fr;gap:42px}
  .resv{grid-template-columns:1fr;gap:46px}
  .acc-map{aspect-ratio:16/10}
}
@media(max-width:860px){
  .rroom{grid-template-columns:1fr;gap:30px}
  .rroom:nth-child(even) .rr-media{order:-1}
  .rr-media{aspect-ratio:16/11}
  .resv-form{grid-template-columns:1fr}
  .nlist .n-item{grid-template-columns:108px 1fr;row-gap:8px}
  .nlist .n-cat{justify-self:start;padding:5px 12px}
  .nlist .n-arr{display:none}
}
@media(max-width:560px){
  .resv-steps{flex-direction:column;align-items:center;gap:14px}
}
