@charset "UTF-8";
/*! kiso.css v1.2.2 | MIT License | https://github.com/tak-dcxi/kiso.css */
/* ======================================================
//  MARK: Universal
// ====================================================== */
*,
::before,
::after {
  /*
  * Includes `padding` and `border` in the element's specified dimensions.
  * It is highly recommended to set `box-sizing: border-box;` by default, as it makes styling much easier, especially when specifying `width: 100%;`.
  */
  box-sizing: border-box;
}

/* ======================================================
//  MARK: Document and Body Elements
// ====================================================== */
:where(:root) {
  /* In Safari, if `font-family` is not specified, a serif font is applied by default, so `sans-serif` is set as the default here. */
  font-family: sans-serif;
  /*
  * For accessibility, it is recommended to set the `line-height` to at least 1.5 times the text size within paragraphs.
  * @see https://waic.jp/translations/WCAG21/#visual-presentation
  */
  line-height: 1.5;
  /* Remove space when punctuation marks are adjacent, and also remove leading spaces in a line. */
  text-spacing-trim: trim-start;
  /* Improves readability by inserting a small space between Japanese and alphanumeric characters. */
  text-autospace: normal;
  /* Prevents misreading by applying strict line-breaking rules. */
  line-break: strict;
  /* Wraps English words mid-word. Specifying `anywhere` also prevents content from overflowing in layouts like `flex` or `grid`. */
  overflow-wrap: anywhere;
  /*
  * Mobile browsers have an algorithm that automatically adjusts font sizes to prevent text from becoming too small.
  * This controls the auto-adjustment feature to prevent unwanted resizing.
  */
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
  /* Prevents layout shift caused by the appearance or disappearance of the scrollbar. */
  scrollbar-gutter: stable;
  /* Suppresses the tap highlight on iOS. */
  -webkit-tap-highlight-color: transparent;
}

:where(body) {
  /*
  * When creating a sticky footer, a minimum height is often required.
  * Setting the `min-block-size` to the dynamic viewport height ensures enough space for the footer.
  */
  min-block-size: 100dvb;
  /* The `margin` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  margin: unset;
}

/* ======================================================
// MARK: Sections
// ------------------------------------------------------ */
:where(h1, h2, h3, h4, h5, h6) {
  /* Prevents the last line of text from ending with a single word, which can look awkward (known as an orphan). */
  text-wrap: pretty;
}

:where(h1) {
  /*
  * Adjusts user agent (UA) styles for `h1` elements within sectioning content.
  * This addresses DevTools warnings that appear when `h1` elements nested within sectioning content lack `font-size` and `margin` properties.
  * @see https://html.spec.whatwg.org/#sections-and-headings
  */
  margin-block: 0.67em;
  font-size: 2em;
}

:where(h2, h3, h4, h5, h6) {
  /* The `margin-block` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
}

:where(search) {
  /*
  * The `<search>` element is supported from Safari 17.
  * This prevents it from being displayed as an inline element in unsupported environments.
  */
  display: block flow;
}

/* ======================================================
//  MARK: Grouping content
// ====================================================== */
:where(p, blockquote, figure, pre, address, ul, ol, dl, menu) {
  /* The `margin-block` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
}

:where(blockquote, figure) {
  /* The `margin-inline` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-inline: unset;
}

:where(p:lang(en)) {
  /*
  * In English, a single word on the last line is called a "widow" or "orphan" and is considered something to avoid as it makes the text harder to read.
  * Therefore, when lang="en", this prevents the last line from ending with a single word.
  */
  text-wrap: pretty;
}

:where(address:lang(ja)) {
  /* Italic style is not common in Japanese, so the `font-style` is reset. */
  font-style: unset;
}

:where(ul, ol, menu) {
  /* The `padding-inline-start` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  padding-inline-start: unset;
  /*
  * In Safari, using `list-style: none` prevents screen readers from announcing lists.
  * `list-style-type: ""` is used to hide markers without affecting accessibility.
  * @see https://matuzo.at/blog/2023/removing-list-styles-without-affecting-semantics
  */
  list-style-type: "";
}

:where(dt) {
  /* It is common to display `<dt>` elements in bold, so `font-weight: bolder;` is set by default. */
  font-weight: bolder;
}

:where(dd) {
  /* The `margin-inline-start` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-inline-start: unset;
}

:where(pre) {
  /*
  * Since `text-spacing-trim` can affect spacing in `<pre>` elements even with its initial value, the final rendering may depend on the user's font settings.
  * To ensure consistent alignment, `space-all` is explicitly specified and inheritance is prevented.
  */
  text-spacing-trim: space-all;
  /* Set to `no-autospace` as it can cause misalignment with monospaced fonts. */
  text-autospace: no-autospace;
}

/* ======================================================
//  MARK: Text-level semantics
// ====================================================== */
:where(em:lang(ja)) {
  /* In Japanese, emphasis is commonly represented by bold text, so `font-weight: bolder;` is set by default. */
  font-weight: bolder;
}

:where(:is(i, cite, em, dfn, var):lang(ja)) {
  /* Italic style is not common in Japanese, so the `font-style` is reset. */
  font-style: unset;
}

:where(code, kbd, samp) {
  /*
  * Set a monospace font family referencing Tailwind.
  * @see https://tailwindcss.com/docs/font-family
  */
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  /* Font feature settings can have adverse effects on monospaced fonts, so their values are explicitly set to `initial` to prevent inheritance. */
  font-feature-settings: initial;
  font-variation-settings: initial;
  /* Resets the `font-size` specified in the UA stylesheet to allow inheritance. */
  font-size: unset;
  /*
  * Disables font ligatures for programming fonts (like Fira Code)
  * to prevent character combinations like `=>` from being rendered as a single symbol (e.g., `⇒`).
  */
  font-variant-ligatures: none;
}

:where(abbr[title]) {
  /*
  * The `<abbr>` element with the `title` attribute isn't helpful regarding accessibility because support is inconsistent, and it's only accessible to some users.
  * This rule shows a dotted underline on abbreviations in all browsers (there's a bug in Safari) and changes the cursor.
  * @see https://adrianroselli.com/2024/01/using-abbr-element-with-title-attribute.html
  */
  text-decoration-line: underline;
  text-decoration-style: dotted;
  cursor: help;
}

:where(time) {
  /* Set to `no-autospace` because date notations in typography do not include spaces. */
  text-autospace: no-autospace;
}

@media (forced-colors: active) {
  :where(mark) {
    /*
    * In forced-colors mode, the color of the mark element may not change, which can be problematic. Use system colors in forced-colors mode.
    * @see https://adrianroselli.com/2017/12/tweaking-text-level-styles.html#MarkWHCM
    */
    background-color: Highlight;
    color: HighlightText;
  }
}
@media print {
  :where(mark) {
    /*
    * Not all printers support color, and users might print in grayscale.
    * It's worth adding a non-disruptive style that scales with the text, as an alternative to relying only on background color.
    * @see https://adrianroselli.com/2017/12/tweaking-text-level-styles.html#MarkPrint
    */
    border-width: 1px;
    border-style: dotted;
  }
}
/* ======================================================
//  MARK: Links
// ====================================================== */
:where(a:-moz-any-link) {
  /* The default `color` from the UA stylesheet is rarely used as is, so it's reset to allow inheritance. */
  color: unset;
  /*
  * While link underlines can be useful, they are often obstructive.
  * They are disabled by default.
  * If needed, restore them using `text-decoration-line: revert;`.
  */
  text-decoration-line: unset;
  /* Set the underline thickness to the font's default thickness. */
  text-decoration-thickness: from-font;
}
:where(a:any-link) {
  /* The default `color` from the UA stylesheet is rarely used as is, so it's reset to allow inheritance. */
  color: unset;
  /*
  * While link underlines can be useful, they are often obstructive.
  * They are disabled by default.
  * If needed, restore them using `text-decoration-line: revert;`.
  */
  text-decoration-line: unset;
  /* Set the underline thickness to the font's default thickness. */
  text-decoration-thickness: from-font;
}

/* ======================================================
//  MARK: Embedded content
// ====================================================== */
:where(img, svg, picture, video, canvas, model, audio, embed, object) {
  /* Automatically adjust block size based on content. */
  block-size: auto;
  /* Prevents overflow by setting the maximum width to `100%`. */
  max-inline-size: 100%;
  /* Prevents extra space from appearing at the bottom of the element. */
  vertical-align: bottom;
}

/* もともと上にiframe含まれていたが block-size: auto の指定があるとheight属性による指定ができなくなり、かつ、上書きもできなかったので直接修正 */
:where(iframe) {
  max-inline-size: 100%;
  vertical-align: bottom;
}

:where(iframe) {
  /* The `border` specified in the UA stylesheet is often unnecessary, so it is reset. */
  border: unset;
}

/* ======================================================
//  MARK: Tabular data
// ====================================================== */
:where(table) {
  /* Collapse borders for a more refined table design. */
  border-collapse: collapse;
}

:where(caption, th) {
  /* The `text-align` specified in the UA stylesheet is often unnecessary, so it is reset. */
  text-align: unset;
}

:where(caption) {
  /* Prevents the last line of text from ending with a single word, which can look awkward (known as an orphan). */
  text-wrap: pretty;
}

/* ======================================================
//  MARK: Forms
// ====================================================== */
:where(button, input, select, textarea),
::file-selector-button {
  /*
  * These elements are often styled with a border, so a `1px` border is applied by default for consistency.
  * This ensures readability even for unstyled elements.
  * When resetting, it's recommended to use `border-color: transparent` instead of `border: none` to account for forced color modes.
  */
  border-width: 1px;
  border-style: solid;
  /* These styles specified in the UA stylesheet are often unnecessary, so they are reset to allow for inheritance. */
  border-color: unset;
  border-radius: unset;
  color: unset;
  font: unset;
  letter-spacing: unset;
  text-align: unset;
}

:where(input:is([type=radio i], [type=checkbox i])) {
  /* The `margin` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  margin: unset;
}

:where(input[type=file i]) {
  /* The `border` is often unnecessary, so it is reset here. */
  border: unset;
}

:where(input[type=search i]) {
  /* Remove the rounded corners of search inputs on macOS and normalize the background color. */
  -webkit-appearance: textfield;
}

@supports (-webkit-touch-callout: none) {
  :where(input[type=search i]) {
    /* normalize the background color on iOS. */
    background-color: Canvas;
  }
}
:where(input:is([type=tel i],
[type=url i],
[type=email i],
[type=number i]):not(:-moz-placeholder)) {
  /*
  * Certain input types need to maintain left alignment even in right-to-left (RTL) languages.
  * However, this only applies when the value is not empty, as the placeholder should be right-aligned.
  * @see https://rtlstyling.com/posts/rtl-styling#form-inputs
  */
  direction: ltr;
}
:where(input:is([type=tel i],
[type=url i],
[type=email i],
[type=number i]):not(:placeholder-shown)) {
  /*
  * Certain input types need to maintain left alignment even in right-to-left (RTL) languages.
  * However, this only applies when the value is not empty, as the placeholder should be right-aligned.
  * @see https://rtlstyling.com/posts/rtl-styling#form-inputs
  */
  direction: ltr;
}

:where(textarea) {
  /* The `margin-block` specified in Firefox's UA stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
  /* Allows vertical resizing for `<textarea>` elements. */
  resize: block;
}

:where(input:not([type=button i], [type=submit i], [type=reset i]),
textarea,
[contenteditable]) {
  /* Set to `no-autospace` because `text-autospace` can insert spaces during input, potentially causing erratic behavior. */
  text-autospace: no-autospace;
}

:where(button,
input:is([type=button i], [type=submit i], [type=reset i])),
::file-selector-button {
  /* The `background-color` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  background-color: unset;
}

:where(button,
input:is([type=button i], [type=submit i], [type=reset i]),
[role=tab i],
[role=button i],
[role=option i]),
::file-selector-button {
  /*
  * On iOS, double-tapping a button can cause zooming, which harms usability.
  * `touch-action: manipulation` is specified to disable zooming on double-tap.
  * Third-party plugins such as Swiper sometimes use div elements with these roles as buttons, since double-tapping a div can still trigger zooming, it's advisable to specify this property.
  */
  touch-action: manipulation;
}

:where(button:enabled,
label[for],
select:enabled,
input:is([type=button i],
[type=submit i],
[type=reset i],
[type=radio i],
[type=checkbox i]):enabled,
[role=tab i],
[role=button i],
[role=option i]),
:where(:enabled)::file-selector-button {
  /* Indicate clickable elements with a pointer cursor. */
  cursor: pointer;
}

:where(fieldset) {
  /*
  * Prevent fieldset from causing overflow.
  * Reset the default `min-inline-size: min-content` to prevent children from stretching fieldset.
  * @see https://github.com/twbs/bootstrap/issues/12359
  */
  min-inline-size: 0;
  /* The following default styles are often unnecessary, so they are reset. */
  margin-inline: unset;
  padding: unset;
  border: unset;
}

:where(legend) {
  /* The default `padding-inline` is often unnecessary, so it is reset. */
  padding-inline: unset;
}

:where(progress) {
  /* Resets the vertical alignment of the `<progress>` element to its initial value. */
  vertical-align: unset;
}

::-moz-placeholder {
  /* Standardize the opacity of placeholder text (it may be set lower by default in Firefox). */
  opacity: unset;
}

::placeholder {
  /* Standardize the opacity of placeholder text (it may be set lower by default in Firefox). */
  opacity: unset;
}

/* ======================================================
//  MARK: Interactive elements
// ====================================================== */
/* :where(summary) {
  // The default triangle marker is often unnecessary, so it is disabled.
  list-style-type: "";

  // Changing the cursor to a pointer clarifies the clickability of the element.
  cursor: pointer;
} 

:where(summary)::-webkit-details-marker {
  // In Safari versions earlier than 18.4 (released in April 2025), a triangle icon is displayed using the -webkit-details-marker CSS pseudo-element, so it should be removed.
  display: none;
}*/
:where(dialog, [popover]) {
  /*
  * When these fixed-position elements are scrolled, preventing scroll chaining on the underlying page and bounce effects on mobile improves usability.
  * Disabling block-direction scroll chaining is recommended.
  */
  overscroll-behavior-block: contain;
  /* The following default styles are often unnecessary, so they are reset. */
  padding: unset;
  border: unset;
}

:where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
  /*
  * These elements can be easily displayed by explicitly setting their `display` property.
  * To prevent them from appearing when not in an open state, they are forcibly hidden.
  */
  display: none !important;
}

:where(dialog) {
  /*
  * The max width and height of a `<dialog>` element are typically determined by the design.
  * These UA stylesheet properties are reset as they can be obstructive, especially when trying to make the dialog full-screen.
  */
  max-inline-size: unset;
  max-block-size: unset;
}

:where(dialog)::backdrop {
  /* Normalize the background color of the `::backdrop` element. */
  background-color: oklch(0% 0 0deg/30%);
}

:where([popover]) {
  /*
  * While the UA stylesheet's `margin` for `<dialog>` elements is useful for centering with `inset: 0`,
  * but `margin` for `popover` elements is often obstructive as they frequently use Anchor Positioning.
  */
  margin: unset;
}

/* ======================================================
//  MARK: Focus Styles
// ====================================================== */
:where(:focus-visible) {
  /* Add space between the content and the focus outline. */
  outline-offset: 3px;
}

[tabindex="-1"]:focus {
  /* Prevent programmatically focused elements from displaying an outline unless they are naturally focusable. */
  outline: none !important;
}

/* ======================================================
//  MARK: Misc
// ====================================================== */
:where(:disabled, [aria-disabled=true i]) {
  /* Display the default cursor on disabled elements to reflect their non-interactive state. */
  cursor: default;
}

[hidden]:not([hidden=until-found i]) {
  /* Ensure that elements intended to be hidden are not displayed, improving clarity and layout control. */
  display: none !important;
}

@media (min-width: 1080.01px) {
  :root {
    --pc-flag: 1;
    --sp-flag: 0;
  }
}
@media (max-width: 1080px) {
  :root {
    --pc-flag: 0;
    --sp-flag: 1;
  }
}

:root {
  --color-blue: #003888;
  --color-blue-light: #809bc3;
  --color-brown: #534741;
  --color-brown-dark: #27181a;
  --color-beige: #f3eee1;
  --color-gray: #aaa6a4;
  --color-bg: var(--color-beige);
  --color-text: #666;
  --font-family-sans: "Noto Sans JP", sans-serif;
  --font-family-mincho: "Shippori Mincho", serif;
  --font-family-serif: "Crimson Text", serif;
  --font-size-base: min(100vw * 10 / 1280, 10px);
  --line-height-base: 1.75;
  --base-radius: 2rem;
  --site-gap: 4rem;
  --site-header-height: 11rem;
  --content-width-pc: 120rem;
  --content-width-sp: 32rem;
  --content-width: var(--content-width-pc);
  --viewport-height: 100vh;
  --viewport-height-without-header: calc(var(--viewport-height) - var(--site-header-height));
  --link-dot-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><circle cx="8" cy="8" r="4.5"/></svg>');
  --link-arrow-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path d="M15.8 7.47 9.71.44A.807.807 0 1 0 8.49 1.5l4.93 5.7H.81c-.45 0-.81.36-.81.81s.36.81.81.81h12.61l-4.93 5.7c-.29.34-.26.85.08 1.14.15.13.34.2.53.2.23 0 .45-.09.61-.28l6.09-7.04c.26-.3.26-.76 0-1.06Z"/></svg>');
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  font-family: var(--font-family-sans);
  color: var(--color-text);
  background-color: var(--color-bg);
  scroll-behavior: smooth;
  scroll-padding-top: var(--site-header-height);
}
@media (max-width: 1080px) {
  :root {
    --font-size-base: min(100vw * 10 / 360, 20px);
    --base-radius: 0.66rem;
    --site-gap: 2rem;
    --site-header-height: 4.3rem;
    --content-width: var(--content-width-sp);
  }
}

:where(h1, h2, h3, h4, h5, h6) {
  font-weight: normal;
}

a {
  --link-icon-mask-image: var(--link-dot-url);
}
a:hover {
  --link-icon-mask-image: var(--link-arrow-url);
}

.holdings-condensed-text {
  width: 7.5em;
  scale: 0.7 1;
  transform-origin: 0% 50%;
  letter-spacing: -0.1em;
  white-space: nowrap;
}

.network-condensed-text {
  width: 9.5em;
  scale: 0.83 1;
  transform-origin: 0% 50%;
  white-space: nowrap;
}

@media (min-width: 1080.01px) {
  .pc-hidden {
    display: none !important;
  }
}

@media (max-width: 1080px) {
  .sp-hidden {
    display: none !important;
  }
}

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

.BgWhite {
  background-color: white;
  overflow: hidden;
}

.Container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.Container93 {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.fs16 {
  font-size: 1.6rem;
}

.fs-16 {
  font-size: 1.6rem;
}

.fs-18 {
  font-size: 1.6rem;
}

.fs-23 {
  font-size: 1.6rem;
}

.fs-31 {
  font-size: 3.1rem;
}

.mt-10 {
  margin-top: 1rem;
}

.mt-15 {
  margin-top: 1.5rem;
}

.mt-20 {
  margin-top: 2rem;
}

.text-center {
  text-align: center;
}

.flex-column {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.flex-row {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
}

.flex-grow {
  flex-grow: 1;
}

.flex-shrink {
  flex-shrink: 0;
}

.pagination {
  margin-top: 5rem;
  font-size: 2rem;
}
@media (max-width: 1080px) {
  .pagination {
    margin-top: 3rem;
    font-size: 2rem;
  }
}
.pagination .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5em 2em;
}
.pagination .nav-links .page-numbers {
  color: var(--color-blue-light);
}
.pagination .nav-links .page-numbers.current {
  color: var(--color-blue);
}

.EditorContent {
  font-size: 1.6rem;
}
.EditorContent p {
  margin-block: 1em;
}
.EditorContent h1,
.EditorContent h2,
.EditorContent h3,
.EditorContent h4,
.EditorContent h5,
.EditorContent h6 {
  margin-block: 2em 1em;
  font-weight: bold;
  line-height: 1.4;
}
.EditorContent ul {
  margin-block: 1em;
  padding-inline: 1.5em;
  list-style: disc;
}
.EditorContent ol {
  margin-block: 1em;
  padding-inline: 1.5em;
  list-style: decimal;
}
.EditorContent li {
  margin-block: 0.5em;
}
.EditorContent a {
  text-decoration: underline;
  color: var(--color-blue);
}

.SiteHeader {
  --bg-color: var(--color-brown-dark);
  --text-color: #fff;
  --logo-color: #fff;
  position: sticky;
  z-index: 100;
  top: 0;
  padding-inline: var(--site-gap);
  width: 100%;
  height: var(--site-header-height);
  background-color: var(--bg-color);
  color: var(--text-color);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (max-width: 1080px) {
  .SiteHeader:not(.SiteHeader-home) {
    --bg-color: var(--color-beige);
    --text-color: var(--color-brown-dark);
    --logo-color: var(--color-blue);
  }
}
.SiteHeader .SiteHeader__left {
  display: flex;
  align-items: center;
}
.SiteHeader .SiteHeader__right {
  display: flex;
  align-items: center;
  gap: 2.5rem;
}

.SiteHeaderLogo {
  --size: 6.4rem;
  margin: 0;
  color: var(--logo-color);
}
@media (max-width: 1080px) {
  .SiteHeaderLogo {
    --size: 3.2rem;
  }
}
.SiteHeaderLogo svg {
  display: block;
  width: auto;
  height: var(--size);
}

.SiteHeaderNav {
  font-size: 1.8rem;
  display: flex;
  align-items: center;
}
@media (max-width: 1080px) {
  .SiteHeaderNav {
    display: none;
  }
}
.SiteHeaderNav .list {
  display: flex;
  gap: 2em;
}
.SiteHeaderNav .list .item {
  position: relative;
}
.SiteHeaderNav .list .item .link {
  display: block;
  font-family: var(--font-family-mincho);
}
.SiteHeaderNav .list .item .sub {
  --space: 5rem;
  font-size: 1.6rem;
  position: absolute;
  left: 50%;
  translate: -50% 0;
  top: calc(100% + var(--space));
  border: 1px solid #fff;
  padding: 0.8em 1em;
  border-radius: 1rem;
  background-color: rgba(0, 0, 0, 0.7);
  white-space: nowrap;
}
.SiteHeaderNav .list .item .sub::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100% + 1px);
  height: var(--space);
}
.SiteHeaderNav .list .item .sub .sub-item {
  padding: 0.3em 0;
}
.SiteHeaderNav .list .item .sub .sub-item:nth-child(n+2) {
  border-top: 1px solid #fff;
}
.SiteHeaderNav .list .item .sub .sub-item .sub-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5em;
}
.SiteHeaderNav .list .item .sub .sub-item .sub-link.indent {
  padding-left: 1em;
}
.SiteHeaderNav .list .item .sub .sub-item .sub-link::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.SiteHeaderMenuButton {
  position: relative;
  z-index: 2;
  aspect-ratio: 1;
  border: none;
  padding: 0;
  width: 4.4rem;
  height: auto;
  border-radius: 50%;
  background-color: #5d5753;
  color: #fff;
}
@media (max-width: 1080px) {
  .SiteHeaderMenuButton {
    width: 2.7rem;
  }
}
.SiteHeaderMenuButton svg {
  display: block;
  width: 100%;
  height: 100%;
}

.js-has-pseudo [csstools-has-2q-33-2s-3d-1m-2w-2p-37-14-1a-2b-2x-38-2t-28-33-34-33-3a-2t-36-25-2t-32-39-2j-2p-36-2x-2p-19-2w-2x-2s-2s-2t-32-1p-2u-2p-30-37-2t-2l-15]:not(.does-not-exist):not(does-not-exist) {
  overflow: hidden;
}

body:has(.SitePopoverMenu[aria-hidden=false]) {
  overflow: hidden;
}

