@charset "UTF-8";
/*!
	Theme Name: SMBP2026-
	Description: SMBパートナーズサイトテーマ
	Theme URI: サイトアドレス
	Author: 株式会社 And Innovation Engineering
	Author URL: https://and-ie.com/
	Version: 1.0
*/
@layer reset, base, components, utilities;
:root {
  --font-sm: clamp(0.625rem, 0.5vw + 0.44rem, 0.75rem);
  --font-base: clamp(0.875rem, 0.3vw + 0.77rem, 1rem);
  --font-md: clamp(1.125rem, 0.5vw + 0.94rem, 1.25rem);
  --font-lg: clamp(1.375rem, 1vw + 1.01rem, 1.75rem);
  --font-xl: clamp(1.75rem, 1.5vw + 1.19rem, 2.25rem);
  --font-xxl: clamp(2.25rem, 2.5vw + 1.32rem, 3rem);
  --font-xxxl: clamp(2.75rem, 3vw + 1.63rem, 3.75rem);
  --font-xxxxl: clamp(2.875rem, 3.2vw + 2.13rem, 5rem);
  --font-hero: clamp(3rem, 8vw + 0.6rem, 7rem);
  --color-base: #3e3a39;
  --color-main: #005b9e;
  --color-primary: #d6eaf1;
  --color-white: #f9fcfd;
  --color-gray: #ccc;
  --color-gray2: #7d7d7d;
  --color-clear: rgb(255 255 255 / 0.6);
  --color-scheme: light;
  --color-demerit: #c0392b;
  --color-paid: #d4820a;
  --color-chart-border: #c5dce9;
  --color-chart-label: rgb(182 182 182 / 0.45);
  --color-chart-text: #444;
  --color-chart-line: #bbb;
  --gradient-main: linear-gradient(45deg, #54d0ff, #9f92ff 20%, #ff7689 90%);
  --space-2xs: clamp(0.25rem, 0.5vw + 0.2rem, 0.5rem);
  --space-xs: clamp(0.5rem, 1vw + 0.3rem, 1rem);
  --space-sm: clamp(1rem, 2vw + 0.5rem, 2rem);
  --space-md: clamp(2rem, 4vw + 0.5rem, 4rem);
  --space-lg: clamp(3rem, 5vw + 1rem, 6rem);
  --space-xl: clamp(4rem, 6vw + 1.5rem, 8rem);
  --space-xxl: clamp(6rem, 8vw + 2rem, 12rem);
  --space-xxxl: clamp(8rem, 10vw + 3rem, 16rem);
  --container-max: 87.5rem;
  --header-height: 6.25rem;
  --radius-sm: 0.5rem;
  --radius-md: 1rem;
  --radius-lg: 2rem;
  --radius-pill: 100vmax;
  --shadow-sm: 0 4px 10px rgb(0 0 0 / 0.08);
  --shadow-md: 0 10px 25px rgb(0 0 0 / 0.12);
  --z-content: 10;
  --z-header: 100;
  --z-banner: 1000;
  --z-loading: 9999;
  scrollbar-color: var(--color-main) var(--color-primary);
  interpolate-size: allow-keywords;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  min-inline-size: 0;
}

html {
  font-size: 100%;
}

body {
  margin: 0;
  font-size: 1rem;
  font-family: "Gabarito", "M PLUS 2", sans-serif;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.05em;
  color: var(--color-base);
  background-color: var(--color-white);
  overflow-x: clip;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color 0.25s ease, opacity 0.25s ease;
}
a:hover {
  color: var(--color-main);
  opacity: 0.9;
}

img,
video {
  display: block;
  max-inline-size: 100%;
  block-size: auto;
}

ul,
ol {
  padding: 0;
  margin: 0;
}

section {
  padding-block: var(--space-lg);
  scroll-margin-top: var(--header-height);
}
@media (1024px <= width) {
  section {
    padding-block: var(--space-xl);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
    scroll-behavior: auto !important;
  }
}
h1 {
  font-size: var(--font-xxxl);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-wrap: balance;
  margin: 0 0 var(--space-xs);
}

h2 {
  font-size: var(--font-xxxl);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-wrap: balance;
  margin: 0 0 var(--space-xs);
}

h3 {
  font-size: var(--font-xl);
  font-weight: 800;
  text-wrap: balance;
  margin: 0 0 var(--space-xs);
}

@media (max-width: 767px) {
  h1,
  h2 {
    font-size: var(--font-xl);
    text-wrap: auto;
  }
  h3 {
    font-size: var(--font-lg);
    text-wrap: auto;
  }
}
.p-section__title {
  padding: var(--space-sm);
  padding-top: 0;
  background: var(--gradient-main);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
}
@media (1024px <= width) {
  .p-section__title {
    padding: var(--space-md);
  }
}

.c-btn {
  background: var(--color-clear);
  border: 1px solid var(--color-main);
  border-radius: var(--radius-pill);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 2rem;
  padding: var(--space-sm);
  padding-right: 3rem;
  color: var(--color-base);
  font-weight: 500;
  text-align: center;
  transition: background 0.3s ease-in-out, color 0.3s ease-in-out;
}
@media (1024px <= width) {
  .c-btn {
    max-width: 400px;
    padding: var(--space-xs);
    padding-right: 3rem;
  }
}
.c-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.5rem;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
  transition: right 0.3s;
}
.c-btn:hover {
  background: var(--color-main);
  color: var(--color-white);
}
.c-btn:hover::after {
  right: 1rem;
}

.c-btn--full {
  inline-size: 100%;
}

.c-only-pc {
  display: none;
}
@media (1024px <= width) {
  .c-only-pc {
    display: block;
  }
}

.c-only-sp {
  display: block;
}
@media (1024px <= width) {
  .c-only-sp {
    display: none;
  }
}

.c-br-sp {
  display: block;
}
@media (768px <= width) {
  .c-br-sp {
    display: none;
  }
}

.c-linkmark {
  width: 1em;
  height: 1em;
  margin-right: var(--space-2xs);
  vertical-align: middle;
}

.c-loading {
  position: fixed;
  inset: 0;
  z-index: var(--z-loading);
  background: var(--color-white);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.c-loading__inner {
  text-align: center;
  z-index: 2;
}

.c-loading__line-wrapper {
  position: absolute;
  bottom: 40%;
  left: 0;
  width: 100%;
  height: 2px;
  overflow: hidden;
}

.c-loading__line {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--color-main);
  transform-origin: left;
  transform: scaleX(0);
  animation: lineGrow 1.8s cubic-bezier(0.77, 0, 0.18, 1) forwards;
}

@keyframes lineGrow {
  to {
    transform: scaleX(1);
  }
}
.c-loading.is-finish {
  animation: reveal 1s cubic-bezier(0.77, 0, 0.18, 1) forwards;
}

@keyframes reveal {
  to {
    transform: translateY(-100%);
  }
}
.c-banner {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: var(--z-banner);
  opacity: 0;
  transform: translateX(60px);
  pointer-events: none;
  transition: opacity 0.6s cubic-bezier(0.77, 0, 0.18, 1), transform 0.6s cubic-bezier(0.77, 0, 0.18, 1);
}
.c-banner.is-visible {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}
.c-banner img {
  display: block;
  width: 10rem;
}
@media (768px <= width) {
  .c-banner img {
    width: 12rem;
  }
}
@media (1024px <= width) {
  .c-banner img {
    width: 13rem;
  }
}

.c-text__title {
  font-size: var(--font-lg);
  font-weight: 800;
  margin: 1rem 0;
}

.c-text__note {
  color: var(--color-gray);
}

.c-text__topic1 {
  font-size: var(--font-md);
  font-weight: 800;
  margin: 0.5rem 0;
}

.c-text__topic2 {
  font-weight: 800;
  color: var(--color-main);
}

.c-text__list li {
  margin-left: 1rem;
}
.c-text__list li::before {
  content: "■";
  display: inline-block;
  color: var(--color-main);
  margin-right: 0.5em;
  font-size: var(--font-sm);
}

.u-text-right {
  text-align: right;
}

.u-bg-primary {
  background: var(--color-primary);
}

.u-bg-img1 {
  background-image: url(img/c-figure4.webp);
}

.u-bg-img2 {
  background-image: url(img/2189307.jpg);
}

.c-table {
  border-collapse: collapse;
  inline-size: 100%;
}
.c-table th,
.c-table td {
  border: solid 1px var(--color-gray);
  padding: var(--space-xs);
}
.c-table th {
  background: var(--color-primary);
  text-align: center;
}
@media (max-width: 767px) {
  .c-table {
    border: solid 1px var(--color-primary);
    font-size: clamp(0.75rem, 3.5vw, 0.875rem);
  }
  .c-table th,
  .c-table td {
    border-bottom: none;
    display: block;
    width: 100%;
  }
}

.c-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  list-style-type: none;
  padding: var(--space-md) 0 0;
  margin: var(--space-md) 0 0;
}
.c-pagination a,
.c-pagination .current,
.c-pagination .dots {
  box-sizing: border-box;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-inline-size: 2.5em;
  block-size: 2.5em;
  padding: 0 var(--space-2xs);
  border-radius: var(--radius-sm);
  font-size: var(--font-base);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.c-pagination a {
  background-color: var(--color-white);
  color: var(--color-main);
  border: 1.5px solid var(--color-primary);
  box-shadow: 0 2px 6px rgba(0, 91, 158, 0.04);
}
.c-pagination a:hover {
  background-color: var(--color-main);
  color: var(--color-white);
  border-color: var(--color-main);
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 91, 158, 0.18);
}
.c-pagination .current {
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  color: var(--color-white);
  border: 1.5px solid var(--color-main);
  pointer-events: none;
  box-shadow: 0 4px 10px rgba(0, 91, 158, 0.25);
}
.c-pagination .dots {
  color: var(--color-gray2);
  background-color: transparent;
  border: none;
  box-shadow: none;
  cursor: default;
}
.c-pagination .prev,
.c-pagination .next {
  padding: 0 var(--space-sm);
  font-weight: 800;
}
.c-pagination .prev span,
.c-pagination .next span {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.c-flex {
  display: block;
}
@media (1024px <= width) {
  .c-flex {
    display: flex;
    justify-content: space-between;
  }
}

.c-flex__img {
  inline-size: 100%;
}
@media (1024px <= width) {
  .c-flex__img {
    inline-size: 35%;
    place-items: center;
  }
}

.c-flex__body {
  inline-size: 100%;
}
@media (1024px <= width) {
  .c-flex__body {
    inline-size: 60%;
  }
}

.l-inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .l-inner {
    padding-inline: 0;
  }
}

body.is-nav-open {
  overflow: hidden;
}

.l-header {
  position: fixed;
  inset-inline: 0;
  inset-block-start: 0;
  block-size: var(--header-height);
  z-index: var(--z-header);
  background-color: var(--color-white);
  transition: background-color 0.25s ease;
}
.l-header.is-scrolled {
  background: var(--color-clear);
  backdrop-filter: blur(12px);
}

.l-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  block-size: 100%;
  padding-inline: var(--space-sm);
}

.l-header__title {
  inline-size: 17.5rem;
}
.l-header__title img {
  inline-size: 100%;
  block-size: auto;
}

.l-header__hamburger {
  inline-size: 48px;
  block-size: 48px;
}

.c-hamburger {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  inline-size: 48px;
  block-size: 48px;
  position: relative;
  z-index: calc(var(--z-header) + 1);
}
.c-hamburger span {
  display: block;
  inline-size: 100%;
  block-size: 2px;
  background: var(--color-base);
  position: absolute;
  inset-inline-start: 0;
  transition: transform 0.3s ease, opacity 0.3s ease, inset 0.3s ease;
}
.c-hamburger span:nth-child(1) {
  inset-block-start: 14px;
}
.c-hamburger span:nth-child(2) {
  inset-block-start: 23px;
}
.c-hamburger span:nth-child(3) {
  inset-block-start: 32px;
}
.c-hamburger.is-active span:nth-child(1) {
  inset-block-start: 23px;
  transform: rotate(45deg);
}
.c-hamburger.is-active span:nth-child(2) {
  opacity: 0;
}
.c-hamburger.is-active span:nth-child(3) {
  inset-block-start: 23px;
  transform: rotate(-45deg);
}

.l-header__nav {
  position: fixed;
  inset: 0;
  height: 100%;
  height: 100dvh;
  overflow-y: auto;
  background: var(--color-white);
  transform: translateX(100%);
  transition: transform 0.35s ease;
}
.l-header__nav.is-open {
  transform: translateX(0);
  background-image: url(img/footer-bg.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: bottom;
}

.l-nav__items {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.l-nav__items a {
  display: block;
  font-size: var(--font-lg);
  font-weight: 800;
  margin-block: 0 1rem;
}

@media (1024px <= width) {
  .l-header__hamburger {
    display: none;
  }
  .l-header__nav {
    position: static;
    inset: auto;
    transform: none;
    background: transparent;
    transition: none;
    inline-size: 50%;
    block-size: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
  .l-nav__items {
    position: static;
    transform: none;
    display: flex;
    gap: 1.5rem;
    align-items: center;
    justify-content: flex-end;
    inline-size: 100%;
    text-align: left;
  }
  .l-nav__items a {
    margin: 0;
    font-size: 1rem;
  }
  .l-nav__items .is-primary a {
    background: var(--color-main);
    color: var(--color-white);
    padding: var(--space-xs);
    border-radius: var(--radius-pill);
  }
}
.l-nav__has-sub {
  position: relative;
}
@media (max-width: 1023px) {
  .l-nav__has-sub {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 1rem;
  }
  .l-nav__has-sub .l-nav__parent {
    display: inline-flex;
    flex: 0 0 auto;
    margin-block: 0;
  }
  .l-nav__has-sub .l-nav__parent .l-nav__caret {
    display: none;
  }
  .l-nav__has-sub .l-nav__sub {
    flex: 0 0 100%;
  }
}

.l-nav__parent {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}

.l-nav__caret {
  display: inline-block;
  inline-size: 8px;
  block-size: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translate(-2px, -2px);
  transition: transform 0.2s ease;
}

.l-nav__sub-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5em 0.8em;
  margin-left: 0.4em;
  background: transparent;
  border: 1px solid currentColor;
  border-radius: var(--radius-pill);
  color: inherit;
  cursor: pointer;
  vertical-align: middle;
}

.l-nav__sub-toggle[aria-expanded=true] .l-nav__caret {
  transform: rotate(-135deg) translate(-2px, -2px);
}

.l-nav__sub {
  list-style: none;
  padding: 0;
  margin: 0;
  max-block-size: 0;
  overflow: hidden;
  transition: max-block-size 0.3s ease;
}

.l-nav__has-sub.is-open .l-nav__sub {
  max-block-size: 500px;
}

.l-nav__sub li a {
  font-size: var(--font-base) !important;
  font-weight: 600 !important;
  padding: 0.6em 0 !important;
  margin-block: 0 !important;
  opacity: 0.85;
}

@media (max-width: 767px) {
  .l-nav__sub {
    width: -moz-max-content;
    width: max-content;
    margin-inline: auto;
  }
  .l-nav__sub li a {
    font-size: clamp(0.65rem, 3.2vw, 0.875rem) !important;
    white-space: nowrap;
  }
}
.l-nav__sub li a::before {
  content: "└ ";
  opacity: 0.5;
  margin-right: 0.2em;
}

@media (1024px <= width) {
  .l-header__nav {
    overflow: visible;
    height: auto;
  }
  .l-nav__sub-toggle {
    display: none;
  }
  .l-nav__parent .l-nav__caret {
    margin-left: 0.2em;
    inline-size: 6px;
    block-size: 6px;
    transition: transform 0.2s ease;
  }
  .l-nav__has-sub .l-nav__sub {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-inline-size: 280px;
    background-color: var(--color-white);
    box-shadow: 0 12px 30px rgba(0, 91, 158, 0.15);
    border-radius: var(--radius-sm);
    padding: 0.5em 0;
    max-block-size: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear 0.2s;
    z-index: var(--z-header);
  }
  .l-nav__has-sub:hover .l-nav__sub,
  .l-nav__has-sub:focus-within .l-nav__sub {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear;
  }
  .l-nav__has-sub:hover .l-nav__parent .l-nav__caret {
    transform: rotate(-135deg) translate(-2px, -2px);
  }
  .l-nav__has-sub .l-nav__sub::before {
    content: "";
    position: absolute;
    top: -6px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    inline-size: 12px;
    block-size: 12px;
    background-color: var(--color-white);
    box-shadow: -2px -2px 6px rgba(0, 91, 158, 0.05);
  }
  .l-nav__sub li {
    display: block;
  }
  .l-nav__sub li a {
    display: block;
    padding: 0.6em 1em !important;
    font-size: 0.92rem !important;
    white-space: nowrap;
    color: var(--color-base);
    transition: background-color 0.2s ease, color 0.2s ease;
  }
  .l-nav__sub li a:hover {
    background-color: var(--color-primary);
    color: var(--color-main);
    opacity: 1;
  }
  .l-nav__sub li a::before {
    display: none;
  }
}
.l-content {
  position: relative;
  z-index: var(--z-content);
  margin-top: 100vh;
}

.c-btn--cta {
  background: #e07b00;
  border-color: #e07b00;
  color: var(--color-white);
  font-weight: 800;
  letter-spacing: 0.05em;
}
.c-btn--cta::after {
  border-color: var(--color-white);
}
.c-btn--cta:hover {
  background: #c46a00;
  border-color: #c46a00;
  color: var(--color-white);
  opacity: 1;
}

.c-btn--cta-lg {
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-md);
  max-width: 360px;
}
@media (1024px <= width) {
  .c-btn--cta-lg {
    font-size: var(--font-lg);
    max-width: 480px;
  }
}

.top-hero {
  position: fixed;
  inset: 0;
  height: 100vh;
  z-index: 1;
  overflow: hidden;
}

.top-hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.top-hero__media video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top-hero__content {
  position: relative;
  z-index: 2;
  height: 80%;
  display: grid;
  align-items: anchor-center;
  padding: var(--space-lg);
  padding-bottom: 0;
}
@media (768px <= width) {
  .top-hero__content {
    align-items: end;
  }
}

.top-hero__text {
  text-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
  transform: translateY(40px);
  opacity: 0;
  animation: heroFadeUp 1.2s cubic-bezier(0.77, 0, 0.18, 1) 0.4s forwards;
  margin-bottom: 2vh;
}

@keyframes heroFadeUp {
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
.top-hero__title {
  font-size: var(--font-xxxl);
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: 0.1em;
  margin: 0 0 1rem;
}

.top-hero__subtitle {
  font-size: var(--font-lg);
  font-weight: 800;
  letter-spacing: 0.2em;
  margin: 0;
}

@media (max-width: 767px) {
  .top-hero__content {
    padding-inline: var(--space-sm);
    align-items: center;
  }
  .top-hero__title {
    font-size: clamp(1rem, 5.3vw, 1.5rem);
  }
  .top-hero__subtitle {
    font-size: clamp(0.8rem, 4vw, 1rem);
  }
}
.top_parallax {
  min-block-size: 25rem;
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  background-attachment: scroll;
}
@media (1024px <= width) {
  .top_parallax {
    background-attachment: fixed;
  }
}

.img_bg_02 {
  background-image: url(img/company-bg.webp);
}

.img_bg_03 {
  background-image: url(img/footer-bg.webp);
}

.top-cta {
  padding-block: var(--space-lg);
}

.top-cta__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-cta__inner {
    padding-inline: 0;
  }
}
.top-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-sm);
}

.top-cta__label {
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.25em;
  color: #e07b00;
  margin: 0;
}

.top-cta__heading {
  font-size: var(--font-md);
  font-weight: 800;
  margin: 0;
}
@media (1024px <= width) {
  .top-cta__heading {
    font-size: var(--font-xxl);
  }
}

