:root {
  --indigo: #1c2a4d;
  --indigo-deep: #0f1a35;
  --kinari: #f5efe1;
  --kinari-soft: #faf6ec;
  --sumi: #1a1a1a;
  --yamabuki: #c89211;
  --gray-line: #d8d2c0;
  --gray-text: #5a5a5a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: "Hiragino Mincho ProN", "YuMincho", "Yu Mincho", serif;
  color: var(--sumi);
  background: var(--kinari-soft);
  line-height: 1.85;
  font-size: 16px;
  word-break: auto-phrase;
  text-wrap: pretty;
  line-break: strict;
  -webkit-font-smoothing: antialiased;
}

/* 見出し共通：文節/句読点改行（必須） */
h1, h2, h3 {
  text-wrap: balance;
  word-break: auto-phrase;
  line-break: strict;
}

/* リード文・3行以上の段落：文節改行 + 行末整え */
.lead, .lead-text, .president-message p {
  text-wrap: pretty;
  word-break: auto-phrase;
  line-break: strict;
}

a { color: var(--indigo); text-decoration: none; transition: color .2s; }
a:hover { color: var(--yamabuki); }

img { max-width: 100%; height: auto; display: block; }

header.site-header {
  background: var(--kinari);
  border-bottom: 1px solid var(--gray-line);
  padding: 18px 0;
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(6px);
  background: rgba(245, 239, 225, 0.92);
}

.container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 28px;
}

header.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.logo {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--indigo-deep);
}
.logo .en {
  display: block;
  font-family: "Cormorant Garamond", "Times New Roman", serif;
  font-size: 11px;
  letter-spacing: 0.32em;
  color: var(--gray-text);
  margin-top: 2px;
  font-weight: 400;
}

nav.gnav ul {
  list-style: none;
  display: flex;
  gap: 28px;
}
nav.gnav a {
  font-size: 14px;
  letter-spacing: 0.1em;
  color: var(--sumi);
  position: relative;
  padding-bottom: 4px;
}
nav.gnav a::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 1px;
  background: var(--yamabuki);
  transition: width .25s;
}
nav.gnav a:hover::after { width: 100%; }

.hero {
  background: linear-gradient(180deg, var(--indigo-deep) 0%, var(--indigo) 100%);
  color: var(--kinari);
  padding: 110px 0 130px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 18% 38%, rgba(200, 146, 17, 0.08), transparent 45%),
    radial-gradient(circle at 82% 70%, rgba(245, 239, 225, 0.06), transparent 50%);
  pointer-events: none;
}
.hero .container { position: relative; }
.hero h1 {
  font-size: 42px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-bottom: 28px;
  text-wrap: balance;
}
.hero h1 .accent {
  color: var(--yamabuki);
  font-weight: 600;
}
.hero h1 .nobr {
  white-space: nowrap;
}
.hero h1 .phrase {
  display: inline-block;
}

/* 句単位で折り返すユーティリティ — 句読点位置で改行を制御する */
.ja-phrase {
  display: inline-block;
}
.ja-phrase + .ja-phrase {
  margin-left: 0;
}

/* スマホ専用の強制改行（PCでは非表示） */
.sp-br { display: none; }
@media (max-width: 820px) {
  .sp-br { display: inline; }
}
.hero p.lead {
  font-size: 17px;
  line-height: 2;
  max-width: 640px;
  color: rgba(245, 239, 225, 0.92);
}
.hero .en-tag {
  font-family: "Cormorant Garamond", serif;
  font-size: 13px;
  letter-spacing: 0.5em;
  color: var(--yamabuki);
  margin-bottom: 24px;
  display: block;
}

section.block {
  padding: 90px 0;
}
section.block.alt {
  background: var(--kinari);
}

.block-head {
  text-align: center;
  margin-bottom: 56px;
}
.block-head .en {
  font-family: "Cormorant Garamond", serif;
  font-size: 13px;
  letter-spacing: 0.5em;
  color: var(--yamabuki);
  display: block;
  margin-bottom: 8px;
}
.block-head h2 {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--indigo-deep);
}
.block-head h2::after {
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  background: var(--yamabuki);
  margin: 18px auto 0;
}

p { margin-bottom: 1.4em; }
p:last-child { margin-bottom: 0; }

.lead-text {
  max-width: 760px;
  margin: 0 auto;
  font-size: 16px;
  line-height: 2.1;
  color: var(--sumi);
  text-align: center;
}

.cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 48px;
}
.card {
  background: #fff;
  border: 1px solid var(--gray-line);
  border-top: 3px solid var(--indigo);
  padding: 36px 28px;
  transition: transform .25s, box-shadow .25s;
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px -16px rgba(28, 42, 77, 0.25);
}
.card .num {
  font-family: "Cormorant Garamond", serif;
  font-size: 14px;
  letter-spacing: 0.32em;
  color: var(--yamabuki);
}
.card h3 {
  font-size: 19px;
  font-weight: 600;
  margin: 12px 0 16px;
  color: var(--indigo-deep);
  letter-spacing: 0.06em;
}
.card p {
  font-size: 14.5px;
  line-height: 1.95;
  color: var(--gray-text);
}