.SitePopoverMenu {
  position: fixed;
  z-index: 101;
  right: 0;
  top: 0;
  background-color: var(--color-brown-dark);
  color: #fff;
}
@media (min-width: 1080.01px) {
  .SitePopoverMenu {
    width: min(100% - 2.4rem, 1600px);
    border-bottom-left-radius: 10rem;
  }
}
@media (max-width: 1080px) {
  .SitePopoverMenu {
    width: 100%;
    height: 100%;
  }
}
.SitePopoverMenu[aria-hidden=true] {
  display: none;
}
.SitePopoverMenu .SitePopoverMenuHeader {
  padding-inline: var(--site-gap);
  height: var(--site-header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.SitePopoverMenu .SitePopoverMenuHeader .SitePopoverMenuHeader__left {
  display: flex;
  align-items: center;
}
.SitePopoverMenu .SitePopoverMenuHeader .SitePopoverMenuHeader__right {
  display: flex;
  align-items: center;
}
.SitePopoverMenu .SitePopoverMenuHeader .logo a {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
}
.SitePopoverMenu .SitePopoverMenuHeader .logo a img {
  display: block;
  width: auto;
  height: 4rem;
}
@media (max-width: 1080px) {
  .SitePopoverMenu .SitePopoverMenuHeader .logo a img {
    height: 2.4rem;
  }
}
@media (min-width: 1080.01px) {
  .SitePopoverMenu .SitePopoverMenuBody {
    padding-block: 3rem 9rem;
  }
}
@media (max-width: 1080px) {
  .SitePopoverMenu .SitePopoverMenuBody {
    overflow-y: scroll;
    padding: 0 var(--site-gap) 2rem;
    height: calc(100% - var(--site-header-height));
  }
}
@media (min-width: 1080.01px) {
  .SitePopoverMenu .SitePopoverMenuItems {
    font-size: 1.5rem;
    margin-inline: auto;
    width: -moz-fit-content;
    width: fit-content;
    line-height: 1.4;
    font-weight: 200;
    display: flex;
    flex-wrap: wrap;
    gap: 2em;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column {
    border-left: 1px solid rgba(255, 255, 255, 0.5);
    padding-left: 1em;
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 0.4em;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .large {
    font-size: 106.66%;
    font-weight: 500;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .indent {
    margin-left: 1em;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .outline {
    border: 1px solid currentcolor;
    padding: 0.1em 0.8em;
    min-width: 9em;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .space {
    height: 0.6em;
  }
}
@media (max-width: 1080px) {
  .SitePopoverMenu .SitePopoverMenuItems {
    margin: 0 0 0 1em;
    padding-block: 1rem 2rem;
    width: -moz-fit-content;
    width: fit-content;
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 2em;
    font-size: 1.2rem;
    font-weight: 200;
    line-height: 1.3;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 1em;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .large,
  .SitePopoverMenu .SitePopoverMenuItems .column .sp-large {
    font-size: 106.66%;
    font-weight: 400;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .outline {
    border: 1px solid currentcolor;
    padding: 0.1em 0.8em;
    min-width: 9em;
  }
  .SitePopoverMenu .SitePopoverMenuItems .column .space {
    margin-top: -0.5em;
    height: 0;
  }
}

.SitePopoverMenuTel {
  font-size: 1.2rem;
  line-height: 1;
  border: 1px solid #fff;
  padding: 1em 1.3em 0.8em;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: var(--base-radius);
  display: grid;
  grid-template-columns: auto auto auto;
  gap: 0.5em 0.7em;
  align-items: center;
}
@media (min-width: 1080.01px) {
  .SitePopoverMenuTel {
    display: none;
  }
}
.SitePopoverMenuTel::before {
  content: "";
  width: 1.2em;
  height: 1.2em;
  background-color: #fff;
  -webkit-mask: url("../assets/common/icon-tel.svg") no-repeat 50%/93.75% auto;
          mask: url("../assets/common/icon-tel.svg") no-repeat 50%/93.75% auto;
}
.SitePopoverMenuTel .title {
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
.SitePopoverMenuTel .number {
  font-size: 125%;
  font-weight: bold;
}
.SitePopoverMenuTel .notes {
  grid-column: 3/span 1;
  font-size: 81%;
}

.SiteFooter {
  background-color: var(--color-brown-dark);
  color: #fff;
}
.SiteFooter .SiteFooter__totop {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  position: relative;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__totop {
    display: none;
  }
}
.SiteFooter .SiteFooter__totop .SiteFooterTotop {
  --size: 8.4rem;
  --font-size: max(1rem, 10px);
  position: absolute;
  right: 0;
  top: calc(-0.5 * var(--size));
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1em;
  font-size: var(--font-size);
  line-height: 1;
  color: var(--color-blue);
  transition: 0.2s;
  transition-property: background-color, color;
}
.SiteFooter .SiteFooter__totop .SiteFooterTotop::before {
  content: "";
  width: 1.2em;
  height: 1.2em;
  background-color: currentcolor;
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  rotate: -90deg;
}
.SiteFooter .SiteFooter__totop .SiteFooterTotop:hover {
  transition-duration: 0.3s;
  background-color: var(--color-blue);
  color: #fff;
}
.SiteFooter .SiteFooter__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  padding-block: 9rem;
  display: grid;
  gap: 3rem;
  grid-template: "logo ." auto ". ." 0 "address nav" auto "toahome nav" auto ". ." 2rem "bottom bottom" auto/auto auto;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container {
    padding-block: 4rem;
    gap: 2rem;
    grid-template: "logo" auto "." 0 "address" auto "toahome" auto "bottom" auto/auto;
    justify-items: center;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__logo {
  grid-area: logo;
}
.SiteFooter .SiteFooter__container .SiteFooter__logo img {
  width: 25.4rem;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__logo img {
    width: 16.6rem;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__address {
  grid-area: address;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__address {
    font-size: 1.3rem;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__toahome {
  grid-area: toahome;
}
.SiteFooter .SiteFooter__container .SiteFooter__toahome img {
  width: 25rem;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__toahome img {
    width: 18.9rem;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__nav {
  grid-area: nav;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__nav {
    display: none;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__bottom {
  grid-area: bottom;
  border-top: 1px solid rgba(255, 255, 255, 0.5);
  padding-top: 2rem;
  display: flex;
  align-items: center;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__bottom {
    border-top: none;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__bottom .copyright {
  font-size: 1.3rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__bottom .copyright {
    font-size: 0.7rem;
  }
}
.SiteFooter .SiteFooter__container .SiteFooter__bottom .links {
  font-size: 1.3rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
@media (max-width: 1080px) {
  .SiteFooter .SiteFooter__container .SiteFooter__bottom .links {
    display: none;
  }
}

.SiteFooterNav {
  min-height: 100%;
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 200;
  display: flex;
  flex-wrap: wrap;
  gap: 2em;
}
.SiteFooterNav .column {
  border-left: 1px solid rgba(255, 255, 255, 0.5);
  padding-left: 2em;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 0.4em;
}
.SiteFooterNav .column .large {
  font-size: 106.66%;
  font-weight: 500;
}
.SiteFooterNav .column .large + a {
  margin-top: 0.4em;
}
.SiteFooterNav .column .indent {
  margin-left: 1em;
}
.SiteFooterNav .column .outline {
  border: 1px solid currentcolor;
  padding: 0.1em 0.8em;
  min-width: 9em;
}
.SiteFooterNav .column .space {
  height: 0.6em;
}
.SiteFooterNav .column .footer-hidden {
  display: none;
}

.SiteContact {
  margin-block: 12rem;
}
@media (max-width: 1080px) {
  .SiteContact {
    margin-block: 5rem;
  }
}
.SiteContact .SiteContact__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: flex;
  justify-content: space-between;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContact__container {
    flex-direction: column;
    gap: 2rem;
  }
}
.SiteContact .SiteContactHeader .heading {
  font-size: 2rem;
  line-height: 1;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactHeader .heading {
    font-size: 1rem;
  }
}
.SiteContact .SiteContactHeader .english {
  margin-top: 0.2em;
  font-size: 8.8rem;
  line-height: 1;
  font-family: var(--font-family-serif);
  color: var(--color-brown);
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactHeader .english {
    font-size: 4.4rem;
  }
}
.SiteContact .SiteContactHeader .description {
  margin-top: 1rem;
  font-size: 1.8rem;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactHeader .description {
    font-size: 1rem;
  }
}
.SiteContact .SiteContactCards {
  display: grid;
  grid-template: 20rem/36rem 36rem;
  gap: 2.4rem;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCards {
    grid-template: 7rem 7rem/100%;
    gap: 1.7rem;
  }
}
.SiteContact .SiteContactCard {
  position: relative;
  border: 1px solid var(--color-blue);
  padding: 3.5rem 2rem 2rem 3.5rem;
  border-radius: var(--base-radius);
  color: var(--color-blue);
  line-height: 1.4;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard {
    justify-content: start;
    padding: 1.4rem 2.4rem 0;
  }
}
.SiteContact .SiteContactCard.-contact {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.SiteContact .SiteContactCard.-contact:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard.-contact {
    justify-content: start;
    gap: 0.3rem;
  }
}
.SiteContact .SiteContactCard.-tel {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard.-tel {
    flex-direction: row;
    align-items: start;
    justify-content: start;
    gap: 1rem;
  }
}
.SiteContact .SiteContactCard .title {
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-size: 2.3rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard .title {
    font-size: 1.8rem;
  }
}
.SiteContact .SiteContactCard .title::before {
  content: "";
  width: 1.4em;
  height: 1.4em;
  background-color: currentcolor;
}
.SiteContact .SiteContactCard .title.contact-icon::before {
  -webkit-mask: url("../assets/common/icon-mail.svg") no-repeat 50%/100% auto;
          mask: url("../assets/common/icon-mail.svg") no-repeat 50%/100% auto;
}
.SiteContact .SiteContactCard .title.tel-icon::before {
  -webkit-mask: url("../assets/common/icon-tel.svg") no-repeat 50%/93.75% auto;
          mask: url("../assets/common/icon-tel.svg") no-repeat 50%/93.75% auto;
}
.SiteContact .SiteContactCard .notes {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard .notes {
    font-size: 1.1rem;
  }
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard.-contact .notes {
    margin-left: 3.7rem;
  }
}
.SiteContact .SiteContactCard .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  position: absolute;
  right: 2rem;
  bottom: 2rem;
}
.SiteContact .SiteContactCard .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard .arrow {
    --disc-arrow-size: 3.2rem;
    right: 1.4rem;
    bottom: 1.4rem;
  }
}
.SiteContact .SiteContactCard .tel-text {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 1.5rem;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard .tel-text {
    margin-top: 0.5rem;
    gap: 0.5rem;
  }
}
.SiteContact .SiteContactCard .number {
  width: auto;
  height: 2.2rem;
}
@media (max-width: 1080px) {
  .SiteContact .SiteContactCard .number {
    height: 1.66rem;
  }
}

.SitePageHeader {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 7rem;
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  gap: 1.5rem 2rem;
}
@media (max-width: 1080px) {
  .SitePageHeader {
    margin-block: 2rem;
    gap: 1rem;
  }
}
.SitePageHeader .heading {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  line-height: 1.2;
}
@media (max-width: 1080px) {
  .SitePageHeader .heading {
    width: 100%;
    gap: 0.5rem;
  }
}
.SitePageHeader .heading .english {
  margin: 0;
  font-size: 2rem;
  line-height: 1;
  font-family: var(--font-family-serif);
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .SitePageHeader .heading .english {
    font-size: 1.6rem;
  }
}
.SitePageHeader .heading .title {
  margin: 0;
  font-size: 5rem;
  font-family: var(--font-family-mincho);
  font-weight: normal;
  color: var(--color-brown);
}
@media (max-width: 1080px) {
  .SitePageHeader .heading .title {
    font-size: 2.5rem;
  }
}
.SitePageHeader .topicpath {
  flex-grow: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  font-size: max(1.3rem, 12px);
  line-height: 1.3;
}
@media (max-width: 1080px) {
  .SitePageHeader .topicpath {
    font-size: 1rem;
  }
}
.SitePageHeader .topicpath > li:nth-child(n+2)::before {
  content: "ー";
  margin-inline: 0.6em;
  color: var(--color-blue);
}

.ModuleHrdNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 2rem;
  font-size: 1.9rem;
  color: var(--color-blue-light);
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .ModuleHrdNav {
    display: none;
  }
}
.ModuleHrdNav dl {
  padding: 0.75em 1.5em;
  border-radius: 2em;
  background-color: var(--color-blue);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em 2em;
}
.ModuleHrdNav dl dt {
  display: flex;
  align-items: center;
  gap: 2em;
}
.ModuleHrdNav dl dt::after {
  content: "";
  border-right: 1px solid currentcolor;
  height: 1em;
}
.ModuleHrdNav dl dt a:hover {
  color: #fff;
}
.ModuleHrdNav dl dd {
  flex-grow: 1;
  display: flex;
  align-items: center;
  gap: 1.5em;
}
.ModuleHrdNav dl dd a {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.ModuleHrdNav dl dd a:hover {
  color: #fff;
}
.ModuleHrdNav dl dd a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.SitePageKv {
  width: 100%;
  height: min(67.4rem, 674px);
  overflow: hidden;
}
@media (min-width: 1080.01px) {
  .SitePageKv {
    margin-block: 5rem 10rem;
  }
}
@media (max-width: 1080px) {
  .SitePageKv {
    margin-block: 2rem 3rem;
    height: 21.1rem;
  }
}
.SitePageKv .image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}

.Banners {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  --banner-item-width: 57.5rem;
  margin-block: 12rem;
  display: grid;
  grid-template-columns: var(--banner-item-width) var(--banner-item-width);
  gap: 5rem;
}
@media (max-width: 1080px) {
  .Banners {
    --banner-item-width: var(--content-width);
    margin-block: 5rem;
    grid-template-columns: 100%;
    gap: 3rem;
  }
}

.BannerWooden {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  position: relative;
  aspect-ratio: 57.5/21.5;
  height: auto;
  border-radius: calc(var(--banner-item-width) * 20 / 575);
  overflow: hidden;
  color: #fff;
  font-size: calc(var(--banner-item-width) * 37 / 575);
  line-height: 1;
  display: grid;
  place-content: center;
}
.BannerWooden:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.BannerWooden .bg {
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.BannerWooden .bg img {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.BannerWooden .content {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5em;
  margin-top: 0.3em;
}
.BannerWooden .content .english {
  position: absolute;
  top: -1em;
  left: 0;
  font-size: 43.2432432432%;
  font-family: var(--font-family-serif);
}
.BannerWooden .content .text {
  font-family: var(--font-family-mincho);
}
.BannerWooden .content .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  --disc-arrow-size: calc(1em * 64 / 37);
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
}
.BannerWooden .content .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}

.BannerHrd {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  position: relative;
  aspect-ratio: 57.5/21.5;
  height: auto;
  border-radius: calc(var(--banner-item-width) * 20 / 575);
  overflow: hidden;
  color: #fff;
  font-size: calc(var(--banner-item-width) * 35 / 575);
  line-height: 1;
  display: grid;
  align-content: center;
}
.BannerHrd:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.BannerHrd .bg {
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.BannerHrd .bg img {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.BannerHrd .content {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5em;
  padding-left: 1em;
}
.BannerHrd .content .text {
  font-family: var(--font-family-mincho);
}
.BannerHrd .content .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  --disc-arrow-size: calc(1em * 64 / 35);
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
}
.BannerHrd .content .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}

.ModuleLocalNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  font-size: 1.9rem;
  display: flex;
  align-items: center;
  gap: 0.7em;
}
@media (max-width: 1080px) {
  .ModuleLocalNav {
    display: none;
  }
}
.ModuleLocalNav a {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.ModuleLocalNav a[aria-current=page] {
  background-color: var(--color-blue);
}
.ModuleLocalNav a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.ModulePageBottomNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
@media (min-width: 1080.01px) {
  .ModulePageBottomNav {
    margin-top: 10rem;
  }
}
@media (max-width: 1080px) {
  .ModulePageBottomNav {
    margin-top: 4.5rem;
  }
}
.ModulePageBottomNav .box {
  padding-inline: var(--site-gap);
  background-color: #fff;
}
@media (min-width: 1080.01px) {
  .ModulePageBottomNav .box {
    padding-block: 6rem;
    border-radius: 3.9rem;
  }
}
@media (max-width: 1080px) {
  .ModulePageBottomNav .box {
    padding-block: 2rem;
    border-radius: 1.3rem;
  }
}
.ModulePageBottomNav .list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.7em;
}
@media (min-width: 1080.01px) {
  .ModulePageBottomNav .list {
    font-size: 1.9rem;
  }
}
@media (max-width: 1080px) {
  .ModulePageBottomNav .list {
    font-size: 1.1rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}
.ModulePageBottomNav .list a {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.ModulePageBottomNav .list a[aria-current=page] {
  display: none;
}
.ModulePageBottomNav .list a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.ModuleHrdBanner {
  padding-inline: var(--site-gap);
  background: #fff;
}
@media (min-width: 1080.01px) {
  .ModuleHrdBanner {
    margin-top: 60px;
    padding-block: 60px;
  }
}
@media (max-width: 1080px) {
  .ModuleHrdBanner {
    margin-top: 30px;
    padding-block: 40px;
  }
}
.ModuleHrdBanner .banner {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
  display: flex;
  margin-inline: auto;
  max-width: var(--content-width);
}
.ModuleHrdBanner .banner:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.ModuleHrdBanner .banner:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
@media (min-width: 1080.01px) {
  .ModuleHrdBanner .banner {
    align-items: end;
    justify-content: space-between;
  }
}
@media (max-width: 1080px) {
  .ModuleHrdBanner .banner {
    position: relative;
    justify-content: center;
    --disc-arrow-size: 4rem;
    --disc-arrow-border-color: #fff;
    --disc-arrow-bg-color: #fff;
    --disc-arrow-icon-color: var(--color-blue);
  }
  .ModuleHrdBanner .banner:hover {
    --disc-arrow-border-color: #fff;
    --disc-arrow-bg-color: #fff;
    --disc-arrow-icon-color: var(--color-blue);
  }
}
.ModuleHrdBanner .banner .title {
  line-height: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25em;
}
@media (min-width: 1080.01px) {
  .ModuleHrdBanner .banner .title {
    font-size: 4.2rem;
    padding-bottom: 1em;
    color: var(--color-blue);
  }
}
@media (max-width: 1080px) {
  .ModuleHrdBanner .banner .title {
    font-size: 2.6rem;
    position: absolute;
    z-index: 1;
    top: 50%;
    translate: 0 -50%;
    flex-direction: row;
    align-items: center;
    color: #fff;
  }
}
.ModuleHrdBanner .banner .title .text {
  font-family: var(--font-family-mincho);
}
.ModuleHrdBanner .banner .title .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.ModuleHrdBanner .banner .title .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
.ModuleHrdBanner .banner .image {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  height: auto;
  border-radius: var(--base-radius);
}
@media (min-width: 1080.01px) {
  .ModuleHrdBanner .banner .image {
    width: 75rem;
  }
}
@media (max-width: 1080px) {
  .ModuleHrdBanner .banner .image {
    width: 100%;
  }
}

.WoodLocalNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  font-size: 1.9rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.7em;
}
@media (max-width: 1080px) {
  .WoodLocalNav {
    display: none;
  }
}
.WoodLocalNav a {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.WoodLocalNav a:nth-child(-n+3) {
  background-color: #b8a18e;
}
.WoodLocalNav a:nth-child(4) {
  grid-column: 1/span 1;
}
.WoodLocalNav a[aria-current=page] {
  background-color: var(--color-blue);
}
.WoodLocalNav a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.WoodBottomNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
@media (min-width: 1080.01px) {
  .WoodBottomNav {
    margin-top: 10rem;
  }
}
@media (max-width: 1080px) {
  .WoodBottomNav {
    margin-top: 4.5rem;
  }
}
.WoodBottomNav .box {
  padding-inline: var(--site-gap);
  background-color: #fff;
  display: flex;
}
@media (min-width: 1080.01px) {
  .WoodBottomNav .box {
    padding-block: 6rem;
    border-radius: 3.9rem;
    align-items: center;
    justify-content: center;
    gap: 6rem;
  }
}
@media (max-width: 1080px) {
  .WoodBottomNav .box {
    padding-block: 2rem;
    border-radius: 1.3rem;
    flex-direction: column;
  }
}
.WoodBottomNav .heading {
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-brown);
  display: flex;
  flex-direction: column;
  align-items: start;
}
@media (min-width: 1080.01px) {
  .WoodBottomNav .heading {
    font-size: 2.6rem;
    margin-bottom: 0.5em;
  }
}
@media (max-width: 1080px) {
  .WoodBottomNav .heading {
    font-size: 1.4rem;
    margin-bottom: 1em;
    align-items: center;
    gap: 0.3em;
  }
}
.WoodBottomNav .heading a {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.WoodBottomNav .heading a:hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
.WoodBottomNav .heading .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.WoodBottomNav .heading .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .WoodBottomNav .heading .arrow {
    --disc-arrow-size: 2.4rem;
  }
}
.WoodBottomNav .list {
  display: grid;
  gap: 0.7em;
}
@media (min-width: 1080.01px) {
  .WoodBottomNav .list {
    grid-template-columns: repeat(2, 29rem);
    font-size: 1.9rem;
  }
}
@media (max-width: 1080px) {
  .WoodBottomNav .list {
    font-size: 1.1rem;
    display: grid;
    grid-template-columns: 1fr;
  }
}
.WoodBottomNav .list a {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.WoodBottomNav .list a[aria-current=page] {
  display: none;
}
.WoodBottomNav .list a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.ServiceLocalNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: flex;
  font-size: 1.9rem;
  gap: 2rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .ServiceLocalNav {
    display: none;
  }
}
.ServiceLocalNav > a {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
}
.ServiceLocalNav > a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
.ServiceLocalNav > a[aria-current=page] {
  background-color: var(--color-blue);
}
.ServiceLocalNav > dl {
  padding: 0.75em 1.5em;
  border-radius: 2em;
  background-color: #aaa6a4;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em 2em;
  color: #fff;
}
.js-has-pseudo [csstools-has-1a-2b-2t-36-3a-2x-2r-2t-24-33-2r-2p-30-26-2p-3a-w-1q-w-2s-30-1m-2w-2p-37-14-2j-2p-36-2x-2p-19-2r-39-36-36-2t-32-38-1p-34-2p-2v-2t-2l-15]:not(.does-not-exist):not(does-not-exist) {
  background-color: var(--color-blue);
}
.ServiceLocalNav > dl:has([aria-current=page]) {
  background-color: var(--color-blue);
}
.ServiceLocalNav > dl dt {
  display: flex;
  align-items: center;
  gap: 2em;
}
.ServiceLocalNav > dl dt::after {
  content: "";
  border-right: 1px solid currentcolor;
  height: 1em;
}
.ServiceLocalNav > dl dd {
  flex-grow: 1;
  display: flex;
  align-items: center;
  gap: 1.5em;
}
.ServiceLocalNav > dl dd a {
  display: flex;
  align-items: center;
  gap: 0.5em;
  color: rgba(255, 255, 255, 0.6);
}
.ServiceLocalNav > dl dd a:hover {
  color: #fff;
}
.ServiceLocalNav > dl dd a[aria-current=page] {
  color: #fff;
}
.ServiceLocalNav > dl dd a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.ServiceBottomNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  font-size: 1.9rem;
}
@media (min-width: 1080.01px) {
  .ServiceBottomNav {
    margin-top: 10rem;
  }
}
@media (max-width: 1080px) {
  .ServiceBottomNav {
    margin-top: 4.5rem;
    font-size: 1.8rem;
  }
}
.ServiceBottomNav .box {
  padding-inline: var(--site-gap);
  background-color: #fff;
  display: flex;
  justify-content: center;
  gap: 2rem;
}
@media (min-width: 1080.01px) {
  .ServiceBottomNav .box {
    padding-block: 6rem;
    border-radius: 3.9rem;
  }
}
@media (max-width: 1080px) {
  .ServiceBottomNav .box {
    padding-block: 2rem;
    border-radius: 1.3rem;
    flex-direction: column;
  }
}
.ServiceBottomNav .button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  min-width: 11em;
}
.ServiceBottomNav .button[aria-current=page] {
  display: none;
}
.ServiceBottomNav .button::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
.ServiceBottomNav .senmon {
  padding: 0.75em 1.5em;
  border-radius: 2em;
  background-color: #aaa6a4;
  display: flex;
  align-items: center;
  gap: 0.5em 2em;
  color: #fff;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .ServiceBottomNav .senmon {
    border-radius: 1em;
    flex-direction: column;
    gap: 0.5em;
  }
}
.ServiceBottomNav .senmon dt {
  display: flex;
  align-items: center;
  gap: 2em;
}
.ServiceBottomNav .senmon dt::after {
  content: "";
  border-right: 1px solid currentcolor;
  height: 1em;
}
@media (max-width: 1080px) {
  .ServiceBottomNav .senmon dt::after {
    display: none;
  }
}
.ServiceBottomNav .senmon dd {
  flex-grow: 1;
  display: flex;
  align-items: center;
  gap: 1.5em;
}
@media (max-width: 1080px) {
  .ServiceBottomNav .senmon dd {
    width: 100%;
    flex-direction: column;
    gap: 0.5em;
  }
}
.ServiceBottomNav .senmon dd a {
  display: flex;
  align-items: center;
  gap: 0.5em;
  color: rgba(255, 255, 255, 0.6);
}
@media (max-width: 1080px) {
  .ServiceBottomNav .senmon dd a {
    width: 100%;
    justify-content: space-between;
  }
}
.ServiceBottomNav .senmon dd a:hover {
  color: #fff;
}
.ServiceBottomNav .senmon dd a[aria-current=page] {
  display: none;
}
.ServiceBottomNav .senmon dd a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.ModulePageIndexNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 7rem;
  display: grid;
  grid-template-columns: 57.1rem 57.1rem;
  gap: 5.8rem;
  font-size: 2rem;
}
@media (max-width: 1080px) {
  .ModulePageIndexNav {
    margin-top: 3rem;
    grid-template-columns: 1fr;
    gap: 2rem;
    font-size: 1.5rem;
  }
}
.ModulePageIndexNav > li > a {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  display: grid;
  gap: 0.7em;
  line-height: 1.3;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-brown);
}
.ModulePageIndexNav > li > a:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.ModulePageIndexNav > li > a .image {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  aspect-ratio: 571/296;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: var(--base-radius);
}
.ModulePageIndexNav > li > a .title {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.ModulePageIndexNav > li > a .title::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  --link-icon-color: var(--color-blue-light);
  translate: 0 0.1em;
}

.FormRequiredLabel,
.FormOptionalLabel {
  display: inline-block;
  padding: 0.25em 0.5em;
  color: white;
  line-height: 1;
  font-size: 1.4rem;
  border-radius: 0.4rem;
  white-space: nowrap;
}
.FormRequiredLabel:where(.FormRequiredLabel),
.FormOptionalLabel:where(.FormRequiredLabel) {
  background-color: #b00000;
}
.FormRequiredLabel:where(.FormOptionalLabel),
.FormOptionalLabel:where(.FormOptionalLabel) {
  background-color: #6f6d6d;
}

.FormLayout {
  margin-block: 5rem;
  display: grid;
  font-size: 1.4rem;
}
@media (min-width: 1080.01px) {
  .FormLayout {
    grid-template-columns: auto 1fr;
    gap: 4rem 2rem;
  }
}
@media (max-width: 1080px) {
  .FormLayout {
    margin-block: 3rem;
    gap: 1rem;
  }
}
.FormLayout.FormLayoutOne {
  grid-template-columns: 1fr;
  margin-top: 3rem;
  gap: 1rem;
}
.FormLayout > dt {
  font-weight: bold;
  display: flex;
  align-items: baseline;
  gap: 0.5em;
}
@media (max-width: 1080px) {
  .FormLayout > dt:not(:first-child) {
    margin-top: 2rem;
  }
}
.FormLayout > dd {
  display: grid;
  gap: 1rem;
}

:where(input[type=text], input[type=email], input[type=tel], select, textarea).FormControl {
  display: block;
  padding: 0.3em;
  border: 1px solid #d6d3d5;
  font-size: 1.6rem;
  border-radius: 0.3rem;
  width: 100%;
}
:where(input[type=text], input[type=email], input[type=tel], select, textarea).FormControl::-moz-placeholder {
  color: #c9caca;
}
:where(input[type=text], input[type=email], input[type=tel], select, textarea).FormControl::placeholder {
  color: #c9caca;
}
:where(input[type=text], input[type=email], input[type=tel], select, textarea).FormControl:where(textarea) {
  min-height: 7lh;
}
@media (max-width: 1080px) {
  :where(input[type=text], input[type=email], input[type=tel], select, textarea).FormControl:where(textarea) {
    min-height: 6lh;
  }
}
:where(input[type=text], input[type=email], input[type=tel], select, textarea).FormControl.zipcode-width {
  max-width: 12rem;
}

label.FormControl {
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.6rem;
}
label.FormControl input {
  margin: 0;
}

.FormCheckItems {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 2rem;
}

.FormAgreement {
  margin-block: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.FormAgreement.with-border {
  margin-top: 10rem;
  padding-top: 3rem;
  border-top: 1px solid #6f6d6d;
}
@media (max-width: 1080px) {
  .FormAgreement.with-border {
    margin-top: 5rem;
  }
}
.FormAgreement p {
  font-size: 1.4rem;
}
.FormAgreement a {
  text-decoration: underline;
}
.FormAgreement label.FormControl {
  align-self: center;
}
.FormAgreement .FormError {
  align-self: center;
  font-size: 1.4rem;
}

.FormButtonWrap {
  margin-block: 4rem;
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  align-items: center;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .FormButtonWrap {
    flex-direction: column;
  }
}

.FormButton {
  position: relative;
  color: white;
  border: none;
  padding: 0.9em 1.5em;
  font-size: 1.8rem;
  font-weight: bold;
  background-color: #aaa6a4;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 15em;
  max-width: 100%;
  border-radius: 2em;
}
.FormButton::after {
  content: "";
  position: absolute;
  right: 1.2em;
  top: calc(50% - 0.5em);
  width: 0.8em;
  height: 0.8em;
  -webkit-mask: var(--link-arrow-url) no-repeat center/contain;
          mask: var(--link-arrow-url) no-repeat center/contain;
  background-color: currentcolor;
}
.FormButton.send {
  background-color: var(--color-blue);
}
.FormButton.back::after {
  transform: rotate(180deg);
  left: 1.2em;
  right: unset;
}

.FormError {
  color: red;
}

.FormErrorMessage {
  margin-block: 3rem;
  color: red;
  font-size: 1.6rem;
  display: flex;
  justify-content: center;
}

.FormFinish {
  margin: 5rem auto 0;
  border-top: 1px solid #6f6d6d;
  padding-top: 5rem;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.6rem;
  display: flex;
  flex-direction: column;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .FormFinish {
    margin-top: 3rem;
    padding-top: 3rem;
  }
}
.FormFinish .tel {
  align-self: start;
  font-size: 2rem;
  font-weight: bold;
}

.FormConfirmValue {
  font-size: 1.8rem;
}

.FormCheckList {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
}

.PageHomeKv {
  position: relative;
  z-index: 1;
  clip-path: inset(0);
}
.PageHomeKv .PageHomeKv__video {
  position: fixed;
  z-index: -1;
  top: var(--site-header-height);
  left: 0;
  width: 100%;
  height: var(--viewport-height-without-header);
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center top;
     object-position: center top;
}
.PageHomeKv .PageHomeKv__paragraph {
  margin: 0;
  height: var(--viewport-height-without-header);
  display: grid;
  place-content: center;
  text-align: center;
  color: #fff;
  line-height: 2.5;
  font-family: var(--font-family-mincho);
  font-size: 1.71875vw;
}
@media (max-width: 1080px) {
  .PageHomeKv .PageHomeKv__paragraph {
    font-size: 5.2777777778vw;
  }
}
.PageHomeKv .PageHomeKv__title {
  width: auto;
  height: 3.7em;
}
@media (max-width: 1080px) {
  .PageHomeKv .PageHomeKv__title {
    height: 2.5em;
  }
}
@keyframes homeTitleFadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.PageHomeKv .PageHomeKv__title path {
  animation: homeTitleFadein 0.6s both;
}
.PageHomeKv .PageHomeKv__title path:nth-child(1) {
  animation-delay: 0.06s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(2) {
  animation-delay: 0.12s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(3) {
  animation-delay: 0.18s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(4) {
  animation-delay: 0.24s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(5) {
  animation-delay: 0.3s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(6) {
  animation-delay: 0.36s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(7) {
  animation-delay: 0.42s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(8) {
  animation-delay: 0.48s;
}
.PageHomeKv .PageHomeKv__title path:nth-child(9) {
  animation-delay: 0.54s;
}
.PageHomeKv .PageHomeKv__logo {
  width: auto;
  height: 3.5em;
}

.PageHomeNews {
  padding-block: 14rem 16rem;
}
@media (max-width: 1080px) {
  .PageHomeNews {
    padding-block: 5rem 7rem;
  }
}
.PageHomeNews .PageHomeNews__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: flex;
  gap: 20rem;
}
@media (max-width: 1080px) {
  .PageHomeNews .PageHomeNews__container {
    flex-direction: column;
    gap: 4rem;
  }
}

.PageHomeNewsHeader {
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 3rem 0;
}
@media (max-width: 1080px) {
  .PageHomeNewsHeader {
    flex-direction: row;
    align-items: end;
    justify-content: space-between;
  }
}
.PageHomeNewsHeader .hgroup {
  display: flex;
  flex-direction: column;
  line-height: 1;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHomeNewsHeader .hgroup {
    gap: 0.5rem;
  }
}
.PageHomeNewsHeader .hgroup .heading {
  font-size: 2rem;
  font-weight: normal;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHomeNewsHeader .hgroup .heading {
    font-size: 1rem;
  }
}
.PageHomeNewsHeader .hgroup .english {
  margin: 0;
  font-size: 8.8rem;
  font-family: var(--font-family-serif);
  color: var(--color-brown);
}
@media (max-width: 1080px) {
  .PageHomeNewsHeader .hgroup .english {
    font-size: 4.4rem;
  }
}
.PageHomeNewsHeader .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  font-size: 1.9rem;
}
.PageHomeNewsHeader .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (max-width: 1080px) {
  .PageHomeNewsHeader .link {
    font-size: 1rem;
  }
}

.PageHomeNewsList {
  flex-grow: 1;
  font-size: 1.7rem;
  padding-top: 4rem;
}
@media (max-width: 1080px) {
  .PageHomeNewsList {
    padding-top: 0;
  }
}

.PageHomeAbout {
  position: relative;
}
.PageHomeAbout .PageHomeAbout__bg {
  display: block;
  position: sticky;
  z-index: -1;
  top: var(--site-header-height);
  width: 100%;
  height: var(--viewport-height-without-header);
}
.PageHomeAbout .PageHomeAbout__bg > img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHomeAbout .PageHomeAbout__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  position: relative;
  padding-bottom: 40rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.PageHomeAbout .PageHomeAboutHeader {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.PageHomeAbout .PageHomeAboutHeader .heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
  gap: 2rem;
  color: var(--color-blue);
}
.PageHomeAbout .PageHomeAboutHeader .heading .english {
  margin: 0;
  font-size: 3rem;
  font-family: var(--font-family-serif);
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageHomeAbout .PageHomeAboutHeader .heading .english {
    font-size: 1.5rem;
  }
}
.PageHomeAbout .PageHomeAboutHeader .heading .title {
  font-size: 8.5rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageHomeAbout .PageHomeAboutHeader .heading .title {
    font-size: 4.4rem;
  }
}
.PageHomeAbout .PageHomeAboutHeader .phrase {
  margin-top: 6rem;
  text-align: center;
  font-size: 3.9rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHomeAbout .PageHomeAboutHeader .phrase {
    margin-top: 2.5rem;
    font-size: 2rem;
  }
}
.PageHomeAbout .PageHomeAboutHeader .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  padding-block: 1em;
  justify-content: center;
  gap: 1em;
  width: 14em;
}
.PageHomeAbout .PageHomeAboutHeader .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (min-width: 1080.01px) {
  .PageHomeAbout .PageHomeAboutHeader .link {
    margin-top: 15rem;
    font-size: 1.9rem;
  }
}
@media (max-width: 1080px) {
  .PageHomeAbout .PageHomeAboutHeader .link {
    margin-top: 3rem;
    font-size: 1rem;
  }
}
.PageHomeAbout .PageHomeAboutLinks {
  margin-top: 5rem;
  display: flex;
  justify-content: center;
  gap: 1.3rem;
  font-size: 1.9rem;
}
@media (max-width: 1080px) {
  .PageHomeAbout .PageHomeAboutLinks {
    display: none;
  }
}
.PageHomeAbout .PageHomeAboutLinks a {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  min-width: 8em;
  background-color: #fff;
  color: var(--color-blue);
}
.PageHomeAbout .PageHomeAboutLinks a::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}

.PageHomeHrd {
  --arc-mask-width: max(1920px, 100vw);
  --arc-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 100"><mask id="mask"><rect fill="white" width="10" height="100"/><ellipse cx="5" cy="-1" rx="5.77" ry="2"/></mask><rect mask="url(%23mask)" width="10" height="100"/></svg>');
  --arc-mask-height: calc(0.1 * var(--arc-mask-width));
  margin-block-start: calc(-1 * var(--arc-mask-height));
  -webkit-mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
          mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
  position: relative;
}
.PageHomeHrd .PageHomeHrdBg {
  display: block;
  position: sticky;
  z-index: -1;
  top: var(--site-header-height);
  width: 100%;
  height: var(--arc-mask-height);
}
.PageHomeHrd .PageHomeHrdBg > img {
  display: block;
  width: 100%;
  height: var(--viewport-height-without-header);
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHomeHrd .PageHomeHrdHeader {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  padding-top: 15rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 6rem;
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdHeader {
    padding-top: 5rem;
    gap: 3rem;
    align-items: center;
  }
}
.PageHomeHrd .PageHomeHrdHeader .hgroup {
  display: flex;
  flex-direction: column;
  line-height: 1;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdHeader .hgroup {
    gap: 0.5rem;
  }
}
.PageHomeHrd .PageHomeHrdHeader .hgroup .english {
  margin: 0;
  font-size: 3rem;
  font-family: var(--font-family-serif);
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdHeader .hgroup .english {
    font-size: 1.5rem;
  }
}
.PageHomeHrd .PageHomeHrdHeader .hgroup .heading {
  font-size: 8.5rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdHeader .hgroup .heading {
    font-size: 4.4rem;
  }
}
.PageHomeHrd .PageHomeHrdHeader .phrase {
  font-size: 3.9rem;
  line-height: 1;
  font-family: var(--font-family-serif);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdHeader .phrase {
    font-size: 2rem;
  }
}
.PageHomeHrd .PageHomeHrdHeader .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  font-size: 1.9rem;
}
.PageHomeHrd .PageHomeHrdHeader .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (min-width: 1080.01px) {
  .PageHomeHrd .PageHomeHrdHeader .link {
    width: 13em;
  }
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdHeader .link {
    font-size: 1rem;
  }
}
.PageHomeHrd .PageHomeHrdCards {
  margin-top: 7.5rem;
  padding-bottom: 40rem;
  overflow: hidden;
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdCards {
    margin-top: 3rem;
    padding-bottom: 20rem;
  }
}
.PageHomeHrd .PageHomeHrdCards .container {
  display: flex;
  gap: 3rem;
  padding-inline: max((100% - var(--content-width)) / 2, var(--site-gap)) 3rem;
  width: -moz-max-content;
  width: max-content;
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdCards .container {
    gap: 1.5rem;
  }
}
.PageHomeHrd .PageHomeHrdCards .card {
  font-size: 1rem;
  position: relative;
  padding: 4em 4em 6em;
  flex: 0 0 40em;
  background-color: var(--color-beige);
  border-radius: var(--base-radius);
  overflow: hidden;
  transition: filter 0.2s;
}
.PageHomeHrd .PageHomeHrdCards .card:hover {
  transition-duration: 0.3s;
  filter: brightness(1.1);
}
@media (max-width: 1080px) {
  .PageHomeHrd .PageHomeHrdCards .card {
    font-size: 0.6rem;
  }
}
.PageHomeHrd .PageHomeHrdCards .card::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
  font-size: 170%;
  position: absolute;
  right: 1.3em;
  bottom: 1.3em;
}
.PageHomeHrd .PageHomeHrdCards .icon {
  position: absolute;
  width: 14em;
  height: 14em;
  right: 0;
  top: 0;
}
.PageHomeHrd .PageHomeHrdCards .english {
  font-size: 170%;
  color: var(--color-blue);
}
.PageHomeHrd .PageHomeHrdCards .title {
  margin: 1em 0 0;
  font-size: 230%;
  font-weight: normal;
}
.PageHomeHrd .PageHomeHrdCards .description {
  margin-top: 1em;
  font-size: 170%;
}

.PageHomeWood {
  --arc-mask-width: max(1920px, 100vw);
  --arc-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 100"><mask id="mask"><rect fill="white" width="10" height="100"/><ellipse cx="5" cy="-1" rx="5.77" ry="2"/></mask><rect mask="url(%23mask)" width="10" height="100"/></svg>');
  --arc-mask-height: calc(0.1 * var(--arc-mask-width));
  margin-block-start: calc(-1 * var(--arc-mask-height));
  -webkit-mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
          mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
  position: relative;
}
.PageHomeWood .PageHomeWoodBg {
  display: block;
  position: sticky;
  z-index: -1;
  top: var(--site-header-height);
  width: 100%;
  height: var(--arc-mask-height);
}
.PageHomeWood .PageHomeWoodBg > img {
  display: block;
  width: 100%;
  height: var(--viewport-height-without-header);
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHomeWood .PageHomeWoodHeader {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  padding-top: 15rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 6rem;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodHeader {
    padding-top: 5rem;
    gap: 3rem;
    align-items: center;
    text-align: center;
  }
}
.PageHomeWood .PageHomeWoodHeader .hgroup {
  display: flex;
  flex-direction: column;
  line-height: 1;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodHeader .hgroup {
    gap: 0.5rem;
  }
}
.PageHomeWood .PageHomeWoodHeader .hgroup .english {
  margin: 0;
  font-size: 3rem;
  font-family: var(--font-family-serif);
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodHeader .hgroup .english {
    font-size: 1.5rem;
  }
}
.PageHomeWood .PageHomeWoodHeader .hgroup .heading {
  font-size: 8.5rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodHeader .hgroup .heading {
    font-size: 3.5rem;
  }
}
.PageHomeWood .PageHomeWoodHeader .phrase {
  font-size: 3.9rem;
  line-height: 1;
  font-family: var(--font-family-serif);
  font-weight: bold;
}
@media (min-width: 1080.01px) {
  .PageHomeWood .PageHomeWoodHeader .phrase br {
    display: none;
  }
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodHeader .phrase {
    font-size: 2rem;
    line-height: 1.75;
  }
}
.PageHomeWood .PageHomeWoodHeader .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  font-size: 1.9rem;
}
.PageHomeWood .PageHomeWoodHeader .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (min-width: 1080.01px) {
  .PageHomeWood .PageHomeWoodHeader .link {
    width: 13em;
  }
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodHeader .link {
    font-size: 1rem;
  }
}
.PageHomeWood .PageHomeWoodForWhom {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 10rem;
  display: flex;
  gap: 3.5rem;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodForWhom {
    margin-top: 4rem;
    flex-direction: column;
    align-items: center;
    gap: 3rem;
  }
}
.PageHomeWood .PageHomeWoodForWhom a {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  font-size: 2.3rem;
  position: relative;
  padding-left: 6.5em;
  padding-block: 1.3em;
  background-color: #b8a18e;
  border: 1px solid #fff;
  font-family: var(--font-family-mincho);
}
.PageHomeWood .PageHomeWoodForWhom a::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodForWhom a {
    font-size: 1.3rem;
  }
}
.PageHomeWood .PageHomeWoodForWhom a .icon {
  position: absolute;
  left: 1.3em;
  bottom: 0.2em;
  width: 4.8em;
  height: 4.8em;
}
.PageHomeWood .PageHomeWoodCards {
  margin-top: 7.5rem;
  padding-bottom: 40rem;
  overflow: hidden;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodCards {
    margin-top: 4rem;
    padding-bottom: 20rem;
  }
}
.PageHomeWood .PageHomeWoodCards .container {
  display: flex;
  gap: 3rem;
  padding-inline: max((100% - var(--content-width)) / 2, var(--site-gap)) 3rem;
  width: -moz-max-content;
  width: max-content;
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodCards .container {
    gap: 1.5rem;
  }
}
.PageHomeWood .PageHomeWoodCards .card {
  font-size: 1rem;
  position: relative;
  padding: 4em 4em 6em;
  flex: 0 0 40em;
  background-color: var(--color-beige);
  border-radius: var(--base-radius);
  overflow: hidden;
  transition: filter 0.2s;
}
.PageHomeWood .PageHomeWoodCards .card:hover {
  transition-duration: 0.3s;
  filter: brightness(1.1);
}
@media (max-width: 1080px) {
  .PageHomeWood .PageHomeWoodCards .card {
    font-size: 0.6rem;
  }
}
.PageHomeWood .PageHomeWoodCards .card::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
  font-size: 170%;
  position: absolute;
  right: 1.3em;
  bottom: 1.3em;
}
.PageHomeWood .PageHomeWoodCards .icon {
  position: absolute;
  width: 14em;
  height: 14em;
  right: 0;
  top: 0;
}
.PageHomeWood .PageHomeWoodCards .english {
  font-size: 170%;
  color: var(--color-blue);
}
.PageHomeWood .PageHomeWoodCards .title {
  margin: 1em 0 0;
  font-size: 230%;
  font-weight: normal;
}
.PageHomeWood .PageHomeWoodCards .description {
  margin-top: 1em;
  font-size: 170%;
}

.PageHomeService {
  padding-block: 14rem 1rem;
}
.PageHomeService .PageHomeService__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageHomeService .PageHomeServiceHeader {
  display: flex;
  align-items: end;
  gap: 6rem;
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceHeader {
    flex-direction: row;
    align-items: end;
    justify-content: space-between;
  }
}
.PageHomeService .PageHomeServiceHeader .hgroup {
  display: flex;
  flex-direction: column;
  line-height: 1;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceHeader .hgroup {
    gap: 0.5rem;
  }
}
.PageHomeService .PageHomeServiceHeader .hgroup .heading {
  font-size: 2rem;
  font-weight: normal;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceHeader .hgroup .heading {
    font-size: 1rem;
  }
}
.PageHomeService .PageHomeServiceHeader .hgroup .english {
  margin: 0;
  font-size: 8.8rem;
  font-family: var(--font-family-serif);
  color: var(--color-brown);
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceHeader .hgroup .english {
    font-size: 4.4rem;
  }
}
.PageHomeService .PageHomeServiceHeader .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  font-size: 1.9rem;
}
.PageHomeService .PageHomeServiceHeader .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (min-width: 1080.01px) {
  .PageHomeService .PageHomeServiceHeader .link {
    margin-bottom: 1rem;
    width: 13em;
  }
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceHeader .link {
    font-size: 1rem;
    margin-bottom: 0.5rem;
  }
}
.PageHomeService .PageHomeServiceSections {
  margin-top: 10rem;
  display: grid;
  gap: 9rem;
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections {
    margin-top: 4rem;
    gap: 3rem;
  }
}
.PageHomeService .PageHomeServiceSections .section {
  display: grid;
  grid-template: "number image content" auto/3rem 52.3rem 1fr;
  gap: 5rem;
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections .section {
    grid-template: "number image" auto "number content" auto/3rem 1fr;
    gap: 1rem;
  }
}
.PageHomeService .PageHomeServiceSections .section .number {
  grid-area: number;
  font-size: 2rem;
  color: var(--color-blue-light);
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections .section .number {
    font-size: 1.5rem;
  }
}
.PageHomeService .PageHomeServiceSections .section .image {
  grid-area: image;
}
.PageHomeService .PageHomeServiceSections .section .image img {
  display: block;
  aspect-ratio: 523/298;
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections .section .image img {
    width: 26rem;
  }
}
.PageHomeService .PageHomeServiceSections .section .content {
  grid-area: content;
}
@media (min-width: 1080.01px) {
  .PageHomeService .PageHomeServiceSections .section .content {
    padding-top: 1rem;
  }
}
.PageHomeService .PageHomeServiceSections .section .content .title {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections .section .content .title {
    font-size: 1.4rem;
  }
}
.PageHomeService .PageHomeServiceSections .section .content .description {
  margin-top: 1em;
  font-size: 1.8rem;
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections .section .content .description {
    font-size: 1.1rem;
  }
}
.PageHomeService .PageHomeServiceSections .section .content .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  margin-top: 1em;
  font-size: 1.9rem;
  width: -moz-fit-content;
  width: fit-content;
}
.PageHomeService .PageHomeServiceSections .section .content .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (max-width: 1080px) {
  .PageHomeService .PageHomeServiceSections .section .content .link {
    font-size: 1.1rem;
  }
}

.PageHomeWorks {
  padding-block: 14rem 20rem;
}
@media (max-width: 1080px) {
  .PageHomeWorks {
    padding-block: 4rem 5rem;
  }
}
.PageHomeWorks .PageHomeWorksHeader {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: flex;
  align-items: end;
  gap: 6rem;
}
@media (max-width: 1080px) {
  .PageHomeWorks .PageHomeWorksHeader {
    flex-direction: row;
    align-items: end;
    justify-content: space-between;
  }
}
.PageHomeWorks .PageHomeWorksHeader .hgroup {
  display: flex;
  flex-direction: column;
  line-height: 1;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHomeWorks .PageHomeWorksHeader .hgroup {
    gap: 0.5rem;
  }
}
.PageHomeWorks .PageHomeWorksHeader .hgroup .heading {
  font-size: 2rem;
  font-weight: normal;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHomeWorks .PageHomeWorksHeader .hgroup .heading {
    font-size: 1rem;
  }
}
.PageHomeWorks .PageHomeWorksHeader .hgroup .english {
  margin: 0;
  font-size: 8.8rem;
  font-family: var(--font-family-serif);
  color: var(--color-brown);
}
@media (max-width: 1080px) {
  .PageHomeWorks .PageHomeWorksHeader .hgroup .english {
    font-size: 4.4rem;
  }
}
.PageHomeWorks .PageHomeWorksHeader .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  font-size: 1.9rem;
}
.PageHomeWorks .PageHomeWorksHeader .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (min-width: 1080.01px) {
  .PageHomeWorks .PageHomeWorksHeader .link {
    margin-bottom: 1rem;
    width: 13em;
  }
}
@media (max-width: 1080px) {
  .PageHomeWorks .PageHomeWorksHeader .link {
    font-size: 1rem;
    margin-bottom: 0.5rem;
  }
}
.PageHomeWorks .PageHomeWorksSlides {
  --item-size: 30rem;
  --item-gap: 2.5rem;
  margin: 8rem auto 0;
  overflow: hidden;
  max-width: calc(var(--item-size) * 6 + var(--item-gap) * 5);
}
@media (max-width: 1080px) {
  .PageHomeWorks .PageHomeWorksSlides {
    --item-size: 15rem;
    --item-gap: 1rem;
    margin-top: 3.5rem;
  }
}
.PageHomeWorks .PageHomeWorksSlides .inner {
  width: calc(var(--item-size) * 12 + var(--item-gap) * 11);
  display: flex;
  justify-content: center;
  gap: var(--item-gap);
  animation: slideRepeat 30s linear infinite;
}
@keyframes slideRepeat {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc(-1 * (var(--item-size) + var(--item-gap)) * 6));
  }
}
.PageHomeWorks .PageHomeWorksSlides .inner:hover {
  animation-play-state: paused;
}
.PageHomeWorks .PageHomeWorksSlides .item {
  flex-shrink: 0;
  width: var(--item-size);
  height: var(--item-size);
}
.PageHomeWorks .PageHomeWorksSlides .link {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: var(--base-radius);
  overflow: hidden;
}
.PageHomeWorks .PageHomeWorksSlides .link:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.PageHomeWorks .PageHomeWorksSlides .image {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PageHomeWorksLinks {
  --item-width: 57.5rem;
  --item-gap: 5rem;
  --font-size: 4.2rem;
  margin-top: 5rem;
  padding-inline: var(--site-gap);
  display: flex;
  justify-content: center;
  gap: var(--item-gap);
}
@media (max-width: 1080px) {
  .PageHomeWorksLinks {
    --item-width: 29rem;
    --item-gap: 2rem;
    --font-size: 2.5rem;
    margin-top: 3rem;
    flex-direction: column;
    align-items: center;
  }
}
.PageHomeWorksLinks .link {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  display: flex;
  align-items: center;
  justify-content: end;
  position: relative;
  aspect-ratio: 115/60;
  width: var(--item-width);
  height: auto;
  border-radius: var(--base-radius);
  overflow: hidden;
}
.PageHomeWorksLinks .link:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.PageHomeWorksLinks .link .image {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHomeWorksLinks .link .title {
  position: relative;
  padding-right: 1.5em;
  font-size: var(--font-size);
  font-family: var(--font-family-mincho);
  color: #fff;
  display: flex;
  align-items: center;
  gap: 0.5em;
  --link-icon-size: 0.4em;
}
.PageHomeWorksLinks .link .title::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}

.PageHomeRecruit {
  position: relative;
  padding-block: 16rem 20rem;
  color: #fff;
}
@media (max-width: 1080px) {
  .PageHomeRecruit {
    padding-block: 8rem 9rem;
  }
}
.PageHomeRecruit .PageHomeRecruitBg {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.PageHomeRecruit .PageHomeRecruitBg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHomeRecruit .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageHomeRecruit .heading {
  display: flex;
  flex-direction: column;
  line-height: 1;
  color: #fff;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHomeRecruit .heading {
    gap: 0.5rem;
  }
}
.PageHomeRecruit .heading .title {
  font-size: 2rem;
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageHomeRecruit .heading .title {
    font-size: 1rem;
  }
}
.PageHomeRecruit .heading .english {
  margin: 0;
  font-size: 8.8rem;
  font-family: var(--font-family-serif);
}
@media (max-width: 1080px) {
  .PageHomeRecruit .heading .english {
    font-size: 4.4rem;
  }
}
.PageHomeRecruit .description {
  margin-top: 7rem;
  font-size: 1.8rem;
}
@media (max-width: 1080px) {
  .PageHomeRecruit .description {
    margin-top: 3rem;
    font-size: 1.1rem;
  }
}
.PageHomeRecruit .link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-blue);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
  margin-top: 3rem;
  font-size: 1.9rem;
  width: 13em;
}
.PageHomeRecruit .link::after {
  flex-shrink: 0;
  content: "";
  width: var(--link-icon-size, 0.8888888889em);
  height: var(--link-icon-size, 0.8888888889em);
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  translate: 0 0.1em;
}
@media (max-width: 1080px) {
  .PageHomeRecruit .link {
    font-size: 1.1rem;
    margin-top: 2rem;
  }
}

@media (min-width: 1080.01px) {
  .PageAboutusHrd {
    margin-top: 15rem;
    padding-inline: var(--site-gap);
  }
}
@media (max-width: 1080px) {
  .PageAboutusHrd {
    margin-top: 5rem;
  }
}
.PageAboutusHrd .box {
  padding-inline: var(--site-gap);
  background-color: #fff;
}
@media (min-width: 1080.01px) {
  .PageAboutusHrd .box {
    margin-inline: auto;
    padding-block: 10rem 14rem;
    max-width: 1600px;
    border-radius: var(--base-radius);
  }
}
@media (max-width: 1080px) {
  .PageAboutusHrd .box {
    padding-block: 4rem 6rem;
  }
}
.PageAboutusHrd .container {
  margin-inline: auto;
  max-width: var(--content-width);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media (min-width: 1080.01px) {
  .PageAboutusHrd .container {
    gap: 5rem;
  }
}
@media (max-width: 1080px) {
  .PageAboutusHrd .container {
    gap: 3rem;
  }
}
.PageAboutusHrd .container .heading {
  width: 100%;
  font-size: 4.2rem;
  line-height: 1;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageAboutusHrd .container .heading {
    font-size: 2rem;
  }
}
.PageAboutusHrd .container .heading a {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.PageAboutusHrd .container .heading a:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
.PageAboutusHrd .container .heading a .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  --disc-arrow-size: 1.2em;
}
.PageAboutusHrd .container .heading a .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
.PageAboutusHrd .container .image {
  aspect-ratio: 575/356;
  width: 57.5rem;
  height: auto;
  border-radius: var(--base-radius);
}
.PageAboutusHrd .container .list {
  flex-grow: 1;
  display: grid;
  line-height: 1.5;
}
@media (min-width: 1080.01px) {
  .PageAboutusHrd .container .list {
    font-size: 2rem;
    gap: 2rem;
  }
}
@media (max-width: 1080px) {
  .PageAboutusHrd .container .list {
    font-size: 1.4rem;
    gap: 1rem;
  }
}
.PageAboutusHrd .container .list li a {
  padding-inline: 1.2em;
  border-radius: 2em;
  width: 100%;
  background-color: var(--color-blue);
  color: #fff;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  display: flex;
  justify-content: space-between;
  gap: 1em;
}
@media (min-width: 1080.01px) {
  .PageAboutusHrd .container .list li a {
    padding-block: 1em;
  }
}
@media (max-width: 1080px) {
  .PageAboutusHrd .container .list li a {
    padding-block: 0.6em;
  }
}
.PageAboutusHrd .container .list li a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.PageMessage {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
@media (min-width: 1080.01px) {
  .PageMessage {
    max-width: 100rem;
  }
}
.PageMessage .heading {
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageMessage .heading {
    font-size: 3.1rem;
  }
}
@media (max-width: 1080px) {
  .PageMessage .heading {
    font-size: 2rem;
  }
}
.PageMessage .content {
  display: flex;
}
@media (min-width: 1080.01px) {
  .PageMessage .content {
    margin: 7rem auto 0;
    gap: 3rem;
  }
}
@media (max-width: 1080px) {
  .PageMessage .content {
    margin-top: 2rem;
    flex-direction: column;
    gap: 2rem;
  }
}
.PageMessage .text .phrase {
  line-height: 1;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageMessage .text .phrase {
    font-size: 3.1rem;
  }
}
@media (max-width: 1080px) {
  .PageMessage .text .phrase {
    font-size: 2rem;
  }
}
@media (min-width: 1080.01px) {
  .PageMessage .text p {
    margin-top: 3rem;
    font-size: 1.6rem;
  }
}
@media (max-width: 1080px) {
  .PageMessage .text p {
    margin-top: 2rem;
    font-size: 1.1rem;
  }
}
.PageMessage .ceo {
  flex-shrink: 0;
}
@media (min-width: 1080.01px) {
  .PageMessage .ceo {
    width: 43.7rem;
  }
}
@media (max-width: 1080px) {
  .PageMessage .ceo {
    max-width: 100%;
  }
}
.PageMessage .ceo img {
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}
.PageMessage .ceo figcaption {
  margin-top: 1em;
  text-align: right;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-brown);
}
@media (min-width: 1080.01px) {
  .PageMessage .ceo figcaption {
    font-size: 1.6rem;
  }
}
@media (max-width: 1080px) {
  .PageMessage .ceo figcaption {
    font-size: 1.1rem;
  }
}
.PageMessage .ceo figcaption .name {
  font-size: 118.75%;
}

.PagePhilosophyKv {
  display: block;
  width: 100%;
  height: min(67.4rem, 674px);
  overflow: hidden;
}
@media (min-width: 1080.01px) {
  .PagePhilosophyKv {
    margin-block: 5rem 6rem;
  }
}
@media (max-width: 1080px) {
  .PagePhilosophyKv {
    margin-block: 2rem 3rem;
    height: 21.1rem;
  }
}
.PagePhilosophyKv .image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PagePhilosophy {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: 100rem;
}
.PagePhilosophy .heading {
  display: grid;
  grid-template-columns: 23rem 1fr;
  gap: 2em 0;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PagePhilosophy .heading {
    font-size: 1.6rem;
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.PagePhilosophy .heading h2,
.PagePhilosophy .heading p {
  margin: 0;
  font-size: 100%;
  font-weight: bold;
}
.PagePhilosophy .heading h2 {
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PagePhilosophy .heading h2 {
    font-size: 150%;
  }
}
.PagePhilosophy .dl {
  margin-top: 8rem;
  border-bottom: 1px solid var(--color-blue);
  padding-bottom: 7rem;
  display: grid;
  grid-template-columns: 17rem 1fr;
  gap: 8rem 3rem;
}
@media (max-width: 1080px) {
  .PagePhilosophy .dl {
    margin-top: 2rem;
    padding-bottom: 2rem;
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}
.PagePhilosophy .dl > dt {
  display: flex;
  flex-direction: column;
  color: var(--color-blue);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PagePhilosophy .dl > dt {
    margin-top: 1rem;
  }
}
.PagePhilosophy .dl > dt .english {
  font-size: 2.3rem;
  line-height: 1;
}
@media (max-width: 1080px) {
  .PagePhilosophy .dl > dt .english {
    font-size: 2rem;
  }
}
.PagePhilosophy .dl > dt .text {
  margin-top: 1em;
  font-size: 1.5rem;
}
@media (max-width: 1080px) {
  .PagePhilosophy .dl > dt .text {
    margin-top: 0.5em;
  }
}
@media (min-width: 1080.01px) {
  .PagePhilosophy .dl > dd {
    border-left: 0.5rem solid #809bc3;
    padding-left: 3rem;
    font-size: 1.7rem;
  }
}
@media (max-width: 1080px) {
  .PagePhilosophy .dl > dd {
    border-top: 1px solid #809bc3;
    padding-top: 2rem;
    font-size: 1.3rem;
  }
}
.PagePhilosophy .dl > dd > ul {
  list-style: disc;
  margin: 0 0 0 1.3em;
  display: grid;
  gap: 0.5em;
  line-height: 1.3;
}
.PagePhilosophy .dl > dd > dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2em;
}
@media (max-width: 1080px) {
  .PagePhilosophy .dl > dd > dl {
    gap: 1em;
  }
}
.PagePhilosophy .dl > dd > dl > dt {
  white-space: nowrap;
  font-weight: normal;
}
.PagePhilosophy .section {
  padding-block: 7rem;
  border-bottom: 1px solid var(--color-blue);
  display: grid;
  grid-template-columns: 23rem 1fr;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PagePhilosophy .section {
    padding-block: 2rem;
    font-size: 1.6rem;
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.PagePhilosophy .section h3,
.PagePhilosophy .section p {
  margin: 0;
  font-size: 100%;
  font-weight: bold;
}
.PagePhilosophy .section h3 {
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PagePhilosophy .section h3 {
    font-size: 150%;
  }
}

.PageCompanyKv {
  display: block;
  width: 100%;
  height: min(67.4rem, 674px);
  overflow: hidden;
}
@media (min-width: 1080.01px) {
  .PageCompanyKv {
    margin-block: 5rem 6rem;
  }
}
@media (max-width: 1080px) {
  .PageCompanyKv {
    margin-block: 2rem 3rem;
    height: 21.1rem;
  }
}
.PageCompanyKv .image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PageCompanyData {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageCompanyData .heading {
  margin: 0;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCompanyData .heading {
    font-size: 2rem;
  }
}
.PageCompanyData .row {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: 77rem 37rem;
  justify-content: space-between;
}
@media (max-width: 1080px) {
  .PageCompanyData .row {
    margin-top: 2rem;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.PageCompanyData .row .column-main {
  display: grid;
  gap: 6rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .column-main {
    gap: 2rem;
  }
}
.PageCompanyData .row .company-data {
  display: grid;
  grid-template-columns: 14rem 1fr;
  gap: 4rem 0;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-data {
    grid-template-columns: 1fr;
    font-size: 1.2rem;
    gap: 1rem 0;
  }
}
.PageCompanyData .row .company-data > :where(dt, dd) {
  position: relative;
  padding-bottom: 4rem;
  line-height: 1.8;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-data > :where(dt, dd) {
    padding-bottom: 1rem;
  }
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-data > :where(dt, dd):where(dt) {
    border-bottom: 1px solid #003888;
    font-size: 120%;
  }
}
.PageCompanyData .row .company-data > :where(dt, dd):where(dt)::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  border-bottom: 2px solid #003888;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-data > :where(dt, dd):where(dt)::before {
    width: 10em;
  }
}
.PageCompanyData .row .company-data > :where(dt, dd):where(dd) {
  padding-left: 4rem;
  border-bottom: 1px solid #003888;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-data > :where(dt, dd):where(dd) {
    padding-left: 0;
    border-bottom: none;
  }
}
.PageCompanyData .row .company-data .address {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1em 2em;
}
.PageCompanyData .row .company-data .address .map-link {
  display: inline-flex;
  color: #809bc3;
}
.PageCompanyData .row .company-skills {
  display: grid;
  grid-template-columns: 14rem 1fr;
  gap: 4rem 0;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-skills {
    grid-template-columns: 1fr;
    font-size: 1.2rem;
    gap: 1rem 0;
  }
}
.PageCompanyData .row .company-skills > :where(dt, dd) {
  padding-bottom: 1rem;
  line-height: 1.8;
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dt) {
  grid-row: span 1;
  border-bottom: 2px solid #003888;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-skills > :where(dt, dd):where(dt) {
    border-bottom-width: 1px;
    position: relative;
    font-size: 120%;
  }
  .PageCompanyData .row .company-skills > :where(dt, dd):where(dt)::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 12em;
    border-bottom: 2px solid #003888;
  }
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) {
  grid-row: span 2;
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dt) {
  padding-bottom: 1rem;
  border-bottom: 1px solid #003888;
  padding-left: 4rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dt) {
    padding-left: 1em;
  }
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dt):not(:first-child) {
  padding-top: 5rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dt):not(:first-child) {
    padding-top: 2rem;
  }
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dd) {
  padding-left: 4rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dd) {
    padding-left: 1em;
  }
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-1v-33-31-34-2p-32-3d-1w-2p-38-2p-w-1a-36-33-3b-w-1a-2r-33-31-34-2p-32-3d-19-37-2z-2x-30-30-37-w-1q-w-1m-3b-2w-2t-36-2t-14-2s-38-18-w-2s-2s-15-1m-3b-2w-2t-36-2t-14-2s-2s-15-w-1q-w-2s-30-w-1q-w-1m-3b-2w-2t-36-2t-14-2s-2s-15-1m-2w-2p-37-14-39-30-1m-33-32-30-3d-19-2r-2w-2x-30-2s-15]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist) {
  grid-template-columns: 1fr;
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dd):has(ul:only-child) {
  grid-template-columns: 1fr;
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dd) > ul {
  margin-top: 1em;
  display: grid;
  font-size: 90%;
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dd) > ul > li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.3em;
}
.PageCompanyData .row .company-skills > :where(dt, dd):where(dd) > dl > :where(dd) > ul > li::before {
  content: "■";
}
.PageCompanyData .row .company-clients {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-clients {
    font-size: 1.2rem;
  }
}
.PageCompanyData .row .company-clients > :where(dt, dd) {
  line-height: 1.8;
  padding-left: 1em;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-clients > :where(dt, dd) {
    padding-left: 0;
  }
}
.PageCompanyData .row .company-clients > :where(dt, dd):where(dt) {
  padding-bottom: 4rem;
  border-bottom: 2px solid #003888;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-clients > :where(dt, dd):where(dt) {
    padding-bottom: 1rem;
    border-bottom-width: 1px;
    position: relative;
    font-size: 120%;
  }
  .PageCompanyData .row .company-clients > :where(dt, dd):where(dt)::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 12em;
    border-bottom: 2px solid #003888;
  }
}
.PageCompanyData .row .company-clients > :where(dt, dd):where(dd) {
  padding-top: 4rem;
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-clients > :where(dt, dd):where(dd) {
    padding-top: 2rem;
  }
}
@media (max-width: 1080px) {
  .PageCompanyData .row .company-clients > :where(dt, dd):where(dd) .pannel[aria-hidden=true] {
    height: 18rem;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to bottom, rgb(0, 0, 0) calc(100% - 6rem), rgba(0, 0, 0, 0.2) 100%);
            mask-image: linear-gradient(to bottom, rgb(0, 0, 0) calc(100% - 6rem), rgba(0, 0, 0, 0.2) 100%);
  }
}
.PageCompanyData .row .company-clients > :where(dt, dd):where(dd) ul {
  display: grid;
  line-height: 1.3;
  gap: 0.7em;
}
.PageCompanyData .company-clients-more {
  --icon-url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='black' d='M6 1v10M1 6h10'/%3E%3C/svg%3E");
  margin-top: 4rem;
  width: 100%;
  border: 1px solid var(--color-blue);
  border-radius: 0.75em;
  height: 4em;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-size: 1.8rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageCompanyData .company-clients-more {
    display: none;
  }
}
.PageCompanyData .company-clients-more[aria-expanded=true] {
  --icon-url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='black' d='M1 6h10'/%3E%3C/svg%3E");
}
.PageCompanyData .company-clients-more::after {
  content: "";
  width: 1.5em;
  height: 1.5em;
  background-color: currentcolor;
  -webkit-mask: var(--icon-url) no-repeat center/100% 100%;
          mask: var(--icon-url) no-repeat center/100% 100%;
}
@media (max-width: 1080px) {
  .PageCompanyData .company-clients-more {
    margin-top: 3rem;
    font-size: 1.5rem;
    height: 4em;
  }
}

.PageCompanySdgs {
  position: relative;
  margin-top: 14rem;
  margin-inline: auto;
  padding: 12rem 0;
  max-width: 1600px;
  background-color: #f2f2f2;
  border-radius: var(--base-radius);
}
@media screen and (max-width: 1600px) {
  .PageCompanySdgs {
    border-radius: 0;
  }
}
@media (max-width: 1080px) {
  .PageCompanySdgs {
    margin-top: 8rem;
    padding: 6rem 0;
  }
}
.PageCompanySdgs .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageCompanySdgs .nav {
  position: absolute;
  top: -1em;
  display: flex;
  gap: 1em;
  font-size: 1.9rem;
}
@media (max-width: 1080px) {
  .PageCompanySdgs .nav {
    font-size: 1.2rem;
  }
}
.PageCompanySdgs .nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.PageCompanySdgs .nav a.blue {
  background-color: var(--color-blue);
}
.PageCompanySdgs .nav a.gray {
  background-color: var(--color-gray);
}
.PageCompanySdgs .nav a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
.PageCompanySdgs .hr {
  margin-block: 8rem;
  border: none;
  border-top: 1px solid var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCompanySdgs .hr {
    margin-block: 4rem;
  }
}
.PageCompanySdgs .statement {
  margin-inline: auto;
  max-width: 93rem;
}
.PageCompanySdgs .statement h2 {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCompanySdgs .statement h2 {
    font-size: 2.2rem;
  }
}
.PageCompanySdgs .statement p {
  margin-top: 1em;
  font-size: 1.6rem;
}
.PageCompanySdgs .statement img {
  margin-top: 3rem;
  display: block;
  width: 58.7rem;
  max-width: 100%;
  height: auto;
}
.PageCompanySdgs .torikumi {
  margin-inline: auto;
  max-width: 93rem;
}
.PageCompanySdgs .torikumi-heading {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCompanySdgs .torikumi-heading {
    font-size: 2.2rem;
  }
}
.PageCompanySdgs .torikumi-section {
  position: relative;
  margin-top: 7rem;
  padding-left: 7rem;
  font-size: 1.6rem;
  display: grid;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageCompanySdgs .torikumi-section {
    margin-top: 4rem;
    padding-left: 0;
  }
}
.PageCompanySdgs .torikumi-section h3 {
  line-height: 1.2;
}
.PageCompanySdgs .torikumi-section h3 > span:first-child {
  font-size: 2em;
  color: var(--color-blue-light);
}
@media (min-width: 1080.01px) {
  .PageCompanySdgs .torikumi-section h3 > span:first-child {
    position: absolute;
    left: 0;
    top: -0.1em;
  }
}
@media (max-width: 1080px) {
  .PageCompanySdgs .torikumi-section h3 > span:first-child {
    font-size: 1.5em;
  }
}
.PageCompanySdgs .torikumi-section h3 > span:nth-child(2) {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCompanySdgs .torikumi-section h3 > span:nth-child(2) {
    font-size: 2.2rem;
  }
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-1v-33-31-34-2p-32-3d-2b-2s-2v-37-w-1a-38-33-36-2x-2z-39-31-2x-19-37-2t-2r-38-2x-33-32-w-34-1m-2w-2p-37-14-2x-31-2v-15]:not(.does-not-exist):not(does-not-exist):not(does-not-exist) {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.PageCompanySdgs .torikumi-section p:has(img) {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-1v-33-31-34-2p-32-3d-2b-2s-2v-37-w-1a-38-33-36-2x-2z-39-31-2x-19-37-2t-2r-38-2x-33-32-w-34-1m-2w-2p-37-14-2x-31-2v-15-w-2x-31-2v]:not(.does-not-exist):not(does-not-exist):not(does-not-exist):not(does-not-exist) {
  aspect-ratio: 1;
  width: 9.6rem;
  height: auto;
}
.PageCompanySdgs .torikumi-section p:has(img) img {
  aspect-ratio: 1;
  width: 9.6rem;
  height: auto;
}
.PageCompanySdgs .torikumi-section h4 {
  font-weight: bold;
  color: var(--color-blue);
}
.PageCompanySdgs .torikumi-section ul {
  list-style: disc;
  margin-left: 2rem;
}
.PageCompanySdgs .mirai {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 1080px) {
  .PageCompanySdgs .mirai {
    flex-direction: column;
    gap: 2rem;
  }
}
.PageCompanySdgs .mirai .mirai-content h3 img {
  display: block;
  width: 54rem;
  max-width: 100%;
  height: auto;
}
.PageCompanySdgs .mirai .mirai-content h4 {
  margin-top: 1.5em;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCompanySdgs .mirai .mirai-content h4 {
    font-size: 2.2rem;
    margin-top: 1em;
  }
}
.PageCompanySdgs .mirai .mirai-content p {
  margin-top: 1em;
  font-size: 1.6rem;
}
.PageCompanySdgs .mirai .mirai-image {
  width: 49rem;
  max-width: 100%;
  height: auto;
}

.PageHistoryKv {
  margin-bottom: 0 !important;
  display: block;
  width: 100%;
  height: min(67.4rem, 674px);
  overflow: hidden;
}
@media (min-width: 1080.01px) {
  .PageHistoryKv {
    margin-block: 5rem 6rem;
  }
}
@media (max-width: 1080px) {
  .PageHistoryKv {
    margin-block: 2rem 3rem;
    height: 21.1rem;
  }
}
.PageHistoryKv .image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PageHistory {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: 75rem;
}
@media (max-width: 1080px) {
  .PageHistory {
    padding-inline: 0.5rem;
  }
}
.PageHistory .PageHistory__inner {
  border-left: 1px solid var(--color-blue);
  border-right: 1px solid var(--color-blue);
}
.PageHistory .PageHistory__heading {
  margin: 0;
  padding: 5rem 1rem 1rem;
  border-bottom: 1px solid var(--color-blue);
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHistory .PageHistory__heading {
    font-size: 2rem;
    padding-top: 2rem;
  }
}
.PageHistory .PageHistory__list {
  font-size: 1.6rem;
  display: grid;
  grid-template-columns: 6em 1fr;
}
@media (max-width: 1080px) {
  .PageHistory .PageHistory__list {
    font-size: 1.3rem;
    grid-template-columns: 5em 1fr;
  }
}
.PageHistory .PageHistory__list > :where(dt, dd) {
  padding: 1rem;
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageHistory .PageHistory__list > :where(dt, dd) {
    padding: 0.5rem;
  }
}
.PageHistory .PageHistory__list > :where(dt, dd):nth-child(-n+2) {
  padding-top: 4rem;
}
@media (max-width: 1080px) {
  .PageHistory .PageHistory__list > :where(dt, dd):nth-child(-n+2) {
    padding-top: 2rem;
  }
}
.PageHistory .PageHistory__list > :where(dt, dd):nth-last-child(-n+2) {
  padding-bottom: 4rem;
}
@media (max-width: 1080px) {
  .PageHistory .PageHistory__list > :where(dt, dd):nth-last-child(-n+2) {
    padding-bottom: 2rem;
  }
}
.PageHistory .PageHistory__list > :where(dt, dd):where(dt) {
  border-right: 1px solid var(--color-blue);
  position: relative;
}
.PageHistory .PageHistory__list > :where(dt, dd):where(dt)::after {
  content: "";
  position: absolute;
  right: 0;
  translate: 50% 70%;
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background-color: #809bc3;
}
.PageHistory .PageHistory__list > :where(dt, dd):where(dd) {
  padding-inline: 3rem;
  position: relative;
}
@media (max-width: 1080px) {
  .PageHistory .PageHistory__list > :where(dt, dd):where(dd) {
    padding-inline: 1.5rem;
  }
}

.PageCsrKv {
  display: block;
  width: 100%;
  height: min(67.4rem, 674px);
  overflow: hidden;
}
@media (min-width: 1080.01px) {
  .PageCsrKv {
    margin-block: 5rem 6rem;
  }
}
@media (max-width: 1080px) {
  .PageCsrKv {
    margin-block: 2rem 3rem;
    height: 21.1rem;
  }
}
.PageCsrKv .image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PageCsr {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: 100rem;
}
.PageCsr .heading {
  margin: 0;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCsr .heading {
    font-size: 2rem;
  }
}
.PageCsr .block1 {
  margin-top: 6rem;
  display: flex;
  display: grid;
  grid-template-columns: 60rem 1fr;
  gap: 1rem 2rem;
}
@media (max-width: 1080px) {
  .PageCsr .block1 {
    grid-template-columns: 1fr;
  }
}
.PageCsr .block1 h3 {
  grid-column: 1/span 2;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCsr .block1 h3 {
    font-size: 2rem;
    grid-column: auto;
  }
}
.PageCsr .block1 p {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageCsr .block1 p {
    font-size: 1.3rem;
  }
}
.PageCsr .block1 img {
  border-radius: var(--base-radius);
  width: 100%;
}
.PageCsr .block2 {
  margin-top: 4rem;
}
@media (max-width: 1080px) {
  .PageCsr .block2 {
    margin-top: 3rem;
  }
}
.PageCsr .block2 h3 {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 2rem;
}
@media (max-width: 1080px) {
  .PageCsr .block2 h3 {
    font-size: 1.3rem;
  }
}
.PageCsr .block2 table {
  position: relative;
  border-top: 1px solid var(--color-blue);
  border-bottom: 1px solid var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageCsr .block2 table {
    width: 100%;
    border-collapse: collapse;
  }
}
@media (max-width: 1080px) {
  .PageCsr .block2 table {
    display: block;
  }
}
.PageCsr .block2 table::before, .PageCsr .block2 table::after {
  content: "";
  position: absolute;
  left: 0;
  width: 15rem;
  border-top: 2px solid var(--color-blue);
}
@media (max-width: 1080px) {
  .PageCsr .block2 table::before, .PageCsr .block2 table::after {
    width: 10rem;
  }
}
.PageCsr .block2 table::before {
  top: -0.5px;
}
.PageCsr .block2 table::after {
  bottom: -0.5px;
}
@media (max-width: 1080px) {
  .PageCsr .block2 table tbody {
    padding-block: 1.5rem;
    display: grid;
    gap: 1rem;
  }
}
@media (min-width: 1080.01px) {
  .PageCsr .block2 table tr:first-child :is(th, td) {
    padding-top: 3rem;
  }
  .PageCsr .block2 table tr:last-child :is(th, td) {
    padding-bottom: 3rem;
  }
}
@media (max-width: 1080px) {
  .PageCsr .block2 table tr {
    display: grid;
    grid-template-columns: 10rem 1fr;
  }
}
.PageCsr .block2 table :where(th, td) {
  vertical-align: top;
  padding: 1em;
  font-size: 1.6rem;
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageCsr .block2 table :where(th, td) {
    display: block;
    padding: 0 0.5em;
    font-size: 1.3rem;
  }
}
@media (min-width: 1080.01px) {
  .PageCsr .block2 table :where(th, td).year {
    width: 15rem;
  }
}
@media (max-width: 1080px) {
  .PageCsr .block2 table :where(th, td).year {
    width: auto;
    white-space: nowrap;
  }
}
@media (min-width: 1080.01px) {
  .PageCsr .block2 table :where(th, td).title {
    padding-inline: 3em;
    width: 1%;
    white-space: nowrap;
  }
}
@media (min-width: 1080.01px) {
  .PageCsr .block2 table :where(th, td).amount {
    padding-inline: 3em;
  }
}
@media (max-width: 1080px) {
  .PageCsr .block2 table :where(th, td).amount {
    grid-column-start: 2;
  }
}
.PageCsr .block2 ul {
  margin-top: 3rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageCsr .block2 ul {
    margin-top: 2rem;
    font-size: 1.2rem;
  }
}
.PageCsr .block3 {
  margin-top: 4rem;
  display: grid;
  gap: 1rem;
}
@media (max-width: 1080px) {
  .PageCsr .block3 {
    margin-top: 3rem;
    gap: 0.5rem;
  }
}
.PageCsr .block3 > div {
  display: grid;
  gap: 1rem;
}
.PageCsr .block3 > div:nth-child(1) {
  grid-template-columns: repeat(3, 1fr);
}
.PageCsr .block3 > div:nth-child(2) {
  grid-template-columns: repeat(4, 1fr);
}
.PageCsr .block3 > div > img {
  border-radius: var(--base-radius);
}

.PageHoldingsKv {
  display: block;
  width: 100%;
  height: min(67.4rem, 674px);
  overflow: hidden;
}
@media (min-width: 1080.01px) {
  .PageHoldingsKv {
    margin-block: 5rem 6rem;
  }
}
@media (max-width: 1080px) {
  .PageHoldingsKv {
    margin-block: 2rem 3rem;
    height: 21.1rem;
  }
}
.PageHoldingsKv .image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PageHoldings {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: 100rem;
}
.PageHoldings .heading {
  margin: 0;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHoldings .heading {
    font-size: 2rem;
  }
}
.PageHoldings .policy1 {
  margin-top: 4rem;
}
@media (max-width: 1080px) {
  .PageHoldings .policy1 {
    margin-top: 2rem;
  }
}
.PageHoldings .policy1 dt {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHoldings .policy1 dt {
    font-size: 2rem;
  }
}
.PageHoldings .policy1 dd {
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (min-width: 1080.01px) {
  .PageHoldings .policy1 dd {
    margin-block: 8rem 14rem;
    font-size: 4.7rem;
    text-align: center;
  }
}
@media (max-width: 1080px) {
  .PageHoldings .policy1 dd {
    margin-top: 0.5em;
    font-size: 2.6rem;
  }
}
@media (min-width: 1080.01px) {
  .PageHoldings .policy2 {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 4rem 2.5rem;
  }
}
@media (max-width: 1080px) {
  .PageHoldings .policy2 {
    margin-top: 2rem;
  }
}
.PageHoldings .policy2 dt {
  display: flex;
  flex-direction: column;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHoldings .policy2 dt {
    margin-top: 1.5rem;
    border-bottom: 0.2rem solid #809bc3;
    padding-bottom: 0.5rem;
    margin-bottom: 0.5rem;
  }
}
.PageHoldings .policy2 dt .english {
  font-size: 2.3rem;
}
@media (max-width: 1080px) {
  .PageHoldings .policy2 dt .english {
    font-size: 2rem;
  }
}
.PageHoldings .policy2 dt .japanese {
  font-size: 1.5rem;
}
@media (max-width: 1080px) {
  .PageHoldings .policy2 dt .japanese {
    font-size: 1.3rem;
  }
}
@media (min-width: 1080.01px) {
  .PageHoldings .policy2 dd {
    border-left: 0.5rem solid #809bc3;
    padding-left: 2.5rem;
    font-size: 1.9rem;
    align-content: center;
  }
}
@media (max-width: 1080px) {
  .PageHoldings .policy2 dd {
    font-size: 1.6rem;
  }
}
.PageHoldings .companies {
  margin-top: 20rem;
  border-top: 1px solid var(--color-blue);
  padding-top: 10rem;
  margin-bottom: 15rem;
}
@media (max-width: 1080px) {
  .PageHoldings .companies {
    margin-top: 8rem;
    padding-top: 5rem;
    margin-bottom: 8rem;
  }
}
.PageHoldings .companies h3 {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHoldings .companies h3 {
    font-size: 2rem;
  }
}
.PageHoldings .companies ul {
  margin-top: 5rem;
  display: flex;
  justify-content: center;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .PageHoldings .companies ul {
    margin-top: 2rem;
    gap: 1rem;
  }
}
.PageHoldings .companies ul img {
  width: 22rem;
}
@media (max-width: 1080px) {
  .PageHoldings .companies ul img {
    width: 10rem;
  }
}

.PageWorksNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageWorksNav .heading {
  margin-left: 0.3em;
  font-size: max(2.3rem * var(--pc-flag), 1.5rem * var(--sp-flag));
  font-weight: bold;
  color: var(--color-blue);
}
.PageWorksNav .body {
  margin-top: max(1.2rem * var(--pc-flag), 0.5rem * var(--sp-flag));
  display: flex;
  justify-content: space-between;
}
.PageWorksNav .box {
  padding: 1rem;
  background-color: #fff;
  border-radius: var(--base-radius);
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
@media (max-width: 1080px) {
  .PageWorksNav .box {
    padding: 1.5rem;
  }
  .PageWorksNav .box.box-sakan {
    display: none;
  }
  .PageWorksNav .box.box-insulation {
    display: none;
  }
}
.PageWorksNav .large-link {
  width: 18.5rem;
  height: 16.3rem;
  background-color: #c7ddeb;
  border-radius: 1.2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-size: 1.7rem;
  line-height: 1;
  font-weight: bold;
  color: var(--color-blue);
}
.PageWorksNav .large-link.large-link-building {
  --icon-url: url("../assets/works/icon-building.svg");
}
@media (max-width: 1080px) {
  .PageWorksNav .large-link.large-link-building {
    display: none;
  }
}
.PageWorksNav .large-link.large-link-sakan {
  --icon-url: url("../assets/works/icon-sakan.svg");
}
.PageWorksNav .large-link.large-link-insulation {
  --icon-url: url("../assets/works/icon-insulation.svg");
}
.PageWorksNav .large-link::before {
  content: "";
  width: 7.6rem;
  height: 7rem;
  background-color: currentcolor;
  -webkit-mask: var(--icon-url) no-repeat center/100% 100%;
          mask: var(--icon-url) no-repeat center/100% 100%;
}
.PageWorksNav .large-link .text {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
}
.PageWorksNav .large-link .text.arrow::after {
  content: "";
}
.PageWorksNav .links {
  padding-right: max(2rem * var(--pc-flag), 0 * var(--sp-flag));
  font-size: max(1.7rem * var(--pc-flag), 1.3rem * var(--sp-flag));
  font-weight: bold;
  line-height: 1;
}
.PageWorksNav .links .links-row {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
@media (max-width: 1080px) {
  .PageWorksNav .links .links-row {
    flex-wrap: wrap;
  }
}
.PageWorksNav .links .links-row:nth-child(n+2) {
  margin-top: 1em;
  border-top: 1px solid #c7ddeb;
  padding-top: 1em;
}
.PageWorksNav .links .links-row .links-label {
  color: var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageWorksNav .links .links-row .links-label {
    flex: 0 0 13rem;
  }
}
@media (max-width: 1080px) {
  .PageWorksNav .links .links-row .links-label {
    flex: 0 0 100%;
  }
}
.PageWorksNav .links .links-row .links-link {
  padding: 0.7em 1.2em;
  background-color: #c7ddeb;
  border-radius: 1.2em;
}
.PageWorksNav .links .links-row .links-link[aria-current=page] {
  background-color: var(--color-blue);
  color: #fff;
}

.PageWorksBoxes {
  display: grid;
  justify-content: center;
}
@media (min-width: 1080.01px) {
  .PageWorksBoxes {
    margin: 6.5rem var(--site-gap) 0;
    grid-template-columns: minmax(0, 1600px);
    gap: 4rem;
  }
}
@media (max-width: 1080px) {
  .PageWorksBoxes {
    margin: var(--site-gap) 0 0;
    gap: var(--site-gap);
    grid-template-columns: 100%;
  }
}

.PageWorksBox {
  padding-block: 6rem 8rem;
  background: #fff;
}
@media (min-width: 1080.01px) {
  .PageWorksBox {
    border-radius: var(--base-radius);
  }
}
@media (max-width: 1080px) {
  .PageWorksBox {
    padding-block: 3rem 4rem;
  }
}
.PageWorksBox .PageWorksBox__inner {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.PageWorksBoxHeading {
  margin-bottom: 1em;
  font-size: max(2.3rem * var(--pc-flag), 1.5rem * var(--sp-flag));
  line-height: 1.75em;
  font-weight: bold;
  color: var(--color-blue);
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.PageWorksBoxHeading a {
  display: flex;
  gap: 0.5em;
}
.PageWorksBoxHeading .sakan-icon {
  flex-shrink: 0;
  position: relative;
  width: 2em;
  height: 1em;
}
.PageWorksBoxHeading .sakan-icon::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: -0.2em;
  aspect-ratio: 76/70;
  width: 2em;
  height: auto;
  background-color: currentcolor;
  -webkit-mask: url("../assets/works/icon-sakan.svg") no-repeat center/100% 100%;
          mask: url("../assets/works/icon-sakan.svg") no-repeat center/100% 100%;
}
.PageWorksBoxHeading .insulation-icon {
  flex-shrink: 0;
  position: relative;
  width: 2em;
  height: 1em;
}
.PageWorksBoxHeading .insulation-icon::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: -0.2em;
  aspect-ratio: 76/70;
  width: 2em;
  height: auto;
  background-color: currentcolor;
  -webkit-mask: url("../assets/works/icon-insulation.svg") no-repeat center/100% 100%;
          mask: url("../assets/works/icon-insulation.svg") no-repeat center/100% 100%;
}
.PageWorksBoxHeading .count {
  font-size: 150%;
}

.PageWorksItemList {
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  gap: var(--item-gap);
  --item-image-ratio: 270 / 200;
}
@media (min-width: 1080.01px) {
  .PageWorksItemList {
    --item-width: calc(100% * 270 / 1200);
    --item-gap: 4rem calc(100% * 40 / 1200);
  }
}
@media (max-width: 1080px) {
  .PageWorksItemList {
    --item-width: 15.5rem;
    --item-gap: 1.5rem 1rem;
    flex-wrap: wrap;
  }
}
.PageWorksItemList .item {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  flex: 0 0 var(--item-width);
}
.PageWorksItemList .item:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.PageWorksItemList .item .image {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  display: block;
  aspect-ratio: var(--item-image-ratio);
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
  overflow: hidden;
}
.PageWorksItemList .item .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWorksItemList .item .image .noimage {
  display: block;
  width: 100%;
  height: 100%;
  background-color: #eee;
}
.PageWorksItemList .item .title {
  display: block;
  margin-top: 0.6em;
  font-size: max(1.9rem * var(--pc-flag), 1.4rem * var(--sp-flag));
  line-height: 1.4;
}
.PageWorksItemList .item .subtext {
  display: block;
  margin-top: 0.7em;
  font-size: max(1.5rem * var(--pc-flag), 1.2rem * var(--sp-flag));
  line-height: 1.4;
  color: var(--color-text-light);
}

@keyframes PageWorksItemListScrollerButtonFadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.js-PageWorksItemListScroller {
  position: relative;
}
.js-PageWorksItemListScroller .PageWorksItemListScroller__button {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  --disc-arrow-size: 4.8rem;
  --button-position-x: 2rem;
  position: absolute;
  z-index: 1;
  top: calc(10rem - var(--disc-arrow-size) / 2);
  animation: PageWorksItemListScrollerButtonFadein 0.6s;
}
.js-PageWorksItemListScroller .PageWorksItemListScroller__button:hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
.js-PageWorksItemListScroller .PageWorksItemListScroller__button::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .js-PageWorksItemListScroller .PageWorksItemListScroller__button {
    --disc-arrow-size: 3rem;
    --button-position-x: -1.5rem;
    top: calc(6rem - var(--disc-arrow-size) / 2);
  }
}
.js-PageWorksItemListScroller .PageWorksItemListScroller__button.prev {
  right: calc(100% + var(--button-position-x));
  scale: -1 1;
}
.js-PageWorksItemListScroller .PageWorksItemListScroller__button.next {
  left: calc(100% + var(--button-position-x));
}
.js-PageWorksItemListScroller .PageWorksItemListScroller__button:disabled {
  display: none;
}
.js-PageWorksItemListScroller .PageWorksItemList {
  flex-wrap: nowrap;
  overflow-x: auto;
  scroll-snap-type: x;
  scrollbar-width: none;
}
.js-PageWorksItemListScroller .PageWorksItemList::-webkit-scrollbar {
  display: none;
}
.js-PageWorksItemListScroller .PageWorksItemList .item {
  scroll-snap-align: start;
}

.PageWorksSakan {
  padding-inline: var(--site-gap);
}
.PageWorksSakan .PageWorksSakan__box {
  margin-inline: auto;
  padding-block: 25px 140px;
  max-width: 1600px;
  background: #fff;
  border-radius: var(--base-radius);
}
.PageWorksSakan .PageWorksSakan__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  font-size: 1.6rem;
}

.PageWorksSakanHeader .title {
  font-size: max(2.3rem * var(--pc-flag), 1.5rem * var(--sp-flag));
  font-weight: bold;
  color: var(--color-blue);
}

.PageWorksSakanBody {
  margin-inline: auto;
  max-width: 93rem;
}

.PageWorksSakanImage {
  margin-top: max(5rem * var(--pc-flag), 2rem * var(--sp-flag));
}
.PageWorksSakanImage img {
  display: block;
  aspect-ratio: 932/587;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: var(--base-radius);
}

.PageWorksSakanNav {
  margin-top: max(5rem * var(--pc-flag), 2rem * var(--sp-flag));
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  justify-content: center;
  gap: max(3rem * var(--pc-flag), 1rem * var(--sp-flag));
}
.PageWorksSakanNav .title {
  font-size: max(3.5rem * var(--pc-flag), 1.6rem * var(--sp-flag));
}
.PageWorksSakanNav .linl-wrap.prev {
  justify-self: end;
  --arrow-scale: -1 1;
}
.PageWorksSakanNav .linl-wrap.next {
  justify-self: start;
  --arrow-scale: 1 1;
}
.PageWorksSakanNav .linl-wrap a {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
  display: flex;
  align-items: center;
  font-size: max(1.7rem * var(--pc-flag), 1.1rem * var(--sp-flag));
  gap: 1em;
}
.PageWorksSakanNav .linl-wrap a:hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
.PageWorksSakanNav .linl-wrap a .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  scale: var(--arrow-scale);
}
.PageWorksSakanNav .linl-wrap a .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageWorksSakanNav .linl-wrap a .arrow {
    --disc-arrow-size: 2rem;
  }
}

.PageWorksSakanList {
  margin-top: max(3rem * var(--pc-flag), 2rem * var(--sp-flag));
  border-top: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue-light);
  width: 100%;
  border-collapse: collapse;
  font-size: max(1.7rem * var(--pc-flag), 1.1rem * var(--sp-flag));
  line-height: 1.3;
}
.PageWorksSakanList :where(th, td) {
  padding: 1em;
  vertical-align: top;
  text-align: center;
}
@media (max-width: 1080px) {
  .PageWorksSakanList :where(th, td) {
    padding: 0.8em 0.7em;
  }
}
.PageWorksSakanList :where(th, td):nth-child(1) {
  width: 45%;
}
.PageWorksSakanList :where(th, td):nth-child(2) {
  border-left: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue-light);
}
.PageWorksSakanList :where(th, td):where(th) {
  border-bottom: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue-light);
  text-align: center;
}
.PageWorksSakanList :where(th, td):where(td) {
  border-top: 1px solid var(--color-blue);
  text-align: left;
}