.top-cta__heading--lg {
  font-size: var(--font-lg);
}
@media (1024px <= width) {
  .top-cta__heading--lg {
    font-size: var(--font-xxxl);
  }
}

.top-cta__desc {
  font-size: var(--font-base);
  margin: 0;
  line-height: 2;
}

.top-cta__desc--lg {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-base);
}

.top-cta--first {
  container-type: inline-size;
  background: linear-gradient(135deg, #003d6b 0%, #005b9e 60%, #0077cc 100%);
}
.top-cta--first .top-cta__inner {
  color: var(--color-white);
}
.top-cta--first .c-btn--cta {
  margin-top: 0;
  min-width: 280px;
  max-width: 360px;
}
@media (max-width: 1023px) {
  .top-cta--first .c-btn--cta {
    inline-size: 100%;
    min-width: 0;
    max-width: none;
    white-space: nowrap;
    font-size: clamp(0.625rem, 2.5vw, 0.875rem);
    font-weight: normal;
    padding-right: 2rem;
  }
}

.top-cta--mid {
  background: var(--color-white);
  border-top: 3px solid #e07b00;
  border-bottom: 3px solid #e07b00;
}
.top-cta--mid .top-cta__inner {
  padding-block: var(--space-md);
}
.top-cta--mid .c-btn--cta {
  margin-top: 0;
  min-width: 240px;
}

.top-cta--bottom {
  background: linear-gradient(135deg, #003d6b 0%, #005b9e 60%, #0077cc 100%);
  color: var(--color-white);
}
.top-cta--bottom .top-cta__heading,
.top-cta--bottom .top-cta__desc {
  color: var(--color-white);
}
.top-cta--bottom .top-cta__desc--lg {
  color: #ffd180;
}
.top-cta--bottom .c-btn--cta {
  margin-top: 0;
}

.top-about {
  container-type: inline-size;
  background: var(--color-primary);
  padding-bottom: 0;
}
.top-about .p-section__title {
  padding-top: 0 !important;
}

.top-about__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-about__inner {
    padding-inline: 0;
  }
}
.top-about__inner {
  display: grid;
  gap: var(--space-sm);
}
@media (max-width: 767px) {
  .top-about__inner h3 {
    font-size: clamp(0.875rem, 4.5vw, 1.125rem);
    white-space: nowrap;
  }
}
@media (max-width: 767px) {
  .top-about__inner p {
    font-size: clamp(0.75rem, 3.5vw, 0.875rem);
  }
}
.top-about__inner .c-btn {
  inline-size: 100%;
}
@media (1024px <= width) {
  .top-about__inner {
    grid-template-columns: 50% 1fr;
    align-items: center;
  }
  .top-about__inner .c-btn {
    inline-size: auto;
  }
}

.top-about__figure {
  display: none;
}
@media (1024px <= width) {
  .top-about__figure {
    display: block;
  }
}

.top-offer {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-offer {
    padding-inline: 0;
  }
}
.top-offer {
  margin-top: var(--space-lg);
}

.top-offer__grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (768px <= width) {
  .top-offer__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.top-offer__card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-sm);
  position: relative;
  box-shadow: var(--shadow-sm);
}
.top-offer__card figure {
  inline-size: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
.top-offer__card .top-offer__title {
  font-size: var(--font-md);
  font-weight: 800;
  border-bottom: 1px solid var(--color-base);
  padding-bottom: 0.2rem;
  margin-bottom: 0.5rem;
  text-align: center;
}
@media (max-width: 767px) {
  .top-offer__card p {
    font-size: clamp(0.75rem, 3.5vw, 0.875rem);
  }
}
.top-offer__card .c-btn {
  position: absolute;
  inset-inline-start: 50%;
  inset-block-end: 5%;
  transform: translateX(-50%);
  inline-size: min(70%, 18rem);
}

.top-strengths {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-strengths {
    padding-inline: 0;
  }
}
.top-strengths {
  margin-top: var(--space-xl);
}

.top-strengths__grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (768px <= width) {
  .top-strengths__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.top-strengths__card {
  margin: var(--space-sm);
}
.top-strengths__card span {
  color: var(--color-main);
  font-size: var(--font-xxl);
  border: 3px solid var(--color-main);
  padding: var(--space-2xs);
}
.top-strengths__card figure {
  inline-size: 80%;
  aspect-ratio: 1/1;
  overflow: hidden;
  margin: -20% auto;
}
@media (max-width: 767px) {
  .top-strengths__card figure {
    margin: var(--space-xs) auto -2.5rem;
  }
}
.top-strengths__card .top-strengths__wrap {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-sm);
  position: relative;
  box-shadow: var(--shadow-sm);
}
.top-strengths__card .top-strengths__title {
  font-size: var(--font-md);
  font-weight: 800;
  border-bottom: 1px solid var(--color-base);
  padding-bottom: 0.2rem;
  margin-bottom: 0.5rem;
  text-align: center;
}
@media (max-width: 767px) {
  .top-strengths__card .top-strengths__title {
    font-size: clamp(0.75rem, 3.6vw, 0.9rem);
    white-space: nowrap;
  }
}
@media (max-width: 767px) {
  .top-strengths__card .top-strengths__text {
    font-size: clamp(0.7rem, 3.4vw, 0.8rem);
  }
}

.top-worries {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-worries {
    padding-inline: 0;
  }
}
.top-worries {
  margin-top: var(--space-md);
}
@media (max-width: 767px) {
  .top-worries h3 {
    font-size: clamp(0.875rem, 4.5vw, 1.125rem);
    white-space: nowrap;
  }
}
.top-worries .c-btn {
  margin-left: auto;
  max-width: 400px;
  font-size: clamp(0.625rem, 3.4vw, 1rem);
  white-space: nowrap;
}
@media (1024px <= width) {
  .top-worries .c-btn {
    font-size: inherit;
    white-space: normal;
  }
}

.top-worries__grid {
  display: block;
}
@media (768px <= width) {
  .top-worries__grid {
    display: grid;
    grid-template-columns: 45% 1fr 45%;
  }
}

.top-worries__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--color-main);
  padding: 0 1rem;
}
.top-worries__arrow::before {
  content: "→";
}
@media (max-width: 767px) {
  .top-worries__arrow {
    padding: 0.5rem 0;
  }
  .top-worries__arrow::before {
    content: "↓";
  }
}

.top-worries__title1 {
  background-color: var(--color-gray2);
  color: var(--color-white);
  font-weight: 800;
  font-size: var(--font-md);
  padding: var(--space-xs);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.top-worries__list1 li {
  border: 1px solid var(--color-gray2);
  box-shadow: var(--shadow-sm);
  padding: var(--space-2xs);
  margin-bottom: var(--space-2xs);
  background-color: var(--color-white);
}
.top-worries__list1 li span {
  color: var(--color-gray2);
  margin-inline: var(--space-xs);
}

.top-worries__title2 {
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 800;
  font-size: var(--font-md);
  padding: var(--space-xs);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.top-worries__list2 li {
  border: 1px solid var(--color-main);
  box-shadow: var(--shadow-sm);
  padding: var(--space-2xs);
  margin-bottom: var(--space-2xs);
  background-color: var(--color-white);
}
.top-worries__list2 li span {
  color: var(--color-main);
  margin-inline: var(--space-xs);
}

.top-result {
  background: linear-gradient(135deg, #003d6b 0%, #005b9e 60%, #0077cc 100%);
  padding-block: var(--space-xl);
  margin-top: var(--space-lg);
}

.top-result__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-result__inner {
    padding-inline: 0;
  }
}
.top-result__inner {
  text-align: center;
}

.top-result__heading {
  color: var(--color-white);
  font-size: var(--font-xl);
  font-weight: 800;
  margin-bottom: var(--space-md);
}
@media (1024px <= width) {
  .top-result__heading {
    font-size: var(--font-xxl);
  }
}

.top-result__grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-sm);
  max-width: 800px;
  margin-inline: auto;
}
@media (1024px <= width) {
  .top-result__grid {
    gap: var(--space-md);
  }
}

.top-result__before,
.top-result__after {
  background: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-lg);
  padding: var(--space-sm) var(--space-xs);
  backdrop-filter: blur(8px);
}

.top-result__before {
  border: 2px solid rgba(255, 255, 255, 0.3);
}

.top-result__after {
  border: 2px solid #ffd180;
  background: rgba(255, 209, 128, 0.1);
}

.top-result__badge {
  display: inline-block;
  font-size: var(--font-sm);
  font-weight: 800;
  padding: 0.2em 1em;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-xs);
  letter-spacing: 0.1em;
}

.top-result__badge--before {
  background: rgba(255, 255, 255, 0.2);
  color: var(--color-white);
}

.top-result__badge--after {
  background: #ffd180;
  color: #5a3a00;
}

.top-result__label {
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--font-sm);
  margin: 0;
  letter-spacing: 0.1em;
}

.top-result__num {
  font-size: clamp(3rem, 8vw, 5rem);
  font-weight: 800;
  color: var(--color-white);
  margin: 0.1em 0;
  line-height: 1;
}
.top-result__num span {
  font-size: var(--font-md);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.8);
  margin-left: 0.2em;
}

.top-result__after .top-result__num {
  color: #ffd180;
}

.top-result__sub {
  color: rgba(255, 255, 255, 0.85);
  font-size: var(--font-sm);
  margin: var(--space-xs) 0 0;
  line-height: 1.6;
}
.top-result__sub strong {
  color: #ffd180;
  font-weight: 800;
  font-size: var(--font-base);
}

.top-result__arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.top-result__arrow-line {
  display: block;
  width: 2px;
  height: 60px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.3), #ffd180);
  position: relative;
}
.top-result__arrow-line::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 12px solid #ffd180;
}
@media (768px <= width) {
  .top-result__arrow-line {
    width: 80px;
    height: 2px;
    background: linear-gradient(to right, rgba(255, 255, 255, 0.3), #ffd180);
  }
  .top-result__arrow-line::after {
    bottom: 50%;
    left: auto;
    right: -12px;
    transform: translateY(50%);
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-left: 12px solid #ffd180;
    border-right: none;
  }
}

.top-result__arrow-text {
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.1em;
  writing-mode: vertical-rl;
  margin: 0;
}
@media (768px <= width) {
  .top-result__arrow-text {
    writing-mode: horizontal-tb;
    white-space: nowrap;
    margin-top: 0.5em;
  }
}

.top-result__note {
  color: rgba(255, 255, 255, 0.75);
  font-size: var(--font-sm);
  line-height: 2;
  margin-top: var(--space-md);
}

@media (max-width: 767px) {
  .top-result__grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    max-width: 340px;
  }
  .top-result__arrow-line {
    width: 2px;
    height: 50px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.3), #ffd180);
  }
  .top-result__arrow-line::after {
    bottom: -10px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-top: 12px solid #ffd180;
    border-bottom: none;
  }
  .top-result__arrow-text {
    writing-mode: horizontal-tb;
  }
}
.top-service {
  container-type: inline-size;
  background: var(--color-primary);
}
.top-service .p-section__title {
  padding-block: 0;
}

.top-service__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-service__inner {
    padding-inline: 0;
  }
}
.top-service__inner {
  margin-top: var(--space-md);
}

.top-service__top {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-md);
  display: grid;
  gap: 1rem;
  align-items: center;
}
@media (max-width: 767px) {
  .top-service__top h3 {
    font-size: clamp(0.875rem, 4.5vw, 1.125rem);
    white-space: nowrap;
  }
}
@media (1024px <= width) {
  .top-service__top {
    grid-template-columns: 45% 1fr;
  }
}
.top-service__top figure {
  margin: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.top-service__grid {
  margin-top: 1rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (768px <= width) {
  .top-service__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.top-service__card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 2rem 2rem 7rem;
  position: relative;
}
.top-service__card figure {
  margin: 0 0 1rem;
  inline-size: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: var(--radius-md);
}
.top-service__card .top-service__title {
  font-size: var(--font-md);
  font-weight: 800;
  border-bottom: 1px solid var(--color-base);
  padding-bottom: 0.2rem;
  margin-bottom: 0.5rem;
  text-align: center;
}
@media (max-width: 767px) {
  .top-service__card .top-service__badge_text {
    font-size: clamp(0.7rem, 1.5vw, 0.7125rem);
  }
}
.top-service__card .c-btn {
  position: absolute;
  inset-inline-start: 50%;
  inset-block-end: 5%;
  transform: translateX(-50%);
  inline-size: min(80%, 20rem);
}
@media (1024px <= width) {
  .top-service__card .c-btn {
    inline-size: min(50%, 18rem);
  }
}

.top-service__badge {
  display: inline-block;
  background: #e07b00;
  color: var(--color-white);
  font-size: var(--font-sm);
  font-weight: 800;
  padding: 0.25em 1.2em;
  border-radius: var(--radius-pill);
  letter-spacing: 0.1em;
  margin-bottom: var(--space-xs);
}

@media (max-width: 767px) {
  .top-service__badge_text {
    font-size: clamp(0.7rem, 3.5vw, 0.8125rem);
  }
}

.top-service__top--featured {
  border: 3px solid #e07b00;
  box-shadow: 0 8px 32px rgba(224, 123, 0, 0.18);
  position: relative;
}
.top-service__top--featured .c-btn {
  inline-size: 100%;
  white-space: nowrap;
  font-size: clamp(0.625rem, 2.5vw, 0.875rem);
  font-weight: normal;
  padding-right: 2rem;
}
@media (1024px <= width) {
  .top-service__top--featured .c-btn {
    inline-size: auto;
    white-space: normal;
    font-size: inherit;
    font-weight: inherit;
    padding-right: 3rem;
  }
}
@media (1024px <= width) {
  .top-service__top--featured {
    grid-template-columns: 1fr 45%;
    padding: var(--space-lg);
  }
}

.top-company {
  container-type: inline-size;
}

.top-company__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-company__inner {
    padding-inline: 0;
  }
}
.top-company__inner h3 {
  text-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}
@media (max-width: 767px) {
  .top-company__inner h3 {
    font-size: clamp(1rem, 4.8vw, 1.125rem);
  }
}
@media (max-width: 767px) {
  .top-company__inner p {
    font-size: clamp(0.75rem, 3.7vw, 0.875rem);
  }
}
.top-company__inner .c-btn {
  inline-size: 100%;
}
@media (1024px <= width) {
  .top-company__inner .c-btn {
    inline-size: 20%;
  }
}

.top-topic {
  container-type: inline-size;
  background: var(--color-primary);
}

.top-topic__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-topic__inner {
    padding-inline: 0;
  }
}

.top-topic__title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.top-topic__title .p-section__title {
  padding: var(--space-lg);
  padding-inline: 0;
}
.top-topic__title .c-btn {
  inline-size: 25%;
  min-inline-size: 10rem;
}

.splide__arrows,
.splide__pagination {
  display: none;
}

@media (max-width: 767px) {
  .splide__pagination {
    display: block;
  }
}
.topic-item {
  background: var(--color-white);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.topic-item figure {
  margin: 0;
}
.topic-item figure img {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
@media (hover: hover) {
  .topic-item:hover img {
    transform: scale(1.08);
  }
}
@media (hover: none) {
  .topic-item a:hover {
    opacity: 1;
  }
}
.topic-item .topic_text {
  padding: var(--space-sm);
}
.topic-item .topic_text time {
  color: var(--color-gray);
}
.topic-item .topic_text .topic__title {
  font-size: var(--font-md);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  line-height: 1.6;
  height: 3.2em;
}
.topic-item .topic_text p {
  margin: var(--space-2xs);
  line-height: 1.5;
}

.topic__tag {
  display: flex;
  gap: 0 15px;
  list-style: none;
  font-size: var(--font-sm);
}
.topic__tag li::before {
  display: inline-block;
  vertical-align: middle;
  inline-size: 1em;
  block-size: 1em;
  margin-right: 4px;
  background-image: url(img/tag.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
}

.top-news {
  container-type: inline-size;
  background: var(--color-primary);
}

.top-news__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .top-news__inner {
    padding-inline: 0;
  }
}
.top-news__inner {
  display: grid;
  justify-content: space-between;
  gap: 2rem;
  grid-template-columns: 1fr;
}
@media (1024px <= width) {
  .top-news__inner {
    grid-template-columns: 30% 70%;
    align-items: start;
  }
}

.top-news__title .p-section__title {
  padding: 0;
}

.top-news__list li {
  border-bottom: 1px solid var(--color-gray);
  padding: var(--space-sm);
  transition: background-color 0.25s ease, transform 0.25s ease;
}
.top-news__list li:last-child {
  border-bottom: 0;
}
.top-news__list li:hover {
  background: var(--color-clear);
}
@media (768px <= width) {
  .top-news__list li:hover {
    transform: translateX(30px);
  }
}
@media (768px <= width) {
  .top-news__list li a {
    display: flex;
    align-items: center;
  }
}
.top-news__list li span {
  display: inline-block;
  font-size: var(--font-sm);
  background: var(--color-main);
  color: var(--color-white);
  font-weight: 800;
  padding: var(--space-2xs);
  margin-inline: 1rem;
}

footer {
  position: relative;
  z-index: var(--z-content);
}

.site-footer__contact {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .site-footer__contact {
    padding-inline: 0;
  }
}
.site-footer__contact {
  display: grid;
  grid-template-columns: 35% 55%;
  justify-content: space-between;
  align-items: start;
  container-type: inline-size;
  padding-bottom: var(--space-md);
  padding-inline: 0;
}
.site-footer__contact .site-footer__contact-title {
  color: var(--color-white);
  font-size: var(--font-xxxl);
}
.site-footer__contact .site-footer__contact-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  justify-content: space-between;
}
.site-footer__contact .site-footer__contact-grid li {
  background: var(--color-clear);
  backdrop-filter: blur(12px);
  padding: var(--space-sm);
  text-align: center;
  border-radius: var(--radius-lg);
}
.site-footer__contact .site-footer__contact-grid li figure {
  max-width: 60%;
  margin: 0 auto 1rem;
  aspect-ratio: 1/1;
}
.site-footer__contact .site-footer__contact-grid li .site-footer__contact-label {
  font-weight: 800;
  font-size: var(--font-md);
}
.site-footer__contact .site-footer__contact-grid li .c-btn {
  margin-inline: auto;
  width: -webkit-fill-available;
  width: -moz-available;
  width: stretch;
}
.site-footer__contact .site-footer__contact-grid li .site-footer__tel {
  color: var(--color-main);
  font-weight: 800;
  font-size: var(--font-xl);
}
.site-footer__contact .site-footer__contact-grid li .site-footer__tel-note {
  font-size: var(--font-sm);
  margin-top: -0.75rem;
}

.site-footer__info {
  background: var(--color-clear);
  backdrop-filter: blur(12px);
}

.site-footer__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .site-footer__inner {
    padding-inline: 0;
  }
}
.site-footer__inner {
  container-type: inline-size;
  padding: var(--space-sm);
  display: grid;
  grid-template-columns: 40% 50%;
  justify-content: space-between;
  padding-block: 0;
}
.site-footer__inner .site-footer__address {
  margin-top: var(--space-sm);
}
.site-footer__inner .site-footer__nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.site-footer__inner .site-footer__menu li {
  margin-block: var(--space-xs);
}
.site-footer__inner .site-footer__copy {
  margin-top: var(--space-md);
  font-size: var(--font-sm);
}

.site-footer__sp {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .site-footer__sp {
    padding-inline: 0;
  }
}
.site-footer__sp {
  padding-inline: 0;
}

.site-footer__sp-btn {
  margin-top: var(--space-lg);
  margin-inline: var(--space-md);
}
.site-footer__sp-btn a {
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  font-weight: 800;
  border-radius: var(--radius-pill);
  background: var(--color-clear);
  padding-block: var(--space-sm);
  padding-inline: var(--space-md);
  font-size: var(--font-md);
  margin-top: var(--space-sm);
}
.site-footer__sp-btn a figure {
  inline-size: 20%;
}

