/* ============================================================
   MINESHAFT — Hotel Management
   ivory × ink × bronze ／ Marcellus + Shippori Mincho
   ============================================================ */
:root{
  --paper:#FAFBF9;
  --paper-2:#EFF1ED;
  --ink:#1B1B19;
  --ink-2:#44423D;
  --muted:#807B6F;
  --line:#DDE1DA;
  --gold:#16352A;
  --gold-soft:#27513F;
  --footer:#16352A;
  --display:'Marcellus','Times New Roman',serif;
  --mincho:'Shippori Mincho','Noto Serif CJK JP','Hiragino Mincho ProN','Yu Mincho',serif;
  --sans:'Noto Sans JP','Noto Sans CJK JP','Hiragino Sans','Yu Gothic',sans-serif;
  --wrap:1160px;
  --pad:clamp(20px,4vw,48px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--mincho);font-weight:400;
  font-feature-settings:"palt";
  line-height:2;letter-spacing:.06em;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--pad)}

/* ---------- header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);height:84px;
  background:rgba(251,250,247,.96);
  border-bottom:1px solid var(--line);
  transition:background .5s,border-color .5s;
}
.brand{font-family:var(--display);font-size:1.32rem;letter-spacing:.3em;line-height:1.1;display:flex;flex-direction:column;color:#16352A}
.brand small{font-family:var(--sans);font-weight:400;font-size:.56rem;letter-spacing:.42em;color:var(--gold);margin-top:.45em}
.nav{display:flex;gap:clamp(1.2rem,2.4vw,2.4rem)}
.nav a{
  font-family:var(--display);font-size:.82rem;letter-spacing:.22em;
  display:flex;flex-direction:column;align-items:center;gap:.3em;
  padding:.4em 0;position:relative;
}
.nav a .jp{font-family:var(--mincho);font-size:.66rem;font-weight:500;letter-spacing:.1em;color:var(--muted)}
.nav a::after{content:"";position:absolute;left:50%;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .4s,left .4s}
.nav a:hover::after,.nav a.active::after{left:0;width:100%}
.nav a.active .jp{color:var(--gold)}

/* transparent over hero */
.site-header.hero-mode:not(.scrolled){background:transparent;border-color:transparent}
.site-header.hero-mode:not(.scrolled) .brand,
.site-header.hero-mode:not(.scrolled) .nav a{color:#fff}
.site-header.hero-mode:not(.scrolled) .nav a .jp{color:rgba(255,255,255,.66)}
.site-header.hero-mode:not(.scrolled) .brand small{color:rgba(255,255,255,.8)}

.burger{display:none;background:none;border:0;width:40px;height:40px;cursor:pointer;flex-direction:column;justify-content:center;gap:7px;z-index:120}
.burger span{display:block;height:1px;background:var(--ink);transition:.4s}
.site-header.hero-mode:not(.scrolled) .burger span{background:#fff}
body.menu-open .burger span{background:var(--ink)}
body.menu-open .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:110;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2.1rem;
  opacity:0;visibility:hidden;transition:opacity .45s,visibility .45s;
}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--display);font-size:1.25rem;letter-spacing:.24em;display:flex;flex-direction:column;align-items:center;gap:.35em}
.mobile-menu a .jp{font-family:var(--mincho);font-weight:500;font-size:.72rem;letter-spacing:.12em;color:var(--muted)}