.PageWorksDetail {
  margin-inline: auto;
  max-width: 100rem;
}

.PageWorksDetailHeader {
  margin-bottom: 4rem;
  border-bottom: 1px solid var(--color-blue);
  padding-bottom: 3rem;
  margin-inline: auto;
  display: grid;
  justify-content: center;
}
@media (max-width: 1080px) {
  .PageWorksDetailHeader {
    margin-bottom: 2rem;
    padding-bottom: 1rem;
  }
}
.PageWorksDetailHeader .categories {
  margin-bottom: 1em;
  font-size: max(1.7rem * var(--pc-flag), 1.2rem * var(--sp-flag));
  display: flex;
  gap: 1em;
}
.PageWorksDetailHeader .categories a {
  padding: 0.3em 0.8em;
  border-radius: 1.2em;
  background-color: #c7ddeb;
  font-weight: bold;
}
.PageWorksDetailHeader .categories .prefecture {
  padding: 0.3em 0.8em;
  border-radius: 1.2em;
  background-color: #c7ddeb;
  font-weight: bold;
}
.PageWorksDetailHeader .title {
  font-size: max(3.5rem * var(--pc-flag), 2rem * var(--sp-flag));
  line-height: 1.4;
  font-weight: bold;
}

.PageWorksDetailGallery {
  position: relative;
  margin-inline: auto;
  width: max(50rem * var(--pc-flag), 32rem * var(--sp-flag));
}
.PageWorksDetailGallery .viewer {
  position: relative;
  aspect-ratio: 5/3;
  width: 100%;
  height: auto;
}
.PageWorksDetailGallery .viewer-image {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWorksDetailGallery :is(.prev, .next) {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  --disc-arrow-size: 6.4rem;
  position: absolute;
  top: calc(50% - var(--disc-arrow-size) / 2);
}
.PageWorksDetailGallery :is(.prev, .next):hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
.PageWorksDetailGallery :is(.prev, .next)::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageWorksDetailGallery :is(.prev, .next) {
    display: none;
  }
}
.PageWorksDetailGallery :is(.prev, .next):is(.prev) {
  right: calc(100% + 2rem);
  scale: -1 1;
}
.PageWorksDetailGallery :is(.prev, .next):is(.next) {
  left: calc(100% + 2rem);
}
.PageWorksDetailGallery .thumbnails {
  margin: max(2rem * var(--pc-flag), 1rem * var(--sp-flag)) auto 0;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  flex-wrap: wrap;
  gap: max(2rem * var(--pc-flag), 1rem * var(--sp-flag));
}
.PageWorksDetailGallery .thumbnails > button {
  position: relative;
  border: none;
  padding: 0;
  aspect-ratio: 1;
  width: max(8.4rem * var(--pc-flag), 5.6rem * var(--sp-flag));
  height: auto;
  transition: filter 0.3s;
}
.PageWorksDetailGallery .thumbnails > button[aria-selected=true], .PageWorksDetailGallery .thumbnails > button:hover {
  filter: brightness(1.1);
}
.PageWorksDetailGallery .thumbnails > button > img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWorksDetailGallery .thumbnails > button::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue);
  opacity: 0;
  transition: opacity 0.3s;
}
.PageWorksDetailGallery .thumbnails > button[aria-selected=true]::after {
  opacity: 0.8;
}