.site-footer__sp-nav {
  background: var(--color-clear);
  backdrop-filter: blur(12px);
  padding: var(--space-md);
}
.site-footer__sp-nav li {
  padding-bottom: 0.5rem;
  margin: 1rem 0;
  border-bottom: 1px solid var(--color-gray);
  font-size: clamp(0.8rem, 3.7vw, 0.875rem);
  white-space: nowrap;
}
.site-footer__sp-nav li:last-child {
  font-size: var(--font-sm);
  margin-top: 1rem;
  margin-bottom: 0;
  border: none;
  text-align: center;
  color: var(--color-gray2);
}

#page {
  margin-top: var(--header-height);
}

.c-breadcrumb {
  display: none;
}
@media (768px <= width) {
  .c-breadcrumb {
    display: block;
    background-color: var(--color-white);
    padding-block: var(--space-xs);
    padding-left: var(--space-xxl);
    border-top: 1px solid var(--color-primary);
  }
}

.breadcrumb {
  display: flex;
  gap: 0 15px;
  list-style: none;
  font-size: var(--font-sm);
}
.breadcrumb li:first-child::before {
  display: inline-block;
  inline-size: 1em;
  block-size: 1em;
  margin-right: 4px;
  background-image: url(img/breadcrumb.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
}
.breadcrumb li:not(:last-child)::after {
  display: inline-block;
  margin-left: 15px;
  content: "/";
}

.page-hero {
  background-repeat: no-repeat;
  background-size: cover;
}
.page-hero .page-hero__inner {
  position: relative;
  color: var(--color-white);
  padding-block: var(--space-md);
  padding-left: var(--space-sm);
  padding-right: var(--space-sm);
}
@media (768px <= width) {
  .page-hero .page-hero__inner {
    padding-block: var(--space-md);
    padding-left: var(--space-xxl);
    padding-right: 0;
  }
}
@media (768px <= width) {
  .page-hero .page-hero__inner .page-hero__note {
    letter-spacing: 0.7em;
  }
}
.page-hero .page-hero__inner .page-hero__title {
  letter-spacing: 0.2em;
  font-size: var(--font-xxxl);
  font-weight: 800;
  text-wrap: balance;
  margin: 0 0 var(--space-xs);
}
@media (max-width: 767px) {
  .page-hero .page-hero__inner .page-hero__title {
    font-size: clamp(1.2rem, 5.9vw, 1.375rem);
  }
}
@media (768px <= width) {
  .page-hero .page-hero__inner .page-hero__lead {
    font-size: var(--font-md);
  }
}
@media (max-width: 767px) {
  .page-hero .page-hero__inner .page-hero__lead {
    font-size: clamp(0.8rem, 3.7vw, 0.875rem);
  }
}

.page-hero__bg1 {
  background-image: url(img/354400.webp);
}

.page-hero__bg2 {
  background-image: url(img/27426269.webp);
}

.p-cta {
  padding-block: var(--space-lg);
}

.p-cta__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .p-cta__inner {
    padding-inline: 0;
  }
}
.p-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-sm);
}

.p-cta__label {
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.25em;
  color: #e07b00;
  margin: 0;
}

.p-cta__heading {
  font-size: var(--font-xl);
  font-weight: 800;
  text-wrap: balance;
  margin: 0;
}
@media (max-width: 767px) {
  .p-cta__heading {
    font-size: clamp(0.875rem, 4.3vw, 1rem);
    width: calc(100% + 3rem);
    margin-inline: -1.5rem;
    text-wrap: auto;
    white-space: nowrap;
  }
}
@media (1024px <= width) {
  .p-cta__heading {
    font-size: var(--font-xxl);
  }
}

.p-cta__desc {
  font-size: var(--font-base);
  line-height: 2;
  margin: 0;
}
@media (max-width: 767px) {
  .p-cta__desc {
    font-size: clamp(0.8rem, 3.7vw, 0.875rem);
  }
}

.p-cta__buttons {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  inline-size: 100%;
  max-inline-size: 28rem;
}
@media (768px <= width) {
  .p-cta__buttons {
    flex-direction: row;
    justify-content: center;
    align-items: stretch;
    inline-size: auto;
    max-inline-size: none;
    gap: var(--space-sm);
  }
}

.p-cta__buttons .c-btn {
  margin-top: 0;
  inline-size: 100%;
  max-inline-size: none;
  padding-left: var(--space-sm);
  padding-right: 3rem;
  justify-content: center;
  font-size: clamp(0.625rem, 3.2vw, 0.85rem);
  white-space: nowrap;
}
@media (768px <= width) {
  .p-cta__buttons .c-btn {
    inline-size: auto;
    min-inline-size: 20rem;
    max-inline-size: 26rem;
    flex: 1 1 auto;
    font-size: inherit;
    white-space: normal;
  }
}

.p-cta--accent {
  background: linear-gradient(135deg, #003d6b 0%, #005b9e 60%, #0077cc 100%);
  color: var(--color-white);
}

.p-cta--accent .p-cta__heading,
.p-cta--accent .p-cta__desc {
  color: var(--color-white);
}

.p-cta--accent .p-cta__buttons .c-btn {
  background: transparent;
  border-color: var(--color-white);
  color: var(--color-white);
}

.p-cta--accent .p-cta__buttons .c-btn:hover {
  background: var(--color-white);
  color: var(--color-main);
}

.p-cta--plain {
  background: var(--color-primary);
}

.page-hero__lead-title {
  display: inline-block;
  font-size: var(--font-md);
  font-weight: 800;
  margin-bottom: var(--space-xs);
  line-height: 1.5;
}
@media (768px <= width) {
  .page-hero__lead-title {
    font-size: var(--font-lg);
  }
}

.about-hero {
  background-image: url(img/1444646.webp);
  background-repeat: no-repeat;
  background-size: cover;
  height: 85vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.about-hero__inner {
  padding-inline: var(--space-sm);
  text-align: center;
}
.about-hero__inner .about-hero__none {
  color: var(--color-white);
  font-weight: bold;
  letter-spacing: 0.5em;
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.8), 0 2px 4px rgba(0, 0, 0, 0.6);
}
.about-hero__inner .about-hero__title {
  font-size: var(--font-hero);
  line-height: 1.2;
  margin-block: var(--space-md);
}
@media (max-width: 767px) {
  .about-hero__inner .about-hero__title {
    font-size: var(--font-xl);
  }
}
.about-hero__inner .about-hero__title span {
  display: block;
  background: var(--gradient-main);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
}
.about-hero__inner .about-hero__lead {
  line-height: 2;
  font-size: var(--font-base);
  -webkit-text-stroke: 0.5px rgba(0, 0, 0, 0.4);
  paint-order: stroke fill;
}

.c-about__heading {
  font-size: var(--font-xl);
  line-height: 1.4;
  margin-bottom: var(--space-sm);
}
@media (max-width: 767px) {
  .c-about__heading {
    font-size: clamp(1rem, 4.8vw, 1.125rem);
    margin-inline: -1rem;
    white-space: nowrap;
  }
}
.c-about__heading span {
  display: block;
  background: var(--gradient-main);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  font-size: var(--font-xxl);
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  .c-about__heading span {
    font-size: clamp(1.4rem, 6.9vw, 1.625rem);
  }
}

.c-about__none {
  color: var(--color-main);
  font-weight: bold;
  letter-spacing: 0.5em;
}

.c-about__lead {
  color: var(--color-gray2);
  margin-block: var(--space-xs);
  font-size: var(--font-md);
  letter-spacing: 0.2em;
  text-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.about-purpose__grid {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .about-purpose__grid {
    padding-inline: 0;
  }
}
.about-purpose__grid {
  display: block;
}
@media (768px <= width) {
  .about-purpose__grid {
    display: grid;
    grid-template-columns: 1fr 50%;
    gap: var(--space-md);
    align-items: start;
    margin-top: var(--space-lg);
  }
}
.about-purpose__grid .about-purpose__left {
  margin-bottom: var(--space-lg);
}
@media (768px <= width) {
  .about-purpose__grid .about-purpose__left {
    margin-bottom: 0;
  }
}

.about-purpose__body {
  margin-bottom: var(--space-xs);
}

.about-value-list__text {
  margin-block: var(--space-xs);
}
.about-value-list__text h3 {
  font-size: var(--font-md);
  font-weight: 800;
  margin-bottom: 0;
}
.about-value-list__text h3::before {
  content: "●";
  display: inline-block;
  color: var(--color-main);
  margin-inline: 0.5em;
  font-size: var(--font-sm);
}
.about-value-list__text p {
  margin-left: 1.8em;
}

.about-product__features {
  display: block;
}
@media (768px <= width) {
  .about-product__features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
  }
}
.about-product__features .about-product__feature {
  margin-top: var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
}
.about-product__features .about-product__feature figure {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
}
.about-product__features .about-product__feature figure img {
  max-width: 150px;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.about-product__features .about-product__feature dt {
  margin-block: var(--space-xs);
  text-align: center;
}

.about-how-flow__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: var(--space-md);
}

.about-how-flow {
  padding-left: 0;
  border-bottom: solid 1px var(--color-primary);
  inline-size: 100%;
}
.about-how-flow > li {
  list-style-type: none;
  display: flex;
  padding: 20px 0;
  border-top: solid 1px var(--color-primary);
}
.about-how-flow > li dl {
  width: calc(100% - 70px);
  margin-top: 0.8em;
}
.about-how-flow > li dl dt {
  font-size: var(--font-md);
  line-height: 2;
  font-weight: bold;
  margin-bottom: 10px;
}
.about-how-flow > li dl dd {
  margin: 0;
}

.about-how-flow__num {
  line-height: 1;
  font-size: var(--font-lg);
  font-weight: bold;
  color: var(--color-main);
  text-align: center;
  width: 70px;
  position: relative;
  margin-top: 0;
}
.about-how-flow__num::before {
  content: "STEP";
  font-size: var(--font-sm);
  display: block;
  margin-bottom: 3px;
  letter-spacing: 1px;
}
.about-how-flow__num::after {
  content: "";
  display: block;
  width: 1px;
  height: calc(100% - 40px);
  background-color: var(--color-gray);
  position: absolute;
  left: 0;
  right: 0;
  top: 60px;
  margin: auto;
}

.about-vision__grid {
  display: block;
}
@media (768px <= width) {
  .about-vision__grid {
    display: grid;
    grid-template-columns: 1fr 40%;
    gap: var(--space-md);
    align-items: center;
    margin-top: var(--space-lg);
  }
}

.about-vision__body {
  margin-bottom: var(--space-xs);
}

.about-vision__table {
  width: 100%;
}
.about-vision__table td {
  border: 5px solid var(--color-primary);
  background-color: var(--color-clear);
  padding-block: var(--space-sm);
  vertical-align: middle;
  text-align: center;
}
.about-vision__table td .about-vision__table-num {
  font-size: var(--font-xl);
  font-weight: 800;
  vertical-align: top;
  color: var(--color-main);
}
.about-vision__table td .about-vision__table-num span {
  font-size: var(--font-md);
}
.about-vision__table td .about-vision__table-label {
  font-size: var(--font-sm);
}

.about-partner__types {
  display: block;
}
@media (768px <= width) {
  .about-partner__types {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
  }
}
.about-partner__types .about-partner__type {
  margin-top: var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
}
.about-partner__types .about-partner__type figure {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
}
.about-partner__types .about-partner__type figure img {
  -o-object-fit: cover;
     object-fit: cover;
}
.about-partner__types .about-partner__type dt {
  font-size: var(--font-md);
  color: var(--color-main);
  margin-block: var(--space-xs);
  text-align: center;
}

.about-partner__conditions {
  margin-top: var(--space-md);
}

.about-partner__conditions-list {
  margin-top: var(--space-sm);
  display: block;
}
@media (768px <= width) {
  .about-partner__conditions-list {
    display: grid;
    grid-template-columns: 1fr 50%;
    gap: var(--space-xs);
    align-items: start;
  }
}
.about-partner__conditions-list li {
  border: 1px solid var(--color-primary);
  padding: var(--space-xs);
  box-shadow: var(--shadow-sm);
}
.about-partner__conditions-list li span {
  color: var(--color-main);
  margin-inline: var(--space-xs);
}

.about-partner__cta {
  margin-top: var(--space-lg);
}
.about-partner__cta .c-btn {
  font-size: var(--font-base);
  max-width: 400px;
  margin-inline: auto;
}
.about-partner__cta .about-partner__note {
  margin-top: var(--space-sm);
  text-align: center;
}

.c-service__eyebrow, .c-service__none {
  color: var(--color-main);
  font-weight: bold;
  letter-spacing: 0.5em;
}

.c-service__heading {
  font-size: var(--font-lg);
  line-height: 1.4;
  margin-bottom: var(--space-sm);
}
@media (max-width: 767px) {
  .c-service__heading {
    font-size: clamp(0.875rem, 4.5vw, 1.125rem);
    white-space: nowrap;
  }
}
.c-service__heading span {
  display: block;
  background: var(--gradient-main);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  font-size: var(--font-xxl);
  letter-spacing: 0.1em;
}

@media (max-width: 767px) {
  .l-inner p {
    font-size: clamp(0.7rem, 3.5vw, 0.8125rem);
  }
}

.service-hero {
  background-image: url(img/1133614.webp);
  background-repeat: no-repeat;
  background-size: cover;
  height: 85vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.service-hero__inner {
  padding-inline: var(--space-sm);
  text-align: center;
}
.service-hero__inner .service-hero__eyebrow {
  font-size: var(--font-md);
  color: var(--color-white);
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.8), 0 2px 4px rgba(0, 0, 0, 0.6);
}
.service-hero__inner .service-hero__none {
  color: var(--color-white);
  font-weight: bold;
  letter-spacing: 0.5em;
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.8), 0 2px 4px rgba(0, 0, 0, 0.6);
}
.service-hero__inner .service-hero__title {
  font-size: var(--font-xxxxl);
  line-height: 1.2;
  margin-block: var(--space-md);
}
@media (max-width: 767px) {
  .service-hero__inner .service-hero__title {
    font-size: clamp(1.1rem, 5.3vw, 1.25rem);
  }
}
.service-hero__inner .service-hero__title span {
  display: block;
  background: var(--gradient-main);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
}
.service-hero__inner .service-hero__lead {
  line-height: 2;
  font-size: var(--font-base);
  -webkit-text-stroke: 0.5px rgba(0, 0, 0, 0.4);
  paint-order: stroke fill;
}
.service-hero__inner .c-btn {
  max-width: 350px;
  margin: 1rem auto 0 auto;
}

.service-hero__buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  margin-top: var(--space-md);
}
@media (768px <= width) {
  .service-hero__buttons {
    flex-direction: row;
    justify-content: center;
    gap: var(--space-sm);
  }
}

.service-hero__buttons .c-btn {
  margin: 0;
  inline-size: 100%;
  max-inline-size: 22rem;
}
@media (768px <= width) {
  .service-hero__buttons .c-btn {
    inline-size: auto;
    min-inline-size: 18rem;
  }
}

.service-worries__grid {
  display: block;
}
@media (768px <= width) {
  .service-worries__grid {
    display: grid;
    grid-template-columns: 45% 1fr 45%;
  }
}

.service-worries__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--color-main);
  padding: 0 1rem;
}
.service-worries__arrow::before {
  content: "→";
}
@media (max-width: 767px) {
  .service-worries__arrow {
    padding: 0.5rem 0;
  }
  .service-worries__arrow::before {
    content: "↓";
  }
}

.service-worries__title1 {
  background-color: var(--color-gray2);
  color: var(--color-white);
  font-weight: 800;
  font-size: var(--font-md);
  padding: var(--space-xs);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.service-worries__list1 li {
  border: 1px solid var(--color-gray2);
  box-shadow: var(--shadow-sm);
  padding: var(--space-2xs);
  margin-bottom: var(--space-2xs);
  display: flex;
  align-items: center;
}
.service-worries__list1 li span {
  color: var(--color-gray2);
  margin-inline: var(--space-xs);
  flex-shrink: 0;
}

.service-worries__title2 {
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 800;
  font-size: var(--font-md);
  padding: var(--space-xs);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.service-worries__list2 li {
  border: 1px solid var(--color-main);
  box-shadow: var(--shadow-sm);
  padding: var(--space-2xs);
  margin-bottom: var(--space-2xs);
  display: flex;
  align-items: center;
}
.service-worries__list2 li span {
  color: var(--color-main);
  margin-inline: var(--space-xs);
  flex-shrink: 0;
}

.service-reason__lists {
  display: block;
}
@media (768px <= width) {
  .service-reason__lists {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
  }
}

.service-reason__list {
  margin-top: var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
}
.service-reason__list dt {
  font-size: var(--font-md);
  color: var(--color-main);
  margin-block: var(--space-xs);
  text-align: center;
}

.service-product__lists {
  display: block;
}
@media (1024px <= width) {
  .service-product__lists {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "item1 item1" "item2 item3";
    gap: var(--space-sm);
  }
}

@media (1024px <= width) {
  .service-product__lists > *:nth-child(1) {
    grid-area: item1;
  }
}

@media (1024px <= width) {
  .service-product__lists > *:nth-child(2) {
    grid-area: item2;
  }
}

@media (1024px <= width) {
  .service-product__lists > *:nth-child(3) {
    grid-area: item3;
  }
}

.service-product__card {
  margin-top: var(--space-sm);
  box-shadow: var(--shadow-sm);
  background-color: var(--color-white);
  transition: box-shadow 0.3s, transform 0.3s;
}
.service-product__card:hover {
  box-shadow: 0 15px 30px -5px rgba(0, 0, 0, 0.15), 0 0 5px rgba(0, 0, 0, 0.1);
  transform: translateY(-4px);
}
.service-product__card .service-product__list-top {
  padding: var(--space-sm);
  padding-bottom: 0;
}
.service-product__card .service-product__list-top span {
  font-size: var(--font-sm);
  background-color: var(--color-main);
  padding: var(--space-xs);
  color: var(--color-white);
  font-weight: 800;
}
.service-product__card .service-product__list-top .pic-span {
  background-image: var(--gradient-main);
}
.service-product__card .service-product__list-top figure {
  display: flex;
  justify-content: center;
  align-items: center;
}
.service-product__card .service-product__list-top figure img {
  max-height: 250px;
}
.service-product__card .service-product__list-top h3 {
  font-size: var(--font-lg);
  text-align: center;
}
@media (max-width: 767px) {
  .service-product__card .service-product__list-top h3 {
    font-size: clamp(0.875rem, 4.3vw, 1rem);
  }
}
.service-product__card .service-product__list-text {
  padding: var(--space-sm);
  padding-top: 0;
  background-color: var(--color-white);
}
.service-product__card .service-product__list-link {
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 800;
  padding: var(--space-xs);
}
.service-product__card .service-product__list-link a:hover {
  color: var(--color-white);
}
.service-product__card .service-product__list-link td {
  padding-block: var(--space-xs);
  padding-inline: var(--space-sm);
}
.service-product__card .pic-link {
  background-image: var(--gradient-main);
}

.service-product__card--main {
  position: relative;
  border: 2px solid #e07b00;
}

.service-product__card--main .service-product__list-top h3 {
  font-size: var(--font-xl);
}
@media (max-width: 767px) {
  .service-product__card--main .service-product__list-top h3 {
    font-size: clamp(1.1rem, 5.3vw, 1.25rem);
  }
}

.service-product__list-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  padding: var(--space-sm);
  padding-top: 0;
  background-color: var(--color-white);
}
@media (768px <= width) {
  .service-product__list-actions {
    flex-direction: row;
    justify-content: center;
  }
}

.service-product__list-actions .c-btn {
  margin-top: 0;
  inline-size: 100%;
  max-inline-size: none;
}
@media (768px <= width) {
  .service-product__list-actions .c-btn {
    inline-size: auto;
    min-inline-size: 18rem;
    max-inline-size: 22rem;
    flex: 0 1 auto;
  }
}

.service-fq__list dt {
  margin-bottom: var(--space-xs);
  font-weight: 600;
  color: var(--color-main);
  font-size: var(--font-md);
}
.service-fq__list dt::before {
  content: "Q.";
  margin-right: var(--space-2xs);
}
.service-fq__list dd {
  margin: var(--space-xs);
  padding: var(--space-sm);
  background-color: var(--color-primary);
}
.service-fq__list dd::before {
  content: "A.";
  font-weight: 800;
  margin-right: var(--space-2xs);
}

.service-hero2 {
  background-image: url(img/22482924.webp);
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 85vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .service-hero2 {
    align-items: flex-start;
    padding-top: max(var(--header-height), 12vh);
    padding-bottom: 5vh;
  }
}

.service-hero2__grid {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .service-hero2__grid {
    padding-inline: 0;
  }
}
.service-hero2__grid {
  display: block;
}
@media (768px <= width) {
  .service-hero2__grid {
    display: grid;
    grid-template-columns: 1fr 35%;
    gap: var(--space-md);
    align-items: center;
  }
}

.service2-hero__none {
  color: var(--color-main);
  font-weight: bold;
  letter-spacing: 0.2em;
  padding-block: var(--space-xs);
  padding-inline: var(--space-sm);
  border: 2px solid var(--color-main);
  border-radius: var(--radius-pill);
  font-size: var(--font-sm);
}

.service2-hero__title {
  font-size: var(--font-xxl);
  line-height: 1.4;
  margin-block: var(--space-sm);
  color: var(--color-white);
}
@media (max-width: 767px) {
  .service2-hero__title {
    font-size: clamp(0.875rem, 4.3vw, 1rem);
  }
}
.service2-hero__title span {
  display: block;
  color: var(--color-main);
  font-weight: 800;
  letter-spacing: 0.1em;
}

.service2-hero__title2 {
  font-size: var(--font-xl);
  line-height: 1.4;
  margin-block: var(--space-sm);
  color: var(--color-white);
}
.service2-hero__title2 span {
  display: block;
  color: var(--color-main);
  font-weight: 800;
  letter-spacing: 0.1em;
}

.service2-hero__lead1 {
  font-size: var(--font-md);
  color: var(--color-white);
  margin-bottom: var(--space-sm);
}
@media (max-width: 767px) {
  .service2-hero__lead1 {
    font-size: clamp(0.75rem, 3.7vw, 0.875rem);
  }
}

.service2-hero__lead2 {
  color: var(--color-white);
}
@media (max-width: 767px) {
  .service2-hero__lead2 {
    font-size: clamp(0.65rem, 3.7vw, 0.775rem);
  }
}

.service2-hero__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 350px;
  padding: var(--space-xs);
  border: none;
  border-radius: var(--radius-sm);
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 600;
  margin-top: var(--space-sm);
}
.service2-hero__btn:hover {
  color: var(--color-white);
}

