.page-hero {
  background: var(--white);
}

.page-hero .wrap {
  padding: 56px 0 0;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: 0 0 16px;
  color: #8A95A0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
}

.breadcrumb a {
  color: #1A549F;
  font-weight: 500;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
}

.breadcrumb span {
  white-space: pre;
}

.article-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px;
  border: 2px solid #1A549F;
  border-radius: 8px;
  background: var(--white);
  color: #14427D;
  font-size: 14px;
  font-weight: 600;
  line-height: 20px;
  white-space: nowrap;
  text-decoration: none !important;
  transition: background-color 160ms ease, color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.article-label:hover,
.article-label:focus-visible {
  background: #1A549F;
  color: var(--white);
  box-shadow: 0 6px 14px rgba(26, 84, 159, .2);
  transform: translateY(-1px);
}

h1 {
  max-width: 952px;
  margin: 0 0 16px;
  padding-bottom: 16px;
  border-bottom: 2px solid #E7EFF7;
  color: #1A549F;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.5;
  letter-spacing: .05em;
  font-weight: 800;
  font-feature-settings: "palt" 1;
  text-align: justify;
}

.page-hero h1 {
  font-weight: 800;
}

@media (min-width: 768px) {
  .page-hero h1 {
    line-height: 1.45;
  }
}

.lead {
  max-width: 780px;
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: flex-end;
  color: #8A95A0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
  white-space: nowrap;
}

.article-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  max-width: 952px;
}

.main {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 48px;
  align-items: start;
  padding: 50px 0 72px;
  background: var(--white);
}

.article-body {
  grid-column: span 6;
  min-width: 0;
  background: var(--white);
  color: var(--muted);
  font-size: 18px;
  line-height: 2.2;
}

.article-cover {
  width: min(100%, 948px);
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  object-fit: cover;
}

.article-inner {
  padding: 64px 0;
}