table.info, table.salary {
  width: 100%;
  border-collapse: collapse;
  margin: 24px auto;
  background: #fff;
  font-size: 15px;
}
table.info th, table.info td,
table.salary th, table.salary td {
  padding: 18px 22px;
  border-bottom: 1px solid var(--gray-line);
  text-align: left;
  vertical-align: top;
}
table.info th {
  width: 200px;
  background: var(--kinari);
  color: var(--indigo-deep);
  font-weight: 500;
  letter-spacing: 0.08em;
}
table.salary {
  max-width: 760px;
}
table.salary th {
  background: var(--indigo-deep);
  color: var(--kinari);
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.08em;
}
table.salary td {
  text-align: center;
}
table.salary td.grade {
  text-align: left;
  background: var(--kinari-soft);
}
table.salary td.grade span {
  display: block;
  font-size: 12px;
  color: var(--gray-text);
  margin-top: 2px;
}
table.salary td.num {
  font-family: "Cormorant Garamond", serif;
  font-size: 17px;
  color: var(--indigo-deep);
}
.salary-note {
  max-width: 760px;
  margin: 24px auto 0;
  font-size: 13.5px;
  color: var(--gray-text);
  line-height: 1.95;
}
.salary-note li {
  list-style: "※ " inside;
  padding-left: 0;
  margin-bottom: 4px;
}

.president {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 40px;
  align-items: start;
  max-width: 880px;
  margin: 0 auto;
}
.president-photo {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: var(--kinari);
  border: 2px solid var(--gray-line);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.president-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  image-rendering: pixelated;
}
.president-name {
  font-size: 13px;
  letter-spacing: 0.3em;
  color: var(--gray-text);
  margin-top: 12px;
  text-align: center;
}
.president-name strong {
  display: block;
  font-size: 18px;
  letter-spacing: 0.18em;
  color: var(--indigo-deep);
  margin-top: 6px;
  font-weight: 500;
}
.president-message p {
  font-size: 15.5px;
  line-height: 2.1;
  margin-bottom: 1.4em;
}
.president-message .sign {
  text-align: right;
  font-size: 14px;
  color: var(--gray-text);
  margin-top: 24px;
}
.president-message .sign strong {
  font-size: 17px;
  color: var(--indigo-deep);
  letter-spacing: 0.16em;
  margin-left: 8px;
  font-weight: 500;
}

.btn {
  display: inline-block;
  padding: 14px 36px;
  background: var(--yamabuki);
  color: #fff;
  font-size: 14.5px;
  letter-spacing: 0.16em;
  border: none;
  cursor: pointer;
  transition: background .2s, transform .15s;
}
.btn:hover {
  background: #b07f08;
  color: #fff;
  transform: translateY(-1px);
}
.btn.secondary {
  background: transparent;
  color: var(--indigo-deep);
  border: 1px solid var(--indigo-deep);
}
.btn.secondary:hover {
  background: var(--indigo-deep);
  color: var(--kinari);
}

.cta-row {
  text-align: center;
  margin-top: 48px;
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

.contact-box {
  max-width: 560px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--gray-line);
  padding: 48px 40px;
  text-align: center;
}
.contact-box dl {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 12px 18px;
  text-align: left;
  margin: 24px 0;
  font-size: 15px;
}
.contact-box dt { color: var(--gray-text); font-size: 13px; padding-top: 4px; }
.contact-box dd { color: var(--indigo-deep); }

footer.site-footer {
  background: var(--indigo-deep);
  color: rgba(245, 239, 225, 0.85);
  padding: 56px 0 24px;
  margin-top: 0;
}
footer.site-footer .footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 40px;
}
footer.site-footer h4 {
  font-size: 13px;
  letter-spacing: 0.2em;
  color: var(--yamabuki);
  margin-bottom: 16px;
  font-weight: 500;
}
footer.site-footer .footer-logo {
  font-size: 18px;
  letter-spacing: 0.18em;
  color: var(--kinari);
  margin-bottom: 12px;
}
footer.site-footer ul { list-style: none; }
footer.site-footer li { margin-bottom: 8px; font-size: 13.5px; }
footer.site-footer a { color: rgba(245, 239, 225, 0.85); }
footer.site-footer a:hover { color: var(--yamabuki); }
footer.site-footer p { font-size: 13px; line-height: 1.9; }
footer.site-footer .copy {
  border-top: 1px solid rgba(245, 239, 225, 0.15);
  padding-top: 20px;
  text-align: center;
  font-size: 12px;
  color: rgba(245, 239, 225, 0.55);
  letter-spacing: 0.1em;
  font-family: "Cormorant Garamond", serif;
}

.mock-banner {
  background: var(--yamabuki);
  color: #fff;
  text-align: center;
  font-size: 12.5px;
  letter-spacing: 0.16em;
  padding: 8px 12px;
  font-family: "Hiragino Sans", sans-serif;
}

@media (max-width: 820px) {
  .hero { padding: 80px 0 90px; }
  .hero h1 { font-size: 28px; }
  .cards { grid-template-columns: 1fr; }
  .president { grid-template-columns: 1fr; }
  .president-photo { margin: 0 auto; }
  table.info th { width: 130px; padding: 14px 16px; }
  table.info td { padding: 14px 16px; }
  table.salary { font-size: 13.5px; }
  table.salary th, table.salary td { padding: 12px 8px; }
  footer.site-footer .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  nav.gnav ul { gap: 14px; flex-wrap: wrap; }
  nav.gnav a { font-size: 13px; }
  section.block { padding: 60px 0; }
}