.service2-hero__btn2 {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 350px;
  padding: var(--space-xs);
  border: none;
  border-radius: var(--radius-sm);
  background-color: var(--color-clear);
  color: var(--color-main);
  font-weight: 600;
  margin-top: var(--space-sm);
}
@media (max-width: 767px) {
  .service2-hero__btn2 {
    margin-bottom: var(--space-sm);
  }
}
.service2-hero__btn2:hover {
  color: var(--color-white);
}

.service-hero2__box {
  position: relative;
  inline-size: 100%;
  padding: calc(1em + 25px) 1.5em 1em;
  background-color: var(--color-clear);
  border: 2px solid var(--color-white);
  border-radius: 5px;
  overflow: auto;
}
.service-hero2__box svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 25px;
  background-color: #f2f2f2;
}
.service-hero2__box .service2-hero__box-text {
  padding: var(--space-xs);
}

.service2-hero__box-graph {
  display: flex;
  align-items: flex-end;
  height: 300px;
}
.service2-hero__box-graph .bar {
  width: 50px;
  margin: 0 10px;
}
.service2-hero__box-graph .a {
  height: calc(var(--value-a) / 100 * 300px);
  background-color: rgba(3, 110, 183, 0.3);
  backdrop-filter: blur(12px);
}
.service2-hero__box-graph .b {
  height: calc(var(--value-b) / 100 * 300px);
  background-color: rgba(3, 110, 183, 0.7);
  backdrop-filter: blur(12px);
  border: 1px solid var(--color-white);
}

.service2-hero__box-graph-note {
  margin-block: var(--space-sm);
  text-align: right;
}
.service2-hero__box-graph-note .service2-hero__box-graph-a {
  color: rgba(3, 110, 183, 0.3);
}
.service2-hero__box-graph-note .service2-hero__box-graph-b {
  color: rgba(3, 110, 183, 0.7);
}

.service2-hero__box-list li {
  border: 1px solid var(--color-primary);
  padding: var(--space-xs);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-2xs);
  display: flex;
  justify-content: space-between;
}
.service2-hero__box-list li span {
  color: var(--color-main);
  font-weight: 800;
}

.service-hero2-box2__before,
.service-hero2-box2__after {
  background-color: var(--color-clear);
  box-shadow: var(--shadow-sm);
  padding: var(--space-xs);
}

.service-hero2-box2__before-title,
.service-hero2-box2__after-title {
  color: var(--color-white);
  font-weight: bold;
  padding: var(--space-2xs);
  text-align: center;
}

.service-hero2-box2__before-title {
  background-color: var(--color-gray);
}

.service-hero2-box2__after-title {
  background-color: var(--color-main);
}

.service-hero2-box2__before-list li,
.service-hero2-box2__after-list li {
  margin-block: var(--space-2xs);
  margin-left: 1rem;
}
.service-hero2-box2__before-list li::before,
.service-hero2-box2__after-list li::before {
  display: inline-block;
  margin-right: 0.5em;
  font-weight: bold;
}

.service-hero2-box2__before-list li::before {
  content: "✕";
  color: var(--color-gray2);
}

.service-hero2-box2__after-list li::before {
  content: "✔";
  color: var(--color-main);
}

.service-hero2-box2__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--color-main);
  padding: 0 1rem;
}
.service-hero2-box2__arrow::before {
  content: "↓";
}

.service-hero2-box2__point {
  margin-top: var(--space-xs);
  background-color: var(--color-clear);
  border: 1px solid var(--color-primary);
  box-shadow: var(--shadow-sm);
  padding: var(--space-xs);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}
.service-hero2-box2__point img {
  width: 1.5em;
  height: 1.5em;
  margin-right: var(--space-2xs);
}
.service-hero2-box2__point span {
  display: inline-block;
  color: var(--color-main);
  font-weight: 800;
}

.service-hero2-box3__list {
  counter-reset: number;
  list-style-type: none !important;
}
.service-hero2-box3__list li {
  position: relative;
  line-height: 1.5em;
  padding: var(--space-xs);
  padding-left: var(--space-md);
  margin-block: var(--space-xs);
  background-color: var(--color-clear);
  box-shadow: var(--shadow-sm);
}
.service-hero2-box3__list li::before {
  counter-increment: number;
  content: counter(number);
  position: absolute;
  display: inline-block;
  background: var(--color-main);
  color: var(--color-white);
  font-weight: 800;
  border-radius: 50%;
  left: 5%;
  width: 25px;
  height: 25px;
  line-height: 25px;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
}

.service-hero2-box3__list-title {
  font-weight: 800;
  color: var(--color-main);
}

.simulation-section__eyebrow {
  display: block;
  text-align: center;
  font-size: var(--font-base);
  font-weight: 800;
  letter-spacing: 0.45em;
  color: var(--color-main);
  margin-bottom: var(--space-sm);
  position: relative;
  padding-bottom: var(--space-sm);
}
@media (768px <= width) {
  .simulation-section__eyebrow {
    font-size: var(--font-md);
  }
}

.simulation-section__eyebrow::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 56px;
  height: 3px;
  background: linear-gradient(90deg, var(--color-main), var(--color-paid));
  border-radius: var(--radius-pill);
}

.simulation-section__eyebrow--inverse {
  color: #ffd180;
}

.simulation-section__eyebrow--inverse::after {
  background: linear-gradient(90deg, #ffd180, #ffb84d);
}

.simulation-section__title {
  font-size: var(--font-xxl);
  font-weight: 900;
  text-align: center;
  margin: 0 0 var(--space-md);
  line-height: 1.4;
  text-wrap: balance;
  letter-spacing: 0.02em;
}
@media (1024px <= width) {
  .simulation-section__title {
    font-size: var(--font-xxxl);
  }
}
@media (max-width: 767px) {
  .simulation-section__title {
    font-size: clamp(1.1rem, 5.3vw, 1.25rem);
  }
}

.simulation-section__title--inverse {
  color: var(--color-white);
}

.simulation-hero {
  background-image: url(img/1041027.webp);
  position: relative;
  overflow: hidden;
  padding-block: var(--space-md);
}

.simulation-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(0, 91, 158, 0.05) 1.2px, transparent 1.2px);
  background-size: 32px 32px;
  pointer-events: none;
  z-index: 0;
}

.simulation-hero::after {
  content: "";
  position: absolute;
  top: -100px;
  right: -100px;
  inline-size: 350px;
  block-size: 350px;
  background: radial-gradient(circle, rgba(212, 130, 10, 0.08), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}

.simulation-hero > * {
  position: relative;
  z-index: 1;
}

.simulation-hero__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .simulation-hero__inner {
    padding-inline: 0;
  }
}
.simulation-hero__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}
@media (1024px <= width) {
  .simulation-hero__inner {
    flex-direction: row;
    align-items: center;
    gap: var(--space-xl);
  }
}
@media (max-width: 767px) {
  .simulation-hero__inner {
    padding-inline: var(--space-sm);
  }
}

@media (1024px <= width) {
  .simulation-hero__text {
    flex: 1 1 0;
  }
}

.simulation-hero__eyebrow {
  display: inline-block;
  font-size: var(--font-base);
  font-weight: 800;
  letter-spacing: 0.35em;
  color: var(--color-white);
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  padding: var(--space-2xs) var(--space-md);
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-md);
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.25);
}
@media (max-width: 767px) {
  .simulation-hero__eyebrow {
    font-size: clamp(0.625rem, 3.2vw, 0.75rem);
  }
}

.simulation-hero__title {
  font-size: var(--font-xxl);
  font-weight: 900;
  line-height: 1.4;
  margin: 0 0 var(--space-md);
  text-wrap: balance;
  position: relative;
  letter-spacing: 0.02em;
}
@media (768px <= width) {
  .simulation-hero__title {
    font-size: var(--font-xxxl);
  }
}

.simulation-hero__sub {
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--color-main);
  line-height: 1.6;
  margin: 0 0 var(--space-sm);
  letter-spacing: 0.02em;
}
@media (768px <= width) {
  .simulation-hero__sub {
    font-size: var(--font-xl);
  }
}

.simulation-hero__body {
  font-size: var(--font-base);
  line-height: 1.95;
  margin: 0 0 var(--space-sm);
  color: var(--color-base);
}
@media (768px <= width) {
  .simulation-hero__body {
    font-size: var(--font-md);
  }
}

@media (1024px <= width) {
  .simulation-hero__chart {
    flex: 0 0 45%;
  }
}

.simulation-hero__note {
  margin-top: var(--space-sm);
  font-size: var(--font-sm);
}

.simulation-chart {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  box-shadow: 0 20px 50px rgba(0, 91, 158, 0.12), 0 0 0 1px rgba(0, 91, 158, 0.05);
  position: relative;
}

.simulation-chart::before {
  content: "STOCK PRICE TREND";
  display: block;
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.3em;
  color: var(--color-gray2);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.simulation-chart__svg {
  display: block;
  inline-size: 100%;
  height: auto;
  max-block-size: 240px;
}

.simulation-chart__line {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: simChartDraw 2.2s cubic-bezier(0.65, 0, 0.35, 1) 0.4s forwards;
}

@keyframes simChartDraw {
  to {
    stroke-dashoffset: 0;
  }
}
.simulation-chart__future {
  transform-origin: 370px 30px;
  animation: simChartPulse 2s ease-in-out 2.5s infinite;
}

@keyframes simChartPulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.6;
  }
  50% {
    transform: scale(1.4);
    opacity: 0;
  }
}
.simulation-chart__data {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs);
  margin-top: var(--space-sm);
}

.simulation-chart__card {
  padding: var(--space-sm);
  border-radius: var(--radius-sm);
  text-align: center;
  position: relative;
}

.simulation-chart__card--now {
  background-color: #e1ecf4;
  border: 2px solid var(--color-main);
  color: var(--color-main);
}

.simulation-chart__card--future {
  background-color: #fde9e1;
  border: 2px solid #c0392b;
  color: #c0392b;
}

.simulation-chart__card-label {
  display: inline-block;
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.25em;
  margin: 0 0 var(--space-xs);
  padding: 2px var(--space-sm);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.6);
}

.simulation-chart__card-data {
  display: grid;
  gap: var(--space-2xs);
  margin: 0;
}

.simulation-chart__card-data dt {
  font-size: var(--font-sm);
  margin-top: var(--space-2xs);
  font-weight: 600;
  opacity: 0.85;
}

.simulation-chart__card-data dd {
  margin: 0;
  font-weight: 900;
  line-height: 1;
}

.simulation-chart__num {
  font-size: var(--font-xl);
}
@media (768px <= width) {
  .simulation-chart__num {
    font-size: var(--font-xxl);
  }
}

.simulation-chart__num--sm {
  font-size: var(--font-lg);
}
@media (768px <= width) {
  .simulation-chart__num--sm {
    font-size: var(--font-xl);
  }
}

.simulation-chart__unit {
  font-size: var(--font-sm);
  margin-left: 2px;
  font-weight: 700;
}

.simulation-cta__btn {
  display: inline-block;
  padding: var(--space-sm) var(--space-md);
  background: var(--color-paid);
  color: var(--color-white);
  font-size: var(--font-md);
  font-weight: 800;
  border-radius: var(--radius-pill);
  letter-spacing: 0.05em;
  text-align: center;
  box-shadow: 0 6px 20px rgba(212, 130, 10, 0.3);
  transition: background-color 0.2s ease, transform 0.2s ease;
}
@media (max-width: 1023px) {
  .simulation-cta__btn {
    line-height: 1;
  }
}

.simulation-cta__btn:hover {
  background: #b87108;
  color: var(--color-white);
  transform: translateY(-2px);
  opacity: 1;
}

.simulation-cta__btn--hero {
  margin-top: var(--space-sm);
}

.simulation-cta__btn--full {
  display: block;
  inline-size: 100%;
  max-inline-size: 32rem;
  margin-inline: auto;
}

.simulation-cta__note {
  font-size: var(--font-sm);
  color: var(--color-gray2);
  margin-top: var(--space-xs);
  text-align: center;
}
@media (1024px <= width) {
  .simulation-cta__note {
    text-align: left;
  }
}

.simulation-cta {
  padding-block: var(--space-lg);
}

.simulation-cta__inner {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .simulation-cta__inner {
    padding-inline: 0;
  }
}
.simulation-cta__inner {
  text-align: center;
}

.simulation-cta__heading {
  font-size: var(--font-xl);
  font-weight: 800;
  margin: 0 0 var(--space-md);
  line-height: 1.5;
  text-wrap: balance;
}
@media (1024px <= width) {
  .simulation-cta__heading {
    font-size: var(--font-xxl);
  }
}
@media (max-width: 767px) {
  .simulation-cta__heading {
    font-size: clamp(1.1rem, 5.3vw, 1.25rem);
  }
}

.simulation-cta__body {
  font-size: var(--font-base);
  line-height: 1.9;
  margin: 0 0 var(--space-md);
}

.simulation-cta--mid {
  background-color: var(--color-white);
  border-top: 3px solid var(--color-main);
  border-bottom: 3px solid var(--color-main);
}

.simulation-cta--final {
  background: linear-gradient(135deg, #003d6b 0%, #005b9e 60%, #0077cc 100%);
  color: var(--color-white);
}

.simulation-cta--final .simulation-cta__heading {
  color: var(--color-white);
}

.simulation-empathy {
  padding-block: var(--space-lg);
  background-color: var(--color-white);
}

.simulation-empathy__list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-inline-size: 40rem;
  display: grid;
  gap: var(--space-xs);
}