/* ---------- hero ---------- */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,8,.34),rgba(10,10,8,.08) 40%,rgba(10,10,8,.3))}
.hero-copy{position:absolute;left:0;bottom:0;z-index:2;padding:0 clamp(28px,6vw,84px) clamp(70px,12vh,112px);max-width:920px}
.tagline{
  color:#fff;font-family:var(--mincho);font-weight:500;
  font-size:clamp(2rem,5vw,3.7rem);letter-spacing:.14em;line-height:1.6;
  text-shadow:0 2px 26px rgba(0,0,0,.4);
}
.en-sub{
  display:flex;align-items:center;gap:1.1em;margin-top:1.3em;
  color:rgba(255,255,255,.92);font-family:var(--display);
  font-size:clamp(.95rem,1.5vw,1.18rem);letter-spacing:.22em;
  text-shadow:0 1px 16px rgba(0,0,0,.45);
}
.en-sub::before{content:"";flex:0 0 auto;width:clamp(40px,5vw,64px);height:1px;background:rgba(255,255,255,.75)}
.scroll-cue{
  position:absolute;right:calc(var(--pad) + 4px);bottom:0;z-index:3;
  color:#fff;font-family:var(--display);font-size:.62rem;letter-spacing:.4em;
  writing-mode:vertical-rl;display:flex;align-items:center;gap:.9em;height:128px;
}
.scroll-cue::after{content:"";width:1px;flex:1;background:linear-gradient(180deg,rgba(255,255,255,.9),transparent);animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- sections ---------- */
.sec{padding:clamp(76px,11vw,140px) 0}
.sec.alt{background:var(--paper-2)}
.page-hero{padding-top:clamp(150px,20vw,220px)}

/* EN big + JP small heading pair (WBC style) */
.sec-head{margin-bottom:clamp(34px,5vw,56px)}
.sec-head .en{
  font-family:var(--display);font-size:clamp(2rem,4.4vw,3.1rem);
  letter-spacing:.14em;line-height:1.25;color:var(--ink);
  display:flex;flex-direction:column;gap:.55em;
}
.sec-head .en .jp{
  font-family:var(--sans);font-weight:400;font-size:.78rem;letter-spacing:.3em;color:var(--gold);
  display:flex;align-items:center;gap:1em;
}
.sec-head .en .jp::before{content:"";width:42px;height:1px;background:var(--gold)}
.sec-head.center{text-align:center}
.sec-head.center .en{align-items:center}
.sec-head.center .en .jp::after{content:"";width:42px;height:1px;background:var(--gold)}
.eyebrow{font-family:var(--display);font-size:.74rem;letter-spacing:.36em;color:var(--gold);text-transform:uppercase;display:inline-flex;align-items:center;gap:.9em}

.lede{font-size:clamp(.95rem,1.5vw,1.04rem);line-height:2.4;color:var(--ink-2);max-width:780px}
.lede em{display:block;font-style:normal;font-family:var(--display);font-size:.8rem;letter-spacing:.16em;color:var(--muted);margin-top:1.6em;line-height:1.9}
.lede.center{margin:0 auto;text-align:center}

/* view-more button */
.more{
  display:inline-flex;align-items:center;gap:1.2em;
  font-family:var(--display);font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;
  border:1px solid var(--ink);padding:1.05em 2.6em;color:var(--ink);
  transition:background .45s,color .45s,border-color .45s;
}
.more::after{content:"→";font-family:var(--sans);transition:transform .45s}
.more:hover{background:var(--ink);color:var(--paper)}
.more:hover::after{transform:translateX(6px)}
.more.light{border-color:rgba(255,255,255,.85);color:#fff}
.more.light:hover{background:#fff;color:var(--ink)}

/* ---------- news ---------- */
.news-list{border-top:1px solid var(--line)}
.news-list li{border-bottom:1px solid var(--line)}
.news-list a,.news-list .row{
  display:grid;grid-template-columns:130px 1fr;gap:clamp(1rem,3vw,3rem);
  align-items:baseline;padding:.62em .2em;transition:background .4s;
}
.news-list .date{font-family:var(--display);font-size:.86rem;letter-spacing:.22em;color:var(--gold)}
.news-list .ttl{font-size:.95rem;line-height:1.9;color:var(--ink-2)}

/* ---------- intro grid (about) ---------- */
.intro-grid{display:grid;grid-template-columns:1.05fr .9fr;gap:clamp(2.4rem,6vw,5.5rem);align-items:center}
.intro-grid .ph{width:100%;aspect-ratio:4/4.6;object-fit:cover}

/* about band — full-bleed photo with overlaid centered text (WBC-style) */
.about-band{position:relative;min-height:clamp(480px,56vw,660px);display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.about-band>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about-band::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(14,24,19,.58),rgba(14,24,19,.66))}
.about-band .inner{position:relative;z-index:2;max-width:820px;padding:clamp(60px,9vw,110px) var(--pad);color:#fff}
.about-band .sec-head{margin-bottom:1.4rem}
.about-band .sec-head .en{color:#fff}
.about-band .sec-head .en .jp{color:var(--gold-soft)}
.about-band .sec-head .en .jp::before,.about-band .sec-head .en .jp::after{background:var(--gold-soft)}
.about-band .lede{color:rgba(255,255,255,.92)}
.about-band .lede em{color:rgba(255,255,255,.72)}
@media (max-width:860px){
  .about-band{min-height:0}
}

/* ---------- hotel cards (top) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.6rem)}
.card .frame{overflow:hidden}
.card .ph{width:100%;aspect-ratio:4/4.8;object-fit:cover;transition:transform 1.4s cubic-bezier(.19,1,.22,1)}
.card:hover .ph{transform:scale(1.06)}
.card .body{padding-top:1.3em}
.card .no{font-family:var(--display);font-size:.66rem;letter-spacing:.3em;color:var(--gold)}
.card h3{font-family:var(--display);font-weight:400;font-size:1.22rem;letter-spacing:.12em;margin-top:.55em;line-height:1.4;display:flex;flex-direction:column;gap:.4em}
.card h3 .jp{font-family:var(--sans);font-weight:400;font-size:.72rem;letter-spacing:.2em;color:var(--muted)}
.card .go{display:inline-flex;align-items:center;gap:.8em;font-family:var(--display);font-size:.66rem;letter-spacing:.32em;color:var(--ink);margin-top:1.2em}
.card .go::after{content:"";width:36px;height:1px;background:var(--gold);transition:width .4s}
.card:hover .go::after{width:58px}

/* ---------- quick links band ---------- */
.quick{display:grid;grid-template-columns:repeat(3,1fr)}
.quick a{position:relative;overflow:hidden;min-height:clamp(240px,30vw,340px);display:flex;align-items:center;justify-content:center}
.quick a img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.6s cubic-bezier(.19,1,.22,1)}
.quick a::after{content:"";position:absolute;inset:0;background:rgba(16,15,12,.5);transition:background .5s}
.quick a:hover img{transform:scale(1.07)}
.quick a:hover::after{background:rgba(16,15,12,.34)}
.quick .lab{position:relative;z-index:2;color:#fff;text-align:center;font-family:var(--display);font-size:1.2rem;letter-spacing:.26em;display:flex;flex-direction:column;gap:.7em;align-items:center}
.quick .lab .jp{font-family:var(--sans);font-size:.66rem;letter-spacing:.26em;color:rgba(255,255,255,.78)}
.quick .lab::after{content:"";width:1px;height:30px;background:var(--gold-soft)}

/* ---------- hotels page ---------- */
.hotel{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;padding:clamp(32px,4.5vw,56px) 0;border-bottom:1px solid var(--line)}
.hotel:last-child{border-bottom:0}
.hotel:nth-child(even){direction:rtl}
.hotel:nth-child(even)>div{direction:ltr}
.hotel .ph{width:100%;aspect-ratio:4/3;object-fit:cover}
.hotel .meta{font-family:var(--display);font-size:.7rem;letter-spacing:.32em;color:var(--gold);text-transform:uppercase}
.hotel h3{font-family:var(--display);font-weight:400;font-size:clamp(1.5rem,2.6vw,1.95rem);letter-spacing:.1em;line-height:1.4;margin-top:.7em;display:flex;flex-direction:column;gap:.45em}
.hotel h3 .jp{font-family:var(--sans);font-weight:400;font-size:.78rem;letter-spacing:.22em;color:var(--muted)}
.hotel p{margin-top:1.4em;font-size:.94rem;line-height:2.3;color:var(--ink-2)}
.hotel p em{display:block;font-style:normal;font-family:var(--display);font-size:.78rem;letter-spacing:.14em;color:var(--muted);margin-top:1.4em;line-height:1.9}
.tag{display:inline-block;margin-top:1.5em;font-family:var(--display);font-size:.64rem;letter-spacing:.32em;color:var(--gold);border:1px solid var(--gold);padding:.55em 1.5em;text-transform:uppercase}
.hmeta-row{display:flex;align-items:center;gap:1.6em;flex-wrap:wrap;margin-top:1.5em}
.hmeta-row .tag{margin-top:0}
.olink{display:inline-flex;align-items:center;gap:.6em;font-family:var(--display);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:.45em;transition:color .4s,gap .4s}
.olink::after{content:"↗";font-family:var(--sans);font-size:.9em}
.olink:hover{color:var(--gold);gap:1em}

/* projects — card grid (L'MONDO-style) */
.hotel.is-portrait{grid-template-columns:.78fr 1.22fr}
.hotel.is-portrait .ph{aspect-ratio:2/3;max-width:460px}
/* projects — pipeline stats + vertical rows */
.pstats{display:flex;flex-wrap:wrap;gap:clamp(1.8rem,6vw,5rem);margin:clamp(28px,4vw,44px) 0 clamp(20px,3vw,32px);padding:clamp(26px,4vw,38px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pstat-item{display:flex;align-items:baseline;gap:1em}
.pstat-item .pn{font-family:var(--display);font-size:clamp(2.8rem,6vw,4.4rem);line-height:.9;color:var(--gold);letter-spacing:.01em}
.pstat-item .pl{display:flex;flex-direction:column;font-family:var(--display);font-size:.8rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink)}
.pstat-item .pl .jp{font-family:var(--sans);font-size:.66rem;letter-spacing:.16em;color:var(--muted);text-transform:none;margin-top:.5em}

.prows{margin-top:clamp(8px,2vw,18px);border-top:1px solid var(--line)}
.prow{position:relative;display:grid;grid-template-columns:84px 1fr auto;gap:clamp(1rem,3vw,2.4rem);align-items:center;padding:clamp(1.5rem,2.8vw,2.1rem) .5em;border-bottom:1px solid var(--line);transition:background .45s,padding-left .45s}
.prow::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.prow:hover{background:var(--paper);padding-left:1.6em}
.prow:hover::before{transform:scaleY(1)}
.prow .pidx{font-family:var(--display);font-size:clamp(1.7rem,3vw,2.3rem);line-height:1;color:var(--gold);letter-spacing:.06em}
.prow .pmain h3{font-family:var(--mincho);font-weight:500;font-size:clamp(1.25rem,2.1vw,1.6rem);letter-spacing:.08em;line-height:1.4}
.prow .pmain .psub{display:block;font-family:var(--sans);font-size:.74rem;letter-spacing:.18em;color:var(--muted);margin-top:.55em}
.prow .pmain .popen{display:block;font-family:var(--sans);font-size:.74rem;letter-spacing:.12em;color:var(--ink-2);margin-top:.4em}
.prow .prooms{justify-self:end;font-family:var(--display);font-size:clamp(1.5rem,2.6vw,2rem);color:var(--ink);letter-spacing:.04em;white-space:nowrap}
.prow .prooms small{font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;color:var(--muted);margin-left:.25em}
@media (max-width:680px){
  .prow{grid-template-columns:46px 1fr auto;gap:1rem .9rem}
  .prow .pidx{font-size:1.5rem}
  .prow .pmain h3{font-size:1.15rem}
}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.3rem,2.6vw,2.2rem);margin-top:clamp(28px,4vw,44px)}
.proj .visual{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(145deg,#ECE7DB,#DDD6C5)}
.proj .visual img{width:100%;height:100%;object-fit:cover}
.proj .visual .badge{position:absolute;left:0;bottom:0;background:rgba(24,23,19,.82);color:#fff;font-family:var(--display);font-size:.6rem;letter-spacing:.3em;padding:.7em 1.4em;text-transform:uppercase}
.proj .pbody{padding-top:1.2em}
.proj h3{font-family:var(--mincho);font-weight:500;font-size:1.05rem;letter-spacing:.12em;line-height:1.8}
.proj dl{margin-top:.9em;border-top:1px solid var(--line)}
.proj dl div{display:flex;justify-content:space-between;padding:.7em .1em;border-bottom:1px solid var(--line);font-size:.8rem}
.proj dt{font-family:var(--sans);font-weight:400;letter-spacing:.16em;color:var(--muted)}
.proj dd{letter-spacing:.1em}

/* ---------- business ---------- */
.strengths{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(2rem,4vw,3.4rem) clamp(2.4rem,5vw,4.5rem)}
.str{border-top:1px solid var(--line);padding-top:1.8em}
.str .num{font-family:var(--display);font-size:.8rem;letter-spacing:.3em;color:var(--gold)}
.str h4{font-family:var(--display);font-weight:400;font-size:1.28rem;letter-spacing:.12em;margin-top:.8em;line-height:1.5;display:flex;flex-direction:column;gap:.45em}
.str h4 .jp{font-family:var(--sans);font-weight:400;font-size:.74rem;letter-spacing:.22em;color:var(--muted)}
.str p{margin-top:1.2em;font-size:.92rem;line-height:2.2;color:var(--ink-2)}
.str p em{display:block;font-style:normal;font-family:var(--display);font-size:.76rem;letter-spacing:.14em;color:var(--muted);margin-top:1.2em;line-height:1.9}

.model-block{
  margin-top:clamp(64px,9vw,100px);
  border:1px solid var(--gold);padding:clamp(2.2rem,5vw,4rem);
  position:relative;background:var(--paper);
}
.model-block::after{content:"";position:absolute;inset:8px;border:1px solid var(--line);pointer-events:none}
.model-block h3{font-family:var(--display);font-weight:400;font-size:clamp(1.4rem,2.6vw,1.9rem);letter-spacing:.12em;margin-top:.9em}
.model-block p{margin-top:1.4em;font-size:.95rem;line-height:2.3;color:var(--ink-2);max-width:760px}
.model-block p em{display:block;font-style:normal;font-family:var(--display);font-size:.78rem;letter-spacing:.14em;color:var(--muted);margin-top:1.4em;line-height:1.9}

/* ---------- company ---------- */
.profile{width:100%;border-collapse:collapse;border-top:1px solid var(--line)}
.profile th,.profile td{border-bottom:1px solid var(--line);padding:1.5em .4em;text-align:left;vertical-align:top;font-weight:400}
.profile th{font-family:var(--sans);font-size:.78rem;letter-spacing:.28em;color:var(--gold);width:200px;white-space:nowrap}
.profile td{font-size:.94rem;letter-spacing:.08em;line-height:2}

.timeline{border-left:1px solid var(--line);margin-left:.4em}
.tl{position:relative;padding:0 0 2.6em 2.6em}
.tl:last-child{padding-bottom:.4em}
.tl::before{content:"";position:absolute;left:-4px;top:.85em;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.tl .yr{font-family:var(--display);font-size:.92rem;letter-spacing:.26em;color:var(--gold)}
.tl p{margin-top:.35em;font-size:.94rem;letter-spacing:.1em}

/* ---------- recruit ---------- */
.role{border:1px solid var(--line);background:var(--paper);padding:clamp(2rem,4.5vw,3.4rem)}
.badge{display:inline-block;font-family:var(--display);font-size:.64rem;letter-spacing:.3em;color:var(--gold);border:1px solid var(--gold);padding:.55em 1.5em;text-transform:uppercase}
.pos{font-family:var(--display);font-size:clamp(1.5rem,2.8vw,2rem);letter-spacing:.1em;margin-top:1em;line-height:1.4;display:flex;flex-direction:column;gap:.4em}
.pos .jp{font-family:var(--sans);font-size:.8rem;letter-spacing:.24em;color:var(--muted)}
.role .en-note{display:block;font-family:var(--display);font-size:.78rem;letter-spacing:.14em;color:var(--muted);margin-top:1em;line-height:1.9}

.want{margin-top:clamp(20px,3vw,30px);border-top:1px solid var(--line)}
.want li{display:flex;gap:2em;align-items:baseline;padding:1.5em .3em;border-bottom:1px solid var(--line);font-size:.95rem;letter-spacing:.08em}
.want .n{font-family:var(--display);font-size:.8rem;letter-spacing:.2em;color:var(--gold);flex:0 0 auto}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2.5rem,6vw,5rem);align-items:start}
.field{margin-bottom:1.7em}
.field label{display:block;font-family:var(--sans);font-size:.74rem;letter-spacing:.26em;color:var(--muted);margin-bottom:.7em}
.field input,.field select,.field textarea{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:.8em .1em;font-family:var(--mincho);font-size:.95rem;letter-spacing:.06em;color:var(--ink);
  border-radius:0;transition:border-color .4s;
}
.field textarea{min-height:150px;resize:vertical;line-height:1.9}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.btn{
  display:inline-flex;align-items:center;gap:1.2em;cursor:pointer;
  font-family:var(--display);font-size:.76rem;letter-spacing:.34em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);padding:1.1em 3em;
  transition:background .45s,color .45s;
}
.btn:hover{background:transparent;color:var(--ink)}
.contact-aside{border-top:1px solid var(--line)}
.contact-aside .line{border-bottom:1px solid var(--line);padding:1.5em .2em}
.contact-aside .k{font-family:var(--display);font-size:.68rem;letter-spacing:.3em;color:var(--gold);text-transform:uppercase}
.contact-aside .v{margin-top:.5em;font-size:.92rem;letter-spacing:.08em;line-height:1.9}

/* ---------- photo band ---------- */
.band-full{height:clamp(260px,44vw,520px);overflow:hidden}
.band-full .ph{width:100%;height:100%;object-fit:cover}

/* ---------- investors ---------- */
.reason{border-top:1px solid var(--line);padding:clamp(1.8em,3vw,2.4em) .2em;display:grid;grid-template-columns:110px 1fr;gap:clamp(1.2rem,3vw,3rem)}
.reason:last-child{border-bottom:1px solid var(--line)}
.reason .rno{font-family:var(--display);font-size:1.1rem;letter-spacing:.3em;color:var(--gold)}
.reason h4{font-family:var(--mincho);font-weight:500;font-size:1.16rem;letter-spacing:.12em;line-height:1.8}
.reason p{margin-top:.9em;font-size:.93rem;line-height:2.2;color:var(--ink-2);max-width:760px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:clamp(28px,4vw,44px)}
.svc{background:var(--paper);padding:1.9em 1.6em;display:flex;flex-direction:column;gap:.7em}
.svc .sno{font-family:var(--display);font-size:.66rem;letter-spacing:.3em;color:var(--gold)}
.svc .sname{font-family:var(--mincho);font-weight:500;font-size:.95rem;letter-spacing:.1em;line-height:1.8}
@media (max-width:860px){.svc-grid{grid-template-columns:repeat(2,1fr)}.reason{grid-template-columns:70px 1fr}}
@media (max-width:520px){.svc-grid{grid-template-columns:1fr}}

/* ---------- footer ---------- */
.site-footer{background:var(--footer);color:#CFCBC0;padding:clamp(60px,8vw,90px) 0 36px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:2.5rem;flex-wrap:wrap;padding-bottom:clamp(36px,5vw,56px);border-bottom:1px solid rgba(255,255,255,.12)}
.foot-addr{font-style:normal;font-family:var(--mincho);font-weight:500;font-size:.74rem;line-height:2.15;letter-spacing:.08em;color:rgba(255,255,255,.52);margin-top:1.7em;max-width:26em}
.foot-brand{font-family:var(--display);font-size:1.4rem;letter-spacing:.3em;color:#fff;display:flex;flex-direction:column}
.foot-brand small{font-family:var(--sans);font-size:.56rem;letter-spacing:.42em;color:var(--gold-soft);margin-top:.5em}
.foot-nav{display:grid;grid-template-columns:repeat(2,auto);gap:1.5em clamp(2.2rem,5vw,4rem);justify-content:start;margin-right:clamp(20px,11vw,170px)}
.foot-nav a{font-family:var(--display);font-size:.84rem;letter-spacing:.22em;color:#E4E2DA;display:flex;flex-direction:column;gap:.42em;transition:color .4s}
.foot-nav a .jp{font-family:var(--mincho);font-weight:500;font-size:.64rem;letter-spacing:.1em;color:rgba(255,255,255,.5)}
.foot-nav a:hover{color:#fff}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;padding-top:30px;font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;color:#8C887D}
.foot-bot a{color:#CFCBC0;transition:color .4s}
.foot-legal{display:flex;flex-direction:column;gap:.4em;font-family:var(--display);font-size:.78rem;letter-spacing:.2em}
.foot-legal .jp{font-family:var(--mincho);font-weight:500;font-size:.64rem;letter-spacing:.1em;color:rgba(255,255,255,.45)}
a.foot-brand{transition:opacity .4s}
a.foot-brand:hover{opacity:.78}
.foot-bot a:hover{color:#fff}
/* legal / privacy */
.legal{max-width:820px}
.legal h2{font-family:var(--display);font-weight:400;font-size:clamp(1.1rem,1.8vw,1.32rem);letter-spacing:.06em;margin:clamp(34px,4vw,48px) 0 1em;padding-top:clamp(28px,3vw,36px);border-top:1px solid var(--line);display:flex;flex-direction:column;gap:.5em}
.legal h2:first-of-type{border-top:0;padding-top:0;margin-top:clamp(8px,2vw,16px)}
.legal h2 .n{font-family:var(--display);font-size:.7rem;letter-spacing:.3em;color:var(--gold)}
.legal p{font-size:.94rem;line-height:2.2;color:var(--ink-2);margin-bottom:1em}
.legal ul{margin:.4em 0 1em;padding-left:0}
.legal li{position:relative;padding-left:1.4em;font-size:.94rem;line-height:2.1;color:var(--ink-2);margin-bottom:.4em}
.legal li::before{content:"";position:absolute;left:0;top:.95em;width:6px;height:1px;background:var(--gold)}
.legal .upd{font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;color:var(--muted);margin-top:clamp(40px,5vw,60px)}

/* ---------- reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 1.1s cubic-bezier(.22,1,.36,1),transform 1.1s cubic-bezier(.22,1,.36,1)}
[data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .scroll-cue::after{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .nav{display:none}
  .burger{display:flex}
  .intro-grid,.hotel,.contact-grid{grid-template-columns:1fr}
  .hotel:nth-child(even){direction:ltr}
  .cards{grid-template-columns:1fr;gap:2.6rem}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .strengths{grid-template-columns:1fr}
  .quick{grid-template-columns:1fr}
  .profile th{width:120px;letter-spacing:.16em}
  .news-list a,.news-list .row{grid-template-columns:1fr;gap:.3rem}
}
@media (max-width:560px){
  .proj-grid{grid-template-columns:1fr}
  .hero-copy{padding-bottom:96px}
  .tagline{font-size:1.75rem;letter-spacing:.1em;line-height:1.7}
  .en-sub{font-size:.82rem;letter-spacing:.16em}
}

/* ============ restrained color pass ============ */
:root{--paper:#FFFFFF;--paper-2:#F5F5F3;--line:#E8E7E4}
/* text labels / numbers → neutral, not accent */
.sec-head .en .jp{color:var(--muted)}
.eyebrow{color:var(--muted)}
.news-list .date{color:var(--muted)}
.card .no{color:var(--muted)}
.hotel .meta{color:var(--muted)}
.profile th{color:var(--muted)}
.tl .yr{color:var(--muted)}
.want .n{color:var(--muted)}
.str .num{color:var(--muted)}
.reason .rno{color:var(--muted)}
.svc .sno{color:var(--muted)}
.contact-aside .k{color:var(--muted)}
.brand small{color:#A8884E}
.pstat-item .pn{color:var(--ink-2)}
.prow .pidx{color:var(--ink-2)}
/* About band → no accent, neutral overlay */
.about-band::after{background:linear-gradient(rgba(20,19,16,.6),rgba(20,19,16,.66))}
.about-band .sec-head .en .jp{color:rgba(255,255,255,.66)}
.about-band .sec-head .en .jp::before,.about-band .sec-head .en .jp::after{background:rgba(255,255,255,.5)}
.foot-brand small{color:#A8884E}

/* legal — numbered article lists */
.legal ol{margin:.3em 0 1.1em;padding-left:1.5em;list-style:decimal}
.legal ol li{padding-left:.3em;font-size:.94rem;line-height:2.1;color:var(--ink-2);margin-bottom:.5em}
.legal ol li::before{content:none}
.legal .sub{padding-left:1.4em;color:var(--ink-2);font-size:.9rem;line-height:2.15;margin:.1em 0 1em}
.legal h2 .ja{font-family:var(--mincho);font-size:1.18rem;letter-spacing:.04em;color:var(--ink)}

/* tighter News section spacing */
.news-sec{padding:clamp(44px,6vw,76px) 0}
.news-sec .sec-head{margin-bottom:clamp(20px,2.6vw,30px)}

/* president message */
.message{max-width:780px}
.message p{font-family:var(--mincho);font-size:clamp(.95rem,1.4vw,1.02rem);line-height:2.5;color:var(--ink-2);margin-bottom:1.5em}
.message .sign{font-family:var(--mincho);font-size:1.05rem;letter-spacing:.1em;color:var(--ink);text-align:right;margin-top:2.4em}

/* projects concept imagery */
.pconcept{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(.5rem,1.2vw,.9rem);margin:clamp(28px,4vw,44px) 0 clamp(10px,1.5vw,16px)}
.pconcept figure{overflow:hidden}
.pconcept .ph{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform 1.2s cubic-bezier(.19,1,.22,1)}
.pconcept figure:hover .ph{transform:scale(1.05)}
.pconcept-cap{font-family:var(--sans);font-size:.7rem;letter-spacing:.14em;color:var(--muted);margin-bottom:clamp(20px,3vw,32px)}
@media (max-width:640px){.pconcept{grid-template-columns:1fr 1fr;gap:.6rem}.pconcept figure:nth-child(5){grid-column:1 / -1}.pconcept figure:nth-child(5) .ph{aspect-ratio:16/7}}

/* ===== mobile fixes (phone only) ===== */
@media (max-width:640px){
  /* About Us: drop the secondary sentence on phones */
  .sp-hide{display:none}
  /* Hotels: enlarge the portrait (Continue) image */
  .hotel.is-portrait{grid-template-columns:1fr}
  .hotel.is-portrait .ph{max-width:none;width:100%;aspect-ratio:3/4}
  /* Footer centered */
  .foot-top{flex-direction:column;align-items:center;text-align:center}
  .foot-left{display:flex;flex-direction:column;align-items:center}
  .foot-brand{align-items:center}
  .foot-addr{text-align:center;max-width:none}
  .foot-nav{justify-content:center;margin-right:0}
  .foot-bot{flex-direction:column;align-items:center;gap:1em;text-align:center}
  .foot-legal{align-items:center}
}