.PageWorksDetailInfo {
  margin: max(3rem * var(--pc-flag), 2rem * var(--sp-flag)) auto 0;
  width: max(50rem * var(--pc-flag), 32rem * var(--sp-flag));
  border-collapse: collapse;
  font-size: max(1.7rem * var(--pc-flag), 1.2rem * var(--sp-flag));
  line-height: 1.5;
}
.PageWorksDetailInfo :where(th, td) {
  padding: max(1rem * var(--pc-flag), 0.5rem * var(--sp-flag));
  vertical-align: top;
  text-align: left;
}
.PageWorksDetailInfo :where(th, td):nth-child(1) {
  white-space: nowrap;
  width: 1%;
  padding-right: max(2rem * var(--pc-flag), 1.5rem * var(--sp-flag));
  font-weight: bold;
  background: var(--color-blue-lightest);
}
.PageWorksDetailInfo :where(th, td):nth-child(2) {
  border-left: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue-light);
  padding-left: max(2rem * var(--pc-flag), 1.5rem * var(--sp-flag));
}
.PageWorksDetailInfo :where(th, td):where(th) {
  text-align: left;
}
.PageWorksDetailInfo :where(th, td):where(td) {
  text-align: left;
}
.PageWorksDetailInfo tr:nth-child(n+2) th,
.PageWorksDetailInfo tr:nth-child(n+2) td {
  border-top: 1px solid var(--color-blue);
}