.simulation-empathy__list li {
  background-color: var(--color-primary);
  padding: var(--space-sm);
  border-radius: var(--radius-sm);
  font-weight: 600;
  line-height: 1.6;
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.simulation-empathy__list li::before {
  content: "✕";
  flex-shrink: 0;
  color: #c0392b;
  font-weight: 800;
  font-size: var(--font-md);
}

.simulation-empathy__warning {
  margin-top: var(--space-md);
  text-align: center;
  font-size: var(--font-lg);
  font-weight: 800;
  color: #c0392b;
}

.simulation-essence {
  padding-block: var(--space-xl);
  background-color: #1a1a2e;
  color: var(--color-white);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.simulation-essence::before {
  content: "?";
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  font-family: serif;
  font-size: 18rem;
  font-weight: 900;
  color: rgba(255, 209, 128, 0.06);
  line-height: 1;
  pointer-events: none;
}

.simulation-essence::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(45deg, transparent, transparent 40px, rgba(255, 209, 128, 0.03) 40px, rgba(255, 209, 128, 0.03) 41px);
  pointer-events: none;
}

.simulation-essence > * {
  position: relative;
  z-index: 1;
}

.simulation-essence__body {
  font-size: var(--font-md);
  line-height: 2;
  margin: 0;
  font-weight: 600;
}
@media (768px <= width) {
  .simulation-essence__body {
    font-size: var(--font-xl);
  }
}

.simulation-solution {
  padding-block: var(--space-lg);
  background-color: var(--color-white);
}

.simulation-solution__flow {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
}
@media (768px <= width) {
  .simulation-solution__flow {
    flex-direction: row;
    justify-content: center;
    gap: var(--space-sm);
  }
}

.simulation-solution__step {
  background-color: var(--color-white);
  border: 2px solid var(--color-main);
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  text-align: center;
  min-inline-size: 14rem;
  box-shadow: var(--shadow-sm);
}

.simulation-solution__step-label {
  display: block;
  font-size: var(--font-sm);
  font-weight: 700;
  color: var(--color-main);
  letter-spacing: 0.1em;
  margin-bottom: var(--space-2xs);
}

.simulation-solution__step-text {
  font-size: var(--font-md);
  font-weight: 800;
  margin: 0;
}
@media (768px <= width) {
  .simulation-solution__step-text {
    font-size: var(--font-lg);
  }
}

.simulation-solution__arrow {
  width: 0;
  height: 0;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 18px solid var(--color-main);
}
@media (768px <= width) {
  .simulation-solution__arrow {
    border-left: 18px solid var(--color-main);
    border-right: none;
    border-top: 12px solid transparent;
    border-bottom: 12px solid transparent;
  }
}

.simulation-compare {
  padding-block: var(--space-xl);
  background: linear-gradient(135deg, var(--color-primary) 0%, #c5dce9 100%);
  position: relative;
  overflow: hidden;
}

.simulation-compare::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  inline-size: 80%;
  block-size: 60%;
  background: radial-gradient(ellipse, rgba(255, 255, 255, 0.4), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.simulation-compare > * {
  position: relative;
  z-index: 1;
}

.simulation-compare__grid {
  display: grid;
  gap: var(--space-md);
  align-items: stretch;
}
@media (768px <= width) {
  .simulation-compare__grid {
    grid-template-columns: 1fr auto 1fr;
    gap: var(--space-sm);
  }
}

.simulation-compare__vs {
  display: flex;
  align-items: center;
  justify-content: center;
}

.simulation-compare__vs-text {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 5rem;
  block-size: 5rem;
  background: linear-gradient(135deg, var(--color-paid), #b87108);
  color: var(--color-white);
  font-size: var(--font-xl);
  font-weight: 900;
  letter-spacing: 0.05em;
  border-radius: 50%;
  border: 4px solid var(--color-white);
  box-shadow: 0 12px 30px rgba(212, 130, 10, 0.4), 0 0 0 1px rgba(212, 130, 10, 0.2);
  position: relative;
}
@media (768px <= width) {
  .simulation-compare__vs-text {
    inline-size: 6rem;
    block-size: 6rem;
    font-size: var(--font-xxl);
  }
}

.simulation-compare__col {
  padding: var(--space-lg) var(--space-md);
  border-radius: var(--radius-md);
  text-align: center;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.1);
  position: relative;
  overflow: hidden;
}
@media (768px <= width) {
  .simulation-compare__col {
    padding: var(--space-xl) var(--space-md);
  }
}

.simulation-compare__col--bad {
  background: linear-gradient(180deg, #fde9e1 0%, #ffcfc3 100%);
  border: 2px solid #c0392b;
}

.simulation-compare__col--bad::before {
  content: "✕";
  position: absolute;
  top: -20px;
  right: -20px;
  font-size: 8rem;
  font-weight: 900;
  color: rgba(192, 57, 43, 0.08);
  line-height: 1;
}

.simulation-compare__col--good {
  background: linear-gradient(180deg, #e1ecf4 0%, #b8d4e6 100%);
  border: 2px solid var(--color-main);
}

.simulation-compare__col--good::before {
  content: "✓";
  position: absolute;
  top: -20px;
  right: -20px;
  font-size: 8rem;
  font-weight: 900;
  color: rgba(0, 91, 158, 0.08);
  line-height: 1;
}

.simulation-compare__col > * {
  position: relative;
  z-index: 1;
}

.simulation-compare__label {
  display: inline-block;
  padding: var(--space-2xs) var(--space-md);
  font-size: var(--font-md);
  font-weight: 800;
  letter-spacing: 0.2em;
  margin: 0 0 var(--space-md);
  background-color: var(--color-white);
  border-radius: var(--radius-pill);
}

.simulation-compare__col--bad .simulation-compare__label {
  color: #c0392b;
}

.simulation-compare__col--good .simulation-compare__label {
  color: var(--color-main);
}

.simulation-compare__data {
  margin: 0;
  display: grid;
  gap: var(--space-2xs);
}

.simulation-compare__data dt {
  font-size: var(--font-sm);
  margin-top: var(--space-xs);
}

.simulation-compare__data dd {
  margin: 0;
  font-weight: 800;
}

.simulation-compare__num {
  font-size: var(--font-xxl);
}
@media (768px <= width) {
  .simulation-compare__num {
    font-size: var(--font-xxxl);
  }
}

.simulation-compare__num--sm {
  font-size: var(--font-xl);
}
@media (768px <= width) {
  .simulation-compare__num--sm {
    font-size: var(--font-xxl);
  }
}

.simulation-compare__unit {
  font-size: var(--font-md);
  margin-left: 4px;
}

.simulation-compare__col--bad .simulation-compare__num,
.simulation-compare__col--bad .simulation-compare__unit {
  color: #c0392b;
}

.simulation-compare__col--good .simulation-compare__num,
.simulation-compare__col--good .simulation-compare__unit {
  color: var(--color-main);
}

.simulation-features {
  padding-block: var(--space-lg);
  background-color: var(--color-white);
}

.simulation-features__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--space-sm);
}
@media (768px <= width) {
  .simulation-features__list {
    grid-template-columns: repeat(3, 1fr);
  }
}

.simulation-features__item {
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  border-top: 4px solid var(--color-main);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.simulation-features__item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.simulation-features__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 4rem;
  block-size: 4rem;
  font-size: var(--font-xl);
  font-weight: 800;
  color: var(--color-white);
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  border-radius: 50%;
  line-height: 1;
  margin-bottom: var(--space-sm);
  box-shadow: var(--shadow-sm);
}

.simulation-features__title {
  font-size: var(--font-md);
  font-weight: 800;
  margin: 0;
  line-height: 1.4;
}

.simulation-features__note {
  font-size: var(--font-sm);
  color: var(--color-gray2);
  margin-top: var(--space-md);
  text-align: center;
}

.simulation-output {
  padding-block: var(--space-lg);
  background-color: var(--color-primary);
}

.simulation-output__list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-md);
  display: grid;
  gap: var(--space-xs);
}
@media (768px <= width) {
  .simulation-output__list {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-sm);
  }
}

.simulation-output__list li {
  background-color: var(--color-white);
  padding: var(--space-sm);
  text-align: center;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}

.simulation-output__item-title {
  font-weight: 800;
  margin: 0;
}

.simulation-output__image {
  display: grid;
}
.simulation-output__image .item {
  display: flex;
}
.simulation-output__image .item img {
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
  align-items: flex-end;
}
@media (max-width: 767px) {
  .simulation-output__image {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }
  .simulation-output__image .item {
    flex-direction: column;
    gap: var(--space-sm);
  }
  .simulation-output__image .item img {
    width: 100%;
  }
}

.simulation-price {
  padding-block: var(--space-lg);
  background-color: var(--color-primary);
}

.simulation-price__title {
  text-align: center;
  font-size: var(--font-lg);
  font-weight: 800;
  margin: var(--space-xs) 0 var(--space-lg);
  letter-spacing: 0.05em;
}
@media (768px <= width) {
  .simulation-price__title {
    font-size: var(--font-xl);
  }
}

.simulation-price__grid {
  display: grid;
  gap: var(--space-md);
  max-inline-size: 56rem;
  margin-inline: auto;
}
@media (768px <= width) {
  .simulation-price__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-sm);
  }
}

.simulation-price__plan {
  background-color: var(--color-white);
  padding: var(--space-lg) var(--space-md);
  border-radius: var(--radius-md);
  border: 1px solid #e8eef3;
  box-shadow: 0 8px 24px rgba(0, 91, 158, 0.06);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
@media (768px <= width) {
  .simulation-price__plan {
    padding: var(--space-lg);
  }
}

.simulation-price__plan:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 91, 158, 0.12);
}

.simulation-price__plan::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  inline-size: 100%;
  block-size: 3px;
  background: var(--color-main);
  border-top-left-radius: var(--radius-md);
  border-top-right-radius: var(--radius-md);
}

.simulation-price__plan:nth-child(2)::before {
  background: linear-gradient(90deg, var(--color-paid), #b87108);
}

.simulation-price__plan:nth-child(2) {
  border-color: var(--color-paid);
}

.simulation-price__plan-name {
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-sm);
  letter-spacing: 0.05em;
  padding-bottom: var(--space-xs);
  border-bottom: 1px dashed #d6eaf1;
}

.simulation-price__plan:nth-child(2) .simulation-price__plan-name {
  color: var(--color-paid);
}

.simulation-price__plan-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-md);
  font-size: var(--font-sm);
}

.simulation-price__plan-features li {
  position: relative;
  padding: var(--space-2xs) 0 var(--space-2xs) 1.5em;
  line-height: 1.7;
}

.simulation-price__plan-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: var(--space-2xs);
  color: var(--color-main);
  font-weight: 900;
}

.simulation-price__plan:nth-child(2) .simulation-price__plan-features li::before {
  color: var(--color-paid);
}

.simulation-price__plan-price {
  margin: 0;
  text-align: center;
  color: var(--color-gray2);
  padding-top: var(--space-xs);
  border-top: 1px solid #e8eef3;
}
.simulation-price__plan-price .simulation-price__plan-price-num {
  font-size: var(--font-xl);
  font-weight: 900;
  color: var(--color-main);
  letter-spacing: -0.02em;
  text-align: right;
}
.simulation-price__plan-price p {
  text-align: right;
}

.simulation-price__plan:nth-child(2) .simulation-price__plan-price span {
  color: var(--color-paid);
}

.service-issue {
  text-align: center;
  position: relative;
  background: linear-gradient(180deg, #fff8ef 0%, #ffeed2 100%);
  border-top: 4px solid #e07b00;
  padding-block: var(--space-xl) var(--space-lg);
  overflow: hidden;
}

.service-issue::before {
  content: "!";
  position: absolute;
  top: -1.5rem;
  left: 50%;
  transform: translateX(-50%);
  inline-size: 3.5rem;
  block-size: 3.5rem;
  background: linear-gradient(135deg, #e07b00, #c46a00);
  color: var(--color-white);
  border-radius: 50%;
  font-size: 1.8rem;
  font-weight: 900;
  font-family: serif;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(224, 123, 0, 0.35);
  z-index: 2;
}

.service-issue::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(224, 123, 0, 0.06) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
  z-index: 0;
}

.service-issue .l-inner {
  position: relative;
  z-index: 1;
}

.service-issue .c-service__eyebrow, .service-issue .c-service__none {
  color: #e07b00;
  font-weight: 800;
  letter-spacing: 0.3em;
}

.service-issue .c-service__heading {
  color: #6b3a00;
  font-size: var(--font-xxl);
  margin-bottom: var(--space-md);
}
@media (max-width: 767px) {
  .service-issue .c-service__heading {
    font-size: clamp(1.2rem, 5.9vw, 1.375rem);
  }
}
@media (768px <= width) {
  .service-issue .c-service__heading {
    font-size: var(--font-xxxl);
  }
}

.service-issue__body {
  font-size: var(--font-base);
  line-height: 2;
  margin: var(--space-sm) auto;
  max-inline-size: 50rem;
  padding: var(--space-md);
  background-color: var(--color-white);
  border-radius: var(--radius-sm);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
  text-align: left;
}
@media (768px <= width) {
  .service-issue__body {
    text-align: center;
  }
}
@media (max-width: 767px) {
  .service-issue__body {
    font-size: clamp(0.7rem, 3.5vw, 0.8125rem);
  }
}

.service-succession__types {
  display: block;
}
@media (768px <= width) {
  .service-succession__types {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
  }
}

.service-succession__type {
  margin-top: var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
  opacity: 0.85;
  transform: scale(0.75);
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.service-succession__type:nth-child(2) {
  opacity: 1;
  transform: scale(1.05);
  box-shadow: var(--shadow-md);
  border: 2px solid var(--color-primary);
}
.service-succession__type figure {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
}
.service-succession__type figure img {
  max-height: 250px;
  -o-object-fit: cover;
     object-fit: cover;
}
.service-succession__type dt {
  font-size: var(--font-md);
  color: var(--color-main);
  margin-block: var(--space-xs);
  text-align: center;
}

.service-succession__type--important {
  border: 3px solid #e07b00;
  opacity: 1;
  background-color: var(--color-white);
  box-shadow: 0 12px 25px rgba(224, 123, 0, 0.15), 0 0 0 4px rgba(224, 123, 0, 0.06);
}
@media (768px <= width) {
  .service-succession__type--important {
    transform: scale(1.05);
  }
}

.service-succession__type--important dt {
  color: #e07b00;
  font-size: var(--font-lg);
}

.service-succession__tag {
  margin-top: var(--space-xs);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
}
.service-succession__tag span {
  border-radius: var(--radius-pill);
  padding-block: var(--space-2xs);
  padding-inline: var(--space-xs);
  background-color: var(--color-primary);
  font-size: var(--font-sm);
  font-weight: 800;
  white-space: nowrap;
}

.flow-container {
  margin-top: var(--space-sm);
}

.flow-cta {
  margin-bottom: var(--space-sm);
}

.flow-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-sm);
  align-items: stretch;
  position: relative;
}
.flow-item:not(:last-child) .flow-left::after {
  content: "";
  position: absolute;
  left: 44px;
  top: 88px;
  bottom: 0px;
  width: 2px;
  background: linear-gradient(to bottom, var(--color-main), rgba(3, 110, 183, 0.2));
  transform: translateX(-50%);
}

.flow-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding-bottom: 40px;
}

