/* ===== 固定ページ用スタイル ===== */
:root {
  --bg: #FAF7F2;
  --ink: #2C1810;
  --ink-soft: #4a3628;
  --ink-mute: #7a6a5c;
  --gold: #C9A84C;
  --line: rgba(44,24,16,0.14);
  --serif: "Noto Serif JP", serif;
  --sans: "Noto Sans JP", system-ui, sans-serif;
  --latin: "Cormorant Garamond", serif;
}

* { box-sizing: border-box; }
body { background: var(--bg); color: var(--ink); font-family: var(--sans); font-weight: 300; line-height: 1.9; letter-spacing: .04em; }

/* ナビ */
.page-nav { position: sticky; top: 0; z-index: 40; background: var(--ink); border-bottom: 1px solid rgba(201,168,76,.3); }
.page-nav-inner { max-width: 1320px; margin: 0 auto; padding: 18px 48px; display: flex; align-items: center; justify-content: space-between; }
.page-nav-brand { display: flex; align-items: center; text-decoration: none; }
.page-nav-logo { height: 34px; width: auto; display: block; filter: invert(1) sepia(1) brightness(.5) saturate(15) hue-rotate(-15deg) brightness(1.09); }
.page-nav ul { display: flex; gap: 32px; list-style: none; margin: 0; padding: 0; }
.page-nav ul a { font-family: var(--sans); font-size: 13px; font-weight: 300; letter-spacing: .12em; color: rgba(255,255,255,.8); text-decoration: none; }
.page-nav ul a:hover { color: var(--gold); }
@media (max-width: 800px) {
  .page-nav-inner { padding: 14px 20px; }
  .page-nav ul { display: none; }
}

/* コンテンツ */
.page-main { min-height: 80vh; }
.page-wrap { max-width: 900px; margin: 0 auto; padding: 80px 48px 120px; }
@media (max-width: 800px) { .page-wrap { padding: 48px 24px 80px; } }

.page-title {
  font-family: var(--serif);
  font-size: clamp(24px, 3vw, 38px);
  letter-spacing: .3em;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 48px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--gold);
}