.PageWorksBuilding {
  padding-inline: var(--site-gap);
}
.PageWorksBuilding .PageWorksBuilding__box {
  margin-inline: auto;
  padding-block: 25px 140px;
  max-width: 1600px;
  background: #fff;
  border-radius: var(--base-radius);
}
.PageWorksBuilding .PageWorksBuilding__container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  font-size: 1.6rem;
}

.PageWorksList {
  margin-top: 3rem;
  display: flex;
  flex-wrap: wrap;
  gap: 3.6rem;
}
.PageWorksList .link {
  flex-shrink: 0;
  width: 27.2rem;
}
.PageWorksList .link .thumbnail {
  display: block;
  aspect-ratio: 272/203;
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
  overflow: hidden;
}
.PageWorksList .link .thumbnail img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWorksList .link .thumbnail .noimage {
  display: block;
  width: 100%;
  height: 100%;
  background-color: #eee;
}
.PageWorksList .link .info {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.PageWorksList .link .info .title {
  font-size: 1.9rem;
  line-height: 1.4;
}
.PageWorksList .link .info .categories {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 1.5rem;
}

.PageWorksInsulationList {
  margin: 3rem auto 0;
  border-top: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue-light);
  width: 93rem;
  border-collapse: collapse;
  font-size: 1.7rem;
  line-height: 1.3;
}
@media (max-width: 1080px) {
  .PageWorksInsulationList {
    font-size: 1.2rem;
    width: 100%;
  }
}
.PageWorksInsulationList :where(th, td) {
  padding: 1em;
  vertical-align: top;
  text-align: center;
}
@media (max-width: 1080px) {
  .PageWorksInsulationList :where(th, td) {
    padding: 1em 0.5em;
  }
}
.PageWorksInsulationList :where(th, td):nth-child(1) {
  white-space: nowrap;
}
.PageWorksInsulationList :where(th, td):nth-child(n+2) {
  border-left: 1px solid var(--color-blue-light);
}
.PageWorksInsulationList :where(th, td):where(th) {
  border-bottom: max(0.4rem * var(--pc-flag), 0.2rem * var(--sp-flag)) solid var(--color-blue-light);
  text-align: center;
}
@media (max-width: 1080px) {
  .PageWorksInsulationList :where(th, td):where(th).area {
    display: none;
  }
}
.PageWorksInsulationList :where(th, td):where(td) {
  border-top: 1px solid var(--color-blue);
  text-align: left;
}
.PageWorksInsulationList :where(th, td):where(td).year {
  white-space: nowrap;
}
.PageWorksInsulationList :where(th, td):where(td).location {
  white-space: nowrap;
}
.PageWorksInsulationList :where(th, td):where(td).title a:hover {
  color: var(--color-blue-light);
}
@media (max-width: 1080px) {
  .PageWorksInsulationList :where(th, td):where(td).area {
    display: none;
  }
}
@media (max-width: 1080px) {
  .PageWorksInsulationList :where(th, td) .city {
    display: none;
  }
}

.PageWorksItemListMore {
  margin-top: 4rem;
  width: 100%;
  border: 1px solid var(--color-blue);
  border-radius: 0.75em;
  height: 5em;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-size: 2rem;
  font-weight: bold;
  color: var(--color-blue);
}
.PageWorksItemListMore::after {
  content: "";
  width: 1.5em;
  height: 1.5em;
  background-color: currentcolor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='black' d='M6 1v10M1 6h10'/%3E%3C/svg%3E") no-repeat center/100% 100%;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='black' d='M6 1v10M1 6h10'/%3E%3C/svg%3E") no-repeat center/100% 100%;
}
@media (max-width: 1080px) {
  .PageWorksItemListMore {
    margin-top: 3rem;
    font-size: 1.5rem;
    height: 4em;
  }
}