.flow-circle {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.flow-circle--free {
  background: var(--color-main);
}
.flow-circle--paid {
  background: var(--color-paid);
}

.flow-num {
  font-size: var(--font-md);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
}

.flow-type {
  font-size: var(--font-sm);
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.05em;
}

.flow-right {
  padding: 0 0 40px;
}

.flow-right03 {
  padding-top: var(--space-md);
}

.flow-badge {
  display: inline-block;
  padding: 3px 14px;
  border-radius: 100px;
  font-weight: 700;
  margin-bottom: 12px;
}
.flow-badge.badge-free {
  background: #e8f7ee;
  color: #1a8a3c;
}
.flow-badge.badge-paid {
  background: #fef3e2;
  color: var(--color-paid);
}

.flow-title {
  font-weight: 700;
  font-size: var(--font-md);
  margin-bottom: var(--space-xs);
  padding-top: 4px;
}

.flow-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.flow-list li {
  line-height: 1.8;
  color: var(--color-base);
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 16px;
  background: var(--color-white);
  border: 1px solid #e8f0f6;
  border-radius: 4px;
}
.flow-list li::before {
  content: "›";
  color: var(--color-main);
  flex-shrink: 0;
  font-weight: 700;
  margin-top: 1px;
}

.deliverables-grid {
  display: grid;
  gap: var(--space-xs);
}
@media (768px <= width) {
  .deliverables-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.deliverable-card {
  background-color: var(--color-white);
  box-shadow: var(--shadow-sm);
}

.deliverable-card__img {
  width: 100%;
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
  align-items: flex-start;
  justify-content: flex-start;
}

.deliverable-card__num {
  font-size: 10px;
  letter-spacing: 0.3em;
  color: var(--color-main);
  margin-block: var(--space-xs);
  display: block;
}

.deliverable-card__title {
  font-weight: 700;
  line-height: 1.5;
}

.service-problem__flow {
  margin-inline: auto;
  inline-size: min(100%, var(--container-max));
  padding-inline: var(--space-md);
}
@media (1024px <= width) {
  .service-problem__flow {
    padding-inline: 0;
  }
}
.service-problem__flow {
  display: block;
  margin-top: var(--space-sm);
}
@media (768px <= width) {
  .service-problem__flow {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

.service-problem__items {
  width: 100%;
}
.service-problem__items li {
  background-color: var(--color-chart-border);
  padding: var(--space-xs);
  margin-bottom: var(--space-xs);
}
@media (768px <= width) {
  .service-problem__items {
    width: 40%;
  }
}

.service-problem__arrow {
  display: none;
}
@media (768px <= width) {
  .service-problem__arrow {
    background-color: var(--color-main);
    width: 50px;
    height: 50px;
    border-radius: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

.service-problem__resolve {
  width: 100%;
  background-color: var(--color-main);
  padding: var(--space-sm);
  justify-content: center;
  align-items: center;
}
@media (768px <= width) {
  .service-problem__resolve {
    width: 40%;
  }
}
.service-problem__resolve .service-problem__resolve-title {
  font-size: var(--font-md);
  color: var(--color-white);
  border-bottom: 1px solid var(--color-white);
  margin-bottom: var(--space-xs);
}
@media (max-width: 767px) {
  .service-problem__resolve .service-problem__resolve-title {
    font-size: clamp(0.875rem, 4.3vw, 1rem);
    white-space: nowrap;
  }
}
.service-problem__resolve .service-problem__resolve-list {
  color: var(--color-white);
}
@media (max-width: 767px) {
  .service-problem__resolve .service-problem__resolve-list {
    font-size: clamp(0.625rem, 3.2vw, 0.75rem);
  }
}

.deliverables-text {
  margin: 5% auto 0;
  width: 80%;
}
.deliverables-text p {
  text-align: left;
  font-size: var(--font-md);
}
@media (max-width: 767px) {
  .deliverables-text p {
    font-size: clamp(0.8rem, 3.7vw, 0.875rem);
  }
}

.service-report__box {
  margin-top: var(--space-sm);
  display: block;
}
@media (768px <= width) {
  .service-report__box {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
    gap: var(--space-sm);
  }
}
.service-report__box li {
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
}

.service-report__box3 {
  grid-column: 1/span 2;
  grid-row: 2/span 1;
}

.service-report__box-eyebrow {
  color: var(--color-main);
  font-size: var(--font-sm);
  letter-spacing: 0.5em;
}

.service-report__box-title {
  font-size: var(--font-md);
  margin-block: var(--space-xs);
  font-weight: 800;
}

.service-report__image {
  margin-top: var(--space-md);
  background-color: var(--color-primary);
}
.service-report__image ul {
  margin-top: var(--space-sm);
  display: block;
}
@media (768px <= width) {
  .service-report__image ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
  }
}

.service-report__image-eyebrow, .service-report__image-none {
  color: var(--color-main);
  letter-spacing: 0.5em;
}

.service-advice-list {
  margin-top: var(--space-sm);
}
.service-advice-list table {
  width: 100%;
  margin-bottom: var(--space-sm);
}
.service-advice-list table tr {
  display: flex;
  flex-direction: column;
}
.service-advice-list table th,
.service-advice-list table td {
  display: block;
  width: 100%;
  border: 1px solid var(--color-primary);
  padding: var(--space-sm);
}
.service-advice-list table th {
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 800;
  text-align: center;
  border-bottom: none;
}
.service-advice-list table td {
  background-color: var(--color-white);
}

.service-training-list {
  margin-top: var(--space-sm);
  display: block;
}
@media (768px <= width) {
  .service-training-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
  }
}
.service-training-list li {
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
}

.service-training__eyebrow, .service-training__none {
  color: var(--color-main);
  font-size: var(--font-sm);
  letter-spacing: 0.5em;
}

.service-training__title {
  font-size: var(--font-md);
  margin-block: var(--space-xs);
  font-weight: 800;
}

.service-training-note {
  padding: 0.5em 1em;
  margin-top: var(--space-sm);
  background: var(--color-white);
  border-left: solid 10px var(--color-main);
}

.service-cases__list {
  list-style: none;
  padding: 0;
  margin-top: var(--space-sm);
  display: block;
}
@media (768px <= width) {
  .service-cases__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
  }
}

.service-cases__list li {
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  border-left: 4px solid var(--color-main);
  padding: var(--space-sm);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-xs);
  line-height: 1.7;
  font-weight: 500;
}
@media (768px <= width) {
  .service-cases__list li {
    margin-bottom: 0;
  }
}

.chart-outer {
  overflow-x: auto;
  margin-top: var(--space-sm);
  -webkit-overflow-scrolling: touch;
}

.chart-layout {
  display: grid;
  grid-template-columns: 40% 60%;
  align-items: stretch;
  min-width: 720px;
}

.chart-left {
  display: grid;
  grid-template-columns: 52px 24px 52px 1fr;
  grid-template-rows: 1fr auto;
  gap: 0;
  padding-right: 8px;
}

.chart-vbox {
  writing-mode: vertical-rl;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: var(--color-main);
  background: var(--color-white);
  border: 2px solid var(--color-main);
  border-radius: 4px;
  letter-spacing: 0.2em;
  padding: 12px 4px;
}
.chart-vbox--jigyou {
  grid-column: 1;
  grid-row: 1/3;
}
.chart-vbox--koukeisha {
  grid-column: 3;
  grid-row: 1/3;
}

.chart-arrow-h {
  grid-column: 2;
  grid-row: 1/3;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2px;
}

.chart-arrow-h__line {
  width: 100%;
  height: 4px;
  background: var(--color-main);
  position: relative;
}
.chart-arrow-h__line::after {
  content: "";
  position: absolute;
  right: -9px;
  top: 50%;
  transform: translateY(-50%);
  border-left: 11px solid var(--color-main);
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
}

.chart-dest-wrap {
  grid-column: 4;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0 0 4px 4px;
}

.chart-dest-row {
  display: flex;
  align-items: center;
  flex: 1;
}

.chart-arrow-sm {
  width: 28px;
  height: 4px;
  background: var(--color-main);
  flex-shrink: 0;
  position: relative;
  margin-right: 9px;
}
.chart-arrow-sm::after {
  content: "";
  position: absolute;
  right: -9px;
  top: 50%;
  transform: translateY(-50%);
  border-left: 10px solid var(--color-main);
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
}

.chart-dest {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 150px;
  padding: 8px 6px;
  border: 2px solid var(--color-main);
  border-radius: 4px;
  background: var(--color-white);
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
}

.chart-haigyo-left {
  grid-column: 4;
  grid-row: 2;
  padding: 6px 0 0 4px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.chart-haigyo-arrow-row {
  display: flex;
  align-items: center;
}

.chart-haigyo-arrow {
  flex: 1;
  height: 3px;
  position: relative;
  margin-right: 9px;
}
.chart-haigyo-arrow::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(90deg, var(--color-chart-line) 0, var(--color-chart-line) 7px, transparent 7px, transparent 13px);
}
.chart-haigyo-arrow::after {
  content: "";
  position: absolute;
  right: -9px;
  top: 50%;
  transform: translateY(-50%);
  border-left: 9px solid var(--color-chart-line);
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
}

.chart-haigyo-label {
  color: #aaa;
  padding-left: 2px;
}

.chart-right {
  display: grid;
  grid-template-columns: 1fr 28px 80px;
  grid-template-rows: 1fr auto;
  gap: 0;
  padding-left: 8px;
}

.chart-merit-wrap {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.chart-merit-block {
  display: grid;
  grid-template-columns: 24px 1fr;
  border: 1px solid var(--color-chart-border);
  border-radius: 4px;
  overflow: hidden;
  background: var(--color-white);
  flex: 1;
}

.chart-row-label {
  writing-mode: vertical-rl;
  font-weight: 700;
  color: var(--color-white);
  background: var(--color-main);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 3px;
  letter-spacing: 0.08em;
}

.chart-row-label2 {
  writing-mode: vertical-rl;
  font-weight: 700;
  color: var(--color-main);
  background: var(--color-white);
  border: 2px solid var(--color-main);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 3px;
  letter-spacing: 0.08em;
}

.chart-merit-table {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 10px;
}

.chart-merit-col {
  padding: 15px 10px;
  line-height: 1.5;
}
.chart-merit-col:first-child {
  border-right: 1px solid #e0ecf4;
}

.chart-merit-col__head {
  font-weight: 700;
  padding-bottom: 6px;
  margin-bottom: 6px;
  border-bottom: 1px solid #e0ecf4;
}
.chart-merit-col__head--merit {
  color: var(--color-main);
}
.chart-merit-col__head--demerit {
  color: var(--color-demerit);
}

.chart-merit-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.chart-merit-col li {
  padding-left: 12px;
  position: relative;
  color: var(--color-chart-text);
}
.chart-merit-col li::before {
  content: "●";
  position: absolute;
  left: 0;
  font-size: 6px;
  top: 6px;
}

.chart-merit-col--merit li::before {
  color: var(--color-main);
}

.chart-merit-col--demerit li::before {
  color: var(--color-demerit);
}

.chart-support {
  grid-column: 2;
  grid-row: 1;
  writing-mode: vertical-rl;
  background: linear-gradient(to bottom, var(--color-main), #1a4a7a);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: 0.2em;
  border: 2px solid #e07b00;
  border-radius: 0 6px 6px 0;
  margin-left: 6px;
  padding-block: var(--space-xs);
  align-self: start;
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.25);
}

.chart-haigyo-right {
  grid-column: 3;
  grid-row: 1/3;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 0 8px 8px;
}
.chart-haigyo-right__spacer {
  flex: 1;
}

.chart-haigyo-box {
  width: 100%;
  border: 1px solid var(--color-chart-border);
  border-radius: 4px;
  background: var(--color-white);
  padding: 8px 4px;
  text-align: center;
}

.chart-haigyo-box__label {
  writing-mode: vertical-rl;
  color: #888;
  letter-spacing: 0.1em;
  margin: 0 auto;
}

#chart-block-1,
#chart-block-2 {
  border: 2px solid var(--color-main);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  background-color: #eef5fb;
}

@media (max-width: 767px) {
  .chart-haigyo-right {
    display: none;
  }
}
.c-section-heading {
  margin-bottom: var(--space-md);
  text-align: center;
}
@media (768px <= width) {
  .c-section-heading {
    text-align: left;
  }
}
.c-section-heading span {
  display: block;
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.4em;
  color: var(--color-gray2);
  margin-bottom: var(--space-2xs);
}
@media (768px <= width) {
  .c-section-heading span {
    letter-spacing: 0.5em;
  }
}
.c-section-heading h3 {
  letter-spacing: 0.12em;
  color: var(--color-main);
  font-size: var(--font-xl);
  font-weight: 800;
  margin: 0;
}
@media (768px <= width) {
  .c-section-heading h3 {
    font-size: var(--font-xxl);
  }
}
.c-section-heading .c-section-heading__line {
  margin-top: var(--space-xs);
  inline-size: 60px;
  block-size: 3px;
  background: linear-gradient(90deg, var(--color-main), #4a90c8);
  border-radius: var(--radius-pill);
  margin-inline: auto;
}
@media (768px <= width) {
  .c-section-heading .c-section-heading__line {
    margin-inline: 0;
  }
}

@media (1024px <= width) {
  .page-section .c-flex__body {
    padding-left: var(--space-md);
    border-left: 1px solid var(--color-primary);
  }
}

.page-section .c-text__title {
  font-size: var(--font-lg);
  color: var(--color-main);
  position: relative;
  padding-bottom: var(--space-xs);
  margin-bottom: var(--space-sm);
}
@media (768px <= width) {
  .page-section .c-text__title {
    font-size: var(--font-xl);
  }
}
@media (max-width: 767px) {
  .page-section .c-text__title {
    font-size: clamp(1rem, 4.8vw, 1.2rem);
  }
}

.page-section .c-text__title:not(.u-text-right)::after {
  content: "";
  display: block;
  inline-size: 48px;
  block-size: 2px;
  background: var(--color-main);
  margin-top: var(--space-xs);
}

.page-section .c-text__title.u-text-right {
  font-size: var(--font-md);
  font-weight: 700;
  color: var(--color-base);
  letter-spacing: 0.15em;
  margin-top: var(--space-md);
}

.page-section .c-table {
  background-color: var(--color-white);
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.06);
  border-radius: var(--radius-sm);
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
}
.page-section .c-table th,
.page-section .c-table td {
  border: none;
  border-bottom: 1px solid var(--color-primary);
  padding: var(--space-sm) var(--space-md);
  line-height: 1.7;
}
.page-section .c-table tr:last-child th,
.page-section .c-table tr:last-child td {
  border-bottom: none;
}
.page-section .c-table th {
  background-color: #f4f9fc;
  color: var(--color-main);
  font-weight: 700;
  text-align: left;
  inline-size: 30%;
  letter-spacing: 0.05em;
}
@media (max-width: 767px) {
  .page-section .c-table {
    border: 1px solid var(--color-primary);
  }
  .page-section .c-table th,
  .page-section .c-table td {
    display: block;
    inline-size: 100%;
  }
  .page-section .c-table th {
    border-bottom: 1px solid var(--color-primary);
    padding-block: var(--space-xs);
  }
}

.company-summary {
  margin-top: var(--space-lg);
  padding: var(--space-lg) var(--space-md);
  background: linear-gradient(135deg, #f4f9fc 0%, var(--color-white) 60%, #f4f9fc 100%);
  border-radius: var(--radius-md);
  position: relative;
  box-shadow: 0 12px 30px rgba(0, 91, 158, 0.08);
  overflow: hidden;
}
@media (768px <= width) {
  .company-summary {
    padding: var(--space-xl) var(--space-lg);
  }
}

.company-summary::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  inline-size: 100%;
  block-size: 4px;
  background: linear-gradient(90deg, var(--color-main), #4a90c8, var(--color-main));
}

.company-summary__title {
  text-align: center;
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-md);
  position: relative;
}
@media (768px <= width) {
  .company-summary__title {
    font-size: var(--font-xl);
    margin-bottom: var(--space-lg);
  }
}

.company-summary__title-en {
  display: block;
  font-size: var(--font-sm);
  font-weight: 700;
  letter-spacing: 0.4em;
  color: var(--color-gray2);
  margin-bottom: var(--space-2xs);
}

.company-summary__stats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--space-md);
}
@media (768px <= width) {
  .company-summary__stats {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-sm);
  }
}

.company-summary__stat {
  text-align: center;
  padding: var(--space-md) var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  position: relative;
}

.company-summary__stat::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  inline-size: 40%;
  block-size: 3px;
  border-radius: var(--radius-pill);
}

.company-summary__stat-num {
  display: inline-block;
  font-size: var(--font-xxxl);
  font-weight: 900;
  line-height: 1;
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  margin-bottom: var(--space-xs);
  letter-spacing: -0.02em;
}
@media (768px <= width) {
  .company-summary__stat-num {
    font-size: clamp(2.5rem, 5vw + 1rem, 4.5rem);
  }
}

.company-summary__stat-num--text {
  font-size: var(--font-xxl);
}
@media (768px <= width) {
  .company-summary__stat-num--text {
    font-size: var(--font-xxxl);
  }
}
@media (max-width: 767px) {
  .company-summary__stat-num--text {
    font-size: clamp(1.3rem, 6vw, 1.75rem);
  }
}

.company-summary__stat-unit {
  font-size: var(--font-md);
  font-weight: 700;
  margin-left: 0.1em;
  letter-spacing: 0;
}
@media (768px <= width) {
  .company-summary__stat-unit {
    font-size: var(--font-lg);
  }
}

.company-summary__stat-label {
  font-size: var(--font-sm);
  font-weight: 700;
  line-height: 1.6;
  color: var(--color-base);
  margin: 0;
}
@media (768px <= width) {
  .company-summary__stat-label {
    font-size: var(--font-base);
  }
}

.company-timeline {
  padding-left: var(--space-md);
}

.company-timeline__item {
  padding: var(--space-sm);
  position: relative;
  border-left: 4px solid var(--color-main);
}
.company-timeline__item .company-timeline__text {
  font-weight: 800;
  color: var(--color-main);
}
.company-timeline__item .company-timeline__text::after {
  content: "";
  display: block;
  position: absolute;
  top: 2em;
  left: -13px;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-pill);
  border: 3px solid var(--color-main);
  background: white;
}
.company-timeline__item .company-timeline__title {
  font-size: var(--font-md);
  font-weight: 800;
}
@media (max-width: 767px) {
  .company-timeline__item .company-timeline__title {
    font-size: clamp(0.75rem, 3.7vw, 0.875rem);
  }
}

.company-timeline__list li {
  position: relative;
  padding-left: var(--space-md);
  margin-top: 5px;
}
@media (1024px <= width) {
  .company-timeline__list li {
    padding-left: var(--space-sm);
  }
}
.company-timeline__list li::before {
  content: "";
  position: absolute;
  top: 0.6em;
  left: 1em;
  width: 10px;
  height: 10px;
  background-color: var(--color-main);
  transform: rotate(45deg);
}

.company-map__embed {
  position: relative;
  inline-size: 100%;
  padding-top: 56.25%;
  height: 0;
}
.company-map__embed iframe {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
}

.company-map__info {
  inline-size: 100%;
  background-color: var(--color-main);
  padding: var(--space-sm);
  color: var(--color-white);
}
@media (1024px <= width) {
  .company-map__info {
    inline-size: 35%;
  }
}
.company-map__info .company-map__title {
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--color-white);
  border-bottom: 2px solid var(--color-white);
  margin-bottom: var(--space-sm);
  text-align: center;
}
.company-map__info .company-map__list li {
  margin-bottom: var(--space-2xs);
  text-indent: -2em;
  padding-left: 2em;
}
@media (max-width: 767px) {
  .company-map__info .company-map__list li {
    font-size: clamp(0.75rem, 3.5vw, 0.875rem);
  }
}
.company-map__info .company-map__list li svg {
  width: 1.5em;
  height: 1.5em;
  margin-right: var(--space-2xs);
}

.page-news {
  background-color: #fafbfc;
}

.page-news__intro {
  margin-bottom: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background-color: var(--color-white);
  border-left: 4px solid var(--color-main);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  box-shadow: 0 2px 8px rgba(0, 91, 158, 0.04);
}

.page-news__intro-label {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-2xs);
  letter-spacing: 0.05em;
}

.page-news__intro-badge {
  display: inline-block;
  padding: 2px var(--space-xs);
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  color: var(--color-white);
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.1em;
  border-radius: var(--radius-pill);
}

.page-news__intro-text {
  font-size: var(--font-sm);
  color: var(--color-gray2);
  margin: 0;
  line-height: 1.7;
}

.news-filter {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
  padding: var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-primary);
}

.news-filter__label {
  font-size: var(--font-sm);
  font-weight: 800;
  color: var(--color-main);
  margin: 0;
  letter-spacing: 0.1em;
  flex-shrink: 0;
}

.news-filter__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
}

.news-filter__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  padding: var(--space-2xs) var(--space-sm);
  background-color: #f4f9fc;
  color: var(--color-base);
  font-size: var(--font-sm);
  font-weight: 700;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.news-filter__btn:hover {
  background-color: var(--color-primary);
  color: var(--color-main);
}

.news-filter__btn.is-active {
  background-color: var(--color-main);
  color: var(--color-white);
}

.news-filter__count {
  display: inline-block;
  padding: 0 6px;
  border-radius: var(--radius-pill);
  font-size: var(--font-sm);
  font-weight: 700;
  line-height: 1.6;
  min-inline-size: 1.4em;
  text-align: center;
  background-color: var(--color-white);
  color: var(--color-main);
  border: 1px solid var(--color-primary);
}

.news-filter__btn.is-active .news-filter__count {
  background-color: rgba(255, 255, 255, 0.25);
  color: var(--color-white);
  border-color: transparent;
}

.news-archive__empty {
  padding: var(--space-xl) var(--space-md);
  text-align: center;
  background-color: var(--color-white);
  border-radius: var(--radius-sm);
  border: 1px dashed var(--color-primary);
  color: var(--color-gray2);
  margin-block: var(--space-md);
}

.news-important {
  background: linear-gradient(135deg, #fff8ef 0%, #ffeed2 100%);
  border: 2px solid #e07b00;
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  box-shadow: 0 6px 20px rgba(224, 123, 0, 0.12);
  position: relative;
}
@media (768px <= width) {
  .news-important {
    flex-direction: row;
    align-items: center;
    gap: var(--space-md);
  }
}

.news-important__label-wrap {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  flex-shrink: 0;
}

.news-important__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 1.5rem;
  block-size: 1.5rem;
  color: #e07b00;
}

.news-important__icon svg {
  inline-size: 100%;
  block-size: 100%;
}

.news-important__label {
  display: inline-block;
  padding: var(--space-2xs) var(--space-sm);
  background: linear-gradient(135deg, #e07b00, #c46a00);
  color: var(--color-white);
  font-size: var(--font-sm);
  font-weight: 800;
  border-radius: var(--radius-pill);
  letter-spacing: 0.15em;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(224, 123, 0, 0.3);
}

.news-important__link {
  display: block;
  font-weight: 600;
  line-height: 1.6;
}
@media (768px <= width) {
  .news-important__link {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
  }
}

.news-important__date {
  color: #e07b00;
  font-size: var(--font-sm);
  font-weight: 700;
}

.news-important__title {
  display: block;
}
@media (768px <= width) {
  .news-important__title {
    display: inline;
  }
}

.news-archive__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.news-archive__item {
  border-bottom: 1px solid var(--color-primary);
  transition: background-color 0.2s ease;
}

.news-archive__item:first-child {
  border-top: 1px solid var(--color-primary);
}

.news-archive__item:hover {
  background-color: var(--color-primary);
}

.news-archive__link {
  display: block;
  position: relative;
  padding: var(--space-sm) var(--space-md) var(--space-sm) var(--space-sm);
}
@media (768px <= width) {
  .news-archive__link {
    display: grid;
    grid-template-columns: 8rem 7rem 1fr;
    gap: var(--space-sm);
    align-items: center;
  }
}

.news-archive__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 8px;
  height: 8px;
  color: var(--color-main);
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

.news-archive__date {
  display: inline-block;
  margin-right: var(--space-sm);
  color: var(--color-gray2);
  font-size: var(--font-sm);
  font-weight: 600;
}
@media (768px <= width) {
  .news-archive__date {
    margin-right: 0;
  }
}

.news-archive__cat {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 800;
  border-radius: var(--radius-sm);
  text-align: center;
  letter-spacing: 0.1em;
  min-inline-size: 5.5rem;
  line-height: 1.4;
  min-width: 130px;
}
@media (768px <= width) {
  .news-archive__cat {
    justify-self: start;
  }
}

.news-archive__cat--info {
  background-color: #e1ecf4;
  color: var(--color-main);
}

.news-archive__cat--service {
  background-color: #e9f5ec;
  color: #2c7a3e;
}

.news-archive__cat--company {
  background-color: #d8d8d8;
  color: #565656;
}

.news-archive__cat--maintenance {
  background-color: #fef3e0;
  color: #b86f08;
}

.news-archive__cat--important {
  background-color: #fce4e4;
  color: #a73224;
}

.news-archive__title {
  display: block;
  margin-top: var(--space-2xs);
  font-weight: 600;
  line-height: 1.6;
}
@media (768px <= width) {
  .news-archive__title {
    margin-top: 0;
  }
}

.news-single__meta {
  display: flex;
}
.news-single__meta .news-single__date {
  font-size: var(--font-md);
  color: var(--color-gray);
  margin-right: var(--space-sm);
}
.news-single__meta .news-single__cat a {
  border: 1px solid var(--color-main);
  padding-block: var(--space-2xs);
  padding-inline: var(--space-xs);
}

.news-single__title {
  padding-block: var(--space-xs);
  border-bottom: 3px dashed var(--color-main);
  font-size: var(--font-md);
  font-weight: 800;
  margin-bottom: var(--space-md);
}
@media (1024px <= width) {
  .news-single__title {
    font-size: var(--font-lg);
    margin-bottom: var(--space-sm);
  }
}

.news-single__nav {
  inline-size: 100%;
  margin-top: var(--space-md);
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
}
@media (768px <= width) {
  .news-single__nav {
    inline-size: 30%;
  }
}

.topic-archive__layout {
  display: block;
}
@media (768px <= width) {
  .topic-archive__layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--space-md);
    align-items: start;
  }
}

.topic-archive__sidebar {
  display: none;
}
@media (768px <= width) {
  .topic-archive__sidebar {
    display: block;
  }
}

.topic-archive__item {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
  margin-block: var(--space-sm);
  transition: box-shadow 0.3s ease;
}
.topic-archive__item:hover {
  box-shadow: var(--shadow-md);
}
@media (768px <= width) {
  .topic-archive__item {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--space-md);
    padding: var(--space-sm);
    align-items: start;
  }
}

.topic-archive__link {
  display: block;
}
@media (768px <= width) {
  .topic-archive__link {
    display: contents;
  }
}

.topic-archive__thumb {
  margin: 0;
  inline-size: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background-color: var(--color-primary);
}
.topic-archive__thumb img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topic-archive__noimage {
  -o-object-fit: contain !important;
     object-fit: contain !important;
  padding: 20%;
  opacity: 0.4;
}

.topic-archive__body {
  margin-top: var(--space-sm);
}
@media (768px <= width) {
  .topic-archive__body {
    margin-top: 0;
  }
}

.topic-archive__title {
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-xs);
  font-size: var(--font-md);
  line-height: 1.5;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.topic-archive__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2xs) var(--space-xs);
  margin-bottom: var(--space-xs);
}