.key-summary {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: min(100%, 948px);
  margin-bottom: 64px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.key-summary-title,
.content .key-summary > .key-summary-title {
  width: 100%;
  margin: 0;
  padding: 16px;
  border: 0;
  border-radius: 8px;
  background: var(--navy-50);
  color: #5A6472;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.48px;
}

.key-summary ul {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.content .key-summary ul {
  display: block;
  margin: 0;
  padding: 0;
}

.key-summary li {
  display: flex;
  gap: .2em;
  padding-left: 0;
  text-indent: 0;
  color: var(--muted);
  font-size: 18px;
  font-weight: 500;
  line-height: 2.2;
}

.key-summary li::before {
  content: "・";
  flex: 0 0 auto;
}

.key-summary li p {
  margin: 0;
  color: inherit;
  font: inherit;
  line-height: inherit;
  text-align: inherit;
}

.key-summary > p:empty {
  display: none;
}

.article-before-supervisor {
  width: min(100%, 948px);
  margin: 0 0 64px;
  color: var(--muted);
}

.article-before-supervisor p {
  margin: 0 0 32px;
  color: var(--muted);
  font-size: 18px;
  line-height: 2.2;
  text-align: justify;
}

.article-before-supervisor > :last-child {
  margin-bottom: 0;
}

.article-before-supervisor h5 {
  color: #1A549F !important;
  font-size: 18px !important;
  font-weight: 800 !important;
}

.article-before-supervisor h2,
.article-before-supervisor h3,
.article-before-supervisor h4,
.article-before-supervisor h6 {
  color: #1A549F !important;
  font-weight: 800 !important;
}

.article-before-supervisor h2 {
  margin: 64px 0 32px;
  padding: 0 0 16px;
  border: 0;
  border-bottom: 2px solid var(--navy-100);
  border-radius: 0;
  background: transparent;
  font-size: 32px !important;
  line-height: 1.5;
  letter-spacing: .02em;
  font-feature-settings: "palt" 1;
}

.article-before-supervisor h3 {
  margin: 40px 0 16px;
  padding-bottom: 0;
  border-bottom: 0;
  font-size: 24px !important;
  line-height: 1.45;
  letter-spacing: .02em;
}

.article-before-supervisor h4 {
  font-size: 20px !important;
}

.article-before-supervisor h6 {
  font-size: 16px !important;
}

.article-before-supervisor .key-summary {
  width: 100%;
  max-width: 948px;
  margin-bottom: 64px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.article-before-supervisor .key-summary > .key-summary-title {
  width: 100%;
  margin: 0;
  padding: 16px;
  border: 0;
  border-radius: 8px;
  background: var(--navy-50);
  color: #5A6472;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.48px;
  text-align: left;
}

.article-before-supervisor .key-summary ul {
  display: block;
  margin: 0;
  padding: 0;
}

.article-before-supervisor .key-summary li {
  display: flex;
  width: 100%;
  gap: .2em;
  padding-left: 0;
  text-indent: 0;
  color: var(--muted);
  font-size: 18px;
  font-weight: 500;
  line-height: 2.2;
  word-break: normal;
  overflow-wrap: normal;
}

.article-before-supervisor .key-summary li::before {
  content: "・";
  flex: 0 0 auto;
}

.supervisor {
  display: grid;
  grid-template-columns: 156px 1fr;
  gap: 20px;
  align-items: center;
  width: min(100%, 948px);
  margin-bottom: 64px;
  padding: 48px 40px;
  border-radius: 8px;
  background: #F1F7FF;
}

.supervisor-photo {
  width: 156px;
  height: 156px;
  border-radius: 9999px;
  background: #D9D9D9;
  object-fit: cover;
}

.supervisor-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.supervisor-title {
  display: block;
  color: #5A6472;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.85;
}

.supervisor-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #1A549F;
  line-height: 1;
}

.supervisor b {
  color: #1A549F;
  font-size: 24px;
  font-weight: 600;
}

.supervisor-name-row span {
  color: #1A549F;
  font-size: 18px;
  font-weight: 500;
  white-space: nowrap;
}

.supervisor-bio {
  margin: 0;
  color: #5A6472;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.85;
}

.article-inner > p {
  margin: 0 0 64px;
}

.article-lead {
  width: min(100%, 948px);
  color: #5A6472;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.9;
  text-align: justify;
}

.toc {
  width: min(100%, 948px);
  margin: 0 0 64px;
  padding: 32px;
  border: 2px solid var(--navy-100);
  border-radius: 8px;
  background: var(--white);
  overflow: hidden;
}

.toc summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  border-bottom: 0;
  background: transparent;
  color: var(--muted);
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  list-style: none;
}

.toc[open] summary {
  padding-bottom: 18px;
  border-bottom: 2px solid var(--navy-100);
}

.toc summary::-webkit-details-marker {
  display: none;
}

.toc summary::after {
  content: "";
  display: block;
  width: 22px;
  height: 2px;
  background: #8A95A0;
}

.content .toc ol {
  display: grid;
  gap: 16px;
  margin: 28px 0 0;
  padding-left: 0;
  list-style: none;
  counter-reset: toc-item;
  color: var(--muted);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.7;
}

.content .toc ol ol {
  gap: 6px;
  margin: 8px 0 0;
  padding: 0 0 0 28px;
  list-style: none;
  counter-reset: toc-subitem;
}

.content .toc li {
  border-top: 0;
}

.content .toc > ol > li {
  position: relative;
  padding-left: 1.8em;
  counter-increment: toc-item;
}

.content .toc > ol > li::before {
  content: counter(toc-item) ".";
  position: absolute;
  top: 0;
  left: 0;
}

.content .toc > ol > li > ol {
  margin-left: 0;
}

.content .toc ol ol li {
  border-top: 0;
}

.content .toc a,
.content .toc a:visited,
.content .toc a:hover,
.content .toc a:focus-visible {
  display: inline;
  padding: 0;
  color: var(--muted);
  text-decoration: none !important;
}

.content .toc a::before {
  content: none;
}

.content .toc ol ol a {
  display: inline;
  padding: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.75;
  text-decoration: none !important;
}

.toc ol ol a::before {
  content: counter(toc-item) "-" counter(toc-subitem) ". ";
  counter-increment: toc-subitem;
  display: inline;
}

.content #ez-toc-container,
#ez-toc-container {
  width: min(100%, 948px);
  margin: 0 0 64px;
  padding: 32px 32px 20px !important;
  border: 2px solid var(--navy-100);
  border-radius: 8px;
  background: var(--white);
  box-shadow: none;
}

#ez-toc-container .ez-toc-title-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
  border-bottom: 0;
}

#ez-toc-container p.ez-toc-title {
  margin: 0;
  color: var(--muted);
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}

#ez-toc-container .ez-toc-title-toggle {
  display: block;
  width: 22px;
  height: 2px;
  background: #8A95A0;
  overflow: hidden;
  text-indent: -9999px;
}

#ez-toc-container nav {
  margin-top: 18px;
  padding-top: 0;
  border-top: 0;
}

#ez-toc-container ul,
#ez-toc-container li {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

#ez-toc-container ul.ez-toc-list {
  display: grid;
  gap: 16px;
  margin-top: 0;
  padding: 18px 0 0 1.5em;
  border-top: 2px solid var(--navy-100);
  list-style: decimal;
  color: var(--muted);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.85;
}

#ez-toc-container ul.ez-toc-list ul {
  display: grid;
  gap: 5px;
  margin-top: 5px;
  padding-left: 24px;
  list-style: none;
}

#ez-toc-container a,
#ez-toc-container a:visited {
  display: inline;
  padding: 0;
  color: var(--muted);
  font-weight: 400;
  text-decoration: none;
}

#ez-toc-container ul ul a {
  font-size: 14px;
  line-height: 1.85;
}