@media (min-width: 1080.01px) {
  .PageWorksInsulationMap {
    margin: 2rem auto 0;
    position: relative;
    width: 93rem;
    height: 58rem;
    background-color: #f2f2f2;
    border-radius: 2rem;
  }
}
.PageWorksInsulationMap [v-cloak] {
  display: none !important;
}
@media (min-width: 1080.01px) {
  .PageWorksInsulationMap .PageWorksInsulationMap__header {
    position: absolute;
    left: 5rem;
    top: 10rem;
    pointer-events: none;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__header .title {
    font-size: 2.3rem;
    font-weight: bold;
    color: var(--color-blue);
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__header .description {
    margin-top: 1em;
    font-size: 1.6rem;
  }
}
@media (max-width: 1080px) {
  .PageWorksInsulationMap .PageWorksInsulationMap__header {
    display: none;
  }
}
.PageWorksInsulationMap .PageWorksInsulationMap__map {
  display: block;
  aspect-ratio: 515/579;
  height: auto;
}
@media (min-width: 1080.01px) {
  .PageWorksInsulationMap .PageWorksInsulationMap__map {
    position: absolute;
    left: 8rem;
    top: 0;
    width: 52rem;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__map svg {
    width: 100%;
    height: 100%;
  }
}
@media (max-width: 1080px) {
  .PageWorksInsulationMap .PageWorksInsulationMap__map {
    margin: 0 auto;
    width: 30rem;
  }
}
@media (min-width: 1080.01px) {
  .PageWorksInsulationMap .PageWorksInsulationMap__item {
    position: absolute;
    right: 2rem;
    top: 28rem;
    display: grid;
    grid-template-columns: 4.8rem 27.5rem 4.8rem;
    gap: 1rem;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-column-prefecture {
    grid-column: 1/span 3;
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-column {
    position: relative;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-button {
    --disc-arrow-bg-color: #fff;
    --disc-arrow-border-color: var(--color-blue);
    --disc-arrow-icon-color: var(--color-blue);
    --disc-arrow-transition-duration: 0.2s;
    aspect-ratio: 1;
    width: var(--disc-arrow-size, 6.4rem);
    height: auto;
    border-radius: 50%;
    background-color: var(--disc-arrow-bg-color, var(--color-blue));
    border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
    display: grid;
    place-content: center;
    transition: var(--disc-arrow-transition-duration, 0.3s);
    transition-property: background-color, border-color;
    margin-top: 7rem;
    --disc-arrow-size: 4.8rem;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-button:hover {
    --disc-arrow-bg-color: var(--color-blue);
    --disc-arrow-icon-color: #fff;
    --disc-arrow-transition-duration: 0.3s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-button::before {
    content: "";
    display: block;
    aspect-ratio: 1;
    width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
    height: auto;
    background-color: var(--disc-arrow-icon-color, #fff);
    -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
            mask: var(--link-arrow-url) no-repeat 50%/100% auto;
    transition: background-color var(--disc-arrow-transition-duration, 0.3s);
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-button.item-button-prev {
    scale: -1 1;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link {
    --hover-fade-opacity: 1;
    --hover-fade-duration: 0.2s;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    display: grid;
    gap: 1.5rem;
    color: inherit;
    text-decoration: none;
    line-height: 1;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link:hover {
    --hover-fade-opacity: 0.75;
    --hover-fade-duration: 0.3s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-fade-enter-from {
    transform: translateY(-20px);
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-fade-enter-active {
    transition: 0.3s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-fade-leave-active {
    transition: 0.1s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-fade-leave-to {
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-prev-enter-from {
    transform: translateX(-20px);
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-prev-enter-active {
    transition: 0.3s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-prev-leave-to {
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-prev-leave-active {
    transition: 0.1s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-next-enter-from {
    transform: translateX(20px);
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-next-enter-active {
    transition: 0.3s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-next-leave-active {
    transition: 0.1s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link.map-work-slide-next-leave-to {
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link .item-link-image {
    transition: opacity var(--hover-fade-duration);
    opacity: var(--hover-fade-opacity);
    aspect-ratio: 275/200;
    width: 100%;
    height: auto;
    border: 1px solid var(--color-blue);
    background-color: #eee;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link .item-link-image img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    opacity: 0;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link .item-link-image img[data-loaded=true] {
    opacity: 1;
    transition: opacity 0.3s;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link .item-link-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 1.8rem;
  }
  .PageWorksInsulationMap .PageWorksInsulationMap__item .item-link .item-link-subtext {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 1.6rem;
  }
}
@media (max-width: 1080px) {
  .PageWorksInsulationMap .PageWorksInsulationMap__item {
    display: none;
  }
}

.PageWorksInsulationMapMapSvg .map-group {
  filter: url("#map-shadow");
}
.PageWorksInsulationMapMapSvg .map-prefecture {
  --fill-color: #fff;
}
.PageWorksInsulationMapMapSvg .map-link {
  --fill-color: #fcdeaf;
}
@media (min-width: 1080.01px) {
  .PageWorksInsulationMapMapSvg .map-link[data-selected=true] {
    --fill-color: #f7bd44;
  }
}
@media (max-width: 1080px) {
  .PageWorksInsulationMapMapSvg .map-link {
    pointer-events: none;
  }
}
.PageWorksInsulationMapMapSvg .map-land {
  fill: var(--fill-color);
  stroke: #000;
  stroke-width: 0.5;
  stroke-linejoin: round;
  transition: fill 0.3s;
}
.PageWorksInsulationMapMapSvg .map-lake {
  fill: #999;
  pointer-events: none;
}
@media (min-width: 1080.01px) {
  .PageWorksInsulationMapMapSvg .map-tooltip {
    pointer-events: none;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip.map-tooltip-enter-from {
    opacity: 0;
    transform: translateY(-5px);
  }
  .PageWorksInsulationMapMapSvg .map-tooltip.map-tooltip-enter-active {
    transition: 0.3s;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip.map-tooltip-enter-to {
    opacity: 1;
    transform: translateY(0);
  }
  .PageWorksInsulationMapMapSvg .map-tooltip.map-tooltip-leave-from {
    opacity: 1;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip.map-tooltip-leave-active {
    transition: 0.1s;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip.map-tooltip-leave-to {
    opacity: 0;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip rect {
    fill: #7f7f7f;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip polygon {
    fill: #7f7f7f;
  }
  .PageWorksInsulationMapMapSvg .map-tooltip text {
    fill: #fff;
  }
}
@media (max-width: 1080px) {
  .PageWorksInsulationMapMapSvg .map-tooltip {
    display: none;
  }
}

.PageHrdTopKv {
  --arc-mask-width: max(1920px, 100vw);
  --arc-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 100"><mask id="mask"><rect fill="white" width="10" height="100"/><ellipse cx="5" cy="-1" rx="5.77" ry="2"/></mask><rect mask="url(%23mask)" width="10" height="100"/></svg>');
  --arc-mask-height: calc(0.1 * var(--arc-mask-width));
  margin-block-start: calc(-1 * var(--arc-mask-height));
  -webkit-mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
          mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
  position: relative;
  z-index: -1;
  width: 100%;
  height: 115rem;
}
@media (max-width: 1080px) {
  .PageHrdTopKv {
    height: 52rem;
  }
}
.PageHrdTopKv .bg {
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.PageHrdTopKv .bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHrdTopKv .texts {
  padding-top: calc(30rem + var(--arc-mask-height));
  display: flex;
  flex-direction: column;
  text-align: center;
  gap: 1em;
  color: #fff;
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageHrdTopKv .texts {
    padding-top: calc(5rem + var(--arc-mask-height));
    font-size: 2.2rem;
  }
}
.PageHrdTopKv .texts .text1 {
  font-size: 100%;
}
.PageHrdTopKv .texts .text2 {
  font-size: 100%;
}
.PageHrdTopKv .texts .text3 {
  font-size: 44%;
}
@media (max-width: 1080px) {
  .PageHrdTopKv .texts .text3 {
    font-size: 50%;
  }
}

.PageHrdKv {
  position: relative;
  margin-top: 5rem;
  width: 100%;
  height: 76.6rem;
  display: grid;
  place-content: center;
}
@media (max-width: 1080px) {
  .PageHrdKv {
    margin-top: 2rem;
    height: 22rem;
  }
}
.PageHrdKv .bg {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
}
.PageHrdKv .bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageHrdKv .box {
  position: relative;
  padding: 5rem;
  background-color: rgba(255, 255, 255, 0.7);
  border-radius: var(--base-radius);
  line-height: 1;
  color: var(--color-blue);
  display: grid;
  gap: 2rem;
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-20-36-2s-23-3a-w-1a-2q-33-3c-1m-2w-2p-37-14-1a-2p-36-36-33-3b-1m-32-33-38-14-1a-2v-33-2p-37-38-15-15]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist) {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
}
.PageHrdKv .box:has(.arrow:not(.goast)) {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-20-36-2s-23-3a-w-1a-2q-33-3c-1m-2w-2p-37-14-1a-2p-36-36-33-3b-1m-32-33-38-14-1a-2v-33-2p-37-38-15-15-1m-2w-33-3a-2t-36]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist) {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
.PageHrdKv .box:has(.arrow:not(.goast)):hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-20-36-2s-23-3a-w-1a-2q-33-3c-1m-2w-2p-37-14-1a-2p-36-36-33-3b-1a-2v-33-2p-37-38-15]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist) {
  --disc-arrow-bg-color: transparent;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
}
.PageHrdKv .box:has(.arrow.goast) {
  --disc-arrow-bg-color: transparent;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-20-36-2s-23-3a-w-1a-2q-33-3c-1m-2w-2p-37-14-1a-2p-36-36-33-3b-1a-2v-33-2p-37-38-15-1m-2w-33-3a-2t-36]:not(.does-not-exist):not(.does-not-exist):not(.does-not-exist):not(.does-not-exist) {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
.PageHrdKv .box:has(.arrow.goast):hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
@media (max-width: 1080px) {
  .PageHrdKv .box {
    padding: 2.5rem 2rem;
    gap: 1rem;
  }
}
.PageHrdKv .box.center {
  text-align: center;
  width: 75rem;
}
@media (max-width: 1080px) {
  .PageHrdKv .box.center {
    width: auto;
  }
}
.PageHrdKv .box .title {
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
  padding-bottom: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdKv .box .title {
    padding-bottom: 1rem;
    font-size: 2rem;
  }
}
.PageHrdKv .box .english {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdKv .box .english {
    font-size: 1.1rem;
  }
}
.PageHrdKv .box .sub {
  font-size: 2.3rem;
}
@media (max-width: 1080px) {
  .PageHrdKv .box .sub {
    font-size: 1.6rem;
  }
  .PageHrdKv .box .sub.sub-ashita {
    font-size: 1.1rem;
  }
}
.PageHrdKv .box .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  --disc-arrow-size: 6.4rem;
  position: absolute;
  right: 2rem;
  bottom: 2rem;
}
.PageHrdKv .box .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageHrdKv .box .arrow {
    --disc-arrow-size: 3.2rem;
    right: 1rem;
    bottom: 1rem;
  }
}

.PageHrdTopLocalNav {
  margin-block: 12rem;
}
@media (max-width: 1080px) {
  .PageHrdTopLocalNav {
    margin-block: 3rem;
  }
  .PageHrdTopLocalNav .ModuleLocalNav {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    font-size: 1.6rem;
  }
}

.PageHrdTopFeature {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
@media (min-width: 1080.01px) {
  .PageHrdTopFeature {
    margin-block: 14rem 10rem;
  }
}
@media (max-width: 1080px) {
  .PageHrdTopFeature {
    margin-block: 3rem 4rem;
  }
}
.PageHrdTopFeature .link {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
}
.PageHrdTopFeature .link:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
.PageHrdTopFeature .link .link-heading {
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-heading {
    font-size: 2.2rem;
  }
}
.PageHrdTopFeature .link .link-block1 {
  margin-top: 2rem;
  display: flex;
  align-items: end;
  gap: 9rem;
  line-height: 1;
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block1 {
    gap: 3rem;
  }
}
.PageHrdTopFeature .link .link-block1 > p {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block1 > p {
    gap: 1rem;
  }
}
.PageHrdTopFeature .link .link-block1 > p .english {
  font-size: 1.7rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block1 > p .english {
    font-size: 1.2rem;
  }
}
.PageHrdTopFeature .link .link-block1 > p .phrase {
  font-size: 2.3rem;
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block1 > p .phrase {
    font-size: 1.6rem;
  }
}
.PageHrdTopFeature .link .link-block1 .icon {
  width: 4.5rem;
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block1 .icon {
    width: 3rem;
  }
}
.PageHrdTopFeature .link .link-block2 {
  margin-top: 3rem;
  display: flex;
  align-items: center;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block2 {
    margin-top: 2rem;
    gap: 1rem;
  }
}
.PageHrdTopFeature .link .link-block2 .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.PageHrdTopFeature .link .link-block2 .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block2 .arrow {
    --disc-arrow-size: 3.2rem;
  }
}
.PageHrdTopFeature .link .link-block2 p {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .link .link-block2 p {
    font-size: 1.1rem;
  }
}
.PageHrdTopFeature .images {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
@media (min-width: 1080.01px) {
  .PageHrdTopFeature .images {
    margin-top: 6rem;
    gap: 3rem;
  }
}
@media (max-width: 1080px) {
  .PageHrdTopFeature .images {
    margin-top: 2rem;
    gap: 1rem;
  }
}
.PageHrdTopFeature .images img {
  aspect-ratio: 1/1;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: var(--base-radius);
}

.PageHrdTopWomen {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: grid;
}
@media (min-width: 1080.01px) {
  .PageHrdTopWomen {
    margin-block: 16rem 10rem;
    grid-template: 43rem/1fr 74rem;
    align-items: center;
  }
}
@media (max-width: 1080px) {
  .PageHrdTopWomen {
    margin-block: 4rem;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.PageHrdTopWomen .link {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
}
.PageHrdTopWomen .link:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
.PageHrdTopWomen .link .link-heading {
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-heading {
    font-size: 2.2rem;
  }
}
.PageHrdTopWomen .link .link-block1 {
  margin-top: 2rem;
  display: flex;
  align-items: center;
  gap: 3rem;
  line-height: 1;
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block1 {
    margin-top: 1rem;
    gap: 2rem;
  }
}
.PageHrdTopWomen .link .link-block1 > p {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block1 > p {
    gap: 1rem;
  }
}
.PageHrdTopWomen .link .link-block1 > p .english {
  font-size: 1.7rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block1 > p .english {
    font-size: 1.2rem;
  }
}
.PageHrdTopWomen .link .link-block1 > p .phrase {
  font-size: 2.3rem;
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block1 > p .phrase {
    font-size: 1.6rem;
  }
}
.PageHrdTopWomen .link .link-block1 .icon {
  width: 5.7rem;
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block1 .icon {
    width: 4rem;
  }
}
.PageHrdTopWomen .link .link-block2 {
  margin-top: 3rem;
  display: flex;
  align-items: center;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block2 {
    margin-top: 2rem;
    gap: 1rem;
  }
}
.PageHrdTopWomen .link .link-block2 .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.PageHrdTopWomen .link .link-block2 .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block2 .arrow {
    --disc-arrow-size: 3.2rem;
  }
}
.PageHrdTopWomen .link .link-block2 p {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdTopWomen .link .link-block2 p {
    font-size: 1.1rem;
  }
}
.PageHrdTopWomen .image {
  border-radius: var(--base-radius);
}

.PageHrdTopBottomHr {
  border: none;
  width: 100%;
  border-top: 1px solid #42210b;
}

.PageHrdBottomNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 10rem;
}
@media (max-width: 1080px) {
  .PageHrdBottomNav {
    margin-block: 4rem;
  }
}
.PageHrdBottomNav .box {
  padding: 3rem 5rem;
  border-radius: 3.8rem;
  background-color: #fff;
  display: flex;
  align-items: center;
  gap: 6rem;
}
@media (max-width: 1080px) {
  .PageHrdBottomNav .box {
    border-radius: 1.5rem;
    padding: 3rem var(--site-gap);
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }
}
.PageHrdBottomNav .heading {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
@media (max-width: 1080px) {
  .PageHrdBottomNav .heading {
    flex-direction: row;
    align-items: center;
    gap: 2rem;
  }
}
.PageHrdBottomNav .heading h2 {
  font-size: 2.9rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageHrdBottomNav .heading h2 {
    font-size: 2.2rem;
  }
}
.PageHrdBottomNav .heading a {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  gap: 1em;
}
.PageHrdBottomNav .heading a:hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
@media (max-width: 1080px) {
  .PageHrdBottomNav .heading a {
    gap: 0.5em;
  }
}
.PageHrdBottomNav .heading a .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.PageHrdBottomNav .heading a .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageHrdBottomNav .heading a .arrow {
    --disc-arrow-size: 3.2rem;
  }
}
@media (min-width: 1080.01px) {
  .PageHrdBottomNav .list {
    flex-grow: 1;
    display: flex;
    align-items: center;
    gap: 0.7em;
    font-size: 1.9rem;
  }
}
@media (max-width: 1080px) {
  .PageHrdBottomNav .list {
    font-size: 1.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}
.PageHrdBottomNav .list a {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.PageHrdBottomNav .list a[aria-current=page] {
  display: none;
}
.PageHrdBottomNav .list a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.PageHrdHamasaki {
  margin: 8rem auto 0;
  padding-block: 3rem 8rem;
  max-width: 138rem;
  background: url("../assets/hrd/hamasaki-bg.webp") repeat-y center top/100% auto;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki {
    margin-top: 0;
    padding-block: 3rem 4rem;
    background-size: 100% auto;
  }
}
.PageHrdHamasaki .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: grid;
  grid-template-columns: 52rem 1fr;
  gap: 7rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .container {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
}
.PageHrdHamasaki .header {
  display: flex;
  justify-content: space-between;
}
.PageHrdHamasaki .header hgroup {
  color: var(--color-blue);
}
.PageHrdHamasaki .header hgroup h3 {
  margin-top: 5rem;
  font-size: 3.1rem;
  line-height: 1.3;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .header hgroup h3 {
    font-size: 2.2rem;
  }
}
.PageHrdHamasaki .header hgroup p {
  margin-top: 0.5em;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .header hgroup p {
    font-size: 1.2rem;
  }
}
.PageHrdHamasaki .header figure {
  margin: 0;
  width: 15.9rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .header figure {
    width: 13rem;
  }
}
.PageHrdHamasaki .header figure img {
  display: block;
  width: 100%;
  height: auto;
}
.PageHrdHamasaki .header figure figcaption {
  margin-top: 0.5rem;
  font-size: 1.3rem;
  text-align: right;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .header figure figcaption {
    font-size: 1.1rem;
  }
}
.PageHrdHamasaki .story {
  margin-top: -8rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .story {
    margin-top: -4rem;
  }
}
.PageHrdHamasaki .story h4 {
  margin-block: 4rem 2rem;
  font-size: 2.3rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .story h4 {
    margin-block: 2rem 1rem;
    font-size: 1.6rem;
  }
}
.PageHrdHamasaki .story p {
  margin-block: 2rem 0;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .story p {
    font-size: 1.3rem;
  }
}
.PageHrdHamasaki .story figure {
  margin-block: 2rem 0;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .story figure {
    margin-block: 1rem 0;
  }
}
.PageHrdHamasaki .story figure img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}
.PageHrdHamasaki .story figure figcaption {
  margin-top: 0.5rem;
  font-size: 1.3rem;
  text-align: right;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .story figure figcaption {
    font-size: 1.1rem;
  }
}
.PageHrdHamasaki .history {
  border-left: 1px solid var(--color-blue);
}
.PageHrdHamasaki .history h3 {
  border-bottom: 1px solid var(--color-blue);
  padding: 1rem 1.5rem;
  font-size: 2.6rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .history h3 {
    padding: 1rem;
    font-size: 2.2rem;
  }
}
.PageHrdHamasaki .history dl {
  font-size: 1.6rem;
  display: grid;
  grid-template-columns: 6em 1fr;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .history dl {
    font-size: 1.3rem;
    grid-template-columns: 5em 1fr;
  }
}
.PageHrdHamasaki .history dl :where(dt, dd) {
  padding: 1.5rem 0 1.5rem 1.5rem;
  font-weight: normal;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .history dl :where(dt, dd) {
    padding: 0.8rem 0 0.8rem 0.8rem;
  }
}
.PageHrdHamasaki .history dl :where(dt, dd):nth-child(-n+2) {
  padding-top: 4rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .history dl :where(dt, dd):nth-child(-n+2) {
    padding-top: 2rem;
  }
}
.PageHrdHamasaki .history dl :where(dt, dd):nth-last-child(-n+2) {
  padding-bottom: 4rem;
}
@media (max-width: 1080px) {
  .PageHrdHamasaki .history dl :where(dt, dd):nth-last-child(-n+2) {
    padding-bottom: 2rem;
  }
}
.PageHrdHamasaki .history dl :where(dt, dd):where(dt) {
  border-right: 1px solid var(--color-blue);
  position: relative;
}
.PageHrdHamasaki .history dl :where(dt, dd):where(dt)::after {
  content: "";
  position: absolute;
  right: 0;
  translate: 52% 60%;
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background-color: #809bc3;
}
.PageHrdHamasaki .history dl :where(dt, dd):where(dd) {
  padding-inline: 2rem;
}

.PageHrdFeatureWhat {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 6rem 8rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat {
    margin-block: 3rem 4rem;
  }
}
.PageHrdFeatureWhat .heading .title {
  font-size: 3.1rem;
  line-height: 1.3;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat .heading .title {
    font-size: 2.2rem;
  }
}
.PageHrdFeatureWhat .heading .english {
  font-size: 1.7rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat .heading .english {
    margin-top: 0;
    font-size: 1.4rem;
  }
}
.PageHrdFeatureWhat .description {
  margin-top: 1em;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat .description {
    font-size: 1.3rem;
  }
}
.PageHrdFeatureWhat .list {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(2, 56rem);
  justify-content: space-between;
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat .list {
    margin-top: 2rem;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.PageHrdFeatureWhat .list > div > dt > img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}
.PageHrdFeatureWhat .list > div > dt > span {
  display: block;
  margin-top: 1.5rem;
  font-size: 2.3rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat .list > div > dt > span {
    margin-top: 1rem;
    font-size: 1.8rem;
  }
}
.PageHrdFeatureWhat .list > div > dd {
  margin-top: 1rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureWhat .list > div > dd {
    margin-top: 1rem;
    font-size: 1.3rem;
  }
}

.PageHrdFeatureWhiteBg {
  padding-block: 2rem 3rem;
  background-color: #fff;
}
.PageHrdFeatureWhiteBg .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.PageHrdFeatureData .row {
  margin-block: 4rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureData .row {
    margin-block: 2rem;
    grid-template-columns: 1fr;
  }
}
.PageHrdFeatureData .note {
  color: var(--color-blue);
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureData .note {
    font-size: 1.3rem;
  }
}
.PageHrdFeatureData h3 {
  margin-block: 5rem 3rem;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureData h3 {
    margin-block: 4rem 2rem;
    font-size: 2.2rem;
  }
}
.PageHrdFeatureData h4 {
  margin-block: 5rem 2rem;
  font-size: 2.3rem;
  line-height: 1.4;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureData h4 {
    margin-block: 2rem;
    font-size: 1.8rem;
  }
}
.PageHrdFeatureData .column > h4 {
  margin-top: 0;
}
.PageHrdFeatureData p {
  margin-top: 1em;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureData p {
    font-size: 1.3rem;
  }
}
.PageHrdFeatureData .column > p {
  margin-block: 0;
}
.PageHrdFeatureData .chart {
  margin-block: 5rem;
  display: block;
  margin-inline: auto;
  width: 100%;
  max-width: 93.6rem;
  height: auto;
  border: 1px solid var(--color-blue);
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageHrdFeatureData .chart {
    margin-block: 2rem;
  }
}
.PageHrdFeatureData .column > .chart {
  margin-block: 0;
}
.PageHrdFeatureData .bordered {
  margin-block: 1em;
  border: 1px solid currentcolor;
  padding: 1em 1.5em;
}
@media (max-width: 1080px) {
  .PageHrdFeatureData .bordered {
    padding: 0.8em 1em;
  }
}

.PageHrdFeatureRequirements {
  margin-top: 10rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements {
    margin-top: 3rem;
  }
}
.PageHrdFeatureRequirements .heading {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements .heading {
    font-size: 2.1rem;
  }
}
.PageHrdFeatureRequirements .cards {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  justify-content: space-between;
  gap: 1.2rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements .cards {
    margin-top: 2rem;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}
.PageHrdFeatureRequirements .card {
  background-color: #f3eee1;
  border-radius: 2.6rem;
  padding: 4rem 2.5rem 3rem;
  counter-increment: card;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1.5rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements .card {
    padding: 3rem 2rem;
    gap: 1rem;
  }
}
.PageHrdFeatureRequirements .card h4 {
  display: flex;
  gap: 0.3em;
  font-size: 2.3rem;
  line-height: 1.3;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements .card h4 {
    font-size: 1.8rem;
  }
}
.PageHrdFeatureRequirements .card h4::before {
  flex-shrink: 0;
  content: counter(card) ".";
  font-weight: bold;
}
.PageHrdFeatureRequirements .card img {
  display: block;
  width: 100%;
  height: auto;
}
.PageHrdFeatureRequirements .card ul {
  font-size: 1.6rem;
  line-height: 1.4;
  display: grid;
  gap: 0.5rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements .card ul {
    font-size: 1.3rem;
  }
}
.PageHrdFeatureRequirements strong {
  margin-top: 1rem;
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageHrdFeatureRequirements strong {
    font-size: 1.4rem;
  }
}

.PageHrdFeatureHere {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 8rem;
  display: grid;
  grid-template-columns: 1fr 60rem;
  gap: 4rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureHere {
    margin-top: 4rem;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.PageHrdFeatureHere h3 {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdFeatureHere h3 {
    font-size: 2.2rem;
  }
}
.PageHrdFeatureHere p {
  margin-top: 2em;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdFeatureHere p {
    margin-top: 1rem;
    font-size: 1.3rem;
  }
}
.PageHrdFeatureHere img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}

.PageHrdAshtaLead {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: 98rem;
  margin-block: 15rem 5rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaLead {
    margin-block: 4rem 2rem;
  }
}
.PageHrdAshtaLead hgroup {
  margin-block: 0 3rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaLead hgroup {
    margin-block: 0 2rem;
  }
}
.PageHrdAshtaLead hgroup p {
  color: var(--color-blue);
}
.PageHrdAshtaLead h3 {
  margin-block: 3rem 0;
  font-size: 3.1rem;
  line-height: 1.3;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdAshtaLead h3 {
    margin-block: 2rem 1rem;
    font-size: 2rem;
  }
}
.PageHrdAshtaLead p {
  margin-top: 1rem;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaLead p {
    font-size: 1.3rem;
  }
}

.PageHrdAshtaFlowChart {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlowChart {
    padding-inline: 0;
  }
}
.PageHrdAshtaFlowChart div {
  padding: 4rem var(--site-gap);
  background-color: #fff;
  border-radius: 3.4rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlowChart div {
    padding: 2rem var(--site-gap);
    border-radius: 0;
  }
}
.PageHrdAshtaFlowChart div img {
  display: block;
  margin-inline: auto;
  width: 900px;
  max-width: 100%;
  height: auto;
}
.PageHrdAshtaFlowChart div p {
  margin-top: 1em;
  margin-inline: auto;
  max-width: 900px;
  font-size: 1.5rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlowChart div p {
    font-size: 1.1rem;
  }
}

.PageHrdAshtaFlows {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 8rem;
  max-width: 93rem;
  display: grid;
  gap: 7rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlows {
    margin-top: 3rem;
    gap: 2rem;
  }
}
.PageHrdAshtaFlows > div {
  display: grid;
}
@media (min-width: 1080.01px) {
  .PageHrdAshtaFlows > div {
    grid-template: "image heaading" auto "image paragraph" 1fr/25.8rem 1fr;
    gap: 3rem 5rem;
  }
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlows > div {
    grid-template: "heaading" auto "image" auto "paragraph" 1fr/1fr;
    gap: 2rem;
  }
}
.PageHrdAshtaFlows > div > h4 {
  grid-area: heaading;
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlows > div > h4 {
    font-size: 1.6rem;
  }
}
.PageHrdAshtaFlows > div > p {
  grid-area: paragraph;
  font-size: 1.6rem;
  padding-bottom: 2em;
  border-bottom: 1px solid #aaa6a4;
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlows > div > p {
    font-size: 1.3rem;
  }
}
.PageHrdAshtaFlows > div:last-child > p {
  border: none;
  padding-bottom: 0;
}
.PageHrdAshtaFlows > div > img {
  grid-area: image;
  aspect-ratio: 1;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageHrdAshtaFlows > div > img {
    aspect-ratio: 16/9;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.PageHrdAshtaQualification {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 10rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification {
    margin-top: 3rem;
    padding-inline: 0;
  }
}
.PageHrdAshtaQualification .box {
  padding: 4rem var(--site-gap);
  background-color: #fff;
  border-radius: 3.4rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .box {
    padding: 2rem var(--site-gap);
    border-radius: 0;
  }
}
.PageHrdAshtaQualification .container {
  margin-inline: auto;
  max-width: 76rem;
}
.PageHrdAshtaQualification .header h3 {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .header h3 {
    font-size: 1.8rem;
  }
}
.PageHrdAshtaQualification .header p {
  margin-top: 1rem;
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .header p {
    font-size: 1.3rem;
  }
}
.PageHrdAshtaQualification .header small {
  display: block;
  margin-top: 0.5rem;
  font-size: 1.1rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .header small {
    font-size: 1.1rem;
  }
}
.PageHrdAshtaQualification .qualifications {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: 14rem 1fr;
  gap: 4rem 0;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .qualifications {
    margin-top: 2rem;
    grid-template-columns: 1fr;
    font-size: 1.2rem;
    gap: 1rem 0;
  }
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd) {
  padding-bottom: 1rem;
  font-weight: normal;
  line-height: 1.8;
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dt) {
  grid-row: span 1;
  border-bottom: 2px solid #003888;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dt) {
    border-bottom-width: 1px;
    position: relative;
    font-size: 120%;
  }
  .PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dt)::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 12em;
    border-bottom: 2px solid #003888;
  }
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) {
  grid-row: span 2;
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dt) {
  padding-bottom: 1rem;
  border-bottom: 1px solid #003888;
  padding-left: 4rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dt) {
    padding-left: 1em;
  }
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dt):not(:first-child) {
  padding-top: 5rem;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dt):not(:first-child) {
    padding-top: 2rem;
  }
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dd) {
  padding-left: 4rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 1080px) {
  .PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dd) {
    padding-left: 1em;
  }
}
.js-has-pseudo [csstools-has-1a-28-2p-2v-2t-20-36-2s-1t-37-2w-38-2p-29-39-2p-30-2x-2u-2x-2r-2p-38-2x-33-32-w-1a-35-39-2p-30-2x-2u-2x-2r-2p-38-2x-33-32-37-w-1q-w-1m-3b-2w-2t-36-2t-14-2s-38-18-w-2s-2s-15-1m-3b-2w-2t-36-2t-14-2s-2s-15-w-1q-w-2s-30-w-1q-w-1m-3b-2w-2t-36-2t-14-2s-2s-15-1m-2w-2p-37-14-39-30-1m-33-32-30-3d-19-2r-2w-2x-30-2s-15]:not(.does-not-exist):not(.does-not-exist):not(does-not-exist):not(does-not-exist) {
  grid-template-columns: 1fr;
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dd):has(ul:only-child) {
  grid-template-columns: 1fr;
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dd) > ul {
  margin-top: 1em;
  display: grid;
  font-size: 90%;
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dd) > ul > li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.3em;
}
.PageHrdAshtaQualification .qualifications > :where(dt, dd):where(dd) > dl > :where(dd) > ul > li::before {
  content: "■";
}

.PageHrdWomen {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 10rem;
  max-width: calc(110rem + var(--site-gap) * 2);
}
@media (max-width: 1080px) {
  .PageHrdWomen {
    margin-top: 3rem;
  }
}

.PageHrdWomenLead > hgroup {
  color: var(--color-blue);
}
.PageHrdWomenLead > hgroup h3 {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageHrdWomenLead > hgroup h3 {
    font-size: 2.2rem;
  }
}
.PageHrdWomenLead > hgroup p {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenLead > hgroup p {
    font-size: 1.3rem;
  }
}
.PageHrdWomenLead > p {
  margin-top: 4rem;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenLead > p {
    margin-top: 2rem;
    font-size: 1.4rem;
  }
}

.PageHrdWomenSakan {
  margin-top: 9rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenSakan {
    margin-top: 4rem;
  }
}
.PageHrdWomenSakan h4 {
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdWomenSakan h4 {
    font-size: 1.8rem;
  }
}
.PageHrdWomenSakan p {
  margin-top: 2rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenSakan p {
    font-size: 1.4rem;
  }
}

.PageHrdWomenBenefits {
  margin-top: 10rem;
  height: 59.3rem;
  background: url("../assets/hrd/women-image01.webp") no-repeat top right/auto 100%;
}
@media (max-width: 1080px) {
  .PageHrdWomenBenefits {
    margin-top: 4rem;
    height: auto;
    background: none;
  }
}
.PageHrdWomenBenefits .container {
  width: 36rem;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenBenefits .container {
    width: auto;
    height: auto;
  }
}
.PageHrdWomenBenefits .container h4 {
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdWomenBenefits .container h4 {
    font-size: 1.8rem;
  }
}
.PageHrdWomenBenefits .container p {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenBenefits .container p {
    font-size: 1.4rem;
  }
}
.PageHrdWomenBenefits .container .chart {
  position: relative;
  flex-grow: 1;
  align-content: end;
}
.PageHrdWomenBenefits .container .chart > span {
  position: absolute;
  left: 0;
  top: 100%;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenBenefits .container .chart > span {
    font-size: 1.1rem;
  }
}

.PageHrdWomenInternship {
  display: grid;
}
@media (min-width: 1080.01px) {
  .PageHrdWomenInternship {
    margin-top: 16rem;
    max-width: 95rem;
    grid-template: "heading image" auto "description image" auto "link image" 1fr/1fr 46.8rem;
    gap: 3rem;
    align-items: start;
  }
}
@media (max-width: 1080px) {
  .PageHrdWomenInternship {
    margin-top: 6rem;
    grid-template: "heading" auto "image" auto "description" auto "link" auto/1fr;
    gap: 2rem;
  }
}
.PageHrdWomenInternship .heading {
  grid-area: heading;
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageHrdWomenInternship .heading {
    grid-area: heading;
    font-size: 1.8rem;
  }
}
.PageHrdWomenInternship .description {
  grid-area: description;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenInternship .description {
    font-size: 1.4rem;
  }
}
.PageHrdWomenInternship .link {
  grid-area: link;
}
.PageHrdWomenInternship .link a {
  font-size: 1.9rem;
  width: 28rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  background-color: var(--color-gray);
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  font-family: var(--font-family-mincho);
}
.PageHrdWomenInternship .link a[aria-current=page] {
  display: none;
}
.PageHrdWomenInternship .link a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
.PageHrdWomenInternship .image {
  grid-area: image;
  place-self: center end;
  width: 100%;
  max-width: 46.8rem;
  height: auto;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageHrdWomenInternship .image {
    justify-self: center;
    max-width: 100%;
    aspect-ratio: 16/9;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.PageHrdWomenHimeboss {
  margin-top: 6rem;
  max-width: 95rem;
  display: flex;
  gap: 5rem;
}
@media (max-width: 1080px) {
  .PageHrdWomenHimeboss {
    margin-top: 5rem;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
  }
}
.PageHrdWomenHimeboss img {
  width: 21rem;
  height: auto;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageHrdWomenHimeboss img {
    width: 18rem;
  }
}
@media (min-width: 1080.01px) {
  .PageHrdWomenHimeboss p {
    padding-top: 5rem;
    font-size: 1.7rem;
  }
}
@media (max-width: 1080px) {
  .PageHrdWomenHimeboss p {
    font-size: 1.4rem;
  }
}

.PageWoodForm {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 6rem 10rem;
  max-width: calc(93rem + 2 * var(--site-gap));
}
@media (max-width: 1080px) {
  .PageWoodForm {
    margin-block: 3rem 6rem;
  }
}

.PageWoodFormHeader {
  margin-bottom: 3rem;
}
.PageWoodFormHeader h3 {
  font-size: 3.5rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodFormHeader h3 {
    font-size: 2.5rem;
  }
}

.PageWoodFormHr {
  border: none;
  border-top: 1px solid #231815;
  margin: 3rem 0;
}

.PageWoodFormLayout1 {
  margin-top: 2rem;
  font-size: 1.6rem;
  display: grid;
  grid-template-columns: auto 1fr;
}
@media (max-width: 1080px) {
  .PageWoodFormLayout1 {
    grid-template-columns: 1fr;
  }
}
.PageWoodFormLayout1 :where(dt, dd) {
  border-bottom: 0.25px solid #231815;
  padding: 2rem 1.5rem;
}
@media (max-width: 1080px) {
  .PageWoodFormLayout1 :where(dt, dd) {
    padding: 1.2rem 1rem;
  }
}
.PageWoodFormLayout1 :where(dt, dd):where(dt) {
  background-color: #f5f5f5;
  white-space: nowrap;
}
@media (max-width: 1080px) {
  .PageWoodFormLayout1 :where(dt, dd):where(dt) {
    white-space: normal;
  }
  .PageWoodFormLayout1 :where(dt, dd):where(dt):first-child {
    border-top: 0.25px solid #231815;
  }
}
.PageWoodFormLayout1 :where(dt, dd):where(dd) {
  display: grid;
  gap: 1rem;
}

.PageWoodFormLayout2 {
  margin-top: 2rem;
}

.PageWoodFormCheckGrid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem 1rem;
}
@media (max-width: 1080px) {
  .PageWoodFormCheckGrid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.PageWoodFormPeriodField {
  display: flex;
  align-items: center;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .PageWoodFormPeriodField {
    flex-direction: column;
    align-items: start;
    gap: 0.5rem;
  }
}
.PageWoodFormPeriodField .column {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.PageWoodFormPeriodField .column label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
@media (max-width: 1080px) {
  .PageWoodFormPeriodField .wave {
    rotate: 90deg;
    margin-left: 2em;
  }
}

.PageWoodAreaField {
  display: flex;
  align-items: center;
  gap: 6px;
}
.PageWoodAreaField input {
  width: 12rem;
  text-align: right;
}

/* -- 木造建築物 トップ -- */
.PageWoodTopKv {
  --arc-mask-width: max(1920px, 100vw);
  --arc-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 100"><mask id="mask"><rect fill="white" width="10" height="100"/><ellipse cx="5" cy="-1" rx="5.77" ry="2"/></mask><rect mask="url(%23mask)" width="10" height="100"/></svg>');
  --arc-mask-height: calc(0.1 * var(--arc-mask-width));
  margin-block-start: calc(-1 * var(--arc-mask-height));
  -webkit-mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
          mask: var(--arc-mask-image) no-repeat 50% 0%/var(--arc-mask-width) auto;
  position: relative;
  z-index: -1;
  width: 100%;
  height: 115rem;
}
@media (max-width: 1080px) {
  .PageWoodTopKv {
    height: 52rem;
  }
}
.PageWoodTopKv .bg {
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.PageWoodTopKv .bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWoodTopKv .texts {
  padding-top: calc(30rem + var(--arc-mask-height));
  display: flex;
  flex-direction: column;
  text-align: center;
  gap: 1em;
  color: #fff;
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageWoodTopKv .texts {
    padding-top: calc(5rem + var(--arc-mask-height));
    font-size: 2.2rem;
  }
}
.PageWoodTopKv .texts .text1 {
  font-size: 100%;
}
.PageWoodTopKv .texts .text2 {
  font-size: 100%;
}
.PageWoodTopKv .texts .text3 {
  font-size: 44%;
}
@media (max-width: 1080px) {
  .PageWoodTopKv .texts .text3 {
    font-size: 50%;
  }
}

.PageWoodTopNav {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 15rem;
  display: grid;
  grid-template-columns: repeat(3, 37.5rem);
  align-items: center;
  justify-content: center;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .PageWoodTopNav {
    grid-template-columns: 24rem;
    margin-block: 6rem;
    gap: 2rem;
  }
}
.PageWoodTopNav a {
  position: relative;
  font-size: 2.3rem;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5em;
  padding: 1.3em 1em 1.3em 6.5em;
  border-radius: 2em;
  line-height: 1.3;
  color: #fff;
  background-color: #b8a18e;
  border: 1px solid #fff;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageWoodTopNav a {
    font-size: 1.3rem;
  }
}
.PageWoodTopNav a .icon {
  position: absolute;
  left: 1.3em;
  bottom: 0.2em;
  width: 4.8em;
  height: 4.8em;
}
.PageWoodTopNav a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}

.PageWoodTopReason {
  position: relative;
  width: 100%;
  height: 76rem;
  display: grid;
  place-content: center;
}
@media (max-width: 1080px) {
  .PageWoodTopReason {
    height: 40rem;
  }
}
.PageWoodTopReason .bg img {
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWoodTopReason .link {
  --disc-arrow-bg-color: transparent;
  --disc-arrow-border-color: #fff;
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
  position: relative;
  width: 46.6rem;
  height: 25.4rem;
  background-color: rgba(66, 33, 11, 0.7019607843);
  background-image: url("../assets/wood/reason-tree.svg");
  background-repeat: no-repeat;
  background-size: 16rem auto;
  background-position: right 7rem bottom -2rem;
  border-radius: 1.8rem;
  color: #fff;
  display: grid;
  place-content: center;
  transition: background-color 0.2s;
}
.PageWoodTopReason .link:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
.PageWoodTopReason .link:hover {
  transition: background-color 0.3s;
  background-color: rgba(66, 33, 11, 0.8666666667);
}
@media (max-width: 1080px) {
  .PageWoodTopReason .link {
    width: 23.3rem;
    height: 12.7rem;
    border-radius: 0.9rem;
    background-size: 8rem auto;
    background-position: right 3.5rem bottom -1rem;
  }
}
.PageWoodTopReason .link .texts {
  display: flex;
  flex-direction: column;
}
.PageWoodTopReason .link .texts .why {
  font-size: 4.5rem;
  font-weight: bold;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageWoodTopReason .link .texts .why {
    font-size: 2.25rem;
  }
}
.PageWoodTopReason .link .texts .english {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageWoodTopReason .link .texts .english {
    font-size: 1rem;
  }
}
.PageWoodTopReason .link .texts .title {
  font-size: 2.3rem;
}
@media (max-width: 1080px) {
  .PageWoodTopReason .link .texts .title {
    font-size: 1.1rem;
  }
}
.PageWoodTopReason .link .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  position: absolute;
  right: 2rem;
  bottom: 3rem;
}
.PageWoodTopReason .link .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageWoodTopReason .link .arrow {
    right: 1rem;
    bottom: 1.5rem;
    --disc-arrow-size: 3.2rem;
  }
}

.PageWoodTopOneStop {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 16rem 12rem;
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  justify-content: center;
  gap: 5rem;
}
@media (max-width: 1080px) {
  .PageWoodTopOneStop {
    margin-block: 8rem 6rem;
    gap: 2rem;
    flex-direction: column;
    align-items: center;
  }
}
.PageWoodTopOneStop .header {
  margin-top: -1rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageWoodTopOneStop .header {
    gap: 1rem;
  }
}
.PageWoodTopOneStop .header .heading {
  display: flex;
  flex-direction: column;
  color: var(--color-blue);
}
.PageWoodTopOneStop .header .heading .text {
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageWoodTopOneStop .header .heading .text {
    font-size: 3rem;
  }
}
.PageWoodTopOneStop .header .heading .english {
  margin-left: 0.6rem;
  font-size: 1.7rem;
}
.PageWoodTopOneStop .header .link {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
  margin-left: 0.6rem;
  font-size: 1.7rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.PageWoodTopOneStop .header .link:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
@media (max-width: 1080px) {
  .PageWoodTopOneStop .header .link {
    font-size: 1.2rem;
  }
}
.PageWoodTopOneStop .header .link .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.PageWoodTopOneStop .header .link .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageWoodTopOneStop .header .link .arrow {
    --disc-arrow-size: 3.2rem;
  }
}
.PageWoodTopOneStop .image {
  aspect-ratio: 61/22.7;
  width: 61rem;
  height: auto;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageWoodTopOneStop .image {
    width: 25rem;
  }
}

.PageWoodTopSe {
  position: relative;
  z-index: 1;
  margin-top: 100px;
  padding-bottom: 40rem;
}
@media (max-width: 1080px) {
  .PageWoodTopSe {
    margin-top: 50px;
    padding-bottom: 10rem;
  }
}
.PageWoodTopSe .bg {
  position: absolute;
  z-index: -1;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 119rem;
  pointer-events: none;
}
@media (max-width: 1080px) {
  .PageWoodTopSe .bg {
    height: 60rem;
  }
}
.PageWoodTopSe .bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.PageWoodTopSe .heading {
  color: var(--color-blue);
  text-align: center;
}
.PageWoodTopSe .heading h2 {
  font-size: 3.9rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageWoodTopSe .heading h2 {
    font-size: 2.5rem;
  }
}
.PageWoodTopSe .heading p {
  margin-top: 0.5em;
  font-size: 2.3rem;
}
@media (max-width: 1080px) {
  .PageWoodTopSe .heading p {
    font-size: 1.5rem;
  }
}
.PageWoodTopSe .problems {
  margin-top: 4rem;
  display: grid;
  justify-content: center;
}
@media (min-width: 1080.01px) {
  .PageWoodTopSe .problems {
    grid-template: 18.2rem/repeat(4, 28.6rem);
    gap: 1.7rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodTopSe .problems {
    margin-top: 2rem;
    gap: 1rem;
  }
}
.PageWoodTopSe .problems > li {
  border: 1px solid #809bc3;
  border-radius: var(--base-radius);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1rem;
  font-size: 2rem;
}
@media (max-width: 1080px) {
  .PageWoodTopSe .problems > li {
    font-size: 1.2rem;
    padding: 1em;
  }
}
.PageWoodTopSe .problems > li span:nth-child(1) {
  color: #b8a18e;
}
.PageWoodTopSe .problems > li span:nth-child(2) {
  color: #666;
  display: flex;
  align-items: center;
}
@media (min-width: 1080.01px) {
  .PageWoodTopSe .problems > li span:nth-child(2) {
    min-height: 2lh;
  }
}
.PageWoodTopSe .text1 {
  margin-top: 3rem;
  text-align: center;
  font-size: 2.3rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodTopSe .text1 {
    margin-top: 2rem;
    font-size: 1.4rem;
  }
}
.PageWoodTopSe .text2 {
  margin-top: 5rem;
  text-align: center;
  font-size: 4.5rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodTopSe .text2 {
    margin-top: 3rem;
    font-size: 2.3rem;
  }
}
.PageWoodTopSe .link {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.2s;
  position: relative;
  margin: 18rem auto 0;
  width: 46.6rem;
  height: 24.4rem;
  background-color: rgba(255, 255, 255, 0.45);
  border-radius: 1.8rem;
  display: grid;
  place-content: center;
  transition: background-color 0.2s;
}
.PageWoodTopSe .link:hover {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.3s;
}
.PageWoodTopSe .link:hover {
  transition: background-color 0.3s;
  background-color: rgba(255, 255, 255, 0.75);
}
@media (max-width: 1080px) {
  .PageWoodTopSe .link {
    margin: 6rem auto 0;
    width: 23.3rem;
    height: 12.2rem;
    border-radius: 0.9rem;
  }
}
.PageWoodTopSe .link .tech {
  position: absolute;
  left: 4rem;
  top: 1.6rem;
  font-size: 1.7rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodTopSe .link .tech {
    left: 2rem;
    top: 0.8rem;
    font-size: 1rem;
  }
}
.PageWoodTopSe .link .logo {
  width: 22.6rem;
  height: auto;
}
@media (max-width: 1080px) {
  .PageWoodTopSe .link .logo {
    width: 12rem;
  }
}
.PageWoodTopSe .link .arrow {
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
  position: absolute;
  right: 2rem;
  bottom: 3rem;
}
.PageWoodTopSe .link .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageWoodTopSe .link .arrow {
    right: 1rem;
    bottom: 1.5rem;
    --disc-arrow-size: 3.2rem;
  }
}

.PageWoodTopNetwork {
  margin: 6rem auto 0;
  width: 104rem;
  height: 94rem;
  background-image: url("../assets/wood/network-map.svg");
  background-size: auto 100%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
@media (max-width: 1080px) {
  .PageWoodTopNetwork {
    margin: 3rem auto 0;
    width: 100%;
    height: auto;
  }
}
.PageWoodTopNetwork .container {
  padding-top: 25rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 1080px) {
  .PageWoodTopNetwork .container {
    padding-top: 12rem;
  }
}
.PageWoodTopNetwork .heading {
  color: var(--color-blue);
}
.PageWoodTopNetwork .heading span {
  font-size: 1.7rem;
}
.PageWoodTopNetwork .heading h2 {
  font-size: 45px;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageWoodTopNetwork .heading h2 {
    font-size: 2.5rem;
  }
}
.PageWoodTopNetwork .phrase {
  margin-top: 3rem;
  font-size: 2.3rem;
  color: var(--color-blue);
  text-align: center;
}
@media (max-width: 1080px) {
  .PageWoodTopNetwork .phrase {
    margin-top: 1.5rem;
    font-size: 1.4rem;
  }
}
.PageWoodTopNetwork .link {
  --disc-arrow-bg-color: var(--color-blue);
  --disc-arrow-border-color: var(--color-blue);
  --disc-arrow-icon-color: #fff;
  --disc-arrow-transition-duration: 0.2s;
  margin-top: 4rem;
  width: 57rem;
  font-size: 1.8rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.PageWoodTopNetwork .link:hover {
  --disc-arrow-bg-color: #fff;
  --disc-arrow-icon-color: var(--color-blue);
  --disc-arrow-transition-duration: 0.3s;
}
@media (max-width: 1080px) {
  .PageWoodTopNetwork .link {
    margin-top: 2rem;
    width: 30rem;
    font-size: 1.2rem;
  }
}
.PageWoodTopNetwork .link .arrow {
  flex-shrink: 0;
  aspect-ratio: 1;
  width: var(--disc-arrow-size, 6.4rem);
  height: auto;
  border-radius: 50%;
  background-color: var(--disc-arrow-bg-color, var(--color-blue));
  border: 1px solid var(--disc-arrow-border-color, var(--color-blue));
  display: grid;
  place-content: center;
  transition: var(--disc-arrow-transition-duration, 0.3s);
  transition-property: background-color, border-color;
}
.PageWoodTopNetwork .link .arrow::before {
  content: "";
  display: block;
  aspect-ratio: 1;
  width: calc(var(--disc-arrow-size, 6.4rem) * 12 / 64);
  height: auto;
  background-color: var(--disc-arrow-icon-color, #fff);
  -webkit-mask: var(--link-arrow-url) no-repeat 50%/100% auto;
          mask: var(--link-arrow-url) no-repeat 50%/100% auto;
  transition: background-color var(--disc-arrow-transition-duration, 0.3s);
}
@media (max-width: 1080px) {
  .PageWoodTopNetwork .link .arrow {
    --disc-arrow-size: 4rem;
  }
}

.PageWoodTopWorks {
  margin-top: 15rem;
}
@media (max-width: 1080px) {
  .PageWoodTopWorks {
    margin-top: 4rem;
  }
}
.PageWoodTopWorks .header {
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 3rem;
}
@media (max-width: 1080px) {
  .PageWoodTopWorks .header {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }
}
.PageWoodTopWorks .header hgroup h2 {
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodTopWorks .header hgroup h2 {
    font-size: 1.5rem;
  }
}
.PageWoodTopWorks .header hgroup p {
  line-height: 1;
  font-size: 8.8rem;
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageWoodTopWorks .header hgroup p {
    font-size: 4.5rem;
  }
}
.PageWoodTopWorks .header .link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1em;
  font-size: 1.9rem;
  padding: 0;
  width: 26rem;
  height: 5rem;
  border-radius: 2.5rem;
  background-color: var(--color-blue);
  color: #fff;
}
.PageWoodTopWorks .header .link::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
@media (max-width: 1080px) {
  .PageWoodTopWorks .header .link {
    font-size: 1.2rem;
    width: 18rem;
    height: 3.5rem;
  }
}
.PageWoodTopWorks .thumbnails {
  margin: 6rem auto 0;
  max-width: 120em;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  justify-content: center;
  gap: 2.5rem;
}
@media (max-width: 1080px) {
  .PageWoodTopWorks .thumbnails {
    margin-top: 3rem;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    max-width: 30em;
  }
}
.PageWoodTopWorks .thumbnails a {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  aspect-ratio: 1/1;
  height: auto;
  border-radius: var(--base-radius);
  overflow: hidden;
}
.PageWoodTopWorks .thumbnails a:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.PageWoodTopWorks .thumbnails a img {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.PageWoodClientKv {
  margin-top: 5rem;
  height: 51rem;
  background: #fff;
}
@media (max-width: 1080px) {
  .PageWoodClientKv {
    height: auto;
  }
}
.PageWoodClientKv .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  position: relative;
  padding-top: 3rem;
  height: 100%;
}
@media (max-width: 1080px) {
  .PageWoodClientKv .container {
    padding-bottom: 2rem;
  }
}
.PageWoodClientKv .container .heading {
  font-size: 3.1rem;
  display: flex;
  align-items: center;
  gap: 1em;
}
@media (max-width: 1080px) {
  .PageWoodClientKv .container .heading {
    gap: 0.7em;
  }
}
.PageWoodClientKv .container .heading .icon {
  width: 4em;
  height: 4em;
}
@media (max-width: 1080px) {
  .PageWoodClientKv .container .heading .icon {
    width: 2.5em;
    height: 2.5em;
  }
}
.PageWoodClientKv .container .heading .title {
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
.PageWoodClientKv .container .nayami {
  margin-top: 1em;
  font-size: 3.5rem;
  color: var(--color-blue);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageWoodClientKv .container .nayami {
    font-size: 2.5rem;
  }
}
.PageWoodClientKv .container .description {
  max-width: 60rem;
  margin-top: 2em;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageWoodClientKv .container .description {
    margin-top: 1em;
    font-size: 1.6rem;
    max-width: 23rem;
  }
}
.PageWoodClientKv .container .illust {
  position: absolute;
  right: 12rem;
  bottom: 0;
}
@media (max-width: 1080px) {
  .PageWoodClientKv .container .illust {
    right: 0;
    width: 10rem;
  }
}

.PageWoodClientDialogue {
  --speech-bubble-mask-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 60 40"><path d="M0 40 50.57 3.27c10.24-7.35 9.41 0 9.41 0L45.58 40z"/></svg>');
  margin-inline: auto;
  max-width: 1420px;
  display: grid;
  grid-template-columns: 100%;
  gap: 7rem;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue {
    gap: 3rem;
  }
}
.PageWoodClientDialogue .box {
  background-color: #e3eef5;
  counter-increment: PageWoodClientDialogue;
}
@media screen and (min-width: 1420px) {
  .PageWoodClientDialogue .box {
    border-radius: var(--base-radius);
  }
}
@media (min-width: 1080.01px) {
  .PageWoodClientDialogue .box {
    padding-block: 11rem 7rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .box {
    padding-block: 4rem 3rem;
  }
}
.PageWoodClientDialogue .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageWoodClientDialogue .question {
  position: relative;
  margin-left: auto;
  background-color: var(--color-blue);
  color: #fff;
}
@media (min-width: 1080.01px) {
  .PageWoodClientDialogue .question {
    padding: 4rem 22rem 3rem 5rem;
    width: 97rem;
    border-radius: 3rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .question {
    margin-left: 8rem;
    padding: 2rem;
    width: auto;
    border-radius: 1.5rem;
  }
}
.PageWoodClientDialogue .question::before {
  content: "";
  position: absolute;
  background-color: var(--color-blue);
  -webkit-mask: var(--speech-bubble-mask-url) no-repeat 0 0/100% 100%;
          mask: var(--speech-bubble-mask-url) no-repeat 0 0/100% 100%;
}
@media (min-width: 1080.01px) {
  .PageWoodClientDialogue .question::before {
    right: 12rem;
    top: -3.6rem;
    width: 6rem;
    height: 4rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .question::before {
    right: 4rem;
    top: -1.6rem;
    width: 3rem;
    height: 2rem;
  }
}
.PageWoodClientDialogue .question .question-number {
  --size: 8.4rem;
  position: absolute;
  left: calc(-0.5 * var(--size));
  top: calc(-0.5 * var(--size));
  padding-top: calc(0.1 * var(--size));
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  line-height: 1.1;
  border: 2px solid currentcolor;
  background-color: #c7ddeb;
  color: #809bc3;
  display: grid;
  place-content: center;
  text-align: center;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .question .question-number {
    --size: 5rem;
  }
}
.PageWoodClientDialogue .question .question-number::before {
  content: "CONCERN";
  font-size: calc(0.14 * var(--size));
}
.PageWoodClientDialogue .question .question-number::after {
  content: counter(PageWoodClientDialogue, decimal-leading-zero);
  font-size: calc(0.25 * var(--size));
}
.PageWoodClientDialogue .question .question-text {
  font-size: 2.8rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .question .question-text {
    font-size: 1.7rem;
  }
}
.PageWoodClientDialogue .answer {
  position: relative;
  margin-top: 7rem;
  padding: 2rem 9rem 3rem 28rem;
  width: 107rem;
  background-color: #fff;
  color: var(--color-blue);
  border-radius: 3rem;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .answer {
    margin-top: 3rem;
    padding: 2rem;
    width: auto;
    border-radius: 1.5rem;
  }
}
.PageWoodClientDialogue .answer::before {
  content: "";
  position: absolute;
  left: 10rem;
  top: -3.6rem;
  width: 6rem;
  height: 4rem;
  background-color: #fff;
  -webkit-mask: var(--speech-bubble-mask-url) no-repeat 0 0/100% 100%;
          mask: var(--speech-bubble-mask-url) no-repeat 0 0/100% 100%;
  scale: -1 1;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .answer::before {
    left: 4rem;
    top: -1.6rem;
    width: 3rem;
    height: 2rem;
  }
}
.PageWoodClientDialogue .answer::after {
  content: "";
  aspect-ratio: 264/270;
  height: auto;
  position: absolute;
  bottom: calc(100% + 1rem);
  background-image: url("../assets/wood/client-dialog-person.svg");
  background-size: 100% 100%;
}
@media (min-width: 1080.01px) {
  .PageWoodClientDialogue .answer::after {
    width: 26.4rem;
    right: calc(100% - 21rem);
  }
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .answer::after {
    width: 9rem;
    left: -1.5rem;
  }
}
.PageWoodClientDialogue .answer .answer-text {
  font-size: 2.8rem;
  font-weight: bold;
  overflow: hidden;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .answer .answer-text {
    font-size: 1.7rem;
  }
}
.PageWoodClientDialogue .answer .answer-text .answer-link {
  margin-top: 1.5rem;
  float: right;
  margin-left: auto;
  font-size: 1.8rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageWoodClientDialogue .answer .answer-text .answer-link {
    margin-top: 0.5rem;
    font-size: 1.3rem;
  }
}
.PageWoodClientDialogue .answer .answer-text .answer-link::after {
  content: ">>";
}

.PageWoodReason {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: calc(93rem + 2 * var(--site-gap));
}

.PageWoodReasonLead hgroup {
  color: var(--color-blue);
}
.PageWoodReasonLead hgroup h2 {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
.PageWoodReasonLead hgroup p {
  margin-top: 0.5em;
  font-size: 1.7rem;
}
.PageWoodReasonLead p {
  margin-top: 2rem;
  font-size: 1.7rem;
}

.PageWoodReasonHeading {
  position: relative;
  margin: 15rem 0 0;
  border-top: 0.5px solid var(--color-blue);
  padding-top: 5rem;
  color: var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageWoodReasonHeading {
    display: grid;
    grid-template-columns: 16rem 1fr;
    align-items: center;
  }
}
@media (max-width: 1080px) {
  .PageWoodReasonHeading {
    margin-top: 11rem;
    padding-top: 2rem;
  }
}
.PageWoodReasonHeading::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 100%;
  width: 7.2rem;
  height: 7.6rem;
  background-image: url("../assets/wood/reason-image05.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
.PageWoodReasonHeading div {
  font-size: 1.7rem;
}
.PageWoodReasonHeading div em {
  font-size: 4.1rem;
}
.PageWoodReasonHeading h3 {
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (min-width: 1080.01px) {
  .PageWoodReasonHeading h3 {
    font-size: 3.1rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodReasonHeading h3 {
    font-size: 2.5rem;
  }
}

@media (min-width: 1080.01px) {
  .PageWoodReasonBody {
    margin-left: 16rem;
  }
}
.PageWoodReasonBody h4 {
  font-size: 2rem;
  color: var(--color-blue);
  counter-increment: section;
}
@media (min-width: 1080.01px) {
  .PageWoodReasonBody h4 {
    margin-top: 4rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodReasonBody h4 {
    margin-top: 2rem;
  }
}
.PageWoodReasonBody h4::before {
  margin-right: 0.5em;
  content: counter(section, decimal-leading-zero);
  color: #809bc3;
}
.PageWoodReasonBody p {
  margin-top: 1.5rem;
  font-size: 1.6rem;
}

@media (min-width: 1080.01px) {
  .PageWoodReasonCirculation {
    margin-block: 10rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodReasonCirculation {
    margin-block: 5rem;
  }
}

.PageWoodReasonBody2 {
  margin-top: 4rem;
}
@media (min-width: 1080.01px) {
  .PageWoodReasonBody2 {
    display: flex;
    align-items: center;
    gap: 4rem;
  }
}
.PageWoodReasonBody2 > img {
  width: 21.5rem;
  height: auto;
}
@media (max-width: 1080px) {
  .PageWoodReasonBody2 > img {
    width: 10rem;
    margin: 0 0 0 0.5rem;
    float: right;
  }
}
.PageWoodReasonBody2 h4 {
  font-size: 2rem;
  color: var(--color-blue);
}
.PageWoodReasonBody2 p {
  margin-top: 1.5rem;
  font-size: 1.6rem;
}

.PageWoodOnestop {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: calc(93rem + 2 * var(--site-gap));
}
.PageWoodOnestop hr {
  border: none;
  border-top: 0.5px solid var(--color-blue);
  margin: 6rem 0;
}
@media (max-width: 1080px) {
  .PageWoodOnestop hr {
    margin: 4rem 0;
  }
}
.PageWoodOnestop .lead hgroup {
  color: var(--color-blue);
}
.PageWoodOnestop .lead hgroup h2 {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
.PageWoodOnestop .lead hgroup p {
  margin-top: 0.5em;
  font-size: 1.7rem;
}
.PageWoodOnestop .lead p {
  margin-top: 2rem;
  font-size: 1.7rem;
}
.PageWoodOnestop .flow-image {
  display: block;
  height: auto;
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .flow-image {
    margin-top: 6rem;
    margin-left: calc(50% - 60rem);
    width: 120rem;
    max-inline-size: none;
  }
}
@media (max-width: 1080px) {
  .PageWoodOnestop .flow-image {
    margin-top: 3rem;
    width: 100%;
  }
}
.PageWoodOnestop .feature {
  position: relative;
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .feature {
    margin-top: 7rem;
    padding-left: 18rem;
  }
}
.PageWoodOnestop .feature h3 {
  font-size: 3.5rem;
  line-height: 1;
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .feature h3 {
    position: absolute;
    left: 0;
    top: 0;
  }
}
@media (max-width: 1080px) {
  .PageWoodOnestop .feature h3 {
    font-size: 3rem;
  }
}
.PageWoodOnestop .feature h4 {
  position: relative;
  line-height: 1.4;
  font-weight: bold;
  color: var(--color-blue);
  counter-increment: section;
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .feature h4 {
    margin-top: 4rem;
    margin-left: -4rem;
    padding-left: 4rem;
    font-size: 2rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodOnestop .feature h4 {
    margin-top: 2rem;
    padding-left: 3.5rem;
    margin-left: 0;
    font-size: 1.8rem;
  }
}
.PageWoodOnestop .feature h4::before {
  content: counter(section, decimal-leading-zero);
  color: #809bc3;
  position: absolute;
  left: 0;
}
.PageWoodOnestop .feature p {
  margin-top: 1.5rem;
  font-size: 1.6rem;
}
.PageWoodOnestop .services {
  display: grid;
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .services {
    margin-top: 7rem;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.8rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodOnestop .services {
    margin-top: 4rem;
    gap: 2rem;
  }
}
.PageWoodOnestop .services > div {
  border: 0.5px solid var(--color-blue);
  border-radius: var(--base-radius);
  padding: 3rem 2rem 6rem;
  position: relative;
  background-color: #faf7f0;
  overflow: hidden;
}
@media (max-width: 1080px) {
  .PageWoodOnestop .services > div {
    padding: 2rem 2rem 6rem;
  }
}
.PageWoodOnestop .services > div > dt {
  font-size: 2rem;
  font-weight: bold;
  color: var(--color-blue);
  text-align: center;
  border-bottom: 0.5px solid var(--color-blue);
  padding-bottom: 0.5em;
}
.PageWoodOnestop .services > div > dd {
  margin-top: 1.5rem;
  font-size: 1.6rem;
}
.PageWoodOnestop .services > div > dd a {
  position: absolute;
  inset: 0;
}
.PageWoodOnestop .services > div > dd a > span {
  position: absolute;
  right: 2rem;
  bottom: 2rem;
}
.PageWoodOnestop .flow {
  position: relative;
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .flow {
    padding-left: 22rem;
  }
}
@media (min-width: 1080.01px) {
  .PageWoodOnestop .flow h3 {
    position: absolute;
    left: 0;
    top: 0;
    font-size: 3.5rem;
    line-height: 1;
  }
}
@media (max-width: 1080px) {
  .PageWoodOnestop .flow h3 {
    font-size: 3rem;
  }
}
.PageWoodOnestop .flow dl {
  border-left: 1px solid var(--color-blue);
  padding-left: 8rem;
}
@media (max-width: 1080px) {
  .PageWoodOnestop .flow dl {
    margin-top: 2rem;
    margin-left: 2rem;
    padding-left: 4rem;
  }
}
.PageWoodOnestop .flow dt {
  position: relative;
  font-size: 2.2rem;
  color: var(--color-blue);
  font-weight: normal;
  counter-increment: section;
}
@media (max-width: 1080px) {
  .PageWoodOnestop .flow dt {
    font-size: 2.2rem;
  }
}
.PageWoodOnestop .flow dt:not(:first-child) {
  margin-top: 5rem;
}
@media (max-width: 1080px) {
  .PageWoodOnestop .flow dt:not(:first-child) {
    margin-top: 3rem;
  }
}
.PageWoodOnestop .flow dt::before, .PageWoodOnestop .flow dt::after {
  --size: 8.4rem;
  width: var(--size);
  height: var(--size);
  position: absolute;
  right: calc(100% + 3.7rem);
  text-align: center;
  color: #809bc3;
  line-height: 1;
}
@media (max-width: 1080px) {
  .PageWoodOnestop .flow dt::before, .PageWoodOnestop .flow dt::after {
    --size: 6rem;
    right: calc(100% + 1rem);
  }
}
.PageWoodOnestop .flow dt::before {
  content: "STEP";
  border-radius: 50%;
  background-color: #c7ddeb;
  border: calc(var(--size) * 0.2 / 8.4) solid #003888;
  padding-top: calc(var(--size) * 2.2 / 8.4);
  font-size: calc(var(--size) * 1.4 / 8.4);
}
.PageWoodOnestop .flow dt::after {
  content: counter(section, decimal-leading-zero);
  padding-top: calc(var(--size) * 4 / 8.4);
  font-size: calc(var(--size) * 2.1 / 8.4);
}
.PageWoodOnestop .flow dd {
  margin-top: 0.5em;
  font-size: 1.6rem;
}

.PageWoodSe {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: calc(93rem + 2 * var(--site-gap));
}
.PageWoodSe .lead hgroup {
  color: var(--color-blue);
}
.PageWoodSe .lead hgroup h2 {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageWoodSe .lead hgroup h2 {
    font-size: 2.6rem;
  }
}
.PageWoodSe .lead hgroup p {
  margin-top: 0.5em;
  font-size: 1.7rem;
}
.PageWoodSe .lead p {
  margin-top: 2rem;
  font-size: 1.7rem;
}
.PageWoodSe .logo {
  border-bottom: 0.5px solid var(--color-blue);
  padding-bottom: 2rem;
}
@media (min-width: 1080.01px) {
  .PageWoodSe .logo {
    margin-block: 10rem;
    padding-bottom: 1rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodSe .logo {
    margin: 5rem auto;
  }
}
.PageWoodSe .logo img {
  display: block;
  height: auto;
}
@media (min-width: 1080.01px) {
  .PageWoodSe .logo img {
    width: 22.6rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodSe .logo img {
    margin-inline: auto;
    width: 18rem;
  }
}
.PageWoodSe .kibo h3 {
  font-size: 2rem;
  color: var(--color-blue);
}
.PageWoodSe .kibo .row {
  display: flex;
}
@media (min-width: 1080.01px) {
  .PageWoodSe .kibo .row {
    margin-top: 5rem;
    align-items: start;
    justify-content: space-between;
    gap: 4rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodSe .kibo .row {
    margin-top: 3rem;
    flex-direction: column;
    gap: 3rem;
  }
}
@media (min-width: 1080.01px) {
  .PageWoodSe .kibo .row table {
    --gap-y: 3.4rem;
    flex-grow: 1;
  }
}
@media (max-width: 1080px) {
  .PageWoodSe .kibo .row table {
    --gap-y: 1rem;
  }
}
.PageWoodSe .kibo .row table :where(th, td) {
  padding-block: calc(var(--gap-y) / 2);
  padding-inline: 2rem 4rem;
  text-align: left;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageWoodSe .kibo .row table :where(th, td) {
    padding-inline: 1rem 3rem;
    font-size: 1.4rem;
  }
}
.PageWoodSe .kibo .row table :where(th, td):where(th) {
  width: 1%;
  white-space: nowrap;
}
.PageWoodSe .kibo .row table tr:first-child :where(th, td) {
  border-top: 0.5px solid var(--color-blue);
  padding-top: var(--gap-y);
}
.PageWoodSe .kibo .row table tr:first-child :where(th, td):where(th) {
  border-top-width: 2px;
}
.PageWoodSe .kibo .row table tr:last-child :where(th, td) {
  border-bottom: 0.5px solid var(--color-blue);
  padding-bottom: var(--gap-y);
}
.PageWoodSe .kibo .row table tr:last-child :where(th, td):where(th) {
  border-bottom-width: 2px;
}
.PageWoodSe .kibo .row iframe {
  flex-shrink: 0;
  width: 55.3rem;
  border-radius: var(--base-radius);
}
.PageWoodSe .pointheader {
  position: relative;
  color: var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageWoodSe .pointheader {
    margin-top: 8rem;
    padding-left: 18rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodSe .pointheader {
    margin-top: 3rem;
  }
}
.PageWoodSe .pointheader div {
  font-size: 1.7rem;
}
@media (min-width: 1080.01px) {
  .PageWoodSe .pointheader div {
    position: absolute;
    left: 0;
    top: -0.5em;
  }
}
.PageWoodSe .pointheader div em {
  font-size: 4.1rem;
}
@media (max-width: 1080px) {
  .PageWoodSe .pointheader div em {
    font-size: 3rem;
  }
}
.PageWoodSe .pointheader h3 {
  font-size: 3.1rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageWoodSe .pointheader h3 {
    font-size: 2.2rem;
  }
}
@media (min-width: 1080.01px) {
  .PageWoodSe .pointbody {
    padding-left: 18rem;
  }
}
.PageWoodSe .image1 {
  margin-top: 4rem;
}
@media (max-width: 1080px) {
  .PageWoodSe .image1 {
    margin-top: 3rem;
  }
}
.PageWoodSe .image1 img {
  display: block;
}
.PageWoodSe .image1 span {
  display: block;
  margin-top: 1em;
  text-align: center;
  font-size: 1.4rem;
}
.PageWoodSe .dl1 {
  position: relative;
}
@media (min-width: 1080.01px) {
  .PageWoodSe .dl1 {
    padding-left: 4rem;
  }
}
.PageWoodSe .dl1 dt {
  margin-top: 4rem;
  font-size: 2rem;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodSe .dl1 dt {
    display: flex;
    gap: 0.5em;
  }
}
.PageWoodSe .dl1 dt span {
  color: #809bc3;
}
@media (min-width: 1080.01px) {
  .PageWoodSe .dl1 dt span {
    position: absolute;
    left: 0;
  }
}
.PageWoodSe .dl1 dd {
  margin-top: 2rem;
  font-size: 1.6rem;
}
.PageWoodSe .text1 {
  margin-top: 3rem;
  font-size: 1.6rem;
}
.PageWoodSe .block1 {
  margin-top: 4rem;
  display: flex;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageWoodSe .block1 {
    flex-direction: column;
  }
}
@media (min-width: 1080.01px) {
  .PageWoodSe .block1 img {
    width: 50%;
  }
}
.PageWoodSe .block1 p {
  font-size: 1.6rem;
}

.PageWoodNet {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: calc(100rem + 2 * var(--site-gap));
}
.PageWoodNet .lead hgroup {
  color: var(--color-blue);
}
.PageWoodNet .lead hgroup h2 {
  line-height: 1.4;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
.PageWoodNet .lead hgroup p {
  margin-top: 0.5em;
  font-size: 1.7rem;
}
.PageWoodNet .map {
  position: relative;
}
@media (min-width: 1080.01px) {
  .PageWoodNet .map {
    height: 118rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodNet .map {
    margin-top: 4rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
  }
}
.PageWoodNet .map .text {
  font-size: 1.6rem;
}
@media (min-width: 1080.01px) {
  .PageWoodNet .map .text {
    padding-top: 6rem;
    width: 50rem;
  }
}
.PageWoodNet .map .logo {
  display: block;
  height: auto;
}
@media (min-width: 1080.01px) {
  .PageWoodNet .map .logo {
    margin-top: 3rem;
    width: 27rem;
  }
}
@media (max-width: 1080px) {
  .PageWoodNet .map .logo {
    position: absolute;
    left: 0;
    top: 3rem;
    width: 14rem;
  }
}
.PageWoodNet .map .japan {
  width: 100%;
  height: auto;
}
@media (min-width: 1080.01px) {
  .PageWoodNet .map .japan {
    position: absolute;
    top: 0;
    right: 0;
    pointer-events: none;
  }
}
.PageWoodNet .map .link {
  background-color: #809bc3;
  color: #fff;
  font-size: 1.6rem;
  padding: 1em 4em 1em 2em;
  border-radius: 2em;
  background-image: url("../assets/wood/network-external-icon.svg");
  background-repeat: no-repeat;
  background-size: 1.5em auto;
  background-position: right 2rem center;
}
@media (min-width: 1080.01px) {
  .PageWoodNet .map .link {
    position: absolute;
    right: 0;
    bottom: 0;
  }
}

.PageWoodClientDialog {
  margin: 0 auto;
  width: 142rem;
  max-width: 100%;
}
.PageWoodClientDialog img {
  display: block;
  width: 100%;
  height: auto;
}

.PageWoodClientOneStop {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  padding-bottom: 10rem;
}
@media (max-width: 1080px) {
  .PageWoodClientOneStop {
    padding-bottom: 5rem;
  }
}
.PageWoodClientOneStop h3 {
  margin-top: 10rem;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageWoodClientOneStop h3 {
    margin-top: 5rem;
    font-size: 2.6rem;
  }
}
.PageWoodClientOneStop p {
  margin-top: 2rem;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageWoodClientOneStop p {
    font-size: 1.3rem;
  }
}
.PageWoodClientOneStop a {
  margin-top: 3rem;
  display: inline-flex;
  gap: 0.5em;
  align-items: center;
  font-size: 1.8rem;
  padding: 1.5rem 3rem;
  border-radius: 3rem;
  background-color: var(--color-blue);
  color: #fff;
}
@media (max-width: 1080px) {
  .PageWoodClientOneStop a {
    margin-top: 2rem;
    font-size: 1.3rem;
    padding: 1rem 2rem;
    border-radius: 2rem;
  }
}
.PageWoodClientOneStop a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
.PageWoodClientOneStop img {
  display: block;
  margin: 6rem auto 0;
  width: 100%;
  height: auto;
}
@media (max-width: 1080px) {
  .PageWoodClientOneStop img {
    margin-top: 3rem;
  }
}

.PagePrivacy {
  background-color: #fff;
  padding-block: 8rem 10rem;
}
@media (max-width: 1080px) {
  .PagePrivacy {
    padding-block: 4rem 5rem;
  }
}
.PagePrivacy p {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PagePrivacy p {
    font-size: 1.4rem;
  }
}
.PagePrivacy .heading {
  margin-block: 1rem;
  font-size: 2.3rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PagePrivacy .heading {
    font-size: 1.8rem;
  }
}
.PagePrivacy .container {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PagePrivacy .statements {
  margin-block: 3em;
  border-top: 1px solid #6f6d6d;
  border-bottom: 1px solid #6f6d6d;
  padding-block: 3em;
}
@media (max-width: 1080px) {
  .PagePrivacy .statements {
    margin-block: 2em;
    padding-block: 2em;
  }
}
.PagePrivacy .statements hr {
  border: none;
  border-top: 1px solid #ddd;
  margin: 3rem 0;
}
@media (max-width: 1080px) {
  .PagePrivacy .statements hr {
    margin: 2rem 0;
  }
}
.PagePrivacy .contact {
  display: flex;
  align-items: start;
  gap: 1rem;
  color: var(--color-blue);
}
.PagePrivacy .contact::before {
  content: "";
  flex-shrink: 0;
  margin-top: 0.6rem;
  width: 2.8rem;
  height: 2.8rem;
  background-color: currentcolor;
  -webkit-mask: url("../assets/common/icon-tel.svg") no-repeat center/contain;
          mask: url("../assets/common/icon-tel.svg") no-repeat center/contain;
}
.PagePrivacy .contact h2 {
  line-height: 1;
  font-size: 2.3rem;
  font-family: var(--font-family-mincho);
  display: flex;
  align-items: center;
  gap: 0.3em;
}
@media (max-width: 1080px) {
  .PagePrivacy .contact h2 {
    font-size: 1.8rem;
  }
}
.PagePrivacy .contact .number {
  font-size: 2.7rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PagePrivacy .contact .number {
    font-size: 2.2rem;
  }
}
.PagePrivacy .contact .note {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PagePrivacy .contact .note {
    font-size: 1.4rem;
  }
}

.PageContact {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 6rem 10rem;
  max-width: calc(93rem + 2 * var(--site-gap));
}
@media (max-width: 1080px) {
  .PageContact {
    margin-block: 3rem 6rem;
  }
}

.PageContactTel {
  display: flex;
  align-items: start;
  gap: 1rem;
  color: var(--color-blue);
  padding-bottom: 2rem;
  border-bottom: 1px solid #6f6d6d;
  margin-bottom: 2rem;
}
.PageContactTel::before {
  content: "";
  flex-shrink: 0;
  width: 2.8rem;
  height: 2.8rem;
  background-color: currentcolor;
  -webkit-mask: url("../assets/common/icon-tel.svg") no-repeat center/contain;
          mask: url("../assets/common/icon-tel.svg") no-repeat center/contain;
}
.PageContactTel h2 {
  margin-bottom: 0.5em;
  line-height: 1;
  font-size: 2.3rem;
  font-family: var(--font-family-mincho);
  display: flex;
  align-items: center;
  gap: 0.3em;
}
@media (max-width: 1080px) {
  .PageContactTel h2 {
    font-size: 1.8rem;
  }
}
.PageContactTel .number {
  font-size: 2.7rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageContactTel .number {
    font-size: 2.2rem;
  }
}
.PageContactTel .note {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageContactTel .note {
    font-size: 1.4rem;
  }
}

.PageContactFormHeaader h2 {
  font-size: 3.5rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageContactFormHeaader h2 {
    font-size: 2.5rem;
  }
}
.PageContactFormHeaader p {
  font-size: 1.6rem;
}

.PageContactFormSteps {
  --gap: 4rem;
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageContactFormSteps {
    --gap: 2rem;
    font-size: 1.2rem;
  }
}
.PageContactFormSteps > li {
  position: relative;
  height: 3em;
  border-radius: 1.5em;
  background-color: #aaa6a4;
  color: white;
  display: grid;
  place-items: center;
}
.PageContactFormSteps > li[aria-current=step] {
  background-color: var(--color-blue);
  font-weight: bold;
}
.PageContactFormSteps > li:not(:last-child)::after {
  --size: 1.2rem;
  content: "";
  position: absolute;
  top: calc(50% - var(--size) / 2);
  right: calc(-1 * (var(--gap) + var(--size)) / 2);
  background-color: var(--color-blue);
  -webkit-mask: var(--link-arrow-url) no-repeat center/contain;
          mask: var(--link-arrow-url) no-repeat center/contain;
  width: var(--size);
  height: var(--size);
}
@media (max-width: 1080px) {
  .PageContactFormSteps > li:not(:last-child)::after {
    --size: 1rem;
  }
}

.PageServiceIndexBanner {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageServiceIndexBanner a {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  display: flex;
  flex-direction: column;
  font-size: 2rem;
  gap: 0.3em;
}
.PageServiceIndexBanner a:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.PageServiceIndexBanner a img {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}
.PageServiceIndexBanner a span {
  padding-top: 0.5em;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
@media (max-width: 1080px) {
  .PageServiceIndexBanner a span {
    padding-top: 0;
  }
}
.PageServiceIndexBanner a span::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  --link-icon-color: var(--color-blue-light);
}
.PageServiceIndexBanner a small {
  font-size: 80%;
}

.PageServiceIndexSenmon {
  background-color: #fff;
}
@media (min-width: 1080.01px) {
  .PageServiceIndexSenmon {
    margin-block: 10rem;
    padding-block: 10rem;
    margin-inline: auto;
    width: clamp(128rem, 100% - 2 * var(--site-gap), 1700px);
    border-radius: 2.5rem;
  }
}
@media (max-width: 1080px) {
  .PageServiceIndexSenmon {
    margin-block: 5rem;
    padding-block: 5rem;
  }
}
.PageServiceIndexSenmon .container {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageServiceIndexSenmon .items {
  display: grid;
  grid-template-columns: 57.1rem 57.1rem;
  gap: 5.8rem;
  font-size: 2rem;
}
@media (max-width: 1080px) {
  .PageServiceIndexSenmon .items {
    margin-top: 3rem;
    grid-template-columns: 1fr;
    gap: 3rem;
    font-size: 1.5rem;
  }
}
.PageServiceIndexSenmon h2 {
  font-size: 4.2rem;
  font-family: var(--font-family-mincho);
  color: var(--color-blue);
  margin-bottom: 1em;
}
@media (max-width: 1080px) {
  .PageServiceIndexSenmon h2 {
    font-size: 2.4rem;
  }
}
.PageServiceIndexSenmon a {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
  display: flex;
  flex-direction: column;
  font-size: 2rem;
  gap: 0.3em;
}
.PageServiceIndexSenmon a:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
@media (max-width: 1080px) {
  .PageServiceIndexSenmon a {
    font-size: 1.8rem;
  }
}
.PageServiceIndexSenmon a img {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  width: 100%;
  height: auto;
  border-radius: var(--base-radius);
}
.PageServiceIndexSenmon a span {
  padding-top: 0.2em;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.PageServiceIndexSenmon a span::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  --link-icon-color: var(--color-blue-light);
}
.PageServiceIndexSenmon a small {
  font-size: 80%;
}

.PageServiceHeader {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: grid;
  margin-bottom: 7rem;
}
@media (min-width: 1080.01px) {
  .PageServiceHeader {
    grid-template: "title title" "phrase phrase" "description image"/auto 41rem;
    gap: 4rem 6rem;
  }
  .PageServiceHeader.PageServiceHeaderArc {
    grid-template: "title title" "phrase image" "description image"/auto 26rem;
  }
}
@media (max-width: 1080px) {
  .PageServiceHeader {
    margin-bottom: 4rem;
    grid-template: "title" "phrase" "description" "image"/auto;
    gap: 1.5rem;
  }
}
.PageServiceHeader .title {
  grid-area: title;
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
  font-size: 5rem;
  line-height: 1.3;
}
@media (max-width: 1080px) {
  .PageServiceHeader .title {
    font-size: 2.8rem;
  }
}
.PageServiceHeader .phrase {
  grid-area: phrase;
  font-size: 3rem;
  font-weight: bold;
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
}
@media (max-width: 1080px) {
  .PageServiceHeader .phrase {
    font-size: 1.8rem;
  }
}
.PageServiceHeader .description {
  grid-area: description;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageServiceHeader .description {
    font-size: 1.6rem;
  }
}
.PageServiceHeader .image {
  grid-area: image;
  height: auto;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageServiceHeader .image {
    justify-self: center;
  }
}

.PageServiceTopWorksContainer {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  padding-block: 10rem;
  display: grid;
  gap: 4rem;
}
@media (max-width: 1080px) {
  .PageServiceTopWorksContainer {
    padding-block: 5rem;
    gap: 2rem;
  }
}

.PageServiceWorks {
  background-color: #e6e6e6;
  border-radius: var(--base-radius);
  padding: 5rem 15rem;
}
@media (max-width: 1080px) {
  .PageServiceWorks {
    padding: 3rem 2rem;
  }
}
.PageServiceWorks.wood {
  background-color: rgba(198, 156, 109, 0.3333333333);
}
.PageServiceWorks.white {
  background-color: #fff;
}
.PageServiceWorks .header {
  margin-bottom: 5rem;
}
@media (max-width: 1080px) {
  .PageServiceWorks .header {
    margin-bottom: 2rem;
  }
}
.PageServiceWorks .title {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceWorks .title {
    font-size: 1.8rem;
  }
}
.PageServiceWorks .description {
  margin-top: 1rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageServiceWorks .description {
    font-size: 1.4rem;
  }
}
.PageServiceWorks .se-link {
  border: 1px solid currentcolor;
  font-size: 1.5rem;
  padding: 0.6em 1.5em;
  border-radius: 2em;
}
@media (max-width: 1080px) {
  .PageServiceWorks .se-link {
    font-size: 1.2rem;
  }
}
.PageServiceWorks .works-heading {
  margin-top: 2rem;
  font-size: 1.7rem;
  font-weight: bold;
}
@media (max-width: 1080px) {
  .PageServiceWorks .works-heading {
    margin-top: 1rem;
  }
}
.PageServiceWorks .works-list {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  justify-content: center;
  gap: 3.5rem;
}
@media (max-width: 1080px) {
  .PageServiceWorks .works-list {
    margin-top: 1rem;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.PageServiceWorks .works-list .works-item {
  --hover-fade-opacity: 1;
  --hover-fade-duration: 0.2s;
}
.PageServiceWorks .works-list .works-item:hover {
  --hover-fade-opacity: 0.75;
  --hover-fade-duration: 0.3s;
}
.PageServiceWorks .works-list img {
  transition: opacity var(--hover-fade-duration);
  opacity: var(--hover-fade-opacity);
  aspect-ratio: 27/20;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 1.4rem;
}
.PageServiceWorks .works-list .works-item-title {
  display: block;
  margin-top: 0.5em;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageServiceWorks .works-list .works-item-title {
    font-size: 1.4rem;
  }
}

.ServiceSakanAbout {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.ServiceSakanAboutLead {
  border-top: 0.5px solid var(--color-blue);
  padding-top: 6rem;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutLead {
    padding-top: 3rem;
  }
}
.ServiceSakanAboutLead .heading {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .ServiceSakanAboutLead .heading {
    font-size: 1.8rem;
  }
}
.ServiceSakanAboutLead .description {
  margin-top: 1rem;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutLead .description {
    font-size: 1.5rem;
  }
}

.ServiceSakanAboutImage {
  position: relative;
  margin-top: 7rem;
  padding-left: 18rem;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutImage {
    margin-top: 3rem;
    padding-left: 0;
  }
}
.ServiceSakanAboutImage .heading {
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .ServiceSakanAboutImage .heading {
    display: flex;
    align-items: end;
  }
}
.ServiceSakanAboutImage .heading .number {
  position: absolute;
  top: 0;
  left: 0;
  line-height: 1;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutImage .heading .number {
    position: static;
    margin-bottom: 0.5em;
  }
}
.ServiceSakanAboutImage .heading .number em {
  font-size: 250%;
  font-weight: normal;
}
.ServiceSakanAboutImage .heading .title {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutImage .heading .title {
    margin-bottom: 0.1em;
    margin-left: 0.6em;
    font-size: 2.2rem;
  }
}
.ServiceSakanAboutImage .description {
  margin-top: 1em;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutImage .description {
    font-size: 1.5rem;
  }
}
.ServiceSakanAboutImage .steps {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .ServiceSakanAboutImage .steps {
    grid-template-columns: 1fr;
    gap: 2rem;
    font-size: 1.4rem;
  }
}
.ServiceSakanAboutImage .steps img {
  display: block;
  aspect-ratio: 3/2;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.ServiceSakanShiageBg {
  background-color: #f5f5f5;
  margin-top: 10rem;
  padding-block: 10rem;
}
@media (max-width: 1080px) {
  .ServiceSakanShiageBg {
    margin-top: 5rem;
    padding-block: 5rem;
  }
}

.ServiceSakanShiage {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.ServiceSakanShiage .heading {
  color: var(--color-blue);
}
.ServiceSakanShiage .heading .title {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
}
@media (max-width: 1080px) {
  .ServiceSakanShiage .heading .title {
    font-size: 2.4rem;
  }
}
.ServiceSakanShiage .heading .en {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .ServiceSakanShiage .heading .en {
    font-size: 1.4rem;
  }
}
.ServiceSakanShiage .description {
  margin-top: 2rem;
  font-size: 1.6rem;
}
.ServiceSakanShiage .subheading {
  margin-top: 5rem;
  font-size: 4.5rem;
  line-height: 1.3;
  font-family: var(--font-family-mincho);
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .ServiceSakanShiage .subheading {
    font-size: 2.8rem;
    margin-top: 3rem;
  }
}
.ServiceSakanShiage .images {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem 1rem;
}
@media (max-width: 1080px) {
  .ServiceSakanShiage .images {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 1rem;
  }
}
.ServiceSakanShiage .images li {
  font-size: 1.4rem;
}
@media (max-width: 1080px) {
  .ServiceSakanShiage .images li {
    font-size: 1.2rem;
  }
}
.ServiceSakanShiage .images li img {
  display: block;
  aspect-ratio: 1.34/1;
  width: 100%;
  height: auto;
}

.PageServiceDaiku1 {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-bottom: 10rem;
}
@media (max-width: 1080px) {
  .PageServiceDaiku1 {
    margin-bottom: 3rem;
  }
}
.PageServiceDaiku1 h3 {
  font-size: 3rem;
  font-family: var(--font-family-mincho);
  color: var(--color-blue);
  margin-bottom: 1rem;
}
@media (max-width: 1080px) {
  .PageServiceDaiku1 h3 {
    font-size: 2.4rem;
  }
}
.PageServiceDaiku1 p {
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageServiceDaiku1 p {
    font-size: 1.5rem;
  }
}

.PageServiceConsultingContainer {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}
.PageServiceConsultingContainer hr {
  border: none;
  border-top: 0.5px solid var(--color-blue);
  margin: 7rem 0;
}
@media (max-width: 1080px) {
  .PageServiceConsultingContainer hr {
    margin: 3rem 0;
  }
}

.PageServiceConsultingChart {
  display: grid;
  place-content: center;
}
.PageServiceConsultingChart img {
  max-width: 75rem;
  width: 100%;
  height: auto;
}

.PageServiceConsultingCaseHeading {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceConsultingCaseHeading {
    font-size: 2rem;
  }
}

.PageServiceConsultingCase {
  border: 1px solid #b8a18e;
  border-radius: var(--base-radius);
  display: grid;
}
@media (min-width: 1080.01px) {
  .PageServiceConsultingCase {
    margin-top: 4.5rem;
    padding: 6rem 4.5rem 6rem 14rem;
    grid-template: "heading image" auto "problem image" auto "solution solution" auto/1fr 25.6rem;
    gap: 2rem 3rem;
  }
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase {
    margin-top: 3rem;
    padding: 3rem 2rem;
    grid-template: "heading" auto "image" auto "problem" auto "solution" auto/1fr;
    gap: 2rem 0;
  }
}
.PageServiceConsultingCase .heading {
  grid-area: heading;
  position: relative;
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase .heading {
    display: flex;
    gap: 1rem;
    align-items: center;
  }
}
.PageServiceConsultingCase .heading .number {
  color: var(--color-blue);
  background-color: #fff;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  display: flex;
  align-items: baseline;
  justify-content: center;
  line-height: 1;
  padding-top: calc(var(--size) * 0.2);
}
@media (min-width: 1080.01px) {
  .PageServiceConsultingCase .heading .number {
    --size: 8.6rem;
    position: absolute;
    top: calc(-1 * var(--size) * 0.2);
    right: calc(100% + 2rem);
  }
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase .heading .number {
    --size: 5rem;
    flex-shrink: 0;
  }
}
.PageServiceConsultingCase .heading .number span {
  font-size: calc(var(--size) * 0.2);
}
.PageServiceConsultingCase .heading .number em {
  font-size: calc(var(--size) * 0.5);
  font-weight: normal;
}
.PageServiceConsultingCase .heading .title {
  font-size: 3.1rem;
  line-height: 1.3;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase .heading .title {
    font-size: 1.8rem;
  }
}
.PageServiceConsultingCase .image {
  grid-area: image;
}
.PageServiceConsultingCase .image img {
  width: 100%;
  height: auto;
}
.PageServiceConsultingCase .problem {
  grid-area: problem;
}
.PageServiceConsultingCase .problem .problem-list {
  list-style: disc;
  padding-left: 1.5em;
  font-size: 1.8rem;
  font-weight: bold;
  display: grid;
  line-height: 1.4;
  gap: 0.5em;
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase .problem .problem-list {
    font-size: 1.6rem;
  }
}
.PageServiceConsultingCase .problem .problem-text {
  margin-top: 1.5rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase .problem .problem-text {
    font-size: 1.5rem;
  }
}
.PageServiceConsultingCase .solution {
  grid-area: solution;
}
.PageServiceConsultingCase .solution .solution-heading {
  font-size: 1.8rem;
  font-weight: bold;
  color: var(--color-blue);
}
.PageServiceConsultingCase .solution .solution-text {
  margin-top: 1rem;
  font-size: 1.8rem;
  font-weight: bold;
}
@media (min-width: 1080.01px) {
  .PageServiceConsultingCase .solution .solution-text {
    margin-right: 8rem;
  }
}
@media (max-width: 1080px) {
  .PageServiceConsultingCase .solution .solution-text {
    font-size: 1.6rem;
  }
}

.PageServiceInsulationAbout {
  border-top: 0.5px solid var(--color-blue);
}
@media (min-width: 1080.01px) {
  .PageServiceInsulationAbout {
    padding: 3rem 3rem 0 0;
    display: flex;
    align-items: center;
    gap: 0 8rem;
  }
}
@media (max-width: 1080px) {
  .PageServiceInsulationAbout {
    padding: 2rem 0 0;
    display: block;
  }
}
.PageServiceInsulationAbout .heading {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
  margin-bottom: 1rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationAbout .heading {
    font-size: 2rem;
  }
}
.PageServiceInsulationAbout .text {
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationAbout .text {
    font-size: 1.5rem;
  }
}
.PageServiceInsulationAbout .link {
  margin-top: 3rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationAbout .link {
    margin-top: 2rem;
  }
}
.PageServiceInsulationAbout .link a {
  background-color: var(--color-blue);
  color: #fff;
  padding: 0.6em 1.5em;
  border-radius: 2em;
  font-size: 1.9rem;
  font-family: var(--font-family-mincho);
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}
@media (max-width: 1080px) {
  .PageServiceInsulationAbout .link a {
    font-size: 1.6rem;
  }
}
.PageServiceInsulationAbout .link a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
}
.PageServiceInsulationAbout .image {
  flex-shrink: 0;
  max-width: 100%;
  height: auto;
}
@media (max-width: 1080px) {
  .PageServiceInsulationAbout .image {
    margin-top: -7rem;
    margin-left: auto;
    width: 20rem;
    pointer-events: none;
  }
}

.PageServiceInsulationDetail {
  margin-top: 5rem;
  margin-inline: auto;
  background-color: #fff;
  border-radius: var(--base-radius);
  max-width: 120rem;
  padding: 8rem 12rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail {
    margin-top: 3rem;
    border-radius: 0;
    padding: 3rem var(--site-gap);
  }
}
.PageServiceInsulationDetail .diff {
  display: flex;
  align-items: flex-start;
  gap: 7rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .diff {
    flex-direction: column;
    gap: 2rem;
  }
}
.PageServiceInsulationDetail .diff .diff-content h3 {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .diff .diff-content h3 {
    font-size: 2rem;
  }
}
.PageServiceInsulationDetail .diff .diff-content p {
  margin-top: 1em;
  font-size: 1.6rem;
}
.PageServiceInsulationDetail .diff .diff-image {
  flex-shrink: 0;
  width: 42rem;
  height: auto;
  border-radius: var(--base-radius);
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .diff .diff-image {
    width: 100%;
    max-width: 100%;
  }
}
.PageServiceInsulationDetail .sto {
  margin-top: 7rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .sto {
    margin-top: 3rem;
  }
}
.PageServiceInsulationDetail .sto .sto-heading {
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .sto .sto-heading {
    font-size: 2.1rem;
  }
}
.PageServiceInsulationDetail .sto .sto-text {
  margin-top: 2rem;
  font-size: 1.6rem;
}
.PageServiceInsulationDetail .sto .sto-image {
  margin-top: 3rem;
  display: flex;
  align-items: start;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .sto .sto-image {
    margin-top: 2rem;
    flex-direction: column;
    gap: 1rem;
  }
}
.PageServiceInsulationDetail .sto .sto-image img {
  width: 41rem;
  max-width: 100%;
  height: auto;
}
.PageServiceInsulationDetail .sto .sto-image dl {
  margin-top: 3rem;
  font-size: 1.5rem;
  line-height: 1.5;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .sto .sto-image dl {
    margin-top: 0;
    font-size: 1.3rem;
  }
}
.PageServiceInsulationDetail .sto .sto-image dl dt {
  margin-top: 0.3em;
  font-weight: bold;
}
.PageServiceInsulationDetail .sto .sto-image dl dd {
  margin-left: 1em;
}
.PageServiceInsulationDetail .features {
  margin-top: 5rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .features {
    margin-top: 3rem;
  }
}
.PageServiceInsulationDetail .features .features-heading {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .features .features-heading {
    font-size: 2rem;
  }
}
.PageServiceInsulationDetail .features .features-list {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  font-size: 1.6rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .features .features-list {
    grid-template-columns: 1fr;
    gap: 2rem;
    font-size: 1.4rem;
  }
}
.PageServiceInsulationDetail .features .features-list dt {
  font-weight: bold;
}
.PageServiceInsulationDetail .features .features-list dt img {
  display: block;
  margin-bottom: 1em;
  aspect-ratio: 306/175;
  width: 100%;
  height: auto;
}
.PageServiceInsulationDetail .features .features-list dd {
  margin-top: 0.5em;
  border-top: 1px solid currentcolor;
  padding-top: 0.5em;
}
.PageServiceInsulationDetail .beauty {
  margin-top: 5rem;
  display: flex;
  align-items: start;
  gap: 2rem;
}
@media (max-width: 1080px) {
  .PageServiceInsulationDetail .beauty {
    flex-direction: column;
    gap: 1rem;
  }
}
.PageServiceInsulationDetail .beauty img {
  width: 30.5rem;
  max-width: 100%;
  height: auto;
}
.PageServiceInsulationDetail .beauty p {
  font-size: 1.6rem;
}

.PageServiceInsulationWoks {
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-top: 5rem;
}

.PageServiceInteriorAbout {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.PageServiceInteriorAboutLead {
  border-top: 0.5px solid var(--color-blue);
  padding-top: 6rem;
}
@media (max-width: 1080px) {
  .PageServiceInteriorAboutLead {
    padding-top: 3rem;
  }
}
.PageServiceInteriorAboutLead .heading {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceInteriorAboutLead .heading {
    font-size: 1.8rem;
  }
}
.PageServiceInteriorAboutLead .description {
  margin-top: 1rem;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageServiceInteriorAboutLead .description {
    font-size: 1.5rem;
  }
}

.PageServiceDaikuAbout {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-bottom: 6rem;
}
@media (max-width: 1080px) {
  .PageServiceDaikuAbout {
    margin-bottom: 3rem;
  }
}

.PageServiceDaikuAboutLead {
  border-top: 0.5px solid var(--color-blue);
  padding-top: 6rem;
}
@media (max-width: 1080px) {
  .PageServiceDaikuAboutLead {
    padding-top: 3rem;
  }
}
.PageServiceDaikuAboutLead .heading {
  font-size: 2.3rem;
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageServiceDaikuAboutLead .heading {
    font-size: 1.8rem;
  }
}
.PageServiceDaikuAboutLead .description {
  margin-top: 1rem;
  font-size: 1.7rem;
}
@media (max-width: 1080px) {
  .PageServiceDaikuAboutLead .description {
    font-size: 1.5rem;
  }
}

.PageNews {
  padding-block: 12rem 16rem;
  background: #fff;
}
@media (max-width: 1080px) {
  .PageNews {
    padding-block: 6rem 8rem;
  }
}

.PageNewsArchiveCotainer {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  display: grid;
}
@media (min-width: 1080.01px) {
  .PageNewsArchiveCotainer {
    grid-template-columns: 16rem 1fr;
    gap: 2rem;
  }
}
@media (max-width: 1080px) {
  .PageNewsArchiveCotainer {
    gap: 2rem;
  }
}

.PageNewsCategoryList {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  line-height: 1.3;
}
@media (max-width: 1080px) {
  .PageNewsCategoryList {
    flex-direction: row;
    align-items: start;
    gap: 1rem;
  }
}
.PageNewsCategoryList .heading {
  flex-shrink: 0;
  font-size: 2.5rem;
  line-height: 1;
  font-family: var(--font-family-serif);
  font-weight: 500;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageNewsCategoryList .heading {
    font-size: 1.6rem;
  }
}
.PageNewsCategoryList .list {
  font-size: 1.5rem;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
@media (max-width: 1080px) {
  .PageNewsCategoryList .list {
    font-size: 1.4rem;
    flex-flow: row wrap;
    gap: 0.3em 0.6em;
  }
}
.PageNewsCategoryList .list li a {
  color: #809bc3;
}
.PageNewsCategoryList .list li a[aria-current=page] {
  color: var(--color-blue);
  font-weight: bold;
}

.PageNewsArticle {
  font-size: 1.6rem;
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  max-width: 90rem;
}
.PageNewsArticle .PageNewsArticleHeader {
  padding-bottom: 2em;
  border-bottom: 1px solid var(--color-blue);
  margin-bottom: 3em;
}
@media (max-width: 1080px) {
  .PageNewsArticle .PageNewsArticleHeader {
    padding-bottom: 1.5em;
    margin-bottom: 2em;
  }
}
.PageNewsArticle .PageNewsArticleHeader .meta {
  color: var(--color-blue);
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2em;
}
.PageNewsArticle .PageNewsArticleHeader .title {
  font-size: 3.7rem;
  line-height: 1.2;
}
@media (max-width: 1080px) {
  .PageNewsArticle .PageNewsArticleHeader .title {
    font-size: 2.5rem;
    line-height: 1.6;
  }
}
.PageNewsArticle .PageNewsArticleBody {
  margin-inline: auto;
  max-width: 75rem;
}
.PageNewsArticle .PageNewsArticleBack {
  margin-top: 14rem;
  display: grid;
  place-content: center;
}
@media (max-width: 1080px) {
  .PageNewsArticle .PageNewsArticleBack {
    margin-top: 7rem;
  }
}
.PageNewsArticle .PageNewsArticleBack a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.9rem;
  font-family: var(--font-family-mincho);
  width: 12em;
  height: 2.7em;
  border-radius: 1.35em;
  background-color: var(--color-blue);
  color: #fff;
}
@media (max-width: 1080px) {
  .PageNewsArticle .PageNewsArticleBack a {
    font-size: 1.6rem;
  }
}
.PageNewsArticle .PageNewsArticleBack a::before {
  content: "";
  position: absolute;
  left: 1em;
  width: 0.8em;
  height: 0.8em;
  background-color: currentcolor;
  -webkit-mask: var(--link-arrow-url) no-repeat center/contain;
          mask: var(--link-arrow-url) no-repeat center/contain;
  scale: -1 1;
}

.NewsList {
  --item-min-height: 7.6em;
  font-size: 1.7rem;
}
.PageHomeNewsList .NewsList {
  --item-min-height: 5em;
}
@media (max-width: 1080px) {
  .NewsList {
    font-size: 1.3rem;
  }
}
.NewsList > li {
  border-top: 1px solid var(--color-blue);
}
.NewsList > li:last-child {
  border-bottom: 1px solid var(--color-blue);
}
.NewsList > li > a {
  --title-color: inherit;
  padding-block: var(--item-padding-block);
  padding: 1.5em 0.5em;
  min-height: var(--item-min-height);
  display: flex;
  align-items: center;
  gap: 2em;
}
.NewsList > li > a:hover {
  --title-color: var(--color-blue-light);
}
@media (max-width: 1080px) {
  .NewsList > li > a {
    padding: 1em 0.3em;
    min-height: 5em;
    gap: 1em;
  }
}
.NewsList > li > a .date {
  flex-shrink: 0;
  width: -moz-max-content;
  width: max-content;
  color: var(--color-blue-light);
}
@media (max-width: 1080px) {
  .NewsList > li > a .date {
    font-size: 90%;
  }
}
.NewsList > li > a .title {
  flex-grow: 1;
  color: var(--title-color);
}
.NewsList > li > a::after {
  flex-shrink: 0;
  content: "";
  display: inline-block;
  aspect-ratio: 1;
  width: var(--link-icon-size, 0.8888888889em);
  height: auto;
  background-color: var(--link-icon-color, currentcolor);
  -webkit-mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
          mask: var(--link-icon-mask-image) no-repeat center/100% 100%;
  --link-icon-color: var(--color-blue-light);
}

.PageRecruit {
  margin-top: 8rem;
}
@media (max-width: 1080px) {
  .PageRecruit {
    margin-top: 4rem;
  }
}

.PageRecruitFresh {
  background-color: #fff;
  padding-block: 10rem;
}
@media (max-width: 1080px) {
  .PageRecruitFresh {
    padding-block: 5rem;
  }
}

.PageRecruitCareer {
  background-color: #f2f2f2;
  padding-block: 10rem;
}
@media (max-width: 1080px) {
  .PageRecruitCareer {
    padding-block: 5rem;
  }
}
.PageRecruitCareer .container {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
}

.PageRecruitContainer {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  font-size: 1.6rem;
}
.PageRecruitContainer > :first-child {
  margin-top: 0 !important;
}
.PageRecruitContainer .heading {
  margin-block: 5rem 2.5rem;
  font-size: 3.1rem;
  font-family: var(--font-family-mincho);
  font-weight: bold;
  color: var(--color-blue);
}
@media (max-width: 1080px) {
  .PageRecruitContainer .heading {
    font-size: 2.4rem;
    margin-block: 3rem 1rem;
  }
}
.PageRecruitContainer .paragraph {
  margin-top: 1rem;
}
.PageRecruitContainer .external-link {
  display: flex;
  justify-content: space-between;
  margin-top: 5rem;
  font-size: 1.9rem;
  line-height: 1.3;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 14em;
  max-width: 100%;
  font-family: var(--font-family-mincho);
  color: #fff;
  background-color: var(--color-blue);
  padding: 1em 2em;
  border-radius: 2em;
}
@media (max-width: 1080px) {
  .PageRecruitContainer .external-link {
    margin-top: 4rem;
    font-size: 1.6rem;
  }
}
.PageRecruitContainer .external-link::after {
  flex-shrink: 0;
  content: "";
  width: 1.2em;
  height: 1.2em;
  background-color: currentcolor;
  -webkit-mask: url("../assets/common/icon-external.svg") no-repeat center/contain;
          mask: url("../assets/common/icon-external.svg") no-repeat center/contain;
}

.PageRecruitList {
  display: grid;
}
.PageRecruitList > :where(dt) {
  font-weight: bold;
}
.PageRecruitList .flex {
  display: flex;
}
@media (min-width: 1080.01px) {
  .PageRecruitList .flex {
    gap: 0 1.5em;
    flex-wrap: wrap;
  }
}
@media (max-width: 1080px) {
  .PageRecruitList .flex {
    flex-direction: column;
  }
}
@media (min-width: 1080.01px) {
  .PageRecruitList {
    margin-top: 5rem;
    grid-template-columns: 14rem 1fr;
    font-size: 1.6rem;
  }
  .PageRecruitList > :where(dt, dd) {
    border-top: 0.25px solid var(--color-blue);
    padding-block: 3rem;
  }
  .PageRecruitList > :where(dt, dd):nth-last-child(2) {
    border-bottom: 1px solid var(--color-blue);
  }
  .PageRecruitList > :where(dt, dd):nth-last-child(1) {
    border-bottom: 0.25px solid var(--color-blue);
  }
  .PageRecruitList > :where(dt, dd):where(dt) {
    border-top-width: 1px;
    padding-inline: 1rem;
  }
  .PageRecruitList > :where(dt, dd):where(dd) {
    padding-inline: 5rem;
  }
}
@media (max-width: 1080px) {
  .PageRecruitList {
    margin-top: 3rem;
    font-size: 1.5rem;
  }
  .PageRecruitList > :where(dt, dd):where(dt) {
    position: relative;
    padding-bottom: 0.5rem;
    border-bottom: 0.25px solid var(--color-blue);
    margin-bottom: 0.5rem;
  }
  .PageRecruitList > :where(dt, dd):where(dt)::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    width: 12rem;
    border-bottom: 1px solid var(--color-blue);
  }
  .PageRecruitList > :where(dt, dd):where(dt):not(:first-child) {
    margin-top: 2rem;
  }
}

.PageRecruitContact {
  --content-width: max(93rem * var(--pc-flag), var(--content-width-sp) * var(--sp-flag));
  margin-inline: auto;
  padding-inline: var(--site-gap);
  max-width: calc(var(--content-width) + var(--site-gap) * 2);
  margin-block: 10rem;
}
@media (max-width: 1080px) {
  .PageRecruitContact {
    margin-block: 5rem;
  }
}