.topic-archive__date {
  color: var(--color-gray2);
  font-size: var(--font-sm);
}

.topic-archive__excerpt {
  font-size: var(--font-sm);
  line-height: 1.8;
  margin: 0;
  display: -webkit-box;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.topic-archive__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: var(--space-2xs);
  list-style: none;
  padding: 0;
  margin: 0;
}

.topic-archive__tags li span,
.topic-archive__tags li a {
  display: inline-block;
  padding: 2px var(--space-xs);
  background-color: var(--color-primary);
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 600;
  border-radius: var(--radius-pill);
  line-height: 1.5;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.topic-archive__tags li a:hover {
  background-color: var(--color-main);
  color: var(--color-white);
}

.topic-archive__tags--sidebar {
  margin-top: var(--space-xs);
}

.topic-sidebar__title {
  display: flex;
  align-items: center;
  padding: var(--space-xs);
  font-size: var(--font-md);
  font-weight: bold;
  background-color: var(--color-primary);
  margin-top: var(--space-sm);
  margin-bottom: var(--space-xs);
}
.topic-sidebar__title::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 1.5em;
  margin-right: 0.5em;
  background-color: var(--color-main);
}

.topic-sidebar__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.topic-sidebar__list a {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--space-xs);
  align-items: center;
  padding: var(--space-xs);
  font-weight: 600;
  font-size: var(--font-sm);
  border-bottom: 1px solid var(--color-primary);
  transition: background-color 0.2s ease;
}

.topic-sidebar__list a:hover {
  background-color: var(--color-primary);
}

.topic-sidebar__thumb {
  margin: 0;
  inline-size: 60px;
  block-size: 60px;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background-color: var(--color-primary);
}

.topic-sidebar__thumb img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topic-sidebar__item-title {
  line-height: 1.5;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.topic-themes {
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  border-left: 4px solid var(--color-main);
  padding: var(--space-sm);
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-sm);
}

.topic-themes__title {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-xs);
}

.topic-themes__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
  list-style: none;
  padding: 0;
  margin: 0;
}

.topic-themes__list a {
  display: inline-block;
  padding: var(--space-2xs) var(--space-sm);
  background-color: var(--color-primary);
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 600;
  border-radius: var(--radius-pill);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.topic-themes__list a:hover {
  background-color: var(--color-main);
  color: var(--color-white);
}

.topic-sidebar__archive li {
  margin-block: var(--space-xs);
  padding-bottom: var(--space-2xs);
  border-bottom: 1px solid var(--color-gray);
}
.topic-sidebar__archive li::before {
  content: "▶";
  display: inline-block;
  color: var(--color-main);
  margin-inline: 0.5em;
  font-size: var(--font-sm);
}

.sitemap__grid {
  display: grid;
  gap: var(--space-md);
}
@media (768px <= width) {
  .sitemap__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg) var(--space-md);
  }
}

.sitemap__group {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.06);
  border-top: 4px solid var(--color-main);
}

.sitemap__group-title {
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 1px dashed var(--color-primary);
  letter-spacing: 0.05em;
}

.sitemap__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sitemap__list > li > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 1px solid var(--color-primary);
  transition: background-color 0.2s ease, padding-left 0.2s ease;
}

.sitemap__list > li > a::after {
  content: "›";
  color: var(--color-main);
  font-weight: 800;
  font-size: var(--font-md);
  transition: transform 0.2s ease;
}

.sitemap__list > li > a:hover {
  background-color: var(--color-primary);
  padding-left: calc(var(--space-sm) + 8px);
}

.sitemap__list > li > a:hover::after {
  transform: translateX(4px);
}

.sitemap__list-parent > a {
  font-weight: 800;
  color: var(--color-main);
}

@media (768px <= width) {
  .sitemap__group--service {
    grid-column: 1/-1;
  }
}

.sitemap__parent-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  background-color: var(--color-primary);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-sm);
  transition: background-color 0.2s ease, padding-left 0.2s ease;
}

.sitemap__parent-link::after {
  content: "›";
  color: var(--color-main);
  font-weight: 800;
  font-size: var(--font-lg);
  transition: transform 0.2s ease;
}

.sitemap__parent-link:hover {
  background-color: var(--color-main);
  color: var(--color-white);
}

.sitemap__parent-link:hover::after {
  color: var(--color-white);
  transform: translateX(4px);
}

.sitemap__parent-label {
  font-weight: 800;
  font-size: var(--font-md);
  letter-spacing: 0.05em;
}

.sitemap__parent-note {
  font-size: var(--font-sm);
  margin-left: auto;
  margin-right: var(--space-sm);
  opacity: 0.8;
  display: none;
}
@media (768px <= width) {
  .sitemap__parent-note {
    display: inline;
  }
}

.sitemap__service-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--space-sm);
}
@media (768px <= width) {
  .sitemap__service-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

.sitemap__service-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
  padding: var(--space-md);
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-sm);
  position: relative;
  box-shadow: 0 2px 8px rgba(0, 91, 158, 0.04);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
  min-block-size: 100%;
}

.sitemap__service-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(0, 91, 158, 0.12);
  border-color: var(--color-main);
}

.sitemap__service-card::after {
  content: "詳しく見る ›";
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 700;
  margin-top: auto;
  padding-top: var(--space-xs);
  border-top: 1px dashed var(--color-primary);
  transition: color 0.2s ease;
}

.sitemap__service-card:hover::after {
  color: var(--color-paid);
}

.sitemap__service-badge {
  display: inline-block;
  align-self: flex-start;
  padding: 2px var(--space-xs);
  background: linear-gradient(135deg, var(--color-paid), #b87108);
  color: var(--color-white);
  font-size: var(--font-sm);
  font-weight: 800;
  letter-spacing: 0.05em;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-2xs);
}

.sitemap__service-name {
  font-weight: 800;
  font-size: var(--font-md);
  color: var(--color-main);
  line-height: 1.4;
}
@media (max-width: 767px) {
  .sitemap__service-name {
    white-space: nowrap;
    font-size: clamp(0.75rem, 4vw, 1rem);
  }
}

.sitemap__service-desc {
  font-size: var(--font-sm);
  color: var(--color-gray2);
  line-height: 1.6;
}

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

.page-legal__inner {
  padding-block: 0;
  background-color: transparent;
  border-radius: 0;
  box-shadow: none;
}

.page-legal__toc {
  background-color: #f4f9fc;
  border-left: 4px solid var(--color-main);
  padding: var(--space-md) var(--space-md);
  margin-bottom: var(--space-lg);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.page-legal__toc-title {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-xs);
  letter-spacing: 0.1em;
}

.page-legal__toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc;
}

.page-legal__toc-list li {
  counter-increment: toc;
  padding: 4px 0;
}
@media (max-width: 767px) {
  .page-legal__toc-list li {
    font-size: clamp(0.75rem, 3.4vw, 0.875rem);
  }
}

.page-legal__toc-list li::before {
  content: counter(toc, decimal-leading-zero);
  display: inline-block;
  margin-right: 0.6em;
  font-weight: 800;
  color: var(--color-main);
  font-size: var(--font-sm);
}

.page-legal__toc-list a {
  color: var(--color-base);
  font-weight: 500;
  transition: color 0.2s ease;
}

.page-legal__toc-list a:hover {
  color: var(--color-main);
}

.page-legal__content {
  line-height: 2;
}

.page-legal__content h2 {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: var(--space-lg) 0 var(--space-sm);
  padding: var(--space-xs) 0 var(--space-xs) var(--space-sm);
  border-left: 5px solid var(--color-main);
  background-color: transparent;
  scroll-margin-top: calc(var(--header-height) + 1rem);
}
@media (768px <= width) {
  .page-legal__content h2 {
    font-size: var(--font-xl);
  }
}

.page-legal__content h3 {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-base);
  margin: var(--space-md) 0 var(--space-xs);
  padding-bottom: var(--space-2xs);
  border-bottom: 1px dashed var(--color-primary);
}

.page-legal__content p {
  line-height: 1.95;
  margin: 0 0 var(--space-sm);
}

.page-legal__content ul,
.page-legal__content ol {
  padding-left: 1.5em;
  margin: 0 0 var(--space-sm);
}

.page-legal__content li {
  padding: 4px 0;
  line-height: 1.8;
}

.page-legal__content--table table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background-color: var(--color-white);
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.06);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-block: var(--space-md);
}

.page-legal__content--table th,
.page-legal__content--table td {
  border: none;
  border-bottom: 1px solid var(--color-primary);
  padding: var(--space-sm) var(--space-md);
  line-height: 1.9;
  vertical-align: top;
}

.page-legal__content--table tr:last-child th,
.page-legal__content--table tr:last-child td {
  border-bottom: none;
}

.page-legal__content--table th {
  background-color: #f4f9fc;
  color: var(--color-main);
  font-weight: 700;
  text-align: left;
  inline-size: 28%;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .page-legal__content--table table {
    box-shadow: none;
  }
  .page-legal__content--table th,
  .page-legal__content--table td {
    display: block;
    inline-size: 100%;
  }
  .page-legal__content--table th {
    padding-block: var(--space-xs);
    white-space: normal;
  }
}
.page-legal__content strong strong {
  font-weight: inherit;
}

.page-legal__intro {
  font-size: var(--font-base);
  line-height: 1.95;
  color: var(--color-gray2);
  text-align: center;
  margin: 0 0 var(--space-md);
  padding-block: var(--space-sm);
  border-block: 1px solid var(--color-primary);
}

.page-legal__contact-box {
  margin-top: var(--space-xl);
  padding: var(--space-md);
  background-color: #f4f9fc;
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-sm);
}
@media (768px <= width) {
  .page-legal__contact-box {
    padding: var(--space-lg);
  }
}

.page-legal__contact-title {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 1px dashed var(--color-primary);
}

.page-legal__contact-info {
  margin: 0;
  display: grid;
  gap: var(--space-2xs);
  font-size: var(--font-base);
}
@media (768px <= width) {
  .page-legal__contact-info {
    grid-template-columns: 8rem 1fr;
    gap: var(--space-xs) var(--space-md);
  }
}

.page-legal__contact-info dt {
  font-weight: 700;
  color: var(--color-main);
}

.page-legal__contact-info dd {
  margin: 0;
  line-height: 1.8;
}

.page-legal__contact-info a {
  color: var(--color-main);
  text-decoration: underline;
}

.page-legal__dates {
  margin-top: var(--space-md);
  text-align: right;
  font-size: var(--font-sm);
  color: var(--color-gray2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
@media (768px <= width) {
  .page-legal__dates {
    flex-direction: row;
    justify-content: flex-end;
    gap: var(--space-md);
  }
}

.page-contact__inner {
  display: grid;
  gap: var(--space-md);
}
@media (1024px <= width) {
  .page-contact__inner {
    grid-template-columns: 1fr 320px;
    gap: var(--space-lg);
  }
}

.page-contact__guide {
  background-color: #f4f9fc;
  border-left: 4px solid var(--color-main);
  padding: var(--space-md);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  grid-column: 1/-1;
}

.page-contact__guide-title {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-sm);
  letter-spacing: 0.05em;
}

.page-contact__guide-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-sm);
  display: grid;
  gap: var(--space-2xs);
}
@media (768px <= width) {
  .page-contact__guide-list {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-xs) var(--space-md);
  }
}

.page-contact__guide-list li {
  position: relative;
  padding-left: 1.5em;
  line-height: 1.7;
}

.page-contact__guide-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-main);
  font-weight: 800;
}

.page-contact__guide-note {
  font-size: var(--font-sm);
  color: var(--color-gray2);
  line-height: 1.8;
  margin: var(--space-xs) 0 0;
  padding-top: var(--space-xs);
  border-top: 1px dashed var(--color-primary);
}

.page-contact__tel {
  grid-column: 1/-1;
  background-color: var(--color-white);
  border: 2px solid var(--color-main);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-md);
  text-align: center;
  position: relative;
  box-shadow: 0 12px 32px rgba(0, 91, 158, 0.08);
  overflow: hidden;
}
@media (1024px <= width) {
  .page-contact__tel {
    grid-column: 2/3;
    grid-row: 2/3;
    align-self: start;
    padding: var(--space-lg) var(--space-sm);
  }
}

.page-contact__tel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  inline-size: 80px;
  block-size: 80px;
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  border-radius: 0 0 100% 0;
  opacity: 0.08;
  pointer-events: none;
}

.page-contact__tel::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  inline-size: 80px;
  block-size: 80px;
  background: linear-gradient(315deg, var(--color-paid), #b87108);
  border-radius: 100% 0 0 0;
  opacity: 0.08;
  pointer-events: none;
}

.page-contact__tel-head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
  position: relative;
  z-index: 1;
}

.page-contact__tel-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 2.5rem;
  block-size: 2.5rem;
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  border-radius: 50%;
  color: var(--color-white);
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0, 91, 158, 0.25);
}

.page-contact__tel-icon svg {
  inline-size: 1.2rem;
  block-size: 1.2rem;
}

.page-contact__tel-label {
  font-size: var(--font-sm);
  font-weight: 700;
  color: var(--color-base);
  margin: 0;
  text-align: left;
  line-height: 1.5;
}

.page-contact__tel-num {
  display: inline-block;
  margin: 0 auto var(--space-xs);
  padding: 0;
  text-decoration: none;
  position: relative;
  z-index: 1;
}

.page-contact__tel-num:hover {
  opacity: 1;
}

.page-contact__tel-num:hover .page-contact__tel-num-text {
  background: linear-gradient(135deg, var(--color-paid), #b87108);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
}

.page-contact__tel-hours {
  font-size: var(--font-sm);
  color: var(--color-base);
  margin: 0;
  padding-top: var(--space-xs);
  border-top: 1px dashed var(--color-primary);
  position: relative;
  z-index: 1;
}

.page-contact__tel-hours-label {
  display: inline-block;
  padding: 2px var(--space-xs);
  background-color: var(--color-primary);
  color: var(--color-main);
  border-radius: var(--radius-pill);
  font-size: var(--font-sm);
  font-weight: 700;
  margin-right: var(--space-2xs);
  letter-spacing: 0.1em;
}

.page-contact__tel-hours-note {
  font-size: var(--font-sm);
  color: var(--color-gray2);
  margin-left: 4px;
}

.page-contact__form {
  background-color: var(--color-white);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.04);
}
@media (768px <= width) {
  .page-contact__form {
    padding: var(--space-lg);
  }
}
@media (1024px <= width) {
  .page-contact__form {
    grid-column: 1/2;
  }
}

.page-contact__notice {
  font-size: var(--font-sm);
  line-height: 1.8;
  color: var(--color-gray2);
  text-align: center;
  margin: var(--space-md) 0 0;
  grid-column: 1/-1;
}

.page-contact__notice a {
  color: var(--color-main);
  text-decoration: underline;
}

.page-contact__notice--sub {
  font-size: var(--font-sm);
  color: var(--color-gray);
  margin-top: var(--space-2xs);
}

.page-other__section h2,
.page-section__news h2 {
  display: flex;
  align-items: center;
  padding: var(--space-xs);
  font-weight: 800;
  font-size: var(--font-lg);
  background-color: var(--color-primary);
  margin-block: var(--space-sm);
}
.page-other__section h2::before,
.page-section__news h2::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 1.5em;
  margin-right: 0.5em;
  background-color: var(--color-main);
}
.page-other__section h3,
.page-section__news h3 {
  padding: var(--space-xs);
  border-bottom: 3px double var(--color-main);
  font-size: var(--font-md);
  font-weight: 800;
  margin-block: var(--space-sm);
}
.page-other__section h4,
.page-section__news h4 {
  font-weight: 800;
  padding: var(--space-2xs);
  padding-left: var(--space-sm);
  border-left: 5px solid var(--color-main);
  margin-block: var(--space-xs);
}
.page-other__section strong,
.page-section__news strong {
  font-weight: 800;
  color: var(--color-main);
}
.page-other__section p,
.page-section__news p {
  margin-bottom: var(--space-2xs);
}

.wp-block-columns {
  gap: var(--space-sm);
}

.has-text-align-right {
  text-align: right;
}

.wp-block-list {
  margin: var(--space-xs);
}
.wp-block-list li {
  margin-left: 1rem;
}
.wp-block-list li::before {
  content: "■";
  display: inline-block;
  color: var(--color-main);
  margin-right: 0.5em;
  font-size: 0.5em;
  vertical-align: middle;
}

.wp-block-table {
  border-collapse: collapse;
  inline-size: 100%;
}
.wp-block-table td,
.wp-block-table th {
  border: 1px solid var(--color-gray) !important;
  padding: var(--space-xs) !important;
}
.wp-block-table th {
  background: var(--color-primary);
  text-align: center;
  vertical-align: middle;
  width: 20%;
}
@media (max-width: 767px) {
  .wp-block-table {
    border: solid 1px var(--color-primary);
  }
  .wp-block-table th,
  .wp-block-table td {
    border-bottom: none;
    display: block;
    width: 100%;
  }
}

.cf7__list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: var(--space-sm);
}
.cf7__list dt {
  width: 35%;
  padding-top: var(--space-xs);
}
.cf7__list dd {
  width: 65%;
}
.cf7__list dt:nth-of-type(n + 2),
.cf7__list dd:nth-of-type(n + 2) {
  margin-top: var(--space-sm);
}
@media (max-width: 767px) {
  .cf7__list dt {
    inline-size: 100%;
    margin-bottom: 15px;
    padding-top: 0;
  }
  .cf7__list dd {
    inline-size: 100%;
  }
  .cf7__list dd:nth-of-type(n + 2) {
    margin-top: 0;
  }
}

.cf7__required,
.cf7__optional {
  margin-right: var(--space-xs);
  padding-block: var(--space-2xs);
  padding-inline: var(--space-xs);
  color: var(--color-white);
  font-size: var(--font-sm);
  vertical-align: 1px;
}

.cf7__required {
  background: #be1d1d;
}

.cf7__optional {
  background: var(--color-gray);
}

.cf7__list dd input[type=text],
.cf7__list dd input[type=tel],
.cf7__list dd input[type=email],
.cf7__list dd textarea {
  inline-size: 100%;
  padding: var(--space-xs);
  background: #f4f4f4;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: var(--radius-sm);
}

.cf7__select {
  position: relative;
}
.cf7__select::before {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-end: 20px;
  transform: translateY(-50%);
  border-top: 8px solid var(--color-base);
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
  pointer-events: none;
}