.page-content { line-height: 2.2; letter-spacing: .08em; }
.page-content h1, .page-content h2 { font-family: var(--serif); font-weight: 400; letter-spacing: .28em; color: var(--ink); margin: 56px 0 24px; }
.page-content h2 { font-size: 22px; padding-left: 16px; border-left: 2px solid var(--gold); }
.page-content h3 { font-family: var(--serif); font-size: 17px; letter-spacing: .2em; margin: 40px 0 16px; color: var(--ink); }
.page-content p { margin-bottom: 24px; font-size: 15px; color: var(--ink-soft); }
.page-content ul, .page-content ol { margin: 0 0 24px 24px; }
.page-content li { margin-bottom: 8px; font-size: 15px; color: var(--ink-soft); }
.page-content table { width: 100%; border-collapse: collapse; margin: 32px 0; }
.page-content th { background: var(--ink); color: #fff; font-family: var(--serif); font-weight: 400; letter-spacing: .2em; padding: 14px 20px; text-align: left; font-size: 13px; }
.page-content td { padding: 14px 20px; border-bottom: 1px solid var(--line); font-size: 14px; }
.page-content tr:nth-child(even) td { background: rgba(44,24,16,.04); }
.page-content hr { border: none; border-top: 1px solid var(--gold); margin: 48px 0; opacity: .5; }
.page-content a { color: var(--ink); border-bottom: 1px solid rgba(201,168,76,.5); }
.page-content a:hover { color: var(--gold); }
.page-content .wp-block-table { margin: 32px 0; }
.page-content .wp-block-table.is-style-stripes tr:nth-child(even) td { background: rgba(44,24,16,.04); }

/* Contact Form 7 */
.wpcf7-form{max-width:560px;margin:0 auto}
.wpcf7-form p{margin-bottom:36px;font-size:13px;letter-spacing:.14em;color:var(--ink-soft)}
.wpcf7-form .required{color:var(--gold);font-size:11px;margin-left:6px;letter-spacing:.1em}
.wpcf7-form-control-wrap{display:block;margin-top:10px}
.wpcf7-text,.wpcf7-email,.wpcf7-tel,.wpcf7-textarea{width:100%;background:#F3EDE3;border:1px solid rgba(44,24,16,.15);border-bottom:2px solid rgba(201,168,76,.4);padding:14px 18px;font-family:var(--sans);font-size:14px;letter-spacing:.08em;color:var(--ink);outline:none;transition:border-color .3s,background .3s;border-radius:2px;-webkit-appearance:none}
.wpcf7-text:focus,.wpcf7-email:focus,.wpcf7-tel:focus,.wpcf7-textarea:focus{border-color:rgba(201,168,76,.6);border-bottom:2px solid var(--gold);background:#EDE5D8}
.wpcf7-textarea{resize:vertical;min-height:160px}
.wpcf7-not-valid{border-color:#a0392b!important;border-bottom-color:#a0392b!important}
.wpcf7-not-valid-tip{display:block;margin-top:6px;font-size:11px;letter-spacing:.1em;color:#a0392b}
.wpcf7-submit{display:block;margin:48px auto 0;padding:16px 56px;background:transparent;border:1px solid var(--gold);color:var(--ink);font-family:var(--serif);font-size:13px;letter-spacing:.34em;cursor:pointer;transition:background .3s,color .3s}
.wpcf7-submit:hover{background:var(--gold);color:#fff}
.wpcf7-response-output{margin-top:32px;padding:16px 20px;font-size:12px;letter-spacing:.12em;border:1px solid var(--gold);color:var(--ink-soft);text-align:center}

/* ご予約についてページ */
.page-id-39 .page-wrap{max-width:760px;padding-top:64px;padding-bottom:100px}
.page-id-39 .page-title{font-size:clamp(22px,2.6vw,32px);letter-spacing:.28em;text-align:center;border-bottom:none;padding-bottom:0;margin-bottom:8px}
.page-id-39 .page-title::after{content:"";display:block;width:48px;height:1px;background:var(--gold);margin:24px auto 0}
.page-id-39 .page-content{line-height:2.3}
.page-id-39 .reservation-lead{text-align:center;font-family:var(--serif);font-size:14px;letter-spacing:.16em;line-height:2.2;color:var(--ink-soft);margin:48px auto 72px;max-width:600px}
.page-id-39 .page-content h2{font-size:18px;letter-spacing:.32em;margin:64px 0 32px;padding:0 0 0 16px;border-left:2px solid var(--gold);border-bottom:none}
.page-id-39 .reservation-list{list-style:none;margin:0;padding:0}
.page-id-39 .reservation-list li{position:relative;padding:0 0 0 24px;margin-bottom:18px;font-size:14px;line-height:2.1;letter-spacing:.1em;color:var(--ink-soft)}
.page-id-39 .reservation-list li::before{content:"";position:absolute;left:0;top:18px;width:10px;height:1px;background:var(--gold)}
.page-id-39 .reservation-notice{position:relative;background:rgba(201,168,76,.07);border-left:3px solid var(--gold);padding:24px 28px 24px 32px;margin:28px 0 0;display:flex;gap:20px;align-items:flex-start}
.page-id-39 .reservation-notice__mark{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;min-width:48px;height:24px;background:var(--gold);color:#fff;font-family:var(--serif);font-size:11px;letter-spacing:.24em;font-weight:500;padding:0 10px;margin-top:4px}
.page-id-39 .reservation-notice p{margin:0!important;font-size:14px!important;line-height:2!important;letter-spacing:.1em!important;color:var(--ink)!important;font-weight:400}
.page-id-39 .reservation-closing{margin-top:88px;padding-top:48px;border-top:1px solid var(--line);text-align:center}
.page-id-39 .reservation-closing p{font-family:var(--serif);font-size:14px!important;line-height:2.2!important;letter-spacing:.16em!important;color:var(--ink-soft)!important;margin-bottom:18px!important}
.page-id-39 .reservation-closing p:last-child{margin-bottom:0!important}
@media (max-width:800px){
  .page-id-39 .page-wrap{padding-top:40px;padding-bottom:60px}
  .page-id-39 .reservation-lead{margin:32px auto 48px;font-size:13px}
  .page-id-39 .page-content h2{font-size:16px;letter-spacing:.24em;margin:48px 0 24px}
  .page-id-39 .reservation-list li{font-size:13.5px;padding-left:20px}
  .page-id-39 .reservation-notice{padding:20px;flex-direction:column;gap:12px}
  .page-id-39 .reservation-notice p{font-size:13.5px!important}
  .page-id-39 .reservation-closing{margin-top:64px;padding-top:36px}
  .page-id-39 .reservation-closing p{font-size:13.5px!important}
}

/* ポリシー系ページ共通（site-policy / privacy） */
.is-policy-page .page-wrap{max-width:760px;padding-top:64px;padding-bottom:100px}
.is-policy-page .page-title{font-size:clamp(22px,2.6vw,32px);letter-spacing:.28em;text-align:center;border-bottom:none;padding-bottom:0;margin-bottom:8px}
.is-policy-page .page-title::after{content:"";display:block;width:48px;height:1px;background:var(--gold);margin:24px auto 0}
.is-policy-page .page-content{line-height:2.3;letter-spacing:.1em}
.is-policy-page .page-content .policy-lead{text-align:center;font-family:var(--serif);font-size:14px;letter-spacing:.16em;line-height:2.2;color:var(--ink-soft);margin:48px auto 72px;max-width:640px}
.is-policy-page .page-content h2{font-size:18px;letter-spacing:.28em;margin:56px 0 22px;padding:0 0 0 16px;border-left:2px solid var(--gold);border-bottom:none;line-height:1.7}
.is-policy-page .page-content p{font-size:14px;line-height:2.2;letter-spacing:.1em;margin-bottom:18px;color:var(--ink-soft)}
.is-policy-page .page-content p + p{margin-top:-4px}
.is-policy-page .policy-list{list-style:none;margin:0 0 18px;padding:0}
.is-policy-page .policy-list li{position:relative;padding:0 0 0 22px;margin-bottom:10px;font-size:14px;line-height:2.1;letter-spacing:.1em;color:var(--ink-soft)}
.is-policy-page .policy-list li::before{content:"";position:absolute;left:0;top:18px;width:10px;height:1px;background:var(--gold)}
.is-policy-page .policy-email{text-align:center;margin:24px 0 0!important}
.is-policy-page .policy-email a{display:inline-block;font-family:var(--serif);font-size:18px;letter-spacing:.08em;color:var(--ink)!important;border:none!important;padding:14px 32px;border-bottom:1px solid var(--gold)!important;transition:color .3s ease,border-color .3s ease}
.is-policy-page .policy-email a:hover{color:var(--gold)!important}
.is-policy-page .policy-contact{text-align:center;margin-top:24px}
.is-policy-page .policy-contact__name{font-family:var(--serif)!important;font-size:14px!important;letter-spacing:.16em!important;color:var(--ink)!important;margin:0 0 8px!important}
.is-policy-page .policy-revised{text-align:right!important;font-size:12px!important;letter-spacing:.14em!important;color:var(--ink-mute)!important;margin:72px 0 0!important;padding-top:24px;border-top:1px solid var(--line)}
@media (max-width:800px){
  .is-policy-page .page-wrap{padding-top:40px;padding-bottom:60px}
  .is-policy-page .page-content .policy-lead{margin:32px auto 48px;font-size:13px}
  .is-policy-page .page-content h2{font-size:15px;letter-spacing:.22em;margin:44px 0 18px}
  .is-policy-page .page-content p{font-size:13.5px}
  .is-policy-page .policy-list li{font-size:13.5px;padding-left:18px}
  .is-policy-page .policy-email a{font-size:15px;word-break:break-all;padding:12px 16px}
}

/* ナラティブ系ページ（歴代・指圧について） */
.is-narrative-page .page-wrap{max-width:780px;padding-top:64px;padding-bottom:120px}
.is-narrative-page .page-title{font-size:clamp(22px,2.6vw,32px);letter-spacing:.28em;text-align:center;border-bottom:none;padding-bottom:0;margin-bottom:8px}
.is-narrative-page .page-title::after{content:"";display:block;width:48px;height:1px;background:var(--gold);margin:24px auto 0}
.is-narrative-page .page-content{line-height:2.4;letter-spacing:.1em}
.is-narrative-page .page-content .narrative-lead{text-align:center;font-family:var(--serif);font-size:15px;letter-spacing:.18em;line-height:2.2;color:var(--ink-soft);margin:48px auto 80px;max-width:640px}
.is-narrative-page .page-content h2{font-family:var(--serif);font-size:20px;letter-spacing:.32em;margin:88px 0 40px;padding:0;border-left:none;text-align:center;font-weight:400;line-height:1.7;color:var(--ink)}
.is-narrative-page .page-content h2::after{content:"";display:block;width:36px;height:1px;background:var(--gold);margin:20px auto 0;opacity:.7}
.is-narrative-page .page-content p{font-size:14.5px;line-height:2.4;letter-spacing:.1em;margin-bottom:32px;color:var(--ink-soft)}
.is-narrative-page .page-content p:first-of-type{margin-top:0}
.is-narrative-page .narrative-list{list-style:none;margin:24px 0 32px;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 32px}
.is-narrative-page .narrative-list li{position:relative;padding:0 0 0 22px;font-size:14px;line-height:2;letter-spacing:.12em;color:var(--ink-soft)}
.is-narrative-page .narrative-list li::before{content:"";position:absolute;left:0;top:18px;width:10px;height:1px;background:var(--gold)}
.is-narrative-page .shiatsu-compare{display:flex;flex-direction:column;gap:24px;margin:32px 0 48px}
.is-narrative-page .shiatsu-compare__item{padding:28px 32px;background:rgba(255,255,255,.5);border:1px solid var(--line-soft);border-left:2px solid var(--line)}
.is-narrative-page .shiatsu-compare__item--highlight{border-left:2px solid var(--gold);background:rgba(201,168,76,.05)}
.is-narrative-page .shiatsu-compare__label{display:block;font-family:var(--serif);font-size:14px;letter-spacing:.28em;color:var(--ink);margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}
.is-narrative-page .shiatsu-compare__item--highlight .shiatsu-compare__label{color:var(--gold)}
.is-narrative-page .shiatsu-compare__item p{font-size:13.5px!important;line-height:2.2!important;letter-spacing:.1em!important;margin:0!important;color:var(--ink-soft)!important}

/* research-card（聖路加共同研究などの引用カード） */
.is-narrative-page .research-card{margin:36px 0 48px;padding:36px 40px;background:rgba(255,255,255,.55);border:1px solid var(--line-soft);border-left:2px solid var(--gold);position:relative}
.is-narrative-page .research-card__year{display:block;font-family:var(--latin);font-size:32px;letter-spacing:.14em;color:var(--gold);font-weight:300;line-height:1;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--line-soft)}
.is-narrative-page .research-card__row{display:flex;flex-direction:column;gap:8px}
.is-narrative-page .research-card__row + .research-card__row{margin-top:20px;padding-top:20px;border-top:1px solid var(--line-soft)}
.is-narrative-page .research-card__label{font-family:var(--latin);font-size:11px;letter-spacing:.42em;color:var(--gold);text-transform:uppercase}
.is-narrative-page .research-card__value{font-family:var(--serif)!important;font-size:14.5px!important;line-height:1.8!important;letter-spacing:.06em!important;margin:0!important;color:var(--ink)!important}

/* lineage-nav（歴代ページ間の前後リンク） */
.is-narrative-page .lineage-nav{display:flex;justify-content:space-between;align-items:stretch;gap:16px;margin:96px 0 0;padding-top:48px;border-top:1px solid var(--line)}
.is-narrative-page .lineage-nav__spacer{flex:1}
.is-narrative-page .lineage-nav__link{flex:1;display:flex;flex-direction:column;gap:8px;padding:24px 28px;border:1px solid var(--line-soft);text-decoration:none!important;color:var(--ink)!important;transition:border-color .3s ease,background .3s ease,transform .3s ease;background:rgba(255,255,255,.4)}
.is-narrative-page .lineage-nav__link:hover{border-color:var(--gold);background:rgba(201,168,76,.06)}
.is-narrative-page .lineage-nav__link--prev{text-align:left}
.is-narrative-page .lineage-nav__link--next{text-align:right}
.is-narrative-page .lineage-nav__direction{font-family:var(--latin);font-size:10px;letter-spacing:.42em;color:var(--gold);text-transform:uppercase}
.is-narrative-page .lineage-nav__gen{font-family:var(--latin);font-size:10px;letter-spacing:.32em;color:var(--ink-mute);text-transform:uppercase}
.is-narrative-page .lineage-nav__name{font-family:var(--serif);font-size:15px;letter-spacing:.22em;color:var(--ink);margin-top:4px}
@media (max-width:800px){
  .is-narrative-page .page-wrap{padding-top:40px;padding-bottom:80px}
  .is-narrative-page .page-content .narrative-lead{margin:32px auto 56px;font-size:13.5px}
  .is-narrative-page .page-content h2{font-size:16px;letter-spacing:.24em;margin:60px 0 28px}
  .is-narrative-page .page-content p{font-size:14px;line-height:2.3;margin-bottom:26px}
  .is-narrative-page .narrative-list{grid-template-columns:1fr;gap:8px}
  .is-narrative-page .shiatsu-compare__item{padding:22px 20px}
  .is-narrative-page .shiatsu-compare__label{font-size:13px;letter-spacing:.22em}
  .is-narrative-page .shiatsu-compare__item p{font-size:13px!important}
  .is-narrative-page .research-card{padding:24px 22px}
  .is-narrative-page .research-card__year{font-size:24px}
  .is-narrative-page .research-card__value{font-size:13px!important}
  .is-narrative-page .lineage-nav{flex-direction:column;gap:12px;margin-top:72px;padding-top:36px}
  .is-narrative-page .lineage-nav__link{padding:20px 22px}
  .is-narrative-page .lineage-nav__name{font-size:14px}
}

/* お問い合わせページ */
.contact-page{padding-top:8px}
.contact-page__lead{text-align:center;font-family:var(--serif);font-size:15px;letter-spacing:.18em;line-height:2.2;color:var(--ink-soft);margin-bottom:64px}
.contact-page__blocks{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:24px}
.contact-block{background:rgba(255,255,255,.55);border:1px solid var(--line);padding:56px 36px;text-align:center;display:flex;flex-direction:column;align-items:center;transition:border-color .3s ease,background .3s ease}
.contact-block:hover{border-color:rgba(201,168,76,.35);background:rgba(255,255,255,.75)}
.contact-block__label{font-family:var(--latin);font-size:11px;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;margin-bottom:16px}
.contact-block__title{font-family:var(--serif)!important;font-size:22px!important;letter-spacing:.32em!important;font-weight:400!important;margin:0!important;padding:0!important;border:none!important;color:var(--ink)!important}
.contact-block__rule{width:32px;height:1px;background:var(--gold);margin:18px 0 22px;opacity:.7}
.contact-block__desc{font-size:13px!important;line-height:2.1!important;letter-spacing:.12em!important;color:var(--ink-soft)!important;margin:0 0 24px!important}
.contact-block__tel,
.contact-block__email{font-family:var(--serif);font-weight:300;color:var(--ink)!important;border:none!important;letter-spacing:.1em;transition:color .3s ease;display:inline-block;padding:6px 0}
.contact-block__tel{font-size:30px;letter-spacing:.08em}
.contact-block__email{font-size:18px;letter-spacing:.06em}
.contact-block__tel:hover,
.contact-block__email:hover{color:var(--gold)!important}
.contact-block__hours{font-size:11px!important;letter-spacing:.18em!important;color:var(--ink-mute)!important;line-height:1.9!important;margin:14px 0 0!important}
.contact-block__note-link{display:inline-flex;align-items:center;gap:8px;margin-top:24px;padding-top:18px;border-top:1px solid var(--line);font-family:var(--serif);font-size:12px;letter-spacing:.16em;color:var(--ink-soft)!important;border-bottom:none!important;width:100%;justify-content:center;transition:color .3s ease}
.contact-block__note-link:hover{color:var(--gold)!important}
.contact-block__note-link .arrow{font-family:var(--latin);font-size:14px;color:var(--gold);transition:transform .3s ease}
.contact-block__note-link:hover .arrow{transform:translateX(4px)}
@media (max-width:800px){
  .contact-page__lead{font-size:14px;margin-bottom:40px}
  .contact-page__blocks{grid-template-columns:1fr;gap:24px}
  .contact-block{padding:40px 24px}
  .contact-block__tel{font-size:24px}
  .contact-block__email{font-size:15px;word-break:break-all}
}

/* === お知らせ（News） === */
.news-archive-wrap,
.news-single-wrap { max-width: 840px; }

/* アーカイブ：タイトル */
.news-archive-wrap .page-title { text-align: center; border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.news-archive-wrap .page-title::after { content: ""; display: block; width: 48px; height: 1px; background: var(--gold); margin: 24px auto 0; }

/* リスト */
.news-list { margin-top: 64px; border-top: 1px solid var(--line); }
.news-item__link { display: flex; align-items: center; gap: 32px; padding: 32px 12px; border-bottom: 1px solid var(--line); text-decoration: none; color: var(--ink); transition: background .2s, color .2s; }
.news-item__link:hover { background: rgba(201,168,76,.05); color: var(--ink); }
.news-item__meta { display: flex; align-items: center; gap: 16px; flex-shrink: 0; width: 270px; }
.news-item__cat { font-family: var(--sans); font-size: 11px; font-weight: 400; letter-spacing: .14em; color: var(--gold); border: 1px solid var(--gold); padding: 5px 0; white-space: nowrap; transition: background .2s, color .2s; width: 120px; text-align: center; flex-shrink: 0; }
.news-item__link:hover .news-item__cat { background: var(--gold); color: #fff; }
.news-item__date { font-family: var(--sans); font-size: 13px; font-weight: 300; letter-spacing: .06em; color: var(--ink-mute); white-space: nowrap; width: 110px; flex-shrink: 0; }
.news-item__title { flex: 1; font-family: var(--serif); font-size: 17px; font-weight: 400; letter-spacing: .14em; line-height: 1.7; margin: 0; color: var(--ink); }
.news-item__link:hover .news-item__title { color: var(--ink); }
.news-empty { text-align: center; color: var(--ink-mute); padding: 96px 0; font-family: var(--serif); letter-spacing: .2em; font-size: 15px; }

/* ページネーション */
.news-pagination { display: flex; justify-content: center; gap: 4px; margin-top: 64px; }
.news-pagination .page-numbers { font-family: var(--latin); font-size: 12px; letter-spacing: .24em; padding: 10px 18px; color: var(--ink-mute); text-decoration: none; border: 1px solid transparent; transition: color .2s, border-color .2s; }
.news-pagination .page-numbers.current { color: var(--gold); border-color: var(--gold); }
.news-pagination .page-numbers:hover:not(.dots) { color: var(--gold); }

/* 個別記事 */
.news-single__meta { display: flex; align-items: center; gap: 18px; margin-bottom: 28px; }
.news-single__date { font-family: var(--latin); font-size: 13px; letter-spacing: .08em; color: var(--ink-mute); }
.news-single__thumb { margin: 0 0 56px; overflow: hidden; }
.news-single__thumb img { width: 100%; height: auto; display: block; }
.news-single__back { margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--line); }
.news-single__back a { font-family: var(--latin); font-size: 12px; letter-spacing: .3em; text-transform: uppercase; color: var(--ink-mute); text-decoration: none; border: none !important; transition: color .2s; }
.news-single__back a:hover { color: var(--gold); }

@media (max-width: 800px) {
  .news-item__link { flex-direction: column; align-items: flex-start; gap: 12px; padding: 24px 8px; }
  .news-item__meta { min-width: unset; gap: 12px; }
  .news-item__cat { font-size: 10px; padding: 4px 10px; }
  .news-item__date { font-size: 12px; }
  .news-item__title { font-size: 15px; letter-spacing: .1em; }
  .news-single__meta { gap: 12px; }
  .news-single__thumb { margin-bottom: 36px; }
  .news-single__back { margin-top: 48px; }
}

/* 採用情報ページ */
.careers-hero { background: var(--ink); color: #EFE6D3; text-align: center; padding: 100px 48px 80px; }
.careers-hero__label { font-family: var(--latin); font-size: 11px; letter-spacing: .5em; color: var(--gold); text-transform: uppercase; margin-bottom: 28px; }
.careers-hero__title { font-family: var(--serif); font-size: clamp(28px, 4vw, 48px); font-weight: 400; letter-spacing: .3em; line-height: 1.7; margin-bottom: 28px; }
.careers-hero__sub { font-family: var(--sans); font-size: 14px; letter-spacing: .18em; color: rgba(239,230,211,.65); }

.careers-page .page-wrap { max-width: 860px; }

.careers-page section { margin-bottom: 80px; }
.careers-page h2 { font-family: var(--serif); font-size: 20px; font-weight: 400; letter-spacing: .28em; color: var(--ink); padding-left: 16px; border-left: 2px solid var(--gold); margin: 0 0 32px; }
.careers-page p { font-size: 14.5px; line-height: 2.3; letter-spacing: .1em; color: var(--ink-soft); margin-bottom: 20px; }

.careers-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.careers-table th { width: 160px; background: rgba(44,24,16,.06); font-family: var(--serif); font-size: 13px; font-weight: 400; letter-spacing: .2em; color: var(--ink); padding: 18px 20px; border-bottom: 1px solid var(--line); vertical-align: top; }
.careers-table td { font-size: 14px; letter-spacing: .1em; color: var(--ink-soft); padding: 18px 20px; border-bottom: 1px solid var(--line); line-height: 1.9; }
.careers-table__note { display: block; margin-top: 8px; font-size: 12px; letter-spacing: .1em; color: var(--ink-mute); }

.careers-points__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 8px; }
.careers-point { padding: 36px 32px; background: rgba(255,255,255,.55); border: 1px solid var(--line); transition: border-color .3s ease, background .3s ease; }
.careers-point:hover { border-color: rgba(201,168,76,.35); background: rgba(255,255,255,.75); }
.careers-point__num { font-family: var(--latin); font-size: 28px; font-weight: 300; color: var(--gold); letter-spacing: .14em; margin-bottom: 16px; }
.careers-point__title { font-family: var(--serif); font-size: 16px; font-weight: 400; letter-spacing: .22em; color: var(--ink); margin: 0 0 14px; }
.careers-point__text { font-size: 13.5px; line-height: 2.1; letter-spacing: .1em; color: var(--ink-soft); margin: 0; }

.careers-apply__cta { margin-top: 40px; text-align: center; }
.careers-btn { display: inline-flex; align-items: center; gap: 16px; padding: 18px 48px; background: transparent; border: 1px solid var(--gold); color: var(--ink); font-family: var(--serif); font-size: 14px; letter-spacing: .28em; text-decoration: none; transition: background .3s, color .3s; }
.careers-btn:hover { background: var(--gold); color: #fff; }
.careers-btn__arrow { font-family: var(--latin); font-size: 18px; color: var(--gold); transition: transform .3s, color .3s; }
.careers-btn:hover .careers-btn__arrow { color: #fff; transform: translateX(4px); }
.careers-apply__note { margin-top: 24px; font-size: 12px; letter-spacing: .14em; color: var(--ink-mute); }

@media (max-width: 800px) {
  .careers-hero { padding: 64px 24px 56px; }
  .careers-hero__title { letter-spacing: .2em; }
  .careers-points__grid { grid-template-columns: 1fr; gap: 16px; }
  .careers-point { padding: 28px 24px; }
  .careers-table th { width: 100px; padding: 14px 14px; font-size: 12px; }
  .careers-table td { padding: 14px 14px; font-size: 13.5px; }
  .careers-btn { padding: 16px 32px; font-size: 13px; }
}

/* フッター */
.page-footer { background: var(--ink); color: rgba(239,230,211,.6); padding: 40px 0; border-top: 2px solid var(--gold); }
.page-footer-inner { max-width: 1320px; margin: 0 auto; padding: 0 48px; display: flex; justify-content: space-between; align-items: center; gap: 24px; font-family: var(--latin); font-size: 11px; letter-spacing: .4em; text-transform: uppercase; }
.page-footer a { color: var(--gold); text-decoration: none; transition: color .3s ease; }
.page-footer a:hover { color: #efe6d3; }
.page-footer-links { display: flex; gap: 28px; }
.page-footer-links a { font-family: var(--sans); font-size: 11px; letter-spacing: .18em; text-transform: none; color: rgba(239,230,211,.7); }
.page-footer-links a:hover { color: var(--gold); }
@media (max-width: 800px) { .page-footer-inner { flex-direction: column; gap: 16px; padding: 0 24px; text-align: center; } .page-footer-links { gap: 20px; } }