.content h1,
.content h2,
.content h3,
.content h4,
.content h5,
.content h6 {
  color: #1A549F !important;
  font-weight: 800 !important;
}

.content h2 {
  margin: 64px 0 32px;
  padding: 0 0 16px;
  border: 0;
  border-bottom: 2px solid var(--navy-100);
  border-radius: 0;
  background: transparent;
  font-size: 32px;
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: .02em;
  font-feature-settings: "palt" 1;
}

.content h2:first-child {
  margin-top: 0;
}

.content h3 {
  margin: 40px 0 16px;
  padding-bottom: 0;
  border-bottom: 0;
  font-size: 24px;
  font-weight: 800;
  line-height: 1.45;
  letter-spacing: .02em;
}

.content h4 {
  font-size: 20px !important;
}

.content h5 {
  font-size: 18px !important;
}

.content h6 {
  font-size: 16px !important;
}

.content p {
  margin: 0 0 32px;
  color: var(--muted);
  font-size: 18px;
  line-height: 2.2;
  text-align: justify;
}

.content strong,
.content b {
  color: #1A549F !important;
  font-weight: 600;
}

.content ul,
.content ol {
  display: grid;
  gap: 8px;
  margin: 0 0 32px;
  padding: 0 0 0 1.5em;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.9;
}

.note-box {
  display: flex;
  gap: 18px;
  align-items: center;
  margin: 40px 0 64px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: var(--gold-50);
}

.note-box::before {
  content: none;
}

.note-box b {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 156px;
  height: 76px;
  padding: 12px 24px;
  border-radius: 8px;
  background: var(--gold);
  color: var(--white);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.45;
  text-align: center;
}

.note-box strong {
  color: var(--white) !important;
}

.note-box-content {
  flex: 1 1 auto;
  min-width: 0;
}

.note-box p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.85;
}

.note-box--attention {
  background: rgba(217, 64, 64, .1);
}

.note-box--attention b {
  background: #D94040;
}

.note-box--supplement {
  background: var(--teal-50);
}

.note-box--supplement b {
  background: #0A7892;
}

.article-before-supervisor .note-box b,
.article-before-supervisor .note-box strong,
.note-box b,
.note-box strong {
  color: var(--white) !important;
}

.article-point {
  display: flex;
  align-items: stretch;
  width: min(100%, 948px);
  margin: 40px 0 64px;
}

.article-point-set {
  display: grid;
  gap: 16px;
  width: min(100%, 948px);
  margin: 40px 0 64px;
}

.article-point-set .article-point {
  width: 100%;
  margin: 0;
}

.article-point-label {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 126px;
  padding: 15px;
  border-radius: 16px 0 0 16px;
  background: var(--navy-500);
  color: var(--white);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.45;
  text-align: center;
  word-break: break-word;
}

.article-point-body {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  min-width: 0;
  padding: 16px 24px;
  border: 1px solid var(--navy-500);
  border-left: 0;
  border-radius: 0 16px 16px 0;
  background: var(--white);
}

.article-point-body p {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.85;
  text-align: left;
  word-break: break-word;
}

.article-point--merit .article-point-label {
  background: var(--navy-500);
}

.article-point--merit .article-point-body {
  border-color: var(--navy-500);
}

.article-point--demerit .article-point-label {
  background: var(--muted);
}

.article-point--demerit .article-point-body {
  border-color: var(--muted);
}

.article-point + p:empty,
.article-point + p:has(br:only-child),
.article-point-set + p:empty,
.article-point-set + p:has(br:only-child) {
  display: none;
  margin: 0;
}

.article-table-wrap {
  width: min(100%, 948px);
  margin: 0 0 64px;
  overflow-x: auto;
}

.wp-block-table {
  margin: 0 0 32px;
}

.wp-block-table table,
.wp-block-table .has-fixed-layout {
  margin-bottom: 0;
}

.article-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 2px;
  table-layout: fixed;
}

.article-table caption {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.article-table th,
.article-table td {
  min-height: 48px;
  padding: 16px;
  text-align: left;
  color: var(--muted);
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: .02em;
  white-space: nowrap;
}

.article-table thead th {
  background: var(--navy-400);
  color: var(--white);
  font-weight: 700;
}

.article-table tbody th {
  background: var(--navy-100);
  color: var(--navy-600);
  font-weight: 700;
}

.article-table tbody tr:nth-child(odd) td {
  background: var(--white);
}

.article-table tbody tr:nth-child(even) td {
  background: var(--navy-50);
}

.article-cta {
  width: min(100%, 950px);
  min-height: 0;
  margin: 64px 0 10px;
  padding: 56px 0;
  border-radius: 0;
  background: var(--navy-50);
  color: var(--ink);
  overflow: hidden;
  text-align: center;
}

.article-cta h2 {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--navy-600);
  font-size: clamp(28px, 3vw, 45px);
  font-weight: 700;
  line-height: 52px;
  text-align: center;
}