.cf7__select select,
.cf7__data {
  inline-size: 100%;
  padding: var(--space-xs);
  background: #f4f4f4;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: var(--radius-sm);
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.cf7__data .wpcf7-date {
  inline-size: 100%;
}

input[type=checkbox],
input[type=radio] {
  position: relative;
  inline-size: 25px;
  block-size: 25px;
  margin-right: 8px;
  border: 1px solid var(--color-gray);
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: var(--color-white);
}

input[type=checkbox]:checked {
  border-color: var(--color-base);
  background: var(--color-base);
}
input[type=checkbox]:checked::before {
  content: "";
  position: absolute;
  top: 2px;
  left: 5px;
  transform: rotate(50deg);
  inline-size: 6px;
  block-size: 10px;
  border-right: 2px solid var(--color-white);
  border-bottom: 2px solid var(--color-white);
}

input[type=radio] {
  border-radius: var(--radius-pill);
}
input[type=radio]:checked::before {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  transform: translate(-50%, -50%);
  inline-size: 9px;
  block-size: 9px;
  border-radius: var(--radius-pill);
  background: var(--color-base);
}

.cf7__button {
  text-align: center;
  place-items: center;
}

input[type=submit] {
  inline-size: 300px;
  padding: var(--space-sm);
  background: var(--color-base);
  color: var(--color-white);
  font-weight: 800;
  border: 0;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: opacity 0.25s ease;
}
input[type=submit]:hover {
  opacity: 0.85;
}
@media (max-width: 767px) {
  input[type=submit] {
    inline-size: 100%;
    block-size: 56px;
  }
}

.wpcf7-spinner {
  vertical-align: middle;
}

.wpcf7-list-item {
  display: block;
  line-height: 2;
}

.cf-turnstile {
  display: block;
  text-align: right;
}

.p-cta--accent .p-cta__heading,
.p-cta--accent .p-cta__desc {
  color: var(--color-white);
}

.p-cta--bordered {
  background: var(--color-white);
  border-top: 1px solid rgba(224, 123, 0, 0.35);
  border-bottom: 1px solid rgba(224, 123, 0, 0.35) !important;
  border-bottom: none;
}

.service-product__badge {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background: #e07b00;
  color: var(--color-white);
  font-size: var(--font-base);
  font-weight: 800;
  letter-spacing: 0.1em;
  padding: var(--space-2xs) var(--space-sm);
  border-radius: 0 0 var(--radius-sm) 0;
}

.service-issue {
  text-align: center;
  position: relative;
  background: linear-gradient(180deg, #fff8ef 0%, #ffeed2 100%);
  border-top: 4px solid #e07b00;
  padding-block: calc(var(--space-xl) + 2rem) var(--space-lg);
  overflow: visible;
  margin-top: 2rem;
}

.chart-support {
  font-weight: 800 !important;
  font-size: 1.05rem !important;
  letter-spacing: 0.2em !important;
  border: 2px solid #e07b00 !important;
  padding-block: var(--space-xs);
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.25);
}

.chart-row-label,
.chart-row-label2 {
  font-weight: 800 !important;
  font-size: 1rem !important;
  letter-spacing: 0.12em !important;
  padding: 12px 6px !important;
  text-align: center;
  border-radius: 4px;
}

.chart-merit-col li {
  font-size: var(--font-base) !important;
}

.company-summary__note {
  text-align: center;
  font-size: var(--font-sm);
  color: var(--color-gray2);
  margin: 0 0 var(--space-md);
  line-height: 1.7;
}
@media (max-width: 767px) {
  .company-summary__note {
    font-size: clamp(0.6rem, 2.8vw, 0.7rem);
    white-space: nowrap;
  }
}

.company-summary__stat::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  inline-size: 40%;
  block-size: 3px;
  background: var(--color-main);
  border-radius: var(--radius-pill);
}

.topic-archive__item {
  background: var(--color-white) !important;
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
  margin-block: var(--space-sm);
  transition: box-shadow 0.3s ease;
}
@media (768px <= width) {
  .topic-archive__item {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--space-md);
    padding: var(--space-sm);
    align-items: start;
  }
}

.topic-archive__item:hover {
  box-shadow: var(--shadow-md);
}

.topic-archive__thumb {
  margin: 0;
  inline-size: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background-color: var(--color-primary);
}

.topic-archive__thumb img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topic-archive__title {
  font-weight: 800 !important;
  color: var(--color-main) !important;
  margin: 0 0 var(--space-xs) !important;
  font-size: var(--font-md) !important;
  line-height: 1.5;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.topic-archive__date {
  color: var(--color-gray2) !important;
  font-size: var(--font-sm);
}

.topic-archive__tags {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: flex-start !important;
  gap: var(--space-2xs) !important;
}

.topic-archive__tags li::before {
  display: none !important;
}

.topic-archive__tags li span,
.topic-archive__tags li a {
  display: inline-block;
  padding: 2px var(--space-xs);
  background-color: var(--color-primary);
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 600;
  border-radius: var(--radius-pill);
  line-height: 1.5;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.topic-sidebar__list a {
  display: grid !important;
  grid-template-columns: 60px 1fr !important;
  gap: var(--space-xs) !important;
  align-items: center;
  padding: var(--space-xs);
  font-weight: 600 !important;
  font-size: var(--font-sm);
  border-bottom: 1px solid var(--color-primary);
  transition: background-color 0.2s ease;
  box-shadow: none !important;
}

.news-important {
  background: linear-gradient(135deg, #fce4e4 0%, #ffcdcd 100%);
  border: 2px solid #c0392b;
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  box-shadow: 0 6px 20px rgba(192, 57, 43, 0.12);
}
@media (768px <= width) {
  .news-important {
    flex-direction: row;
    align-items: center;
    gap: var(--space-md);
  }
}

.news-important__label {
  display: inline-block;
  padding: var(--space-2xs) var(--space-sm);
  background: linear-gradient(135deg, #c0392b, #a73224);
  color: var(--color-white);
  font-size: var(--font-sm);
  font-weight: 800;
  border-radius: var(--radius-pill);
  letter-spacing: 0.15em;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(192, 57, 43, 0.3);
}

.news-archive__cat {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px var(--space-sm) 4px calc(var(--space-sm) + 4px);
  background-color: var(--color-white);
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 800;
  border-radius: var(--radius-sm);
  text-align: center;
  letter-spacing: 0.1em;
  min-inline-size: 5.5rem;
  border: 1.5px solid var(--color-main);
  position: relative;
  line-height: 1.4;
}
@media (768px <= width) {
  .news-archive__cat {
    justify-self: start;
  }
}

.news-archive__cat--important {
  background-color: #fce4e4;
  color: #a73224;
  border-color: #c0392b;
}

.news-archive__cat--important::before {
  background-color: #c0392b;
}

.news-archive__cat--update {
  background-color: #e1ecf4;
  color: var(--color-main);
  border-color: var(--color-main);
}

.news-archive__cat--maintenance {
  background-color: #fef3e0;
  color: #b86f08;
  border-color: #e07b00;
}

.news-archive__cat--maintenance::before {
  background-color: #e07b00;
}

.news-archive__cat--company,
.news-archive__cat--info {
  background-color: #f1f3f5;
  color: var(--color-base);
  border-color: #999;
}

.news-archive__cat--company::before,
.news-archive__cat--info::before {
  background-color: #999;
}

.news-archive__cat--service {
  background-color: #e9f5ec;
  color: #2c7a3e;
  border-color: #3da062;
}

.news-archive__cat--service::before {
  background-color: #3da062;
}

.c-pagination {
  flex-wrap: wrap;
  gap: 6px !important;
}

.c-pagination a,
.c-pagination .current,
.c-pagination .dots {
  box-sizing: border-box;
  display: inline-flex !important;
  justify-content: center;
  align-items: center;
  min-inline-size: 2.5em;
  block-size: 2.5em !important;
  padding: 0 var(--space-2xs);
  border-radius: var(--radius-sm);
  font-size: var(--font-base);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.c-pagination a {
  background-color: var(--color-white);
  border: 1.5px solid var(--color-primary) !important;
  box-shadow: 0 2px 6px rgba(0, 91, 158, 0.04);
}

.c-pagination a:hover {
  background-color: var(--color-main);
  color: var(--color-white);
  border-color: var(--color-main) !important;
  transform: translateY(-1px);
}

.c-pagination .current {
  background: linear-gradient(135deg, var(--color-main), #1a4a7a) !important;
  border: 1.5px solid var(--color-main);
  box-shadow: 0 4px 10px rgba(0, 91, 158, 0.25);
}

.c-pagination .dots {
  color: var(--color-gray2);
  background-color: transparent;
  border: none;
  box-shadow: none;
  cursor: default;
}

.simulation-hero {
  background: linear-gradient(180deg, #f4f9fc 0%, var(--color-white) 100%);
  padding-block: var(--space-lg);
  position: relative;
  overflow: hidden;
}
@media (768px <= width) {
  .simulation-hero {
    padding-block: var(--space-xl);
  }
}

.simulation-hero__title {
  font-size: var(--font-xl);
  font-weight: 900;
  line-height: 1.4;
  margin: 0 0 var(--space-md);
  text-wrap: balance;
  letter-spacing: 0.02em;
}
@media (768px <= width) {
  .simulation-hero__title {
    font-size: var(--font-xxxl);
  }
}
@media (max-width: 767px) {
  .simulation-hero__title {
    font-size: clamp(1rem, 5.6vw, 1.375rem);
    text-wrap: auto;
  }
}

.simulation-hero__sub {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  line-height: 1.6;
  margin: 0 0 var(--space-sm);
}
@media (768px <= width) {
  .simulation-hero__sub {
    font-size: var(--font-xl);
  }
}

@keyframes simChartDraw {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes simChartPulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.6;
  }
}
.simulation-chart__card-label {
  display: inline-block;
  font-size: var(--font-base);
  font-weight: 800;
  letter-spacing: 0.25em;
  margin: 0 0 var(--space-xs);
  padding: 4px var(--space-sm);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.7);
}
@media (768px <= width) {
  .simulation-chart__card-label {
    font-size: var(--font-md);
  }
}

.simulation-chart__card-data dt {
  font-size: var(--font-base);
  margin-top: var(--space-xs);
  font-weight: 700;
  opacity: 0.85;
}
@media (768px <= width) {
  .simulation-chart__card-data dt {
    font-size: var(--font-md);
  }
}

.simulation-chart__unit {
  font-size: var(--font-base);
  margin-left: 4px;
  font-weight: 800;
}
@media (768px <= width) {
  .simulation-chart__unit {
    font-size: var(--font-md);
  }
}

.simulation-chart__disclaimer {
  font-size: var(--font-sm);
  line-height: 1.7;
  color: var(--color-gray2);
  margin: var(--space-sm) 0 0;
  padding-top: var(--space-xs);
  border-top: 1px dashed var(--color-primary);
  text-align: center;
}

.simulation-cta--mid {
  background-color: #fff8ef;
  border-top: 3px solid var(--color-paid);
  border-bottom: 3px solid var(--color-paid);
}

.simulation-compare__vs-text {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 5rem;
  block-size: 5rem;
  background: linear-gradient(135deg, var(--color-paid), #b87108);
  color: var(--color-white);
  font-size: var(--font-xl);
  font-weight: 900;
  border-radius: 50%;
  border: 4px solid var(--color-white);
  box-shadow: 0 12px 30px rgba(212, 130, 10, 0.4);
}
@media (768px <= width) {
  .simulation-compare__vs-text {
    inline-size: 6rem;
    block-size: 6rem;
    font-size: var(--font-xxl);
  }
}

.simulation-compare__col--bad .simulation-compare__num,
.simulation-compare__col--bad .simulation-compare__unit {
  color: #c0392b;
}

.simulation-compare__col--good .simulation-compare__num,
.simulation-compare__col--good .simulation-compare__unit {
  color: var(--color-main);
}

.simulation-features__title {
  font-size: var(--font-md);
  font-weight: 800;
  margin: 0 0 var(--space-xs);
  line-height: 1.4;
}

.simulation-features__desc {
  line-height: 1.8;
  color: var(--color-gray2);
  margin: 0;
  text-align: left;
}
@media (768px <= width) {
  .simulation-features__desc {
    text-align: center;
  }
}
@media (max-width: 767px) {
  .simulation-features__desc {
    font-size: clamp(0.7rem, 3.5vw, 0.8125rem);
  }
}

.simulation-output__list li {
  background-color: var(--color-white);
  padding: var(--space-sm);
  text-align: center;
  border-radius: var(--radius-sm);
  border-left: 4px solid var(--color-main);
  box-shadow: var(--shadow-sm);
}

.simulation-price {
  padding-block: var(--space-lg);
  background-color: #fafbfc;
}

.simulation-price__eyebrow {
  text-align: center;
  font-size: var(--font-md);
  color: var(--color-main);
  letter-spacing: 0.4em;
  margin: 0;
  font-weight: 800;
}

.simulation-price__title {
  text-align: center;
  font-size: var(--font-lg);
  font-weight: 800;
  margin: var(--space-xs) 0 var(--space-lg);
}
@media (768px <= width) {
  .simulation-price__title {
    font-size: var(--font-xl);
  }
}

.simulation-price__plan-name {
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 1px dashed #d6eaf1;
}

.simulation-price__plan:nth-child(2) .simulation-price__plan-features .sitemap__list-note {
  display: block;
  font-size: var(--font-sm);
  color: var(--color-gray2);
  font-weight: 400;
  line-height: 1.6;
  margin-top: var(--space-2xs);
}

@media (max-width: 767px) {
  .sitemap__list > li > a {
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    padding-right: calc(var(--space-sm) + 1.5rem);
  }
  .sitemap__list > li > a::after {
    position: absolute;
    right: var(--space-sm);
    top: 50%;
    transform: translateY(-50%);
  }
  .sitemap__list > li > a:hover::after {
    transform: translateY(-50%) translateX(4px);
  }
}
.sitemap__service-card::after {
  content: "詳しく見る ›";
  color: var(--color-main);
  font-size: var(--font-sm);
  font-weight: 700;
  margin-top: auto;
  padding-top: var(--space-xs);
  border-top: 1px dashed var(--color-primary);
}

.page-legal__content ul,
.page-legal__content ol {
  padding-left: 1.5em;
  margin: 0 0 var(--space-sm);
}

.page-legal__content--table th,
.page-legal__content--table td {
  border: none;
  border-bottom: 1px solid var(--color-primary);
  padding: var(--space-sm) var(--space-md);
  line-height: 1.9;
  vertical-align: top;
}

.page-legal__content--table tr:last-child th,
.page-legal__content--table tr:last-child td {
  border-bottom: none;
}

.page-legal__content--table th {
  background-color: #f4f9fc;
  color: var(--color-main);
  font-weight: 700;
  text-align: left;
  inline-size: 28%;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .page-legal__content--table th,
  .page-legal__content--table td {
    display: block;
    inline-size: 100%;
  }
  .page-legal__content--table th {
    padding-block: var(--space-xs);
    white-space: normal;
  }
}
.page-contact__guide-title {
  font-size: var(--font-md);
  font-weight: 800;
  color: var(--color-main);
  margin: 0 0 var(--space-sm);
}

@media (max-width: 767px) {
  .page-contact__guide {
    padding-inline: var(--space-sm);
  }
}
.page-contact__tel {
  grid-column: 1/-1;
  background-color: var(--color-white);
  border: 1.5px solid var(--color-main);
  border-radius: var(--radius-sm);
  padding: var(--space-sm);
  text-align: center;
  position: relative;
  box-shadow: 0 6px 16px rgba(0, 91, 158, 0.06);
  overflow: hidden;
}
@media (1024px <= width) {
  .page-contact__tel {
    grid-column: 2/3;
    grid-row: 2/3;
    align-self: start;
  }
}

.page-contact__tel-num-text {
  display: inline-block;
  font-size: var(--font-lg);
  font-weight: 900;
  letter-spacing: 0.05em;
  background: linear-gradient(135deg, var(--color-main), #1a4a7a);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  line-height: 1.1;
  white-space: nowrap;
}
@media (768px <= width) {
  .page-contact__tel-num-text {
    font-size: var(--font-xl);
  }
}

.page-contact input[type=submit],
.page-contact button[type=submit],
.page-contact .wpcf7-submit {
  display: block;
  inline-size: 300px;
  max-inline-size: 100%;
  margin-inline: auto;
  padding: var(--space-sm) var(--space-md);
  background: linear-gradient(135deg, var(--color-paid), #b87108);
  color: var(--color-white);
  font-weight: 800;
  font-size: var(--font-md);
  letter-spacing: 0.1em;
  border: 0;
  border-radius: var(--radius-pill);
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(212, 130, 10, 0.3);
  transition: opacity 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.page-contact input[type=submit]:hover,
.page-contact button[type=submit]:hover,
.page-contact .wpcf7-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(212, 130, 10, 0.4);
  opacity: 0.95;
}

@media (max-width: 767px) {
  .page-contact input[type=submit],
  .page-contact button[type=submit],
  .page-contact .wpcf7-submit {
    inline-size: 100%;
    min-block-size: 56px;
    line-height: 1;
  }
}
.page-template-page-contact .site-footer__contact {
  display: none;
}

.service-fq__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.service-fq__item {
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: box-shadow 0.2s ease;
}

.service-fq__item[open] {
  box-shadow: 0 4px 14px rgba(0, 91, 158, 0.08);
}

.service-fq__item > summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-sm) var(--space-md);
  padding-right: 3rem;
  font-weight: 700;
  color: var(--color-main);
  font-size: var(--font-md);
  position: relative;
  transition: background-color 0.2s ease;
}
.service-fq__item > summary::-webkit-details-marker {
  display: none;
}
.service-fq__item > summary::before {
  content: "Q.";
  margin-right: var(--space-2xs);
  font-weight: 900;
}
.service-fq__item > summary::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.2rem;
  inline-size: 10px;
  block-size: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-65%) rotate(45deg);
  transition: transform 0.2s ease;
}

.service-fq__item[open] > summary::after {
  transform: translateY(-25%) rotate(-135deg);
}

.service-fq__item > summary:hover {
  background-color: var(--color-primary);
}

.service-fq__answer {
  padding: var(--space-sm) var(--space-md);
  background-color: var(--color-primary);
  line-height: 1.9;
}

.service-fq__answer::before {
  content: "A.";
  font-weight: 900;
  margin-right: var(--space-2xs);
  color: var(--color-paid);
}

@media (768px <= width) {
  .service-hero2__grid {
    grid-template-columns: 1fr 42% !important;
    align-items: start !important;
  }
}

.service-hero2-box2__before,
.service-hero2-box2__after {
  background-color: rgba(255, 255, 255, 0.92) !important;
  padding: var(--space-sm) !important;
  border-radius: var(--radius-sm);
}

.service-hero2-box2__before-list li,
.service-hero2-box2__after-list li {
  margin-block: var(--space-2xs) !important;
  margin-left: 0.8rem !important;
  line-height: 1.65;
  font-size: var(--font-base) !important;
}

.service-hero2-box2__point {
  margin-top: var(--space-sm) !important;
  background-color: rgba(255, 255, 255, 0.95) !important;
  border: 2px solid var(--color-paid) !important;
  padding: var(--space-sm) !important;
  font-weight: 700;
}

.service-hero2-box2__point span {
  color: var(--color-paid);
  font-size: var(--font-lg);
  font-weight: 900;
}

.service-problem__arrow {
  display: flex !important;
  background-color: var(--color-main);
  width: 50px;
  height: 50px;
  border-radius: 100vh;
  justify-content: center;
  align-items: center;
  margin: var(--space-xs) auto !important;
}

.service-problem__arrow svg {
  transform: rotate(90deg);
}

@media (768px <= width) {
  .service-problem__arrow {
    margin: 0 !important;
  }
  .service-problem__arrow svg {
    transform: none;
  }
}
.top-result__disclaimer {
  color: rgba(255, 255, 255, 0.55);
  font-size: var(--font-sm);
  line-height: 1.7;
  margin-top: var(--space-xs);
  padding-top: var(--space-xs);
  border-top: 1px dashed rgba(255, 255, 255, 0.2);
}

.about-partner {
  padding-block: var(--space-md);
}
@media (768px <= width) {
  .about-partner {
    padding-block: var(--space-lg);
  }
}

.about-partner__conditions {
  padding: var(--space-xs);
}
@media (768px <= width) {
  .about-partner__conditions {
    padding: var(--space-sm);
  }
}

.about-hero [data-aos],
.service-hero [data-aos],
.service-hero2 [data-aos],
.simulation-hero [data-aos],
.page-hero [data-aos] {
  opacity: 1 !important;
  transform: none !important;
}

.about-hero__inner .about-hero__title {
  color: var(--color-base);
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.85), 0 2px 8px rgba(255, 255, 255, 0.6);
}

.about-hero__inner .about-hero__title span {
  text-shadow: none;
}

.about-hero__inner .about-hero__lead {
  color: var(--color-base);
  text-shadow: 0 0 16px rgba(255, 255, 255, 0.9), 0 2px 4px rgba(255, 255, 255, 0.6);
}/*# sourceMappingURL=style.css.map */