.article-cta p {
  margin: 0;
  color: var(--muted);
}

.article-cta-body {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  justify-content: center;
  padding: 0;
}

.cta-left {
  min-width: 0;
}

.cta-question {
  position: relative;
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  padding: 0;
  background: transparent;
  text-align: center;
}

.cta-question::after {
  content: none;
  position: absolute;
  left: 50%;
  bottom: -14px;
  width: 28px;
  height: 28px;
  background: var(--gold-50);
  transform: translateX(-50%) rotate(45deg);
}

.cta-question p {
  position: relative;
  z-index: 1;
  color: var(--muted);
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
}

.cta-mini-label {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  margin-bottom: 12px;
  border: 1px solid rgba(255, 255, 255, .34);
  border-radius: 8px;
  color: #f5dca2;
  font-size: 13px;
  font-weight: 900;
}

.cta-card {
  display: flex;
  width: min(100%, 860px);
  flex-direction: row;
  flex-wrap: wrap;
  gap: clamp(16px, 2.3vw, 29px);
  align-items: center;
  justify-content: center;
  padding: 0;
  background: transparent;
  box-shadow: none;
  margin: 0 auto;
}

.cta-benefits {
  display: grid;
  gap: 14px;
  margin: 0;
}

.cta-benefit {
  display: none;
}

.cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.article-cta .btn-outline {
  border-color: var(--navy);
  color: var(--navy);
  background: var(--white);
}

.cta-primary {
  display: grid;
  gap: 18px;
  margin-top: 0;
}

.cta-line-button {
  display: flex;
  flex: 1 1 380px;
  min-width: 0;
  min-height: clamp(74px, 8vw, 100px);
  align-items: center;
  justify-content: center;
  gap: clamp(10px, 1.5vw, 16px);
  padding: clamp(12px, 1.5vw, 16px);
  border-radius: 8px;
  background: var(--green);
  color: var(--white);
  box-shadow: 0 8px 4px rgba(0, 0, 0, .15);
  transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.cta-line-button:hover,
.cta-line-button:focus-visible {
  background: #09A854;
  box-shadow: 0 3px 6px rgba(0, 0, 0, .12), 0 8px 14px rgba(0, 0, 0, .08);
  transform: translateY(-2px);
}

.cta-line-button img {
  width: clamp(48px, 5.6vw, 72px);
  height: clamp(46px, 5.4vw, 69px);
  flex: 0 0 auto;
  object-fit: contain;
}

.cta-line-button span {
  display: flex;
  min-width: 0;
  flex-direction: column;
  gap: 2px;
  align-items: flex-start;
  justify-content: center;
  white-space: nowrap;
}

.cta-line-button strong {
  color: var(--white);
  font-size: clamp(20px, 2.35vw, 34px);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: 1px;
}

.cta-line-button small {
  color: var(--white);
  font-size: clamp(11px, 1.1vw, 17px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .85px;
}

.cta-contact-row {
  display: flex;
  flex: 0 1 auto;
  min-width: 0;
  gap: 0;
  align-items: stretch;
  width: auto;
}

.cta-primary .btn {
  width: 100%;
  min-height: 66px;
  border-radius: 8px;
  font-size: clamp(17px, 2.4vw, 26px);
  letter-spacing: 0;
  box-shadow: inset 0 -8px 0 rgba(0, 0, 0, .15), 0 12px 22px rgba(18, 60, 105, .2);
}

.article-cta .btn-line {
  background: var(--green);
  color: var(--white);
  border: 0;
  box-shadow: inset 0 -8px 0 rgba(0, 105, 45, .28), 0 12px 22px rgba(6, 199, 85, .24);
}

.article-cta .btn-call {
  background: var(--navy-500);
  color: var(--white);
  border: 0;
  box-shadow: inset 0 -8px 0 rgba(0, 0, 0, .18), 0 12px 22px rgba(18, 60, 105, .2);
}

.cta-mail-lead {
  display: block;
  margin-bottom: -8px;
  color: var(--muted);
  font-size: 17px;
  font-weight: 900;
  text-align: center;
}

.cta-phone-box {
  display: flex;
  flex: 0 1 auto;
  min-width: 0;
  gap: clamp(8px, 1.2vw, 14px);
  align-items: center;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.cta-phone-icon {
  position: relative;
  display: grid;
  flex: 0 0 clamp(40px, 4.2vw, 54px);
  width: clamp(40px, 4.2vw, 54px);
  height: clamp(40px, 4.2vw, 54px);
  place-items: center;
  border-radius: 8px;
  background: var(--navy-700);
}

.cta-phone-icon img {
  width: clamp(32px, 3.4vw, 43px);
  height: clamp(31px, 3.3vw, 41px);
  object-fit: contain;
}

.cta-phone-box > span:last-child {
  display: flex;
  min-width: 0;
  flex-direction: column;
  gap: 2px;
  align-items: flex-start;
  justify-content: center;
  white-space: nowrap;
}

.cta-phone-box b {
  max-width: 100%;
  color: var(--navy-700);
  font-family: var(--font-num);
  font-size: clamp(24px, 2.8vw, 42px);
  font-weight: 500;
  line-height: 1;
}

.cta-phone-box small {
  color: var(--navy-700);
  font-size: clamp(9px, 1vw, 16px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: .15px;
}

.cta-mail-button {
  display: flex;
  flex: 1 1 0;
  min-height: 57.745px;
  gap: 7px;
  align-items: center;
  justify-content: center;
  padding: 0 42px;
  border-radius: 7px;
  background: var(--navy-500);
  color: var(--white);
  box-shadow: 0 3.5px 1.75px rgba(0, 0, 0, .15);
  transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.cta-mail-button:hover,
.cta-mail-button:focus-visible {
  background: var(--navy-700);
  box-shadow: 0 3px 6px rgba(0, 0, 0, .12), 0 8px 14px rgba(0, 0, 0, .08);
  transform: translateY(-2px);
}

.cta-mail-button img {
  width: 43.636px;
  height: 40.145px;
  object-fit: contain;
}

.cta-mail-button span {
  color: var(--white);
  font-size: 19.2px;
  font-weight: 600;
  line-height: 24.436px;
  white-space: nowrap;
}

.cta-note {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
  text-align: center;
}

.cta-card--sp {
  display: none;
}

.article-faq {
  width: min(100%, 948px);
  margin: 64px 0;
}

.article-faq h2 {
  margin: 0 0 32px;
  padding: 0 0 16px;
  border-bottom: 2px solid var(--navy-100);
  color: var(--navy-500);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .02em;
}

.article-faq-list {
  border-top: 0;
}

.article-faq-item {
  border-bottom: 1px solid var(--navy-200);
}

.article-faq-item summary::-webkit-details-marker {
  display: none;
}

.article-faq-question {
  display: flex;
  gap: 18px;
  align-items: center;
  justify-content: space-between;
  min-height: 68px;
  padding: 16px;
  color: var(--navy-500);
  cursor: pointer;
  list-style: none;
}

.article-faq-question:focus-visible {
  outline: 2px solid var(--navy-500);
  outline-offset: -2px;
}

.article-faq-badge {
  display: inline-flex;
  flex: 0 0 36px;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  aspect-ratio: 1 / 1;
  padding: 0;
  border-radius: 50%;
  color: var(--white);
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}

.article-faq-badge--question {
  background: var(--navy-600);
}

.article-faq-badge--answer {
  background: var(--gold);
}

.article-faq-question-text {
  flex: 1 1 auto;
  min-width: 0;
  color: var(--navy-500);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.article-faq-toggle {
  flex: 0 0 auto;
  color: var(--navy-600);
  font-size: 36px;
  font-weight: 300;
  line-height: 1;
}

.article-faq-item[open] .article-faq-toggle {
  font-size: 0;
}

.article-faq-item[open] .article-faq-toggle::before {
  content: "−";
  font-size: 36px;
  line-height: 1;
}

.article-faq-answer {
  display: flex;
  gap: 18px;
  align-items: center;
  min-height: 68px;
  border-top: 1px solid var(--navy-100);
  padding: 16px;
  color: var(--muted);
}

.article-faq-answer-body {
  flex: 1 1 auto;
  min-width: 0;
}

.article-faq-answer-body p {
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.85;
  text-align: left;
}

.article-faq-answer-spacer {
  flex: 0 0 36px;
  width: 36px;
}

@media (max-width: 1180px) and (min-width: 641px) {
  .cta-card {
    width: min(100%, 560px);
    flex-direction: column;
    align-items: stretch;
  }

  .cta-line-button {
    flex-basis: auto;
    width: 100%;
  }

  .cta-contact-row {
    flex-basis: auto;
    width: 100%;
    justify-content: center;
  }
}

.sidebar {
  display: grid;
  grid-column: span 2;
  gap: 47px;
}

.side-box {
  border-radius: 8px;
  background: var(--white);
  overflow: hidden;
}

.side-box--search {
  border-radius: 0;
  background: transparent;
  overflow: visible;
}

.side-box h2 {
  margin: 0;
  padding: 24px 0;
  background: var(--navy-500);
  color: var(--white);
  border-radius: 8px 8px 0 0;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .02em;
  text-align: center;
}

.side-box-body {
  padding: 24px 0 0;
}

.side-box--search .side-box-body {
  padding: 0;
}

.side-search-form {
  margin: 0;
}

.side-search-inner {
  display: flex;
  border: 1.5px solid var(--navy-100);
  border-radius: 8px;
  overflow: hidden;
}

.side-search-input {
  flex: 1;
  min-width: 0;
  padding: 10px 12px;
  border: 0;
  background: var(--white);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.5;
  outline: none;
}

.side-search-button {
  margin: 0;
  padding: 10px 14px;
  border: 0;
  background: var(--navy-500);
  color: var(--white);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.5;
  cursor: pointer;
  white-space: nowrap;
  transition: background-color 160ms ease;
}

.side-search-button:hover,
.side-search-button:focus-visible {
  background: var(--navy-700);
}

.side-cta {
  display: grid;
  gap: 10px;
}

.side-cta .btn {
  width: 100%;
}

.side-list {
  display: grid;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.side-list a {
  display: block;
  padding-bottom: 0;
  border-bottom: 0;
  color: var(--navy-500);
  font-size: 18px;
  font-weight: 500;
  line-height: 30px;
}

.side-list li:last-child a {
  padding-bottom: 0;
  border-bottom: 0;
}

.side-article-list {
  display: grid;
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.side-article {
  display: flex;
  flex-direction: column;
  gap: 16px;
  text-decoration: none;
  transition: transform 160ms ease;
}

.side-article-img {
  aspect-ratio: 16 / 9;
  background: #d9d9d9;
  border-radius: 8px;
  width: 100%;
  object-fit: cover;
}

.side-article:hover,
.side-article:focus-visible {
  transform: translateY(-2px);
}

.side-article:hover .side-article-title,
.side-article:focus-visible .side-article-title {
  color: var(--navy-700);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}

.side-article-title {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
  line-height: 30px;
  color: var(--navy-500);
  letter-spacing: 0;
  word-break: auto-phrase;
  overflow-wrap: break-word;
}

.side-article-tag {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  justify-content: center;
  padding: 4px 8px;
  border: 2px solid var(--navy-500);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--navy-600);
  letter-spacing: 0.1px;
  white-space: nowrap;
}

.side-link-list {
  display: grid;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.side-link-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  height: 56px;
  padding: 16px;
  border: 2px solid var(--navy-400);
  border-radius: 88px;
  font-size: 18px;
  font-weight: 600;
  line-height: 22px;
  letter-spacing: -0.43px;
  color: var(--navy-500);
  text-decoration: none;
  transition: background-color 160ms ease, color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.side-link-btn:hover,
.side-link-btn:focus-visible {
  background: var(--navy-500);
  color: var(--white);
  box-shadow: 0 3px 6px rgba(0, 0, 0, .12), 0 8px 14px rgba(0, 0, 0, .08);
  transform: translateY(-2px);
}

.side-link-btn svg {
  flex-shrink: 0;
}

.side-link-btn svg circle,
.side-link-btn svg path {
  transition: fill 160ms ease, stroke 160ms ease;
}

.side-link-btn:hover svg circle,
.side-link-btn:focus-visible svg circle {
  fill: var(--white);
}

.side-link-btn:hover svg path,
.side-link-btn:focus-visible svg path {
  stroke: var(--navy-500);
}

.side-cta-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  padding: 44px 24px;
  background: var(--navy-50);
  border-radius: 8px;
}

.side-cta-heading {
  margin: 0;
  font-size: 24px;
  font-weight: 700;
  line-height: 36px;
  color: var(--navy-600);
  text-align: center;
  letter-spacing: 0;
}

.side-cta-buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  width: 100%;
}

.side-cta-line {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 24px 40px;
  background: var(--green);
  border-radius: 24px;
  box-shadow: var(--shadow-cta);
  text-decoration: none;
  color: var(--white);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 1px;
  text-align: center;
  transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.side-cta-line:hover,
.side-cta-line:focus-visible {
  background: #09A854;
  box-shadow: 0 3px 6px rgba(0, 0, 0, .12), 0 8px 14px rgba(0, 0, 0, .08);
  transform: translateY(-2px);
}

.side-cta-line-logo {
  width: 90px;
  height: auto;
}

.side-cta-mail {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  padding: 16px;
  background: var(--navy-500);
  border-radius: 24px;
  box-shadow: 0 3px 2px rgba(0, 0, 0, 0.15);
  text-decoration: none;
  color: var(--white);
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  white-space: nowrap;
  transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.side-cta-mail:hover,
.side-cta-mail:focus-visible {
  background: var(--navy-700);
  box-shadow: 0 3px 6px rgba(0, 0, 0, .12), 0 8px 14px rgba(0, 0, 0, .08);
  transform: translateY(-2px);
}

.side-cta-mail img {
  width: 30px;
  height: auto;
  flex-shrink: 0;
}

.side-cta-phone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.side-cta-tel {
  font-family: var(--font-num);
  font-size: 36px;
  font-weight: 500;
  line-height: 1;
  color: var(--navy-700);
  text-decoration: none;
  white-space: nowrap;
}

.side-cta-hours {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
  color: var(--navy-700);
  letter-spacing: 0.13px;
}

.side-cta-call {
  display: flex;
  align-items: center;
  gap: 9px;
  text-decoration: none;
  color: var(--navy-600);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 1px;
  white-space: nowrap;
}

.side-cta-phone-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 35px;
  height: 35px;
  background: var(--navy-700);
  border-radius: 5px;
  flex-shrink: 0;
}

.side-cta-phone-badge img {
  width: 26px;
  height: auto;
  filter: brightness(0) invert(1);
}

.related {
  display: flex;
  width: min(100%, 950px);
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
  margin-top: 64px;
}

.related h2 {
  width: 100%;
  margin: 0;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--navy-100);
  color: var(--muted);
  font-size: 24px;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: .48px;
}

.related h2 span {
  color: var(--navy-500);
}

.related-grid {
  display: flex;
  gap: 32px;
  align-items: center;
  width: 100%;
}

.related-card {
  display: flex;
  flex: 1 1 0;
  min-width: 0;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  justify-content: center;
  text-decoration: none;
  transition: transform 160ms ease;
}

.related-card-main {
  display: flex;
  gap: 16px;
  align-items: center;
  width: 100%;
}

.related-thumb {
  flex: 0 0 153px;
  width: 153px;
  height: 86px;
  border-radius: 8px;
  background: #D9D9D9;
  object-fit: cover;
  transition: transform 160ms ease;
}

.related-card:hover,
.related-card:focus-visible {
  transform: translateY(-2px);
}

.related-card:hover .related-thumb,
.related-card:focus-visible .related-thumb {
  transform: scale(1.03);
}

.related-card:hover h3,
.related-card:focus-visible h3 {
  color: var(--navy-700);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}

.related-thumb.t2 { background-position: 50% center; }
.related-thumb.t3 { background-position: 100% center; }

.related-card h3 {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  padding: 0;
  color: var(--navy-500);
  font-size: 18px;
  font-weight: 500;
  line-height: 30px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.related-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 4px 8px;
  border: 2px solid var(--navy-500);
  border-radius: 8px;
  color: var(--navy-600);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .main { grid-template-columns: 1fr; padding-top: 32px; gap: 47px; }
  .article-body,
  .sidebar { grid-column: 1 / -1; }
  .sidebar { position: static; }}

@media (max-width: 640px) {
  .page-hero .wrap { padding: 32px 0 0; }
  .breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
  }
  .breadcrumb a,
  .breadcrumb span {
    white-space: normal;
  }
  h1 {
    font-size: 24px;
    line-height: 1.5;
    letter-spacing: 0;
  }
  .article-meta-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
  }
  .article-meta {
    justify-content: flex-start;
    white-space: normal;
    gap: 6px;
  }
  .article-inner { padding: 32px 0 0; }
  .content p {
    line-height: 1.85;
  }
  .key-summary { margin-bottom: 32px; }
  .content .key-summary ul {
    display: block;
    margin: 0;
    padding: 0;
  }
  .content .key-summary li {
    display: flex;
    gap: .2em;
    padding-left: 0;
    text-indent: 0;
    line-height: 1.7;
  }
  .content ul,
  .content ol {
    gap: 4px;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.75;
  }
  .supervisor { margin-bottom: 32px; }
  .article-inner > p { margin-bottom: 32px; }
  .toc { margin-bottom: 32px; }
  .content h2 { margin: 40px 0 32px; }
  .note-box { margin: 32px 0; }
  .article-point { margin: 32px 0; }
  .article-point-set {
    gap: 12px;
    margin: 32px 0;
  }
  .article-point--merit,
  .article-point--demerit { margin-bottom: 0; }
  .article-table-wrap { margin-bottom: 32px; }
  .article-table { min-width: 560px; }
  .article-table th,
  .article-table td { white-space: normal; padding: 10px 12px; font-size: 14px; }
  .article-faq {
    margin-top: 32px;
  }
  .article-faq h2 {
    margin-bottom: 24px;
    font-size: 26px;
  }
  .article-faq-question,
  .article-faq-answer {
    gap: 12px;
    padding: 14px 0;
  }
  .article-faq-badge {
    flex-basis: 36px;
    width: 36px;
    height: 36px;
    aspect-ratio: 1 / 1;
    font-size: 20px;
  }
  .article-faq-question-text {
    font-size: 17px;
    line-height: 1.6;
  }
  .article-faq-toggle {
    font-size: 30px;
  }
  .article-cta { margin-top: 32px; }
  .related { margin-top: 32px; margin-bottom: 0; gap: 24px; }
  .related h2 { margin: 0; }
  .supervisor {
    display: grid;
    grid-template-columns: 95px 1fr;
    column-gap: 16px;
    row-gap: 8px;
    align-items: start;
    padding: 24px;
  }
  .toc { padding: 16px; }
  #ez-toc-container {
    margin-bottom: 32px;
    padding: 16px !important;
  }
  .note-box { padding: 16px; flex-direction: column; gap: 10px; }
  .note-box b { width: 100%; height: auto; white-space: nowrap; }
  .note-box p { font-size: 16px; }
  .article-point {
    flex-direction: column;
  }
  .article-point-label {
    flex-basis: auto;
    min-height: 54px;
    border-radius: 16px 16px 0 0;
  }
  .article-point-body {
    padding: 16px;
    border-top: 0;
    border-left: 1px solid var(--navy-500);
    border-radius: 0 0 16px 16px;
  }
  .article-point--merit .article-point-body {
    border-left-color: var(--navy-500);
  }
  .article-point--demerit .article-point-body {
    border-left-color: var(--muted);
  }
  .article-point-body p {
    font-size: 16px;
    line-height: 1.85;
  }
  .supervisor-photo {
    flex: 0 0 95px;
    grid-column: 1;
    grid-row: 1 / 3;
    width: 95px;
    height: 95px;
  }
  .supervisor-content {
    display: contents;
  }
  .supervisor-title,
  .supervisor-name-row {
    grid-column: 2;
  }
  .supervisor-title {
    grid-row: 1;
    line-height: 1.85;
  }
  .supervisor-name-row {
    grid-row: 2;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .supervisor-bio {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 2px solid #D2E1F3;
  }
  .article-cta h2 {
    font-size: 34px;
  }
  .side-cta-card .side-cta-phone,
  .cta-card--sp .side-cta-phone {
    gap: 8px;
  }
  .side-cta-card .side-cta-tel,
  .cta-card--sp .side-cta-tel {
    letter-spacing: 0;
  }
  .side-cta-card .side-cta-hours,
  .cta-card--sp .side-cta-hours {
    letter-spacing: 0.13px;
  }
  .side-cta-card .side-cta-call,
  .cta-card--sp .side-cta-call {
    letter-spacing: 1px;
  }
  .article-cta .side-cta-hours {
    color: var(--navy-700);
  }
  .article-cta .side-cta-call {
    gap: 9px;
  }
  .article-cta {
    background: var(--sky);
    padding: 44px 24px;
    min-height: 0;
    border-radius: 8px;
  }
  .article-cta-body { grid-template-columns: 1fr; gap: 22px; }
  .cta-card--desktop { display: flex; width: 100%; }
  .cta-card--sp { display: none; }
  .cta-card {
    flex-direction: column;
    align-items: center;
  }
  .cta-line-button {
    flex: none;
    min-height: 0 !important;
    width: 100%;
    flex-direction: column;
    gap: 10px;
    padding: 18px 16px !important;
    text-align: center;
  }
  .cta-line-button span {
    align-items: center;
    white-space: normal;
  }
  .cta-line-button strong {
    font-size: 24px;
    line-height: 1.35;
  }
  .cta-line-button small {
    font-size: 14px;
  }
  .cta-contact-row {
    width: 100%;
    justify-content: center;
  }
  .cta-phone-box {
    flex: 1 1 auto;
    justify-content: center;
  }
  .cta-phone-box b {
    font-size: 34px;
  }
  .cta-mail-button {
    flex: 1 1 auto;
  }
  .cta-benefits { grid-template-columns: 1fr; }
  .related-grid {
    flex-direction: column;
    align-items: stretch;
    gap: 20px;
  }
  .side-article {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas: "img title" "tag tag";
    gap: 16px;
  }
  .side-article-img {
    grid-area: img;
    width: auto;
    height: 60px;
    aspect-ratio: 16 / 9;
    align-self: start;
  }
  .side-article-title {
    grid-area: title;
    align-self: center;
  }
  .side-article-tag {
    grid-area: tag;
    justify-self: start;
  }
  .related-card-main { align-items: flex-start; }
  .related-thumb {
    flex: 0 0 auto;
    width: auto;
    height: 60px;
    align-self: start;
    aspect-ratio: 16 / 9;
  }
}

@media (min-width: 641px) and (max-width: 900px) {
  .page-hero .wrap,
  .main {
    width: min(100% - 48px, 720px);
  }

  .page-hero .wrap {
    padding: 40px 0 0;
  }

  .breadcrumb {
    flex-wrap: wrap;
    max-width: 100%;
    white-space: normal;
  }

  .breadcrumb a,
  .breadcrumb span {
    white-space: normal;
  }

  h1 {
    max-width: 100%;
    font-size: 34px;
    line-height: 1.45;
  }

  .article-meta-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 16px;
  }

  .article-meta {
    flex-wrap: wrap;
    justify-content: flex-start;
    white-space: normal;
  }

  .article-body {
    font-size: 17px;
    line-height: 2;
  }

  .article-inner {
    padding: 48px 0;
  }

  .content h2 {
    font-size: 28px;
  }

  .content h3 {
    font-size: 24px;
  }

  .article-cta {
    padding: 40px 24px;
  }

  .article-cta h2 {
    font-size: 30px;
    line-height: 1.45;
  }

  .cta-line-button {
    min-height: 0;
    padding: 24px 20px;
  }

  .sidebar {
    width: min(100%, 560px);
    margin-inline: auto;
  }
}
