@charset "UTF-8";
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none; /* 1 */
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit; /* 2 */
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Fix appearance for Firefox
 */
[type=number] {
  -moz-appearance: textfield;
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

/* -------------------------------
   font
------------------------------- */
/* -------------------------------
   Colors
------------------------------- */
/* -------------------------------
transition
------------------------------- */
/* ----------------------------------------
contents
---------------------------------------- */
/* ----------------------------------------
responsive
---------------------------------------- */
/* ----------------------------------------
ヘッダー高さ
---------------------------------------- */
/**
 * Swiper 11.1.14
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2024 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: September 12, 2024
 */
@font-face {
  font-family: swiper-icons;
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color:#007aff;
}

:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
  display: block;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-horizontal {
  touch-action: pan-y;
}

.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden;
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
}

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide {
  transform-style: preserve-3d;
}

.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none;
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none;
}

.swiper-css-mode.swiper-centered > .swiper-wrapper::before {
  content: "";
  flex-shrink: 0;
  order: 9999;
}

.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color:#fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color:#000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}

:root {
  --swiper-navigation-size:44px;
}

.swiper-button-next, .swiper-button-prev {
  position: absolute;
  top: var(--swiper-navigation-top-offset, 50%);
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-next.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
  display: none !important;
}

.swiper-button-next svg, .swiper-button-prev svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transform-origin: center;
}

.swiper-rtl .swiper-button-next svg, .swiper-rtl .swiper-button-prev svg {
  transform: rotate(180deg);
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 10px);
  right: auto;
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}

.swiper-button-lock {
  display: none;
}

.swiper-button-next:after, .swiper-button-prev:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 0.3s opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: var(--swiper-pagination-bottom, 8px);
  top: var(--swiper-pagination-top, auto);
  left: 0;
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  right: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 0.2s transform, 0.2s top;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s left;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s right;
}

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25));
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: var(--swiper-pagination-progressbar-size, 4px);
  left: 0;
  top: 0;
}

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
  width: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  position: relative;
  touch-action: none;
  background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1));
}

.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: var(--swiper-scrollbar-sides-offset, 1%);
  bottom: var(--swiper-scrollbar-bottom, 4px);
  top: var(--swiper-scrollbar-top, auto);
  z-index: 50;
  height: var(--swiper-scrollbar-size, 4px);
  width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
  position: absolute;
  left: var(--swiper-scrollbar-left, auto);
  right: var(--swiper-scrollbar-right, 4px);
  top: var(--swiper-scrollbar-sides-offset, 1%);
  z-index: 50;
  width: var(--swiper-scrollbar-size, 4px);
  height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
  touch-action: none;
}

.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active {
  pointer-events: auto;
}

.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper.swiper-cube {
  overflow: visible;
}

.swiper-cube .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-prev {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  z-index: 0;
}

.swiper-cube .swiper-cube-shadow:before {
  content: "";
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px);
}

.swiper-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top {
  z-index: 0;
  backface-visibility: hidden;
}

.swiper.swiper-flip {
  overflow: visible;
}

.swiper-flip .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top {
  z-index: 0;
  backface-visibility: hidden;
}

.swiper-creative .swiper-slide {
  backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform, opacity, height;
}

.swiper.swiper-cards {
  overflow: visible;
}

.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  backface-visibility: hidden;
  overflow: hidden;
}

/* -------------------------------
   section header
------------------------------- */
.secHead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  -moz-column-gap: 30px;
       column-gap: 30px;
  row-gap: 20px;
  margin-bottom: 6rem;
}
.secHead.--wrap {
  flex-wrap: wrap;
}

.secHead__en {
  font-size: 6.4rem;
}

.secHead__ttl {
  font-size: clamp(2.8rem, 3.4vw, 4.8rem);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
}
.secHead__ttl small {
  font-size: 2.1rem;
}

.secTitle {
  font-size: clamp(2.1rem, 4vw, 3.6rem);
}

@media screen and (max-width: 768px) {
  .secHead {
    margin-bottom: 3rem;
  }
  .secHead__ttl {
    font-size: 2.4rem;
  }
  .secHead__ttl small {
    font-size: 1.2rem;
  }
  .secHead__en {
    font-size: 4rem;
  }
}
/* -------------------------------
   button
------------------------------- */
.btnAll {
  border: 1px solid rgba(0, 0, 0, 0.2);
  outline: 2px solid transparent;
  outline-offset: -2px;
  display: flex;
  align-items: center;
  gap: 15px;
  background: #F1F1F1;
  padding: 1.5em 2em;
  border-radius: 50px;
}
.btnAll::after {
  content: "";
  display: block;
  width: 7px;
  aspect-ratio: 1/1;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: rotate(45deg);
  transition: all 0.25s;
}
.btnAll:hover {
  color: #4E726F;
  outline-color: #4E726F;
}
.btnAll:hover::after {
  border-color: #4E726F;
}

.btnArrow {
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}

a.btnArrow:hover {
  color: #4E726F;
}
a.btnArrow:hover .btnArrow__txt {
  transform: translateX(5px);
}
a.btnArrow:hover .btnArrow__arrow {
  transform: translateX(-5px);
}
a.btnArrow:hover .btnArrow__arrow::before {
  background: #4E726F;
}
a.btnArrow:hover .btnArrow__arrow::after {
  border-color: #4E726F;
}

.btnArrow__txt {
  display: flex;
  align-items: center;
  gap: 15px;
  flex-shrink: 0;
  transition: all 0.25s;
}

.btnArrow__arrow {
  width: 100%;
  display: flex;
  align-items: center;
  position: relative;
  transition: all 0.25s;
}
.btnArrow__arrow::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: #000;
}
.btnArrow__arrow::after {
  content: "";
  display: block;
  width: 10px;
  aspect-ratio: 1/1;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
  position: absolute;
  right: 0;
}

@media screen and (max-width: 480px) {
  .btnAll {
    font-size: 1.2rem;
    padding: 1.2em 1.5em;
  }
}
.mySwiper {
  overflow: hidden;
}
.mySwiper__inner {
  position: relative;
}

.swiper-wrapper {
  cursor: grab;
}
.swiper-wrapper:active {
  cursor: grabbing;
}

.swiper-button-next,
.swiper-button-prev {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.2);
  bottom: 0;
  top: auto;
  transition: all 0.25s;
}
.swiper-button-next:hover,
.swiper-button-prev:hover {
  border-color: #4E726F;
  opacity: 1;
  filter: brightness(0.9);
}

.swiper-button-next {
  right: 0;
}

.swiper-button-prev {
  right: 50px;
  left: auto;
}

.swiper-button-next:after,
.swiper-button-prev:after {
  font-size: 14px;
  color: #000;
}

@media screen and (max-width: 480px) {
  .swiper-button-next,
  .swiper-button-prev {
    width: 40px;
    height: 40px;
    right: 5%;
  }
  .swiper-button-prev {
    right: calc(5% + 40px);
  }
}
html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  color: #000;
  font-family: "Poppins", "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 0.05em;
}

main {
  margin-top: 78px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  line-height: 1.3;
}

p {
  line-height: 1.8;
}
p + p {
  margin-top: 1.5em;
}

a {
  transition: all 0.25s;
}

li {
  line-height: 1.4;
}

img {
  max-width: 100%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

@media screen and (max-width: 1000px) {
  main {
    margin-top: 114px;
  }
}
/* -------------------------------
   text
------------------------------- */
.show {
  display: none;
}

@media screen and (max-width: 768px) {
  .hide.--tb {
    display: none;
  }
  .show.--tb {
    display: block;
  }
}
@media screen and (max-width: 480px) {
  .hide.--sp {
    display: none;
  }
  .show.--sp {
    display: block;
  }
}
/* -------------------------------
   フォーム
------------------------------- */
::-moz-placeholder {
  color: #ccc;
}
::placeholder {
  color: #ccc;
}

input[type=date] {
  min-height: 50px;
  text-align: left;
}

input[type=text],
input[type=email],
input[type=date],
input[type=tel],
input[type=number],
textarea,
select {
  background-color: rgba(0, 0, 0, 0.03);
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 4px;
  padding: 0.6em;
  line-height: 1.7;
}

input[type=date],
input[type=radio] {
  cursor: pointer;
}

label {
  cursor: pointer;
}

input[type=checkbox] {
  background-color: #FAFAFA;
  border: 1px solid rgba(0, 0, 0, 0.1);
  margin-right: 10px;
}

@media screen and (max-width: 768px) {
  input[type=text],
  input[type=email],
  input[type=date],
  input[type=tel],
  textarea {
    font-size: 1.4rem;
    padding: 8px;
  }
  label,
  select,
  input[type=date],
  input[type=radio],
  input[type=checkbox] {
    font-size: 1.4rem;
  }
}
/* -------------------------------
   layout
------------------------------- */
.l-contentWidth {
  width: 70%;
  max-width: 1200px;
  margin: 0 auto;
}

.l-secPadding {
  padding-top: 80px;
  padding-bottom: 80px;
}

.l-articleBody {
  padding-top: 100px;
  padding-bottom: 100px;
}

.l-pageBody {
  padding-top: 80px;
  padding-bottom: 80px;
  word-break: break-all;
}

@media screen and (max-width: 1280px) {
  .l-contentWidth {
    width: 88%;
  }
}
@media screen and (max-width: 768px) {
  .l-secPadding {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .l-articleBody {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .l-pageBody {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
/* -------------------------------
   グローバルナビ
------------------------------- */
.header {
  width: 100%;
  background: #fff;
  padding: 10px 0;
  position: fixed;
  top: 0;
  z-index: 100;
  box-shadow: 0 10px 30px 0 rgba(0, 0, 0, 0.05);
  transition: 0.2s;
}
.header.hide {
  transform: translateY(-100%);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  -moz-column-gap: 20px;
       column-gap: 20px;
  row-gap: 8px;
}

.header__logo {
  font-size: 1.2rem;
  color: #4E726F;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
}
.header__logo img {
  max-width: 200px;
}
.header__logo p {
  line-height: 1.4;
}
.header__logo a:hover {
  opacity: 0.7;
}

.gnavi {
  font-size: 1.4rem;
  border-radius: 50px;
}

.gnavi__item.swiper-slide {
  width: auto;
}
.gnavi__item a {
  display: block;
  padding: 12px 0;
  position: relative;
}
.gnavi__item a::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #000;
  position: absolute;
  bottom: 0;
  transition: all 0.25s;
  transform: scale(0, 1);
}
.gnavi__item a:hover::after {
  transform: scale(1, 1);
}
.gnavi__item.current a::after {
  transform: scale(1, 1);
}

/* -------------------------------
   SPナビ
------------------------------- */
.spnavi {
  display: none;
  width: 100%;
  max-width: 450px;
  height: 100dvh;
  font-size: 1.4rem;
  padding: 40px;
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  transform: translateX(-100%);
  transition: 0.3s ease-in;
  z-index: 100;
  overflow-y: scroll;
  box-shadow: 0 10px 30px 0 rgba(0, 0, 0, 0.05);
}
.spnavi.open {
  transform: translateX(0);
}

.spnavi__parent {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 1.5em 0;
}
.spnavi__parent a {
  display: block;
  font-weight: 700;
}
.spnavi__parent:has(.spnavi__index) .spnavi__child {
  margin-top: 1.5em;
}

.spnavi__child a {
  display: block;
  opacity: 0.5;
  font-weight: 500;
  margin-top: 8px;
}

.spnavi__property .spnavi__child {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding-bottom: 1.5em;
}
.spnavi__property .spnavi__child li {
  width: 50%;
  padding-right: 1.5em;
}
.spnavi__property a:not(:nth-child(1 of .spnavi__index)) {
  margin-top: 1em;
}

.hamburger {
  display: none;
  background: #fff;
  position: fixed;
  width: 58px;
  aspect-ratio: 1/1;
  border-radius: 0 0 0 10px;
  cursor: pointer;
  top: 10px;
  right: 3%;
  z-index: 110;
  transition: 0.1s;
}
.hamburger span {
  display: inline-block;
  width: 100%;
  height: 2px;
  background: #000;
  position: absolute;
  transition: 0.2s;
}
.hamburger span:nth-child(1) {
  top: 0;
}
.hamburger span:nth-child(2) {
  top: 50%;
}
.hamburger span:nth-child(3) {
  top: 100%;
}
.hamburger.close span:nth-child(1) {
  top: 50%;
  transform: rotate(45deg);
}
.hamburger.close span:nth-child(2) {
  width: 0;
}
.hamburger.close span:nth-child(3) {
  top: 50%;
  transform: rotate(-45deg);
}
.hamburger.hide {
  top: -100%;
}

.hamburger__inner {
  width: 27px;
  height: 20px;
  position: absolute;
  left: 50%;
  bottom: 50%;
  transform: translate(-50%, 50%);
  transition: 0.1s;
}

@media screen and (max-width: 1000px) {
  .gnavi {
    width: 100%;
  }
  .header {
    padding-top: 20px;
  }
  .header__logo {
    width: 100%;
    font-size: 1rem;
  }
  .header__logo img {
    max-width: 140px;
  }
  .gnavi__item a {
    padding: 8px 0;
  }
  .spnavi,
  .hamburger {
    display: block;
  }
}
/* -------------------------------
  TOPページ
------------------------------- */
#pageHome .header {
  visibility: hidden;
  transform: translateY(-100%);
  transition: 0.3s;
}
#pageHome .header.visible {
  visibility: visible;
  transform: translateY(0);
}
#pageHome .hamburger__inner {
  left: 20px;
  bottom: 30px;
  transform: translate(0);
}
#pageHome .hamburger {
  background: #4E726F;
  width: 80px;
  top: 0;
  right: 0;
}
#pageHome .hamburger span {
  background: #fff;
}
#pageHome .hamburger.visible {
  background: #fff;
  width: 58px;
  top: 10px;
  right: 3%;
}
#pageHome .hamburger.visible span {
  background: #000;
}
#pageHome .hamburger.visible .hamburger__inner {
  left: 50%;
  bottom: 50%;
  transform: translate(-50%, 50%);
}

/* -------------------------------
   固定フッター
------------------------------- */
.fixced_info {
  position: fixed;
  right: 0;
  bottom: 0;
  border-radius: 10px 0px 0px 0px;
  background-color: #4e726f;
  width: 400px;
  line-height: 3;
  z-index: 2000;
}
.fixced_info:hover {
  opacity: 0.8;
}
.fixced_info a {
  color: #fff;
  display: block;
  text-align: center;
  font-size: 16px;
}
.fixced_info a span {
  font-weight: 400;
  font-size: 14px;
}

@media screen and (max-width: 768px) {
  .fixced_info {
    position: fixed;
    right: 0;
    bottom: 0;
    border-radius: 10px 0px 0px 0px;
    background-color: #4e726f;
    width: 250px;
    max-width: 80%;
    line-height: 3;
  }
  .fixced_info a {
    color: #fff;
    display: block;
    text-align: center;
    font-size: 12px;
  }
  .fixced_info a span {
    font-weight: 400;
    font-size: 10px;
  }
}
.fixedFooter {
  display: none;
  width: 90%;
  max-width: 500px;
  border-radius: 10px 10px 0 0;
  background: rgba(255, 255, 255, 0.8);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid rgba(78, 114, 111, 0.1);
  padding: 30px 40px 20px;
  color: #4E726F;
  position: fixed;
  bottom: -1px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 90;
  overflow: hidden;
}

.fixedFooter__inner {
  display: flex;
  align-items: center;
  -moz-column-gap: 25px;
       column-gap: 25px;
}

.fixedFooter__deco {
  width: 100px;
  aspect-ratio: 1/1;
  background: url("/cmn/img/global/footer_deco.png") no-repeat center/contain;
  position: absolute;
  bottom: -30px;
  right: -30px;
}

@media screen and (max-width: 1000px) {
  .fixedFooter {
    display: block;
  }
}
/* -------------------------------
   フッター
------------------------------- */
.footer {
  font-size: 1.4rem;
  background: #fff;
}

.footer__inner {
  display: flex;
  justify-content: space-between;
  padding: 55px 0;
  row-gap: 20px;
}

.footer__info {
  width: 35%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.footer__logo {
  color: #4E726F;
  font-size: 2.1rem;
  font-weight: 700;
  max-width: 300px;
}
.footer__logo a:hover {
  opacity: 0.7;
}
.footer__logo p {
  line-height: 1.4;
  margin-top: 20px;
}

.footer__contact {
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  padding: 5rem 0;
  gap: 10px;
}
.footer__contact a:hover {
  color: #4E726F;
  text-decoration: underline;
}
.footer__contact p {
  line-height: 1.4;
}

.fnavi {
  width: 62%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.fnavi__group {
  width: 30%;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.fnavi__group a {
  display: block;
}
.fnavi__group a:hover {
  color: #4E726F;
  text-decoration: underline;
  opacity: 1;
}

.fnavi__parent {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 1.2em 0;
}
.fnavi__parent a {
  font-weight: 700;
}
.fnavi__parent:has(.fnavi__index) .fnavi__child {
  margin-top: 1.2em;
}
.fnavi__parent.--area {
  border-bottom: none;
  padding-bottom: 0;
}

.fnavi__child a {
  display: block;
  opacity: 0.5;
  font-weight: 500;
  margin-top: 6px;
}
.fnavi__child.--condition {
  display: flex;
  flex-wrap: wrap;
}
.fnavi__child.--condition li {
  width: 50%;
}

.copyright {
  font-size: 1.2rem;
  opacity: 0.5;
}

@media screen and (max-width: 960px) {
  .footer__logo {
    max-width: 240px;
    margin: 0 auto;
    text-align: center;
  }
  .footer__logo p {
    font-size: 1.6rem;
  }
  .footer__info {
    width: 30%;
  }
  .fnavi {
    width: 65%;
  }
  .fnavi__child {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .footer__info,
  .fnavi {
    width: 100%;
  }
  .footer__inner {
    padding: 35px 0;
  }
  .fnavi {
    display: none;
  }
  .footer__contact {
    margin-top: 5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
  }
}
.wave {
  overflow: hidden;
}
.wave::after {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 2393/234;
  background: url("../img/global/wave_wh.png") no-repeat center/contain;
  margin-bottom: -2px;
}
.wave.--home::after {
  position: absolute;
  bottom: -20px;
  left: 0;
}

@media screen and (max-width: 960px) {
  .wave::after {
    aspect-ratio: 113/20;
    background-image: url("../img/global/wave_wh_sp.png");
  }
  .wave.--home::after {
    bottom: 10px;
  }
}
@media screen and (max-width: 768px) {
  .wave::after {
    aspect-ratio: 113/20;
    background-image: url("../img/global/wave_wh_sp.png");
  }
  .wave.--home::after {
    bottom: 15px;
  }
}
@media screen and (max-width: 600px) {
  .wave.--home::after {
    bottom: 30px;
  }
}
@media screen and (max-width: 480px) {
  .wave.--home::after {
    bottom: 50px;
  }
}
/* -------------------------------
   サブナビ
------------------------------- */
.subNavi {
  font-weight: 500;
  width: 70%;
  max-width: 1200px;
  margin: 0 auto;
  background: #fff;
  font-size: 1.4rem;
  border-radius: 0 0 10px 10px;
  padding: 12px 10px 12px 30px;
  box-shadow: 0 10px 40px 0 rgba(0, 0, 0, 0.06);
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 10;
}
.subNavi .swiper-navi {
  overflow: hidden;
  padding-left: 20px;
}
.subNavi::after {
  content: "";
  display: block;
  width: 80px;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0), #fff);
  border-radius: 0 0 10px 0;
  position: absolute;
  right: 0;
  top: 0;
  pointer-events: none;
  z-index: 1;
}

.subNavi__item.swiper-slide {
  display: flex;
  align-items: center;
  width: auto;
}
.subNavi__item a {
  display: inline-block;
  padding: 10px 0;
  position: relative;
}
.subNavi__item a::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: all 0.25s;
  transform: scale(0, 1);
}
.subNavi__item.current a::after,
.subNavi__item a:hover::after {
  transform: scale(1, 1);
}
.subNavi__item.--border {
  border-right: 1px solid rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
  padding-right: 20px;
}

.subNavi__side {
  border-right: 1px solid rgba(0, 0, 0, 0.1);
  padding-right: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}
.subNavi__side img {
  width: 20px;
  height: 20px;
}

.subNavi__icon {
  position: relative;
  padding: 10px 3px;
}
.subNavi__icon::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: all 0.25s;
  transform: scale(0, 1);
}
.subNavi__icon.current::after, .subNavi__icon:hover::after {
  transform: scale(1, 1);
}

@media screen and (max-width: 768px) {
  .subNavi {
    width: 100%;
    padding: 15px;
    border-radius: 0;
    box-shadow: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  }
  .subNavi__icon span {
    display: none;
  }
}
@media screen and (max-width: 480px) {
  .subNavi {
    font-size: 1.2rem;
    padding: 10px 15px;
  }
}
.unitBlock:not(:first-child) {
  margin-top: 7.5rem;
}
.unitBlock p {
  font-weight: 400;
}
.unitBlock p + p {
  margin-top: 1.2em;
}
.unitBlock img {
  width: 100%;
  border-radius: 20px;
  /*object-fit: cover;*/
}
.unitBlock + .unitTitle {
  margin-top: 7.5rem;
}

.unitTitle {
  font-size: 2.1rem;
  margin-bottom: 1.2em;
}
.unitTitle + .unitBlock {
  margin-top: 0;
}

.--titleBig {
  font-size: 3.2rem !important;
  margin-bottom: 3rem !important;
  padding-top: 1.2em;
  position: relative;
  padding-top: 0.7em;
}
.--titleBig::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 3px;
  background: #000;
  position: absolute;
  top: 0;
  left: 0;
}

.unitTableOfContent {
  margin-top: 40px;
}
.unitTableOfContent.--box {
  background: #FAFAFA;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
}

.unitTableOfContent__ttl {
  font-weight: 700;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.unitTableOfContent__ttl::after {
  content: "";
  border-top: 8px solid #000;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
}

.unitTableOfContent__list li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.unitTableOfContent__list a {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 1.2em 0;
}
.unitTableOfContent__list a::before {
  content: "";
  display: block;
  width: 15px;
  aspect-ratio: 1/1;
  background: url("/cmn/img/icon/arrow_d.png") no-repeat center/contain;
  flex-shrink: 0;
}
.unitTableOfContent__list a:hover {
  color: #4E726F;
  opacity: 0.8;
}

.unit2col {
  display: flex;
  justify-content: space-between;
  row-gap: 30px;
}
.unit2col__content {
  width: 52%;
}
.unit2col__img {
  width: 42%;
}
.unit2col__img img {
  height: 100%;
}
.unit2col.--reverse {
  flex-direction: row-reverse;
}
.unit2col.--reverse {
  flex-direction: row-reverse;
}
.unit2col .unitLink {
  margin-top: 3rem;
}

.unit2col__ttl {
  font-size: 2.1rem;
  margin-bottom: 1.5em;
}

.unitText .unitLink {
  max-width: 450px;
  margin-top: 3rem;
}
.unitText li {
  line-height: 1.5;
  margin-top: 8px;
}
.unitText ul {
  list-style: disc;
}
.unitText ol {
  list-style: decimal;
}
.unitText a {
  text-decoration: underline;
}
.unitText a:hover {
  opacity: 0.8;
}

.unitText__img {
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 35px;
}

.unitText__ttl {
  font-size: 2.1rem;
  margin-bottom: 1.2em;
}

.unitImage img {
  border-radius: 20px;
}

.unitFlexImage {
  display: flex;
  justify-content: space-between;
}

.unitFlexImage__inner {
  width: 48%;
}
.unitFlexImage__inner img {
  aspect-ratio: 3/2;
}

.unitFlexImage__caption {
  margin-top: 1em;
}

.unitGallery img {
  aspect-ratio: 3/2;
  border-radius: 10px;
}

.unitGallery__zoom {
  background: #F1DABD;
  border-radius: 20px;
  text-align: center;
  aspect-ratio: 3/2;
}
.unitGallery__zoom img {
  height: 100%;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

.unitGallery__thumb {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 15px;
}
.unitGallery__thumb img {
  cursor: pointer;
  outline: 4px solid transparent;
}
.unitGallery__thumb img.current {
  outline-color: #4E726F;
}
.unitGallery__thumb img:hover {
  opacity: 0.9;
}

.unitLink {
  display: block;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  padding: 1.5em;
  padding-right: 4em;
  position: relative;
}
.unitLink::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
  position: absolute;
  right: 2em;
  top: calc(50% - 4px);
  transition: all 0.25s;
}
.unitLink:hover {
  border-color: #000;
}
.unitLink:hover::after {
  right: 1.8em;
}

.unitTable table {
  width: 100%;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  line-height: 1.3;
}
.unitTable tr {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.unitTable th,
.unitTable td {
  padding: 1.5em;
}
.unitTable th {
  width: 10em;
}

.unitList li {
  padding: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  counter-increment: li;
  padding-left: 3em;
  position: relative;
}
.unitList ul li {
  text-indent: -35px;
}
.unitList ul li::before {
  content: "";
  display: inline-block;
  width: 12px;
  aspect-ratio: 1/1;
  background: #000;
  border-radius: 50%;
  margin-right: 20px;
}
.unitList ol li::before {
  content: counter(li, decimal-leading-zero);
  font-size: 1.2rem;
  display: inline-block;
  text-align: center;
  width: 25px;
  line-height: 25px;
  color: #fff;
  background: #000;
  border-radius: 50%;
  margin-right: 20px;
  position: absolute;
  left: 5px;
  top: 18px;
}

.unitList ul li::before {
  content: "";
  display: inline-block;
  width: 12px;
  aspect-ratio: 1/1;
  background: #000;
  border-radius: 50%;
  margin-right: 1.5em;
}

@media screen and (max-width: 768px) {
  .unitBlock:not(:first-child) {
    margin-top: 6rem;
  }
  .unitBlock img {
    border-radius: 10px;
  }
  .unitBlock + .unitTitle {
    margin-top: 6rem;
  }
  .unitTitle + .unitBlock {
    margin-top: 0;
  }
  .unit2col {
    flex-direction: column-reverse;
  }
  .unit2col__content {
    width: 100%;
  }
  .unit2col__img {
    width: 100%;
    /*  aspect-ratio: 3/2;*/
  }
  .unit2col.--reverse {
    flex-direction: column-reverse;
  }
  .unitTitle,
  .unit2col__ttl,
  .unitText__ttl {
    font-size: 1.8rem;
    margin-bottom: 0.5em;
  }
  .--titleBig {
    font-size: 2.4rem !important;
    margin-bottom: 12px !important;
  }
  .unitTable tr {
    display: flex;
    flex-wrap: wrap;
  }
  .unitTable th,
  .unitTable td {
    padding: 1em;
  }
  .unitTable th {
    width: 100%;
    padding-bottom: 0;
  }
  .unitFlexImage {
    flex-direction: column;
  }
  .unitFlexImage__inner {
    width: 100%;
  }
  .unitFlexImage__inner:not(:first-child) {
    margin-top: 30px;
  }
  .unitGallery__thumb {
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    margin-top: 15px;
  }
  .unitGallery__thumb img {
    border-radius: 5px;
  }
}
/* -------------------------------
   空き家ポテンシャル
------------------------------- */
.secCase {
  background: #F1DABD;
  position: relative;
  overflow: hidden;
  padding-top: 180px;
}
.secCase::before, .secCase::after {
  content: "";
  display: block;
  width: 120%;
  aspect-ratio: 12/1;
  border-radius: 50%;
  position: absolute;
  left: -10%;
}
.secCase::before {
  background: #fff;
  top: 0;
  transform: translateY(-50%);
}
.secCase .caseItem {
  max-width: 275px;
  margin-bottom: 50px;
}
.secCase .caseItem:nth-child(odd) {
  transform: translateY(40px);
}
.secCase .swiper-case {
  padding-bottom: 70px;
}
.secCase .swiper-button-next,
.secCase .swiper-button-prev {
  background: #f1dabd;
}
.secCase .swiper-button-next.swiper-button-disabled,
.secCase .swiper-button-prev.swiper-button-disabled {
  opacity: 1;
  background: #cebdb0;
}
.secCase .btnAll {
  background: #fff;
}

.secCase__slideHead {
  width: 245px;
  height: auto;
  padding-right: 20px;
}
.secCase__slideHead p {
  margin-top: 50px;
}

.secCase__footer {
  display: flex;
  align-items: center;
  justify-content: right;
  padding: 50px 0 120px;
  position: relative;
}

.secSupport__deco {
  position: absolute;
  max-width: 380px;
  left: 0;
  bottom: 20px;
}

.secCaseSp {
  display: none;
  justify-content: space-between;
  margin-bottom: 4rem;
  max-width: 500px;
}

.secCaseSp__ttl {
  margin-bottom: 20px;
}

.secCaseSp__deco {
  width: 45%;
  min-width: 160px;
  -o-object-fit: contain;
     object-fit: contain;
  flex-shrink: 0;
}

@media screen and (max-width: 768px) {
  .secCase {
    padding-top: 8rem;
  }
  .secCase__slideHead,
  .secCase__footer {
    display: none;
  }
  .secCaseSp {
    display: flex;
  }
}
/* -------------------------------
   お問合せセクション
------------------------------- */
.secContact {
  background: #fff;
  padding-top: 80px;
  position: relative;
  z-index: 1;
}
.secContact::before {
  content: "";
  display: block;
  width: 100%;
  height: 50%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.secContact__bg {
  background: no-repeat center/cover;
  border-radius: 100px 0 0 100px;
  width: 55%;
  height: 75%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
}

.secContact__inner {
  width: 55%;
  color: #fff;
  background: #4E726F;
  border-radius: 0 100px 100px 0;
  padding: 70px;
  padding-left: calc((100vw - 1200px) / 2);
  margin-top: 50px;
  position: relative;
}

.secContact__ttl {
  font-size: max(3.4vw, 3.6rem);
}

.secContact__list {
  font-weight: 500;
  margin: 25px 0;
}
.secContact__list li {
  padding-left: 18px;
  text-indent: -18px;
}
.secContact__list li + li {
  margin-top: 1em;
}
.secContact__list li::before {
  content: "";
  display: inline-block;
  width: 13px;
  aspect-ratio: 7/5;
  background: url("../img/icon/check.png") no-repeat center/contain;
  margin-right: 5px;
}

.secContact__btn {
  max-width: 400px;
  background: #fff;
  border-radius: 10px;
  font-size: 2rem;
  color: #4E726F;
  padding: 1.2em 2em;
  margin-top: 3em;
}
.secContact__btn .btnArrow__arrow::before {
  height: 2px;
}
.secContact__btn .btnArrow__arrow::after {
  border-top: 2px solid #4E726F;
  border-right: 2px solid #4E726F;
}

.secContact__deco {
  width: 250px;
  aspect-ratio: 1/1;
  background: no-repeat center/contain;
  position: absolute;
  top: 0;
  right: 10%;
  transform: translateY(-25%);
}

@media screen and (max-width: 1280px) {
  .secContact__inner {
    width: 65%;
    padding: 50px;
  }
}
@media screen and (max-width: 960px) {
  .secContact__deco {
    width: 180px;
  }
}
@media screen and (max-width: 768px) {
  .secContact {
    padding: 0;
    display: flex;
    flex-direction: column-reverse;
  }
  .secContact__btn {
    font-size: 1.6rem;
  }
  .secContact__bg {
    width: 100%;
    max-width: 600px;
    height: 30dvh;
    min-height: 250px;
    position: static;
    align-self: flex-end;
  }
  .secContact__inner {
    width: 100%;
    max-width: 600px;
    margin-top: 0;
    margin-top: -8%;
  }
  .secContact__deco {
    width: 120px;
    right: 5%;
  }
}
@media screen and (max-width: 480px) {
  .secContact__inner {
    padding: 50px 70px 50px 10%;
  }
  .secContact__list {
    font-size: 1.2rem;
  }
  .secContact__btn {
    font-size: 1.4rem;
  }
}
#pageHome main {
  margin-top: 0;
}

/* -------------------------------
   main visual
------------------------------- */
.mainVisual {
  height: 100dvh;
  max-height: 1080px;
  padding: 10dvh 10%;
  position: relative;
}

.mainVisual__logo {
  width: 25%;
  min-width: 160px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: #fff;
  position: relative;
  container-type: inline-size;
}
.mainVisual__logo h1 {
  margin-top: 0.8em;
  font-size: min(9cqw, 2.4rem);
}

.mainVisual__nav {
  font-weight: 600;
  color: #4E726F;
  width: 673px;
  max-width: 100%;
  background: #fff;
  padding: 15px 20px;
  border-radius: 50px;
  position: absolute;
  bottom: 20%;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
}
.mainVisual__nav .gnavi {
  justify-content: center;
}
.mainVisual__nav .gnavi__item:first-child {
  margin-left: 10px;
}
.mainVisual__nav .gnavi__item a::after {
  background: #4E726F;
}

.mainVisual__slide {
  overflow: hidden;
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: #4e726f;
}
.mainVisual__slide::after {
  content: "";
  display: block;
  width: 100%;
  height: 70%;
  background: linear-gradient(to bottom, transparent, rgba(53, 116, 110, 0.5));
  position: absolute;
  bottom: 0;
}

.mainVisual__bg {
  background: no-repeat center/cover;
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(1.05);
}
.mainVisual__bg.active {
  animation: fadeIn 2s forwards;
}
.mainVisual__bg.inactive {
  animation: fadeOut 2s forwards;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: scale(1.05);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(1.05);
  }
}
.mainVisual__deco {
  width: 200px;
  aspect-ratio: 1/1;
  position: absolute;
  background: no-repeat center/contain;
}
.mainVisual__deco.--img01 {
  bottom: 3vmax;
  right: 50%;
  transform: translateX(-350px);
  z-index: 1;
}
.mainVisual__deco.--img02 {
  bottom: 5.5vmax;
  left: 50%;
  transform: translateX(350px);
}

@media screen and (max-width: 1280px) {
  .mainVisual {
    height: 70dvh;
    min-height: 600px;
    padding: 50px 5%;
  }
  .mainVisual::after {
    min-width: 1200px;
  }
  .mainVisual__deco {
    width: 180px;
  }
  .mainVisual__deco.--img01 {
    right: auto;
    left: 0;
    transform: translateX(0);
  }
  .mainVisual__deco.--img02 {
    left: auto;
    right: 0;
    transform: translateX(0);
  }
}
@media screen and (max-width: 960px) {
  .mainVisual::after {
    min-width: auto;
    bottom: 50px;
  }
  .mainVisual__nav {
    width: 100%;
    bottom: -2px;
    border-radius: 0;
    z-index: 1;
    box-shadow: 0 20px 20px 0 rgba(0, 0, 0, 0.05);
  }
  .mainVisual__deco.--img01 {
    bottom: 6vw;
  }
  .mainVisual__deco.--img02 {
    bottom: 11vw;
  }
}
@media screen and (max-width: 600px) {
  .mainVisual__nav .gnavi {
    justify-content: left;
  }
}
@media screen and (max-width: 480px) {
  .mainVisual {
    min-height: 500px;
  }
  .mainVisual__deco {
    width: 120px;
  }
  .mainVisual__deco.--img01 {
    bottom: 12vw;
  }
  .mainVisual__deco.--img02 {
    bottom: calc(20vw + 10px);
  }
}
/* -------------------------------
   about
------------------------------- */
.topAbout {
  position: relative;
  margin: 20px 0;
}

.topAbout__inner {
  display: flex;
  justify-content: space-between;
}

.topAbout__left {
  width: 40%;
  container-type: inline-size;
}

.topAbout__right {
  width: 55%;
  position: relative;
}

.topAbout__ttl {
  font-size: 11cqw;
  margin-bottom: 1.2em;
}

.topAbout__txt {
  margin-bottom: 4rem;
}

.topAbout__grid {
  height: 100%;
  display: grid;
  grid-template-columns: 3;
  grid-template-rows: 4;
  position: relative;
}

.topAbout__img {
  background: no-repeat center/cover;
  border-radius: 20px;
  background-color: #4e726f;
}
.topAbout__img.--img01 {
  grid-column: 2/4;
  grid-row: 1/3;
}
.topAbout__img.--img02 {
  grid-column: 1/3;
  grid-row: 2/4;
}
.topAbout__img.--img03 {
  grid-column: 3/4;
  grid-row: 3/4;
}
.topAbout__img.--img04 {
  grid-column: 1/2;
  grid-row: 4/5;
}

.topAbout__deco {
  width: 200px;
  aspect-ratio: 1/1;
  background: no-repeat center/contain;
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (max-width: 768px) {
  .topAbout {
    margin-top: 50px;
  }
  .topAbout__inner {
    flex-direction: column;
  }
  .topAbout__left,
  .topAbout__right {
    width: 100%;
  }
  .topAbout__ttl {
    font-size: 2.8rem;
  }
  .topAbout__grid {
    aspect-ratio: 1/1;
  }
  .topAbout__deco {
    width: 35%;
    min-width: 130px;
  }
}
/* -------------------------------
   空き家ポテンシャル
------------------------------- */
.topCase {
  overflow: hidden;
  position: relative;
  padding-bottom: 20px;
}
.topCase::before, .topCase::after {
  content: "";
  display: block;
  background: #fff;
  width: 120%;
  aspect-ratio: 12/1;
  border-radius: 50%;
  position: absolute;
  left: -10%;
}
.topCase::before {
  top: 0;
  transform: translateY(-50%);
}
.topCase::after {
  bottom: 0;
  transform: translateY(50%);
}

.topCase__head {
  height: 70dvh;
  max-height: 700px;
  padding: 30px 5%;
  position: relative;
}

.topCase__ttl {
  width: 250px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.topCase__deco {
  width: 400px;
  position: absolute;
  bottom: -60px;
  left: 50%;
  transform: translateX(calc(-50% - 80px));
}

.topCase__btn {
  max-width: 1200px;
  height: 100%;
  margin: 0 auto;
  display: flex;
  align-items: end;
  justify-content: end;
}

.topCaseBg {
  position: absolute;
  inset: 0;
  display: flex;
  z-index: -1;
}
.topCaseBg::before {
  content: "";
  display: block;
  width: 140%;
  height: 10dvh;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}

.topCaseBg__img {
  width: 50%;
  height: 100%;
  background: no-repeat center/cover;
  position: relative;
  background-color: #4e726f;
}
.topCaseBg__img::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
}
.topCaseBg__img:nth-child(1)::before {
  background: linear-gradient(to left, rgba(53, 116, 110, 0.5), rgba(28, 58, 55, 0) 80%, transparent);
  right: 0;
}
.topCaseBg__img:nth-child(2)::before {
  background: linear-gradient(to right, rgba(53, 116, 110, 0.5), rgba(28, 58, 55, 0) 80%, transparent);
  left: 0;
}

.topCase__body {
  background: #F1DABD;
}

.topCase .swiper-wrapper {
  align-items: flex-start;
  padding-bottom: 80px;
}
.topCase .caseItem {
  max-width: 275px;
  margin-bottom: 50px;
}
.topCase .caseItem:nth-child(odd) {
  transform: translateY(40px);
}

.topCase__slideTtl {
  font-size: 2.4rem;
  width: auto;
  height: auto;
  writing-mode: vertical-rl;
  border-right: 2px solid #000;
  padding-right: 0.5em;
  margin-right: 35px;
}

@media screen and (max-width: 768px) {
  .topCase__head {
    height: 50dvh;
    padding-bottom: 0;
  }
  .topCase__ttl {
    width: 150px;
  }
  .topCase__deco {
    width: 55%;
    max-width: 270px;
    bottom: -30px;
    transform: translateX(calc(-50% - 40px));
  }
  .topCase__btn {
    transform: translateY(25px);
  }
  .topCase .swiper-wrapper {
    padding-bottom: 50px;
  }
  .topCase .caseItem {
    max-width: 200px;
  }
  .topCase__slideTtl {
    font-size: 1.8rem;
  }
}
/* -------------------------------
   map
------------------------------- */
.topHirosimaMap .hiroshimaMap {
  background: #fff;
  padding: 0;
  margin-top: 0;
}
.topHirosimaMap .hiroshimaMap__inner {
  background: #E0F2F0;
  padding: 30px;
  border-radius: 20px;
}
.topHirosimaMap .hiroshimaMap__svg {
  width: 600px;
}
.topHirosimaMap .hiroshimaMap__head .btnAll {
  background: #fff;
}

@media screen and (max-width: 768px) {
  .topHirosimaMap {
    margin-top: 50px;
  }
  .topHirosimaMap .hiroshimaMap {
    padding: 0 20px;
  }
  .topHirosimaMap .hiroshimaMap__head {
    flex-direction: column;
    row-gap: 20px;
  }
  .topHirosimaMap .hiroshimaMap__svg {
    width: 450px;
  }
}
/* -------------------------------
   topics
------------------------------- */
.topTopic__list {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.topTopic__list .topicItem__link {
  padding: 30px 0;
}
.topTopic__list .topicItem__link::after {
  display: none;
}

/* -------------------------------
   support
------------------------------- */
.secSupport {
  background: #FBFBFB;
  overflow: hidden;
}

.swiper-support {
  visibility: hidden;
}
.swiper-support.swiper-initialized {
  visibility: visible;
}

.supportItem {
  font-size: 1.4rem;
  height: auto;
  margin-bottom: 1px;
}

.supportItem__link {
  height: 100%;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  padding: 40px;
  background: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.supportItem__link:hover {
  color: #4E726F;
  border-color: #4E726F;
}
.supportItem__link:hover .btnArrow__txt {
  transform: translateX(5px);
}
.supportItem__link:hover .btnArrow__arrow {
  transform: translateX(-5px);
}
.supportItem__link:hover .btnArrow__arrow::before {
  background: #4E726F;
}
.supportItem__link:hover .btnArrow__arrow::after {
  border-color: #4E726F;
}

.supportItem__head {
  margin-bottom: 60px;
}

.supportItem__ttl {
  font-size: 2.1rem;
  margin-bottom: 1em;
}

@media screen and (max-width: 768px) {
  .supportItem__head {
    margin-bottom: 25px;
  }
  .supportItem__link {
    padding: 25px;
  }
  .supportItem__ttl {
    font-size: 1.6rem;
  }
}
/* -------------------------------
   page header
------------------------------- */
.resultsWrapper {
  flex: 1;
}

.propertyHeader {
  margin-bottom: 20px;
}

.propertyHeader__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}

.prppertyHeader__ttl {
  color: #4E726F;
  font-size: 3.6rem;
}

.propertyResultMessage {
  text-align: center;
  font-weight: 700;
  margin: 3em 0 1em;
}

.sortBtn {
  font-size: 1.4rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  background: #E0F2F0;
  border-radius: 10px;
  justify-content: space-between;
  padding: 1em 1.5em;
  border: 2px solid transparent;
  transition: all 0.25s;
}
.sortBtn:hover {
  background: #4E726F;
  color: #fff;
}
.sortBtn:hover .sortBtn__txt {
  color: #fff;
}

.sortBtn__icon {
  display: flex;
  align-items: center;
  gap: 16px;
}
.sortBtn__icon::before {
  content: "";
  display: inline-block;
  width: 20px;
  aspect-ratio: 37/35;
  background: url("/cmn/img/icon/sort.png") no-repeat center/contain;
}

@media screen and (max-width: 768px) {
  .resultsWrapper {
    flex: initial;
  }
  .prppertyHeader__ttl {
    font-size: 2.4rem;
  }
  .sortBtn {
    padding: 15px;
  }
  .sortBtn__icon {
    gap: 10px;
  }
  .sortBtn__icon::before {
    width: 18px;
  }
}
@media screen and (max-width: 480px) {
  .propertyHeader__inner {
    flex-wrap: wrap;
  }
  .sortBtn {
    width: 100%;
    max-width: 400px;
    justify-content: center;
  }
}
/* -------------------------------
   一覧ページ
------------------------------- */
#pageProperty .breadCrumb {
  margin-top: 35px;
}

.propertyWrapper {
  padding-top: 50px;
  padding-bottom: 80px;
}

.breadCrumb {
  font-weight: 700;
  display: flex;
  align-items: center;
}
.breadCrumb span:not(:first-child) {
  display: flex;
  align-items: center;
  gap: 15px;
  padding-left: 10px;
}
.breadCrumb span:not(:first-child)::before {
  content: "";
  display: inline-block;
  width: 10px;
  aspect-ratio: 1/1;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
}

.sortResult {
  font-weight: 700;
  margin-top: 15px;
  display: flex;
  align-items: center;
}

.sortResult__page {
  display: flex;
  align-items: center;
}
.sortResult__page::before {
  content: "-";
  margin: 0 1em;
  font-weight: 400;
}

@media screen and (max-width: 768px) {
  .propertyWrapper {
    padding-top: 25px;
    padding-bottom: 50px;
  }
  .breadCrumb {
    font-size: 1.2rem;
  }
  .breadCrumb span:not(:first-child)::before {
    width: 8px;
  }
  .sortResult {
    font-size: 1.4rem;
  }
}
/* -------------------------------
   ページャー
------------------------------- */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 50px;
}

.pagination__item a {
  cursor: pointer;
  display: grid;
  place-content: center;
  width: 36px;
  aspect-ratio: 1/1;
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.pagination__item.current a, .pagination__item:hover a {
  border-color: #000;
}

.pagination__prev::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-top: 1px solid #000;
  border-left: 1px solid #000;
  transform: rotate(-45deg);
  margin-right: -3px;
}

.pagination__next::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
  margin-left: -3px;
}

@media screen and (max-width: 768px) {
  .pagination {
    margin-top: 30px;
    gap: 7px;
  }
  .pagination__item {
    font-size: 1.4rem;
  }
  .pagination__item a {
    width: 28px;
  }
}
/* -------------------------------
   ダイアログ共通設定
------------------------------- */
.dialog,
.dialogNotice {
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 100%;
  height: 100dvh;
  max-height: 100%;
  background: none;
  box-sizing: border-box;
  transition: 0.3s;
}
.dialog::backdrop,
.dialogNotice::backdrop {
  background-color: rgba(0, 0, 0, 0.3);
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  transition: 0.5s;
  cursor: pointer;
}

body.noscroll {
  overflow: hidden;
}

/* -------------------------------
   ダイアログ レイアウト
------------------------------- */
.dialog {
  overflow-y: scroll;
}
.dialog::-webkit-scrollbar {
  display: none;
}

.dialog__box {
  width: 90%;
  max-width: 700px;
  margin: 100px auto 0;
  background: #fff;
  border-radius: 30px;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
  container-type: inline-size;
  position: relative;
}

.dialog__content {
  padding: 35px 8% 20px;
}

.dialog.open, .dialog.hide {
  transform: translateY(100%);
}
.dialog.open::backdrop, .dialog.hide::backdrop {
  opacity: 0;
}

@media screen and (max-width: 768px) {
  .dialog {
    padding: 10dvh 0 0;
  }
  .dialog__box {
    width: 100%;
    max-width: 100%;
    border-radius: 30px 30px 0 0;
  }
}
.dialog__head {
  font-size: clamp(16px, 6cqw, 24px);
  border-bottom: 3px solid #4E726F;
  padding: 40px 8%;
}

@media screen and (max-width: 480px) {
  .dialog__head {
    padding: 40px 5% 25px;
  }
}
.closeDialog {
  display: inline-block;
  width: 35px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #000;
  position: absolute;
  top: 15px;
  right: 15px;
}
.closeDialog::before, .closeDialog::after {
  content: "";
  display: inline-block;
  width: 17px;
  height: 2px;
  background: #fff;
  position: absolute;
  top: calc(50% - 1px);
  left: calc(50% - 8px);
  transition: all 0.25s;
}
.closeDialog::before {
  transform: rotate(45deg);
}
.closeDialog::after {
  transform: rotate(-45deg);
}
.closeDialog:hover::before, .closeDialog:hover::after {
  top: 50%;
  transform: rotate(0);
}

.dialogBtns {
  font-size: 1.4rem;
  width: 100%;
  max-width: 700px;
  background: linear-gradient(to bottom, transparent, rgba(255, 255, 255, 0.5) 20%, rgba(255, 255, 255, 0.9) 100%);
  padding: 12px 0;
  display: flex;
  justify-content: center;
  gap: 15px;
  position: sticky;
  top: auto;
  bottom: 0;
  left: 0;
  margin-top: 30px;
  z-index: 10;
}

.dialogBtns__prev {
  display: flex;
  align-items: center;
}
.dialogBtns__prev a,
.dialogBtns__prev button {
  display: block;
  background: #fff;
  border-radius: 50px;
  padding: 1.5em 2em;
  border: 1px solid rgba(0, 0, 0, 0.2);
  transition: all 0.25s;
}
.dialogBtns__prev a:hover,
.dialogBtns__prev button:hover {
  border-color: #000;
  opacity: 0.9;
}

.dialogBtns__next {
  font-weight: 700;
  position: relative;
  display: flex;
  align-items: center;
}
.dialogBtns__next button,
.dialogBtns__next input[type=submit] {
  display: block;
  color: #fff;
  background: #21BAAB;
  border-radius: 50px;
  padding: 1.5em 3em 1.5em 2em;
  transition: all 0.25s;
}
.dialogBtns__next::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  right: 15px;
  top: calc(50% - 5px);
  transition: all 0.25s;
}
.dialogBtns__next:hover input {
  background: #4E726F;
}

@media screen and (max-width: 768px) {
  .dialogBtns {
    max-width: 100%;
  }
  .dialogBtns__reset input[type=reset] {
    padding: 1.2em;
  }
  .dialogBtns__submit input[type=submit] {
    padding: 1.2em 2.4em 1.2em 1.2em;
  }
  .dialogBtns__submit::after {
    width: 6px;
    top: calc(50% - 4px);
  }
  .dialogBtns__next,
  .dialogBtns__prev {
    font-size: 1.2rem;
  }
}
/* -------------------------------
   絞り込みダイアログ
------------------------------- */
.filterHead {
  font-size: clamp(16px, 6cqw, 28px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 80px 8% 20px;
  border-bottom: 3px solid #4E726F;
}

.filterHead__ttl {
  color: #4E726F;
  display: flex;
  align-items: center;
}
.filterHead__ttl::before {
  content: "";
  display: inline-block;
  width: 1.5em;
  margin-right: 0.5em;
  aspect-ratio: 37/35;
  background: url("/cmn/img/icon/sort_gr.png") no-repeat center/contain;
  flex-shrink: 0;
}

.filterHead__btn {
  font-size: max(0.5em, 14px);
  font-weight: 700;
  background: #E0F2F0;
  display: flex;
  align-items: center;
  gap: 1em;
  padding: 1em;
  border-radius: 10px;
  transition: all 0.25s;
}
.filterHead__btn:hover {
  background: #4E726F;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .filterHead {
    padding-top: 60px;
  }
}
.filter__list {
  margin: 0 auto;
}

.filter__item {
  font-weight: 600;
}
.filter__item:not(:first-child) {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  margin-top: 40px;
  padding-top: 40px;
}
.filter__item dt {
  font-size: 1.8rem;
  margin-bottom: 5px;
}

.selectWrapper {
  width: 85%;
  max-width: 200px;
  position: relative;
  margin-top: 15px;
}
.selectWrapper::after {
  content: "";
  display: inline-block;
  border-top: 8px solid rgba(0, 0, 0, 0.3);
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
  position: absolute;
  right: 10px;
  top: calc(50% - 4px);
  z-index: 1;
}

select {
  width: 100%;
  background: #EAEAEA;
  border-radius: 4px;
  border: 1px solid rgba(0, 0, 0, 0.3);
  cursor: pointer;
}

.checkWrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.checkLabel {
  display: flex;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  cursor: pointer;
  position: relative;
  margin-top: 15px;
}

.checkLabel__icon {
  display: inline-block;
  width: 9px;
  height: 5px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  position: absolute;
  top: 5px;
  left: 4px;
  transform: rotate(-45deg);
  visibility: hidden;
}

.checkArea {
  display: flex;
  flex-direction: column;
}

.checkChild {
  padding-left: 2em;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 20px;
       column-gap: 20px;
}
.checkChild:not(:last-of-type) {
  margin-bottom: 10px;
}

input[type=checkbox] {
  width: 17px;
  height: 17px;
  background: #EAEAEA;
  border-radius: 4px;
  border: 1px solid rgba(0, 0, 0, 0.3);
  margin-right: 12px;
}

input[type=checkbox]:checked {
  background: #4E726F;
}
input[type=checkbox]:checked ~ .checkLabel__icon {
  visibility: visible;
}

.filterChild__inner {
  display: flex;
  flex-direction: column;
}

.filterChild__ttl {
  margin-top: 30px;
}

/* -------------------------------
   保存済みダイアログ
------------------------------- */
.savrdItem {
  font-size: 1.4rem;
  margin-bottom: 20px;
}

.savrdItem__radio {
  display: none;
}

.savrdItem__label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px;
  border-radius: 10px;
  outline: 1px solid rgba(0, 0, 0, 0.2);
}
.savrdItem__label::before {
  content: "";
  color: #21BAAB;
  width: 5em;
  font-weight: 700;
  flex-shrink: 0;
}
.savrdItem__label:hover {
  border-color: #000;
  background: #fafafa;
}

.savrdItem__detail {
  flex: 1;
  line-height: 1.3;
}

.savrdItem__row {
  display: flex;
  align-items: center;
}
.savrdItem__row dt {
  width: 6em;
  font-weight: 400;
  flex-shrink: 0;
}
.savrdItem__row:not(:first-child) {
  margin-top: 10px;
}

.savrdItem__radio:checked + .savrdItem__label {
  outline-color: #21BAAB;
  outline-width: 2px;
  outline-offset: -1px;
}
.savrdItem__radio:checked + .savrdItem__label::before {
  content: "選択";
}

.savrdItem__txt {
  line-height: 1.4;
  opacity: 0.5;
}

@media screen and (max-width: 768px) {
  #saved.dialog {
    padding-top: 20dvh;
  }
}
/* -------------------------------
   保存ダイアログ
------------------------------- */
.dialogNotice {
  overflow: visible;
}

.dialogNotice__box {
  width: 90%;
  max-width: 700px;
  background: #fff;
  border-radius: 30px;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 50px;
}

.dialogNotice__ttl {
  font-size: clamp(16px, 6cqw, 24px);
  margin-bottom: 20px;
}

.dialogNotice__txt {
  margin-bottom: 30px;
}

.dialogNotice.open, .dialogNotice.hide {
  transform: translateY(20px);
}
.dialogNotice.open::backdrop, .dialogNotice.hide::backdrop {
  opacity: 0;
}

.dialogNotice__btn {
  display: inline-block;
  width: 50%;
  max-width: 100px;
  text-align: center;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 50px;
  padding: 1em 2em;
  transition: all 0.25s;
}
.dialogNotice__btn:hover {
  border-color: #000;
  background: #fafafa;
}

@media screen and (max-width: 768px) {
  .dialogNotice__box {
    padding: 50px 8%;
  }
  .dialogNotice__ttl {
    font-size: 2.1rem;
  }
}
/* -------------------------------
   メールダイアログ
------------------------------- */
.emailHead {
  font-size: 2rem;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 80px 8% 20px;
}
.emailHead::before {
  content: "";
  display: inline-block;
  width: 40px;
  aspect-ratio: 2/1;
  background: url("../img/icon/sort_bk.png") no-repeat center/contain;
  flex-shrink: 0;
  margin-right: 20px;
}

.emailContent {
  padding: 0 8%;
}

.emailContent__box {
  font-size: 1.4rem;
  line-height: 1.5;
  font-weight: 700;
}

.emailContent__deco {
  width: 140px;
  aspect-ratio: 1/1;
  background: url("../img/pages/property/dialog_deco.png") no-repeat center/contain;
  margin: 0 auto;
}

.emailContent__inner {
  background: #E0F2F0;
  border-radius: 10px;
  padding: 25px;
  position: relative;
  transform: translateY(-25px);
}

.emailContent__row {
  display: flex;
  margin-bottom: 1em;
}
.emailContent__row dt {
  width: 7em;
  flex-shrink: 0;
}

.emailContent__area {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 15px;
       column-gap: 15px;
  margin-top: 1em;
}

.emailBody__ttl {
  font-size: 1.8rem;
}

.emailContent__label {
  font-size: 1.8em;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.emailContent__required {
  font-size: 1.6rem;
  color: #4E726F;
}

.emailContent__input {
  width: 100%;
  font-size: 1.6rem !important;
  background: #F9F9F9;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 4px;
  padding: 1em;
  margin-top: 10px;
}
.emailContent__input::-moz-placeholder {
  color: rgba(0, 0, 0, 0.2);
}
.emailContent__input::placeholder {
  color: rgba(0, 0, 0, 0.2);
}

.emailContent__note {
  opacity: 0.5;
  margin-top: 5px;
}

.emailContent__txt {
  margin-top: 25px;
}
.emailContent__txt h3 {
  font-size: 1.8rem;
}
.emailContent__txt p {
  font-size: 1.4rem;
  font-weight: 700;
  margin-top: 10px;
  line-height: 1.5;
}

.emailContent__privacy {
  text-align: center;
  margin-top: 25px;
  font-weight: 700;
}
.emailContent__privacy a {
  text-decoration: underline;
  display: inline-block;
  margin-right: 10px;
}

/* -------------------------------
   絞り込み検索
------------------------------- */
.searchWrapper {
  display: flex;
  align-items: flex-start;
  padding-top: 50px;
  padding-bottom: 80px;
}

@media screen and (max-width: 768px) {
  .searchWrapper {
    display: block;
    padding-top: 25px;
    padding-bottom: 50px;
  }
}
.pcFilter {
  width: 290px;
  font-size: 1.4rem;
  margin-right: 90px;
  position: relative;
  flex-shrink: 0;
}

.pcFilter__head {
  font-size: 2.1rem;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 3px solid #4E726F;
}

.pcFilter__ttl {
  color: #4E726F;
  display: flex;
  align-items: center;
}
.pcFilter__ttl::before {
  content: "";
  display: inline-block;
  width: 1.5em;
  margin-right: 0.5em;
  aspect-ratio: 37/35;
  background: url("/cmn/img/icon/sort_gr.png") no-repeat center/contain;
  flex-shrink: 0;
}

.pcFilter__btn {
  font-size: 1.4rem;
  font-weight: 700;
  background: #E0F2F0;
  display: flex;
  align-items: center;
  gap: 1em;
  padding: 0.8em;
  border-radius: 10px;
  transition: all 0.25s;
  margin-top: 15px;
}
.pcFilter__btn:hover {
  background: #4E726F;
  color: #fff;
}

.pcFilter__clear {
  margin-top: 50px;
  margin-bottom: 20px;
  text-align: center;
}
.pcFilter__clear a {
  display: block;
  width: 100%;
  background: #fff;
  border-radius: 50px;
  padding: 1.5em 2em;
  border: 1px solid rgba(0, 0, 0, 0.2);
  transition: all 0.25s;
}
.pcFilter__clear a:hover {
  border-color: #000;
  opacity: 0.9;
}

.pcFilter__submit {
  text-align: center;
  font-weight: 700;
  position: fixed;
  bottom: 30px;
  z-index: 100;
}
.pcFilter__submit input[type=submit] {
  display: block;
  width: 290px;
  color: #fff;
  background: #21BAAB;
  border-radius: 50px;
  padding: 1.5em 3em 1.5em 2em;
  transition: all 0.25s;
}
.pcFilter__submit::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  right: 15px;
  top: calc(50% - 5px);
  transition: all 0.25s;
}
.pcFilter__submit:hover input {
  background: #4E726F;
}

@media screen and (max-width: 768px) {
  .pcFilter {
    display: none;
  }
}
.sortDetail {
  font-weight: 700;
  background: #E0F2F0;
  border-radius: 15px;
  margin-top: 30px;
}

.sortDetail__head {
  display: none;
  align-items: center;
  justify-content: space-between;
  padding: 25px;
}

.sortDetail:has(.sortDetail__selected) .sortDetail__head {
  border-bottom: 1px solid #000;
}

.sortDetail__selected {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 10px;
  padding: 25px;
}
.sortDetail__selected li {
  padding: 0 1em;
}
.sortDetail__selected li:not(:last-child) {
  border-right: 1px solid rgba(0, 0, 0, 0.2);
}

.sortDetail__icon {
  display: flex;
  align-items: center;
  gap: 16px;
}
.sortDetail__icon::before {
  content: "";
  display: inline-block;
  width: 24px;
  aspect-ratio: 37/35;
  background: url("/cmn/img/icon/sort.png") no-repeat center/contain;
}

.sortDetail__btn {
  color: #4E726F;
  cursor: pointer;
}
.sortDetail__btn:hover {
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  .sortDetail__head {
    display: flex;
    padding: 20px;
  }
  .sortDetail__selected {
    padding: 20px;
    font-size: 1.4rem;
  }
}
.endSort {
  font-size: 1.8rem;
  font-weight: 700;
  display: inline-block;
  background: #E2E2E2;
  border-radius: 50px;
  padding: 1em 1.5em 1em 3em;
  position: relative;
}
.endSort::before, .endSort::after {
  content: "";
  display: inline-block;
  width: 15px;
  height: 2px;
  background: #000;
  position: absolute;
  left: 23px;
  top: 26px;
}
.endSort::before {
  transform: rotate(45deg);
}
.endSort::after {
  transform: rotate(-45deg);
}
.endSort:hover {
  background: #4E726F;
  color: #fff;
}
.endSort:hover::before, .endSort:hover::after {
  background: #fff;
}

@media screen and (max-width: 768px) {
  .endSort {
    font-size: 1.4rem;
  }
  .endSort::before, .endSort::after {
    left: 15px;
    top: 20px;
  }
}
.result {
  display: flex;
}
.result .filter {
  position: static;
  transform: translateX(0);
  box-shadow: none;
  height: auto;
  overflow-y: visible;
  z-index: 1;
}

.resultHead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  -moz-column-gap: 30px;
       column-gap: 30px;
  row-gap: 10px;
  margin-top: 4rem;
}

.resultHead__ttl {
  font-size: 3.2rem;
}

.resultHead__num {
  margin-top: 10px;
  font-weight: 700;
}

.resultHead__status {
  display: inline-block;
  padding: 15px;
  font-size: 1.4rem;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 6px;
}

.sortGroup {
  font-size: 1.2rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 20px;
  row-gap: 10px;
}

.searchBtns {
  font-weight: 700;
  display: flex;
  gap: 15px;
}

.searchBtns__save,
.searchBtns__email {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 1em;
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.2);
}
.searchBtns__save::before,
.searchBtns__email::before {
  content: "";
  display: inline-block;
  width: 18px;
  aspect-ratio: 1/1;
  background: no-repeat center/contain;
  flex-shrink: 0;
}
.searchBtns__save:hover,
.searchBtns__email:hover {
  border-color: #000;
  opacity: 0.8;
}

.searchBtns__save::before {
  background-image: url("/cmn/img/icon/save.png");
}

.searchBtns__email::before {
  background-image: url("/cmn/img/icon/mail.png");
}

@media screen and (max-width: 768px) {
  .resultHead {
    flex-direction: column-reverse;
    margin-top: 0;
  }
  .resultHead__status {
    padding: 10px;
    font-size: 1.2rem;
  }
  .resultHead__ttl {
    font-size: 2.8rem;
  }
  .sortGroup {
    flex-direction: column-reverse;
  }
  .searchBtns {
    margin-bottom: 40px;
  }
  .searchBtns a::before {
    width: 16px;
  }
  .searchBtns__save,
  .searchBtns__email {
    flex: 1;
  }
}
/* -------------------------------
   一覧
------------------------------- */
.propertyList {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}

.propertyItem {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.propertyItem.hide {
  display: none;
}

.propertyItem__link {
  display: block;
  padding: 40px 20px;
}
.propertyItem__link:hover {
  color: #4E726F;
  background: #fafafa;
}

.propertyItem__inner {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 40px;
       column-gap: 40px;
  row-gap: 15px;
  position: relative;
}

.propertyItem__thumb {
  width: 200px;
  aspect-ratio: 3/2;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
}
.propertyItem__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.propertyItem__label {
  position: absolute;
  top: 0;
  left: 0;
  background: #4E726F;
  color: #fff;
  font-size: 1.2rem;
  padding: 8px 12px;
  font-weight: 700;
  border-radius: 0 0 10px 0;
}

.propertyItem__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 15px;
}

.priceDetail {
  position: relative;
}

.priceDetail__price {
  color: #4E726F;
  display: flex;
  display: block;
  display: block;
  align-items: center;
  flex-wrap: wrap;
  -moz-column-gap: 25px;
       column-gap: 25px;
  row-gap: 5px;
  padding-right: 40px;
  white-space: nowrap;
}
.priceDetail__price .propertyPrice__comment {
  padding-left: 54px;
  padding-top: 6px;
  padding-bottom: 15px;
  padding-right: 2em;
  white-space: normal !important;
}

.priceDetail__row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.priceDetail__row dt {
  display: inline-block;
  font-size: 1.2rem;
  padding: 3px 8px;
  border-radius: 4px;
  border: 1px solid #4E726F;
  background: #4E726F;
  color: #fff;
}
.priceDetail__row dt.--white {
  background: #fff;
  color: #4E726F;
  border: 1px solid #4E726F;
}
.priceDetail__row dd {
  font-size: 2rem;
  font-weight: 700;
}

.priceDetail__fav {
  width: 28px;
  aspect-ratio: 1/1;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../img/icon/star.png") no-repeat center/contain;
  transition: 0.2s;
}
.priceDetail__fav.--added {
  background-image: url("../img/icon/star_fill.png");
}

@keyframes starAnimation {
  0%, to {
    transform: scale(1, 1);
  }
  30% {
    transform: scale(1.3, 0.8);
  }
  40% {
    transform: scale(0.8, 1.3);
  }
  50% {
    transform: scale(1.25, 0.8);
  }
  65% {
    transform: scale(0.9, 1.05);
  }
  75% {
    transform: scale(1.05, 0.9);
  }
}
.propertyItem__ttl {
  font-size: 2.1rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-top: 2.5rem;
}

.propertyItem__tags {
  font-size: 1.4rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 0.3em;
}
.propertyItem__tags span:not(:last-child)::after {
  content: "／";
  margin: 0 0.5em;
}

.propertyItem__date {
  font-size: 1.4rem;
  font-weight: 700;
  margin-top: 0.3em;
}

@media screen and (max-width: 768px) {
  .propertyItem__inner {
    gap: 15px;
    align-items: flex-start;
    flex-wrap: nowrap;
  }
  .propertyItem__label {
    font-size: 1rem;
    padding: 5px 10px;
    border-bottom-right-radius: 4px;
  }
  .propertyItem__link {
    padding: 25px 0;
  }
  .propertyItem__thumb {
    width: 40%;
    min-width: 120px;
    border-radius: 4px;
  }
  .priceDetail__price {
    font-size: 1.6rem;
    padding-right: 35px;
  }
  .propertyItem__ttl {
    font-size: 1.6rem;
    -webkit-line-clamp: 2;
    margin-top: 1.5em;
  }
  .priceDetail__row {
    width: 100%;
    margin-bottom: 8px;
  }
  .priceDetail__row dt {
    padding: 2px 6px;
  }
  .priceDetail__row dd {
    font-size: 1.6rem;
  }
  .propertyItem__tags {
    font-size: 1.2rem;
  }
  .propertyItem__tags span:not(:last-child)::after {
    margin: 0 0.5em;
  }
  .propertyItem__date {
    font-size: 1.2rem;
  }
  .priceDetail__fav {
    width: 28px;
  }
}
/* -------------------------------
   あなたのカルテ
------------------------------- */
.record {
  color: #4E726F;
  border-radius: 10px;
  background: #F8EDE7;
  padding: 60px 0;
}

.record__inner {
  width: 70%;
  max-width: 1200px;
  margin: 0 auto;
}

.record__head {
  font-weight: 700;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  -moz-column-gap: 25px;
       column-gap: 25px;
  row-gap: 8px;
}
.record__head h1 {
  font-size: 3.5rem;
}

.record__body {
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  gap: 25px;
  margin-top: 30px;
}

.record__item {
  flex: 2;
  max-width: 100%;
  background: #fff;
  border-radius: 8px;
  padding: 20px;
}
.record__item dt {
  width: 100%;
  font-size: 2.3rem;
}
.record__item dd {
  font-weight: 700;
}

.record__item:nth-child(1) {
  min-width: 250px;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  row-gap: 20px;
}

.favourites {
  font-size: 7rem;
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 10px;
}
.favourites::before {
  content: "";
  display: inline-block;
  width: 1em;
  aspect-ratio: 1/1;
  background: url("/cmn/img/pages/property/favorite.png") no-repeat center/contain;
  margin-top: -5px;
}

.record__item:nth-child(2) {
  min-width: 400px;
}
.record__item:nth-child(2) dt {
  text-align: right;
}

.graph {
  display: flex;
  gap: 16px;
  margin-top: 20px;
}

.graph__item {
  flex: 1;
  max-width: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.graph__item:nth-child(n+7) {
  opacity: 0.5;
}

.graph__bar {
  width: 100%;
  height: 100px;
  display: flex;
  align-items: flex-end;
}

.graph__height {
  background: #4E726F;
  border-radius: 4px;
}

.graph__name {
  font-size: 1.4rem;
  writing-mode: vertical-rl;
  height: 6rem;
  flex-shrink: 0;
  line-height: 1;
}

.graph__item:first-child {
  max-width: 45px;
  flex: 2;
  color: #fff;
}
.graph__item:first-child .graph__bar {
  width: 100%;
  font-size: 1.8rem;
}
.graph__item:first-child .graph__height {
  background: #F3AE89;
  padding: 9px;
  display: flex;
  align-items: center;
  flex-direction: column;
}
.graph__item:first-child .graph__name {
  color: #F3AE89;
}

.record__item:last-child {
  min-width: 300px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 40px;
       column-gap: 40px;
  row-gap: 20px;
}
.record__item:last-child dt {
  margin-bottom: 10px;
}

.rate__num {
  font-size: 5.4rem;
  text-align: center;
}
.rate__num span {
  opacity: 0.5;
  display: inline-block;
  margin: 0 5px;
}

.avr__num {
  font-size: 3.6rem;
  text-align: center;
  letter-spacing: 0;
  white-space: nowrap;
}
.avr__num small {
  font-size: 0.4em;
  margin-left: 5px;
}

.avr:nth-child(2) .avr__num {
  font-size: 5.4rem;
}

@media screen and (max-width: 768px) {
  .record {
    padding: 40px;
  }
  .record__inner {
    width: 100%;
  }
  .record__body {
    gap: 15px;
    margin-top: 15px;
  }
  .record__item {
    flex: initial;
  }
  .record__item:nth-child(1), .record__item:nth-child(2), .record__item:last-child {
    min-width: auto;
    width: 100%;
  }
  .record__item:nth-child(1) {
    flex-direction: row;
  }
  .record__item:nth-child(2) dt {
    text-align: left;
  }
  .record__item:nth-child(3) {
    text-align: center;
  }
  .graph {
    flex-direction: column;
  }
  .graph__item {
    max-width: 100%;
    flex-direction: row-reverse;
  }
  .graph__name {
    writing-mode: horizontal-tb;
    height: auto;
    width: 5em;
    text-align: right;
  }
  .graph__bar {
    width: 100%;
    height: 12px;
  }
  .graph__item:first-child {
    max-width: 100%;
  }
  .graph__item:first-child .graph__bar {
    height: auto;
    font-size: 1.6rem;
  }
  .graph__item:first-child .graph__height {
    flex-direction: row;
  }
}
@media screen and (max-width: 480px) {
  .record {
    padding: 40px 25px;
  }
  .record__item dt {
    font-size: 1.8rem;
  }
  .favourites {
    font-size: 4rem;
  }
  .graph__name {
    font-size: 1.2rem;
  }
  .rate__num,
  .avr__num,
  .avr:nth-child(2) .avr__num {
    font-size: 3.2rem;
  }
}
/* -------------------------------
   地域別ページ
------------------------------- */
.hiroshimaMap {
  color: #4E726F;
  margin-bottom: 25px;
  background: #E0F2F0;
  margin-top: -64px;
  padding-top: 110px;
  padding-bottom: 80px;
}

.hiroshimaMap__inner {
  width: 90%;
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

.hiroshimaMap__scroll {
  width: 85vw;
  display: flex;
  justify-content: right;
  display: none;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 10;
}
.hiroshimaMap__prev, .hiroshimaMap__next {
  width: 32px;
  line-height: 30px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.2);
  background: #fff;
  text-align: center;
}
.hiroshimaMap__prev::before, .hiroshimaMap__next::before {
  content: "";
  display: inline-block;
  width: 7px;
  aspect-ratio: 1/1;
  border-bottom: 2px solid #000;
  border-right: 2px solid #000;
}
.hiroshimaMap__prev::before {
  transform: rotate(135deg);
}
.hiroshimaMap__next::before {
  transform: rotate(-45deg);
}

.hiroshimaMap__head {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: absolute;
  top: 0;
  left: 0;
  padding: 30px;
}

.hiroshimaMap__ttl {
  font-size: 6.4rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  line-height: 1;
}
.hiroshimaMap__ttl small {
  display: block;
  font-size: 2.1rem;
  margin-top: 10px;
}

.hiroshimaMap__sum {
  font-size: 6.4rem;
  font-weight: 700;
  margin-top: -1em;
}
.hiroshimaMap__sum small {
  font-size: 0.5em;
}

.hiroshimaMap__svg {
  width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.hiroshimaMap__svg svg {
  width: 100%;
}

.hiroshimaMap__deco {
  width: 25%;
  max-width: 250px;
  aspect-ratio: 1/1;
  background: url("../img/pages/property/dialog_deco.png") no-repeat center/contain;
  position: absolute;
  right: 0;
  bottom: 0;
}

.loading-modal {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  background: url("../img/global/loading.svg") no-repeat center;
  background-color: #fff;
}

.mapHeader {
  margin-top: 50px;
}

.mapHeader__inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  -moz-column-gap: 20px;
       column-gap: 20px;
  row-gap: 14px;
}
.mapHeader__inner:not(:first-child) {
  margin-top: 50px;
}

.mapHeader__ttl {
  color: #4E726F;
}
.mapHeader__ttl h1 {
  font-size: 2.1rem;
}

.mapHeader__en {
  font-size: 6.4rem;
  font-weight: 700;
  line-height: 0.8;
  margin-bottom: 15px;
}

.mapHeader__btn {
  font-size: 1.8rem;
  color: #4E726F;
  font-weight: 700;
  display: flex;
  align-items: center;
  background: #E0F2F0;
  border-radius: 10px;
  justify-content: space-between;
  padding: 1.2em;
  border: 2px solid transparent;
  transition: all 0.25s;
}
.mapHeader__btn:hover {
  background: #4E726F;
  color: #fff;
}
.mapHeader__btn:hover .sortBtn__txt {
  color: #fff;
}

.mapHeader__icon {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mapHeader__icon::before {
  content: "";
  display: inline-block;
  width: 24px;
  aspect-ratio: 37/35;
  background: url("/cmn/img/icon/map.png") no-repeat center/contain;
}

@media screen and (max-width: 1280px) {
  .hiroshimaMap__deco {
    width: 160px;
    right: -40px;
  }
  .hiroshimaMap__ttl,
  .hiroshimaMap__sum {
    font-size: 4.8rem;
  }
}
@media screen and (max-width: 768px) {
  .loading-modal {
    background-size: 100px;
  }
  .hiroshimaMap {
    background: #fff;
    padding: 84px 20px 20px;
    overflow: scroll;
  }
  .hiroshimaMap__inner {
    background: #E0F2F0;
    width: 100%;
    min-width: 600px;
    border-radius: 20px;
    padding: 30px;
    display: flex;
    align-items: flex-start;
    flex-direction: column;
  }
  .hiroshimaMap__ttl {
    font-size: 3.6rem;
  }
  .hiroshimaMap__svg {
    width: 450px;
    margin-top: 60px;
  }
  .hiroshimaMap__sum {
    font-size: 3.6rem;
    margin-top: 0;
  }
  .hiroshimaMap__deco {
    width: 120px;
    right: 20px;
  }
  .mapHeader__ttl h1 {
    font-size: 1.8rem;
  }
  .mapHeader__en {
    font-size: 4rem;
  }
  .mapHeader__btn {
    font-size: 1.6rem;
    padding: 10px 14px;
  }
}
@media screen and (max-width: 630px) {
  .hiroshimaMap__scroll {
    display: flex;
  }
}
@media screen and (max-width: 480px) {
  .mapHeader__inner {
    flex-wrap: wrap;
  }
  .mapHeader__btn {
    font-size: 1.4rem;
    width: 100%;
    max-width: 400px;
    font-size: 1.6rem;
    justify-content: center;
  }
  .mapHeader__icon::before {
    width: 18px;
  }
}
/* -------------------------------
   詳細ページ
------------------------------- */
#postProperty .secCase::before {
  background: #fbfbfb;
}

.postPropertyHead__main {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  -moz-column-gap: 40px;
       column-gap: 40px;
  row-gap: 10px;
}

.postPropertyHead__ttl {
  font-size: 3.6rem;
}

.postPropertyHead__num {
  font-size: 1.4rem;
  opacity: 0.5;
}

.postPropertyHead_flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 20px;
  padding-top: 1em;
}

.propertySummary__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4rem;
}

.propertyPrice {
  color: #4E726F;
}

.propertyPrice__inner {
  display: flex;
  align-items: center;
  gap: 11px;
  padding-bottom: 8px;
}
.propertyPrice__inner:last-child {
  margin-top: 10px;
}

.propertyPrice__comment {
  padding-left: 58px;
  padding-bottom: 8px;
}

.propertyPrice__label {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #fff;
  background: #4E726F;
  border-radius: 4px;
  padding: 8px;
  transition: all 0.25s;
}
.propertyPrice__label.--white {
  background: #fff;
  color: #4E726F;
  border: 1px solid #4E726F;
}

.propertyPrice__num {
  font-weight: 700;
  font-size: 3.2rem;
  display: flex;
  align-items: flex-end;
  gap: 5px;
}
.propertyPrice__num span {
  line-height: 1;
}
.propertyPrice__num small {
  font-size: 0.6em;
  margin-top: -5px;
}

@media screen and (max-width: 768px) {
  small.pc_only {
    display: none;
  }
}
.addFavorites {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 1.2rem;
}
.addFavorites span {
  white-space: nowrap;
}

.addFavorites__icon {
  width: 30px;
  aspect-ratio: 1/1;
  background: url("../img/icon/star.png") no-repeat center/contain;
}
.addFavorites__icon.--added {
  animation: starAnimation 1s both ease-in;
  background-image: url("../img/icon/star_fill.png");
}

.postPropertyImages {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 15px;
}

.postPropertyImages__item {
  aspect-ratio: 3/2;
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  position: relative;
}
.postPropertyImages__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.postPropertyImages__item:first-child {
  grid-column: span 4;
}
.postPropertyImages__item:first-child .postPropertyImages__zoom {
  right: 14px;
  bottom: 14px;
  width: 25px;
}
.postPropertyImages__item:first-child .postPropertyImages__zoom::before, .postPropertyImages__item:first-child .postPropertyImages__zoom::after {
  height: 12px;
}
.postPropertyImages__item:hover {
  opacity: 0.8;
}

.postPropertyImages__zoom {
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  width: 15px;
  bottom: 5px;
  right: 5px;
}
.postPropertyImages__zoom:hover {
  background: #fafafa;
}
.postPropertyImages__zoom::before, .postPropertyImages__zoom::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 8px;
  background: #707070;
  position: absolute;
  top: 25%;
  left: calc(50% - 1px);
}
.postPropertyImages__zoom::after {
  transform: rotate(90deg);
}

.imageModal {
  display: none;
  z-index: 1000;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
}

.imageModal__content {
  text-align: center;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.imageModal__img {
  width: 100%;
  max-width: 1200px;
  max-height: 90%;
  margin: 0 auto;
  height: auto;
  transition: all 0.3s ease;
}

/* 閉じるボタン */
.imageModal__close {
  position: absolute;
  top: 20px;
  right: 30px;
  color: white;
  font-size: 30px;
  cursor: pointer;
  z-index: 10;
}

/* 前/次ボタン */
.imageModal__prev,
.imageModal__next {
  display: grid;
  place-content: center;
  cursor: pointer;
  color: white;
  background: rgba(0, 0, 0, 0.5);
  font-weight: bold;
  width: 35px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  font-size: 13px;
}

.imageModal__prev {
  left: 0%;
}

.imageModal__next {
  right: 0%;
}

@media screen and (max-width: 768px) {
  .postPropertyHead__ttl {
    font-size: 2.1rem;
  }
  .propertyPrice {
    gap: 15px;
  }
  .postPropertyHead__num {
    margin-top: 0;
  }
  .propertyPrice__label {
    font-size: 1.2rem;
    padding: 9px 12px;
  }
  .propertyPrice__num {
    font-size: 2.4rem;
  }
  .imageModal__img {
    max-width: 100%;
  }
}
.unitPropertyTitle {
  margin-bottom: 1.5em;
}

.unitPropertyBlock {
  margin-top: 7.5rem;
}

.unitProperty2col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 50px;
       column-gap: 50px;
  row-gap: 40px;
}

.unitPrContent {
  font-size: 1.4rem;
}
.unitPrContent h2 {
  font-weight: 700;
  margin-bottom: 1em;
}
.unitPrContent p {
  margin-bottom: 1.5em;
}

.unitPropertyContent__body {
  font-size: 1.4rem;
}
.unitPropertyContent__body p {
  opacity: 0.5;
}
.unitPropertyContent__body p:not(:first-child) {
  margin-top: 1.2em;
}
.unitPropertyContent__body ul {
  list-style: disc;
  list-style-position: inside;
}
.unitPropertyContent__body li {
  opacity: 0.5;
  padding-left: 19px;
  text-indent: -19px;
}
.unitPropertyContent__body li:not(:first-child) {
  margin-top: 7px;
}

.unitPropertyDetail {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.4;
}
.unitPropertyDetail.--2col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 20px;
       column-gap: 20px;
}

.unitPropertyDetail__row {
  display: flex;
  align-items: center;
  padding: 1.5em 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.unitPropertyDetail__row dt {
  width: 6em;
  flex-shrink: 0;
}
.unitPropertyDetail__row dd {
  width: calc(100% - 7em);
  padding-left: 1.5em;
}
.unitPropertyDetail__row dd span:not(:first-child)::before {
  content: "、";
}

.unitPropertyDetail__map {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  -moz-column-gap: 20px;
       column-gap: 20px;
  row-gap: 10px;
}
.unitPropertyDetail__map a {
  font-weight: 700;
  text-decoration: underline;
  flex-shrink: 0;
}
.unitPropertyDetail__map a:hover {
  color: #4E726F;
  opacity: 1;
}

.unitPropertyVr {
  aspect-ratio: 3/1;
}
.unitPropertyVr iframe {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-fit: center;
     object-fit: center;
  background: #EAEAEA;
}

.unitPropertyTag {
  font-size: 1.2rem;
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 1em;
       column-gap: 1em;
  row-gap: 1em;
}
.unitPropertyTag a {
  display: inline-block;
  background: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  padding: 1em 1.5em;
}
.unitPropertyTag a:hover {
  color: #4E726F;
  border-color: #4E726F;
}

.unitPropertyBtn {
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  padding: 24px;
}
.unitPropertyBtn:hover {
  color: #4E726F;
  border-color: #4E726F;
}
.unitPropertyBtn:not(:first-child) {
  margin-top: 15px;
}

.unitPropertyBtn__txt {
  flex: 1;
}

.unitPropertyBtn__inner {
  display: flex;
  align-items: center;
  gap: 10px;
}

.unitPropertyBtn__sub {
  opacity: 0.5;
  flex-shrink: 0;
}

.unitPropertyBtn__icon {
  display: inline-block;
  width: 20px;
  height: 15px;
  background: url("/cmn/img/icon/link.png") no-repeat center/contain;
  flex-shrink: 0;
}

.dobox {
  background: #F9E7E7;
  border: 1px solid rgba(243, 32, 32, 0.5);
  border-radius: 30px;
  padding: 30px 40px;
  display: flex;
  position: relative;
  margin-bottom: 60px;
}
.dobox::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-top: 2px solid #EE2727;
  border-right: 2px solid #EE2727;
  transform: rotate(45deg);
  position: absolute;
  right: 30px;
  top: calc(50% - 5px);
  transition: all 0.25s;
}
.dobox p {
  font-size: 1.2rem;
  line-height: 1.65;
}
.dobox:hover {
  opacity: 0.8;
}
.dobox:hover::after {
  right: 25px;
}

.dobox__logo {
  width: 110px;
  flex-shrink: 0;
  margin-right: 20px;
}

.dobox__ttl {
  font-size: 3.3rem;
  margin-bottom: 5px;
}

@media screen and (max-width: 768px) {
  .unitProperty2col {
    grid-template-columns: 1fr;
  }
  .unitPropertyBlock {
    margin-top: 5rem;
  }
  .unitPropertyDetail.--2col {
    grid-template-columns: 1fr;
  }
  .unitPropertyTitle {
    font-size: 1.6rem;
  }
  .unitPropertyVr {
    aspect-ratio: 3/2;
  }
  .dobox {
    padding: 25px;
    gap: 15px;
  }
  .dobox__logo {
    width: 80px;
  }
}
/* -------------------------------
   空き家ポテンシャル
------------------------------- */
#postProperty .secCase::after {
  background: #fff;
  bottom: 0;
  transform: translateY(50%);
}

/* -------------------------------
   おすすめの空き家
------------------------------- */
.secProperty.l-secPadding,
.secRecommend.l-secPadding {
  padding-bottom: 0;
}
.secProperty.l-secPadding .mySwiper,
.secRecommend.l-secPadding .mySwiper {
  padding-bottom: 50px;
}

.secRecommend .subNavi {
  border: none;
  box-shadow: 0 10px 40px 0 rgba(0, 0, 0, 0.06);
}

.swiper-recommend {
  padding-top: 40px;
  height: 540px;
}

.secRecommend__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  -moz-column-gap: 30px;
       column-gap: 30px;
  margin-left: 15%;
}

.secRecommend__ttl {
  font-size: clamp(2.8rem, 3.4vw, 3.6rem);
}

.propertyCard {
  font-weight: 700;
  max-width: 340px;
  position: relative;
  height: auto;
}
.propertyCard:nth-child(2n) {
  transform: translateX(50px);
}

.propertyCard__link {
  height: 100%;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow: 0 10px 40px 0 rgba(0, 0, 0, 0.06);
  display: flex;
  flex-direction: column;
  padding: 20px;
}
.propertyCard__link:hover {
  color: #4E726F;
  border-color: #4E726F;
  box-shadow: none;
}

.propertyCard__star {
  width: 30px;
  mix-blend-mode: darken;
}

.propertyCard__head {
  display: flex;
  justify-content: space-between;
  gap: 15px;
}

.propertyCard__thumb {
  width: 100px;
  aspect-ratio: 4/3;
  border-radius: 4px;
  background: no-repeat center/cover;
  border: 1px solid rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
}

.propertyCard__summary {
  width: calc(100% - 120px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.propertyCard__ttl {
  font-size: 1.6rem;
  margin-top: 15px;
  margin-bottom: 10px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.propertyCard__info {
  font-size: 1.2rem;
  margin-top: auto;
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}

@media screen and (max-width: 1280px) {
  .secRecommend__head {
    margin-left: 6%;
  }
}
@media screen and (max-width: 768px) {
  .swiper-recommend {
    height: 435px;
  }
  .propertyCard {
    width: 300px;
  }
  .propertyCard__link {
    padding: 15px;
  }
  .propertyCard__link:hover {
    color: inherit;
    border-color: transparent;
    box-shadow: inherit;
  }
  .propertyCard__ttl {
    -webkit-line-clamp: 1;
    margin-bottom: 0;
    margin-top: 8px;
  }
  .propertyCard__summary {
    width: calc(100% - 80px);
  }
  .secRecommend__head {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 0;
  }
  .propertyCard__info {
    margin-top: 20px;
  }
  .secRecommend__ttl {
    font-size: 2.4rem;
  }
}
/* -------------------------------
   pickup
------------------------------- */
.pickup {
  display: block;
  border-radius: 10px;
  border: 2px solid #4E726F;
  box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.06);
  margin-top: 50px;
}

.pickup__inner {
  display: flex;
  padding: 40px;
  position: relative;
  justify-content: space-between;
}

.pickup__head {
  display: flex;
  align-items: flex-end;
  gap: 25px;
}

.pickup__sp {
  display: none;
  align-items: flex-end;
  -moz-column-gap: 25px;
       column-gap: 25px;
  position: relative;
}

.pickup__right {
  width: 55%;
  display: flex;
  flex-direction: column;
}

.pickup__thumb {
  width: 40%;
  aspect-ratio: 3/2;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
  flex-shrink: 0;
}

.pickup__fav {
  width: 30px;
  aspect-ratio: 1/1;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../img/icon/star.png") no-repeat center/contain;
  transition: 0.2s;
}
.pickup__fav.--added {
  animation: starAnimation 1s both ease-in;
  background-image: url("../img/icon/star_fill.png");
}

.pickup__ttl {
  font-size: 2.1rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-bottom: 15px;
}

.my-interview:not(:first-child) {
  margin-bottom: 50px;
}

.pickup__price {
  color: #4E726F;
  display: flex;
  display: block;
  align-items: center;
  flex-wrap: wrap;
  -moz-column-gap: 25px;
       column-gap: 25px;
  row-gap: 5px;
  white-space: nowrap;
}
.pickup__price .propertyPrice__comment {
  padding-left: 54px;
  padding-top: 6px;
  padding-bottom: 8px;
}
.pickup__price .priceDetail__row {
  margin-bottom: 8px;
}

.pickup__data {
  width: 60%;
  font-weight: 700;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 0.5em;
  margin-top: 5px;
  margin-bottom: 10px;
}
.pickup__data span:not(:last-child) {
  display: inline-block;
  margin-right: 1em;
}

.pickupLink {
  display: block;
  margin-top: 30px;
  border-radius: 4px;
  color: #fff;
  background: #4E726F;
  padding: 15px 50px 15px 30px;
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.pickupLink::after {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  right: 20px;
  top: calc(50% - 5px);
  transition: all 0.25s;
  transition: all 0.25s;
}
.pickupLink:hover {
  opacity: 0.9;
}
.pickupLink:hover::after {
  right: 16px;
}

@media screen and (max-width: 782px) {
  .my-interview:nth-child(odd) {
    flex-direction: column-reverse;
  }
  .my-interview:not(:first-child) {
    margin-bottom: 35px;
  }
}
.interview-ttl {
  padding: 0.2em 0.8em;
  border-left: 8px solid var(--);
}

@media screen and (max-width: 768px) {
  .pickup__pc {
    display: none;
  }
  .pickup__sp {
    display: block;
  }
  .pickup__inner {
    display: block;
    padding: 20px;
  }
  .pickup__thumb {
    width: 50%;
  }
  .pickup__price {
    font-size: 1.6rem;
  }
  .pickup__ttl {
    font-size: 1.6rem;
    margin-top: 15px;
    margin-bottom: 0;
  }
  .pickup__data {
    margin-top: 10px;
  }
  .pickup__fav {
    top: 15px;
    right: 15px;
  }
  .pickupLink {
    margin-top: 0;
    padding: 24px 50px 24px 30px;
  }
}
/* -------------------------------
   共通ヘッダー
------------------------------- */
.interviewHead {
  background: no-repeat center/cover;
  height: calc(30vw + 30vh);
  max-height: 1080px;
  position: relative;
  display: flex;
  align-items: flex-end;
}
.interviewHead::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 50%;
  bottom: 0;
  background: linear-gradient(to bottom, transparent, rgba(119, 105, 56, 0.5));
}

.interviewHead__inner {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  row-gap: 20px;
  margin-bottom: calc(5vw + 5vh);
  position: relative;
  z-index: 1;
}

.interviewHead__ttl {
  font-weight: 700;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  color: #fff;
}
.interviewHead__ttl h1,
.interviewHead__ttl h2 {
  font-size: max(4.8vw, 3.6rem);
  line-height: 0.7;
  margin-top: 30px;
}

.interviewHead__deco {
  width: 100%;
  background: no-repeat center/contain;
  position: absolute;
}
.interviewHead__deco.--img01 {
  aspect-ratio: 601/106;
  top: 0;
}
.interviewHead__deco.--img02 {
  aspect-ratio: 400/39;
  bottom: -10px;
}

@media screen and (max-width: 960px) {
  .interviewHead {
    height: 70dvh;
  }
  .interviewHead__inner {
    margin-bottom: 10dvh;
  }
}
@media screen and (max-width: 768px) {
  .interviewHead__deco.--img01 {
    aspect-ratio: 569/151;
  }
  .interviewHead__deco.--img02 {
    aspect-ratio: 563/85;
  }
}
@media screen and (max-width: 480px) {
  .interviewHead {
    height: 50dvh;
    min-height: 400px;
  }
  .interviewHead__ttl {
    font-size: 1.2rem;
  }
  .interviewHead__ttl h1,
  .interviewHead__ttl h2 {
    margin-top: 15px;
  }
  .interviewHead__ttl p {
    line-height: 1.4;
  }
}
/* -------------------------------
   共通 記事一覧
------------------------------- */
.secInterview {
  position: relative;
  margin-bottom: -25px;
}
.secInterview::after {
  content: "";
  display: block;
  background: #F1EEDC;
  width: 100%;
  height: calc(100% - 25px);
  position: absolute;
  top: 0;
  z-index: -1;
}

.interviewList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  padding: 80px 0;
}

.interviewCard__link {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  color: #4E726F;
  background: #fff;
  border-radius: 20px;
  outline: 2px solid transparent;
  outline-offset: -2px;
}
.interviewCard__link:hover {
  outline-color: #4E726F;
}

.interviewCard__head {
  padding: 25px;
}

.interviewCard__ttl {
  font-size: 3.2rem;
  margin-top: 5px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.interviewNum {
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
}

.interviewNum__txt {
  flex-shrink: 0;
}

.interviewNum__line {
  display: block;
  width: 60%;
  height: 1px;
  background: #4E726F;
}

.interviewNum__num {
  font-size: 4rem;
  flex-shrink: 0;
}

.interviewThumb {
  text-align: center;
  display: flex;
  justify-content: space-between;
  padding-bottom: 25px;
}

.interviewThumb__img {
  width: 100%;
  aspect-ratio: 4/5;
  background: no-repeat center/cover;
  background-color: #4E726F;
  overflow: hidden;
}

.interviewThumb__item {
  width: 33.3333333333%;
  display: flex;
  flex-direction: column;
  gap: 50px;
}
.interviewThumb__item:first-child .interviewThumb__img {
  border-radius: 0 100px 100px 0;
}
.interviewThumb__item:nth-child(2) .interviewThumb__img {
  border-radius: 100px;
}
.interviewThumb__item:last-child .interviewThumb__img {
  border-radius: 100px 0 0 100px;
}
.interviewThumb__item.--empty .interviewThumb__img {
  position: relative;
  background: none;
}
.interviewThumb__item.--empty .interviewThumb__img::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: #4E726F;
  position: absolute;
  top: 50%;
}

.interviewThumb__txt {
  align-items: center;
  padding: 0 1em;
}

.swiper-interview {
  padding: 20px 0 100px;
}
.swiper-interview .swiper-button-next,
.swiper-interview .swiper-button-prev {
  background: #F1EEDC;
}
.swiper-interview .swiper-button-next.swiper-button-disabled,
.swiper-interview .swiper-button-prev.swiper-button-disabled {
  opacity: 1;
  background: #e3e3e3;
}
.swiper-interview .interviewCard {
  width: 90%;
  max-width: 480px;
  height: auto;
}

@media screen and (max-width: 960px) {
  .interviewList {
    gap: 30px;
  }
  .interviewNum__num {
    font-size: 3.2rem;
  }
  .interviewCard__ttl {
    font-size: 2.8rem;
  }
  .interviewThumb__item {
    gap: 20px;
  }
}
@media screen and (max-width: 768px) {
  .interviewList {
    grid-template-columns: 1fr;
    padding: 60px 0;
  }
  .interviewNum__num {
    font-size: 2rem;
  }
  .interviewCard__ttl {
    font-size: 1.8rem;
    margin-top: 10px;
  }
  .interviewNum__txt {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 480px) {
  .secInterview {
    margin-bottom: -20px;
  }
  .secInterview::after {
    height: calc(100% - 20px);
  }
  .swiper-interview {
    padding-bottom: 70px;
  }
}
/* -------------------------------
   一覧ページ
------------------------------- */
#pageInterview {
  background: #F1EEDC;
}
#pageInterview .secContact::before {
  background: #F1EEDC;
}

.interviewLead {
  display: flex;
  justify-content: space-between;
  position: relative;
}
.interviewLead__left {
  width: 48%;
}
.interviewLead__right {
  width: 44%;
}

.interviewLead__ttl {
  font-size: max(2.5vw, 2.8rem);
  margin-left: -0.6em;
  margin-bottom: 3rem;
  padding-top: 1.2em;
}

.interviewLead__imgs {
  display: grid;
  grid-template-columns: 3;
  grid-template-rows: 2;
}
.interviewLead__imgs img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 20px;
}

.interviewImg01 {
  grid-column: 1/3;
}

.interviewImg02 {
  grid-column: 3/4;
}

.interviewImg03 {
  grid-column: 2/4;
  grid-row: 2/3;
}

@media screen and (max-width: 768px) {
  .interviewLead {
    flex-direction: column;
    row-gap: 30px;
    margin-top: 3rem;
  }
  .interviewLead__left, .interviewLead__right {
    width: 100%;
  }
  .interviewLead__ttl {
    font-size: 2.4rem;
  }
}
/* -------------------------------
   詳細ページ
------------------------------- */
.postInterviewHead {
  position: relative;
  padding-top: 5rem;
}

.postInterviewHead__inner {
  width: 94%;
  height: calc(15vw + 40vh);
  min-height: 300px;
  margin: 0 auto;
  aspect-ratio: 3/1;
  border-radius: 20px;
  overflow: hidden;
  display: flex;
}
.postInterviewHead__inner::after {
  content: "";
  display: block;
  width: 94%;
  height: 70%;
  background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.3));
  position: absolute;
  bottom: 0;
  border-radius: 20px;
}

.postInterviewHead__thumb {
  width: 50%;
  height: 100%;
  background: no-repeat center/cover;
  background-color: #4e726f;
}

.postInterviewHead__ttl {
  max-width: 80%;
  font-size: 3.2rem;
  color: #fff;
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
}

.postInterviewHead__num {
  font-size: 4rem;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  margin-bottom: 20px;
}
.postInterviewHead__num::after {
  content: "INTERVIEW";
  font-size: 0.35em;
}

.postInterviewBody {
  margin: 80px 0 50px;
}

@media screen and (max-width: 768px) {
  .postInterviewBody {
    margin-top: 50px;
  }
}
.interviewMember {
  display: flex;
  justify-content: space-between;
  margin-top: 50px;
}

.interviewMember__img {
  width: 100%;
  aspect-ratio: 2/1;
  background: #4E726F;
  overflow: hidden;
}
.interviewMember__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.interviewMember__item {
  width: 33.3333333333%;
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.interviewMember__item:first-child .interviewMember__img {
  border-radius: 10px 150px 150px 10px;
}
.interviewMember__item:nth-child(2) {
  text-align: center;
}
.interviewMember__item:nth-child(2) .interviewMember__img {
  border-radius: 150px;
}
.interviewMember__item:nth-child(2) .profile__detail {
  margin-left: auto;
  margin-right: auto;
}
.interviewMember__item:last-child {
  text-align: right;
}
.interviewMember__item:last-child .interviewMember__img {
  border-radius: 150px 10px 10px 150px;
}
.interviewMember__item:last-child .profile__detail {
  margin-left: auto;
}
.interviewMember__item.--empty .interviewMember__img {
  position: relative;
  background: none;
}
.interviewMember__item.--empty .interviewMember__img::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: #4E726F;
  position: absolute;
  top: 50%;
}

.profile {
  color: #4E726F;
}

.profile__job {
  font-size: 1.2rem;
  font-weight: 500;
}

.profile__name {
  font-size: 2.1rem;
  font-weight: 700;
  margin-top: 5px;
}

.profile__detail {
  max-width: 80%;
  font-size: 1.4rem;
  margin-top: 20px;
}
.profile__detail p {
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .interviewMember {
    flex-direction: column;
  }
  .interviewMember__img {
    width: 40%;
    max-width: 150px;
    aspect-ratio: initial;
    min-height: 140px;
  }
  .profile {
    flex: 1;
  }
  .profile__detail {
    max-width: 100%;
  }
  .profile__name {
    font-size: 1.8rem;
  }
  .interviewMember__item {
    width: 100%;
    flex-direction: row;
    gap: 20px;
  }
  .interviewMember__item.profile_nodata {
    display: none;
  }
  .interviewMember__item:first-child .interviewMember__img {
    border-radius: 0 0 100px 100px;
  }
  .interviewMember__item:nth-child(2) {
    text-align: left;
  }
  .interviewMember__item:nth-child(2) .interviewMember__img {
    border-radius: 100px;
  }
  .interviewMember__item:nth-child(2) .profile {
    padding: 20px 0;
  }
  .interviewMember__item:last-child {
    text-align: left;
  }
  .interviewMember__item:last-child .interviewMember__img {
    border-radius: 100px 100px 0 0;
  }
  .postInterviewHead {
    padding-top: 0;
  }
  .postInterviewHead__inner {
    width: 100%;
    aspect-ratio: 3/2;
    border-radius: 0;
  }
  .postInterviewHead__inner::after {
    width: 100%;
    border-radius: 0;
  }
  .postInterviewHead__ttl {
    font-size: 2.4rem;
  }
  .postInterviewHead__num {
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 480px) {
  .postInterviewHead__ttl {
    font-size: 2.1rem;
  }
  .postInterviewHead__num {
    font-size: 2.8rem;
  }
  .interviewMember__txt {
    font-size: 1.6rem;
  }
  .interviewMember__img {
    aspect-ratio: 1/1;
  }
  .interviewMember__item {
    gap: 20px;
  }
}
#postInterview .secContact::before {
  background: #F1EEDC;
}

#scrollTopBtn {
  width: 50px;
  aspect-ratio: 1/1;
  position: fixed;
  bottom: 15px;
  right: 15px;
  z-index: 90;
}

/* -------------------------------
   記事一覧（共通パーツ）
------------------------------- */
.caseItem {
  color: #fff;
  position: relative;
}

.caseItem__thumb {
  background: no-repeat center/cover;
  background-color: #4e726f;
  position: absolute;
  inset: 0;
  transition: all 0.25s;
}
.caseItem__thumb::before {
  content: "";
  display: block;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), transparent);
  position: absolute;
  inset: 0;
  transition: all 0.25s;
}

.caseItem__inner {
  aspect-ratio: 5/6;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  transition: all 0.25s;
}
.caseItem__inner:hover {
  opacity: 0.9;
}
.caseItem__inner:hover .caseItem__thumb {
  transform: scale(1.1);
}
.caseItem__inner:hover .caseItem__thumb::before {
  opacity: 0.85;
}

.caseItem__link {
  height: 100%;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  padding: 25px;
  padding-bottom: 40px;
  position: relative;
  z-index: 1;
}

.caseItem__ttl {
  font-size: min(4vw, 2.1rem);
  writing-mode: vertical-rl;
  text-orientation: upright;
}

.caseItem__num {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: min(7.5vw, 4rem);
}
.caseItem__num::before {
  content: "CASE";
  display: inline-block;
  font-size: 0.4em;
}

.caseItem__icons {
  position: absolute;
  bottom: -20px;
  right: 10px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.caseItem__icons img {
  width: 40px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  border: 2px solid #fff;
}
.caseItem__icons img:not(:last-child) {
  transform: translateX(10px);
}

@media screen and (max-width: 768px) {
  .caseItem__ttl {
    font-size: 2.1rem;
  }
  .caseItem__link {
    padding: 20px;
  }
  .caseItem__icons {
    bottom: -15px;
  }
  .caseItem__icons img {
    width: 30px;
  }
}
/* -------------------------------
   一覧ページ
------------------------------- */
#pageCase {
  background: #F1DABD;
}
#pageCase .secContact::before {
  background: #F1DABD;
}

.caseHead {
  height: calc(30dvh + 20dvw);
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  overflow: hidden;
}

.caseHead__ttl {
  width: 20%;
  min-width: 250px;
  position: absolute;
  top: 10%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}

.caseHead__bg {
  background: no-repeat center/cover;
  background-color: #4e726f;
  border-radius: 0 0 100px 100px;
  position: relative;
  overflow: hidden;
}
.caseHead__bg::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
}
.caseHead__bg.--bg01 {
  z-index: 1;
  width: 120%;
}
.caseHead__bg.--bg01::before {
  background: linear-gradient(to left, rgba(53, 116, 110, 0.5), rgba(28, 58, 55, 0) 40%, transparent);
  right: 0;
}
.caseHead__bg.--bg02 {
  grid-row: span 2;
}
.caseHead__bg.--bg02::before {
  background: linear-gradient(to right, rgba(53, 116, 110, 0.5), rgba(28, 58, 55, 0) 40%, transparent);
  left: 0;
}

.caseHead__contents {
  margin-top: 5rem;
  padding-right: 5rem;
  padding-left: 20%;
}
.caseHead__contents h2 {
  font-size: max(2.1vw, 3.2rem);
  margin-bottom: 0.8em;
}

@media screen and (max-width: 1280px) {
  .caseHead__contents {
    padding: 4rem 5%;
    margin: 0;
  }
}
@media screen and (max-width: 768px) {
  .caseHead {
    height: auto;
    display: flex;
    flex-wrap: wrap;
  }
  .caseHead__bg {
    border-radius: 0;
    width: 50%;
    height: 35dvh;
    min-height: 350px;
  }
  .caseHead__bg.--bg01 {
    width: 50%;
    transform: scale(1);
  }
  .caseHead__bg.--bg01::before {
    background: linear-gradient(to left, rgba(53, 116, 110, 0.5), rgba(28, 58, 55, 0) 70%, transparent);
  }
  .caseHead__bg.--bg02 {
    grid-row: inherit;
  }
  .caseHead__bg.--bg02::before {
    background: linear-gradient(to right, rgba(53, 116, 110, 0.5), rgba(28, 58, 55, 0) 70%, transparent);
  }
  .caseHead__contents {
    grid-column: span 2;
    position: relative;
    padding: 50px 7% 0;
  }
  .caseHead__contents::before {
    content: "";
    display: block;
    width: 110%;
    height: 60px;
    background: #F1DABD;
    border-radius: 50%;
    position: absolute;
    top: -20px;
    left: -5%;
    z-index: 1;
  }
  .caseHead__contents h2 {
    font-size: 2.8rem;
  }
  .caseHead__ttl {
    top: 12%;
    transform: translateX(-65%);
  }
}
#pageCase .caseList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: flex-start;
  -moz-column-gap: 65px;
       column-gap: 65px;
}
#pageCase .caseItem:nth-child(3n+2) {
  margin-top: 50px;
}
#pageCase .caseItem:nth-child(3n+3) {
  margin-top: 100px;
}

@media screen and (max-width: 1280px) {
  #pageCase .caseList {
    -moz-column-gap: 30px;
         column-gap: 30px;
  }
  #pageCase .caseItem:nth-child(3n+2) {
    margin-top: 30px;
  }
  #pageCase .caseItem:nth-child(3n+3) {
    margin-top: 60px;
  }
}
@media screen and (max-width: 768px) {
  #pageCase .caseList {
    grid-template-columns: repeat(2, 1fr);
    -moz-column-gap: 15px;
         column-gap: 15px;
  }
  #pageCase .caseItem:nth-child(3n+2) {
    margin-top: 0;
  }
  #pageCase .caseItem:nth-child(3n+3) {
    margin-top: 0;
  }
  #pageCase .caseItem:nth-child(2n) {
    margin-top: 40px;
  }
}
@media screen and (max-width: 480px) {
  #pageCase .caseList {
    grid-template-columns: 1fr;
  }
  #pageCase .caseItem {
    margin-bottom: 40px;
    width: 80%;
  }
  #pageCase .caseItem:nth-child(2n) {
    margin-top: 0;
  }
  #pageCase .caseItem:nth-child(2n) {
    justify-self: right;
  }
}
/* -------------------------------
   詳細ページ
------------------------------- */
#postCase {
  background: #F1DABD;
}

.postCaseHead {
  overflow: hidden;
}

.postCaseHead__bg {
  height: 90dvh;
  background: no-repeat center/cover;
  position: relative;
}
.postCaseHead__bg::after {
  content: "";
  display: block;
  width: 102%;
  aspect-ratio: 476/41;
  background: url("/cmn/img/pages/case/post_deco.png") no-repeat center/contain;
  position: absolute;
  left: -1%;
  bottom: -25px;
}
.postCaseHead__bg::before {
  content: "";
  display: block;
  width: 100%;
  height: 40%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.8));
}

.postCaseSummary {
  margin-top: calc(-7.6923076923vw - 120px);
  display: flex;
  justify-content: space-between;
  position: relative;
}

.postCaseSummary__thumb {
  background: no-repeat center/cover;
  border-radius: 20px;
  width: 40%;
}

.postCaseSummary__content {
  width: 55%;
}

.postCaseSummary__ttl {
  font-size: clamp(2.8rem, 2.5vw, 4.4rem);
  color: #fff;
  display: flex;
  align-items: center;
  margin-bottom: 3em;
}

.postCaseSummary__num {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: clamp(3rem, 7.5vw, 7rem);
  margin-right: 28px;
  padding-right: 28px;
  border-right: 1px solid #fff;
  flex-shrink: 0;
}
.postCaseSummary__num::before {
  content: "CASE";
  font-size: 0.4em;
}

.caseBody__inner:not(:first-child) {
  margin-top: 100px;
}

.caseBody__anchor {
  scroll-margin-top: 100px;
}

.caseBody__inner {
  display: flex;
  align-items: flex-start;
  gap: 60px;
  position: relative;
}

.caseBody__ttl {
  font-size: 2.1rem;
  text-orientation: upright;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 45px;
  flex-shrink: 0;
  position: sticky;
  top: 100px;
  z-index: 10;
}
.caseBody__ttl h2 {
  background: #fff;
  border-radius: 0 0 50px 50px;
  padding: 35px 25px;
  writing-mode: vertical-rl;
}

.caseBody__icons {
  display: flex;
}
.caseBody__icons img {
  width: 50px;
  aspect-ratio: 1/1;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50%;
}

.caseBody__content .unitBlock:not(:first-child) {
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  .postCaseHead__bg {
    height: 50dvh;
  }
  .postCaseHead__bg::after {
    width: 120%;
    left: -19%;
    bottom: -5px;
  }
  .caseBody__anchor {
    scroll-margin-top: 140px;
  }
  .postCaseSummary {
    margin-top: -25.2307692308vw;
    flex-direction: column-reverse;
    align-items: center;
    row-gap: 40px;
  }
  .postCaseSummary__thumb {
    width: 50%;
    aspect-ratio: 3/4;
    margin: 4rem auto 0;
  }
  .postCaseSummary__content {
    width: 100%;
  }
  .postCaseSummary__ttl {
    font-size: clamp(2rem, 4vw, 3.2rem);
  }
  .caseBody__inner {
    gap: 15px;
    flex-direction: column;
  }
  .caseBody__ttl {
    top: 113px;
    gap: 25px;
    margin-left: -6%;
  }
  .caseBody__ttl h2 {
    width: 85vw;
    writing-mode: inherit;
    text-orientation: inherit;
    padding: 15px 35px 15px 6%;
    border-radius: 0 0 30px 0;
  }
  .caseBody__icons {
    justify-content: right;
    gap: 5px;
  }
  .caseBody__icons img {
    width: 30px;
  }
}
.secProperty {
  background: #fff;
}

.secProperty__arrow {
  display: none;
  width: 40px;
  height: 20px;
  cursor: pointer;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  transition: background all 0.25s;
}
.secProperty__arrow::before, .secProperty__arrow::after {
  content: "";
  display: inline-block;
  width: 50%;
  height: 2px;
  background: #000;
  position: absolute;
  top: 50%;
}
.secProperty__arrow::before {
  left: 2px;
  transform: rotate(30deg);
}
.secProperty__arrow::after {
  right: 2px;
  transform: rotate(-30deg);
}
.secProperty__arrow:hover::before, .secProperty__arrow:hover::after {
  background: #4E726F;
}
.secProperty__arrow.close {
  transform: translate(-50%) scale(1, -1);
}

.secProperty__list {
  margin-top: 7.2rem;
}

.secProperty__list.more::after {
  content: "";
  display: block;
  width: 100%;
  height: 350px;
  background: linear-gradient(to bottom, transparent 0, rgba(255, 255, 255, 0.7) 50%, #fff 100%);
  position: absolute;
  bottom: 0;
}
.secProperty__list.more .secProperty__arrow {
  display: block;
}

.secProperty__list.close::after {
  display: none;
}

.caseInterview {
  background: #fff;
}
.caseInterview .mySwiper {
  margin-top: 3rem;
}
.caseInterview .interviewCard__link {
  outline-color: rgba(78, 114, 111, 0.2);
}
.caseInterview .interviewCard__link:hover {
  outline-color: #4E726F;
}
.caseInterview .swiper-button-next,
.caseInterview .swiper-button-prev {
  background: #fff;
}

/* -------------------------------
   ヘッダー
------------------------------- */
.supportHeader {
  color: #4E726F;
  background: rgba(78, 114, 111, 0.1);
  padding: 70px 0;
}

.supportHeader__inner {
  font-size: 6.4rem;
  font-weight: 700;
}

.supportHeader__ttl {
  font-size: max(0.33em, 14px);
  margin-top: 5px;
}

@media screen and (max-width: 768px) {
  .supportHeader {
    padding: 40px 0;
  }
  .supportHeader__inner {
    font-size: 4rem;
  }
}
/* -------------------------------
   サブナビ
------------------------------- */
.supportNavi .subNavi::after {
  display: none;
}

@media screen and (min-width: 769px) {
  .supportNavi {
    position: relative;
  }
  .supportNavi .subNavi {
    width: auto;
    position: absolute;
    top: 0;
    right: 0;
  }
}
@media screen and (max-width: 768px) {
  .supportNavi {
    width: 100% !important;
  }
}
/* -------------------------------
   index
------------------------------- */
.supportIdx {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  overflow: hidden;
}

.supportIdx__thumb {
  background: no-repeat center/cover;
  width: 50%;
}

.supportIdx__inner {
  width: 50%;
  color: #fff;
  background: #4E726F;
  padding: 100px 10%;
}

.supportIdx__ttl {
  display: flex;
  flex-direction: column;
  font-size: max(3.4vw, 6.4rem);
}
.supportIdx__ttl small {
  font-size: 2.1rem;
}

.supportIdx__list {
  font-weight: 500;
  margin-top: 7rem;
}
.supportIdx__list li {
  padding-left: 18px;
  text-indent: -18px;
}
.supportIdx__list li + li {
  margin-top: 1em;
}
.supportIdx__list li::before {
  content: "";
  display: inline-block;
  width: 13px;
  aspect-ratio: 7/5;
  background: url("../img/icon/check.png") no-repeat center/contain;
  margin-right: 5px;
}

.supportIdx__deco {
  width: 200px;
  aspect-ratio: 1/1;
  background: no-repeat center/contain;
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
}

.supportIdxList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
}

.supportIdxItem a {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
}
.supportIdxItem a:hover {
  border-color: #4E726F;
  color: #4E726F;
  background: #fafafa;
  border-color: #4E726F;
}
.supportIdxItem a:hover .supportIdxItem__btn {
  border-color: #4E726F;
}
.supportIdxItem a:hover .supportIdxItem__btn::after {
  border-color: #4E726F;
  margin-right: -4px;
}

.supportIdxItem__inner {
  padding: 2.5rem;
}

.supportIdxItem__ttl {
  font-size: 3rem;
  display: flex;
  flex-direction: column;
  margin-bottom: 1em;
}
.supportIdxItem__ttl small {
  font-size: 1.2rem;
  display: block;
  margin-top: 5px;
}

.supportIdxItem__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 700;
  gap: 20px;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  padding: 2.5rem;
  transition: border all 0.25s;
}
.supportIdxItem__btn::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
  flex-shrink: 0;
  transition: all 0.25s;
}

.supportFront {
  margin-top: 3rem;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  padding: 2.5rem;
}

.supportFront__ttl {
  font-size: 3rem;
  display: flex;
  flex-direction: column;
  margin-bottom: 1.5em;
}
.supportFront__ttl small {
  font-size: 1.2rem;
  display: block;
  margin-top: 5px;
}

.supportFront__row {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  padding: 1.5em;
}
.supportFront__row dt {
  width: 8em;
  flex-direction: 0;
  font-weight: 400;
}

@media screen and (max-width: 1280px) {
  .supportIdx__inner {
    padding: 70px 50px;
  }
}
@media screen and (max-width: 768px) {
  .supportIdx {
    flex-direction: column-reverse;
  }
  .supportIdx__inner {
    width: 100%;
    padding: 50px 6%;
  }
  .supportIdx__thumb {
    width: 100%;
    height: 30dvh;
  }
  .supportIdx__ttl {
    font-size: 3.6rem;
  }
  .supportIdx__ttl small {
    font-size: 1.4rem;
  }
  .supportIdx__list {
    margin-top: 5rem;
  }
  .supportIdxList {
    grid-template-columns: 1fr;
  }
  .supportFront__ttl,
  .supportIdxItem__ttl {
    font-size: 2.4rem;
  }
  .supportIdx__deco {
    width: 120px;
    right: 5%;
    top: 35%;
    transform: translate(0);
    left: auto;
  }
  .supportFront__row {
    padding: 1em;
  }
}
/* -------------------------------
   FAQ
------------------------------- */
.faq__item {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
}
.faq__item:not(:first-child) {
  margin-top: 4rem;
}
.faq__item a {
  line-height: 1.3;
  text-decoration: underline;
}
.faq__item a:hover {
  opacity: 0.8;
}

.question {
  padding: 3.6rem;
  display: flex;
  align-items: flex-start;
}
.question::before {
  content: "Q";
  font-size: 6.4rem;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
  margin-right: 0.5em;
}

.question__ttl {
  font-size: 2.8rem;
  margin-bottom: 0.8em;
}

.question__tag {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.question__tag span {
  display: inline-block;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.2);
  padding: 3px 10px;
  border-radius: 4px;
}

.answer {
  padding: 3.6rem;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: flex-start;
}
.answer::before {
  content: "A";
  font-size: 6.4rem;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
  margin-right: 0.5em;
}

@media screen and (max-width: 768px) {
  .question,
  .answer {
    flex-direction: column;
    padding: 2rem;
  }
  .question::before {
    font-size: 3.6rem;
    margin-right: 0;
    margin-bottom: 8px;
  }
  .answer::before {
    content: "";
  }
  .question__ttl {
    font-size: 2.4rem;
  }
}
/* -------------------------------
   お問い合わせ
------------------------------- */
.contactLead {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5rem;
  container-type: inline-size;
}

.contactLead__ttl {
  font-size: 3.2cqw;
}

.contactList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 7rem;
  gap: 3rem;
}

.contactItem {
  padding: 4rem;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  align-items: flex-end;
  gap: 3rem;
}

.contactItem__ttl {
  font-size: 3.2rem;
  align-self: flex-start;
}

.contactItem__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 700;
  gap: 20px;
  border-radius: 5px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  padding: 1.5em;
  transition: all 0.25s;
}
.contactItem__link::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
  flex-shrink: 0;
}
.contactItem__link:hover {
  border-color: #4E726F;
  color: #4E726F;
  background: #fafafa;
}
.contactItem__link:hover::after {
  border-color: #4E726F;
}

@media screen and (max-width: 768px) {
  .contactLead,
  .contactList {
    grid-template-columns: 1fr;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }
  .contactLead {
    gap: 2.1rem;
  }
  .contactLead__ttl {
    font-size: 2.1rem;
  }
  .contactList {
    margin-top: 4rem;
  }
  .contactItem {
    padding: 2.5rem;
    gap: 20px;
  }
  .contactItem__ttl {
    font-size: 2.1rem;
  }
  .contactItem__link {
    padding: 1.2em;
  }
}
/* -------------------------------
   空き家に関するお問い合わせ先
------------------------------- */
.contactTable {
  width: 100%;
  min-width: 700px;
  margin-top: 7rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

.contactTable__row {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.contactTable__row td {
  padding: 1.5em 1em;
  line-height: 1.5;
  vertical-align: middle;
}
.contactTable__row a:hover {
  color: #4E726F;
  opacity: 0.8;
  text-decoration: underline;
}

.contactTable__area {
  width: 30%;
}
.contactTable__name {
  width: 40%;
}
.contactTable__tel {
  width: 20%;
}
.contactTable__link {
  width: 10%;
}
.contactTable__link a::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 15px;
  background: url("/cmn/img/icon/link.png") no-repeat center/contain;
  flex-shrink: 0;
  margin-left: 1em;
}

/* -------------------------------
   補助金情報
------------------------------- */
.subsidyWrapper {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
}

.subsidyThumb {
  background: no-repeat center/cover;
  background-color: #ccc;
  border-radius: 10px;
  aspect-ratio: 3/2;
}

.subsidyTtl {
  font-size: 2.1rem;
  margin: 1.5em 0 0.5em;
}

.subsidyFilter {
  width: 290px;
  font-size: 1.4rem;
  margin-right: 90px;
  flex-shrink: 0;
  position: relative;
}

.subsidyFilter__head {
  font-size: 2.1rem;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 3px solid #4E726F;
}

.subsidyFilter__ttl {
  color: #4E726F;
  display: flex;
  align-items: center;
}
.subsidyFilter__ttl::before {
  content: "";
  display: inline-block;
  width: 1.5em;
  margin-right: 0.5em;
  aspect-ratio: 37/35;
  background: url("/cmn/img/icon/sort_gr.png") no-repeat center/contain;
  flex-shrink: 0;
}

.subsidyFilter__clear {
  margin-top: 50px;
  margin-bottom: 20px;
  text-align: center;
}
.subsidyFilter__clear a {
  display: block;
  width: 100%;
  background: #fff;
  border-radius: 50px;
  padding: 1.5em 2em;
  border: 1px solid rgba(0, 0, 0, 0.2);
  transition: all 0.25s;
}
.subsidyFilter__clear a:hover {
  border-color: #000;
  opacity: 0.9;
}

.subsidyFilter__submit {
  text-align: center;
  font-weight: 700;
  position: fixed;
  bottom: 30px;
  z-index: 100;
}
.subsidyFilter__submit input[type=submit] {
  display: block;
  width: 290px;
  color: #fff;
  background: #21BAAB;
  border-radius: 50px;
  padding: 1.5em 3em 1.5em 2em;
  transition: all 0.25s;
}
.subsidyFilter__submit::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  right: 20px;
  top: calc(50% - 5px);
  transition: all 0.25s;
}
.subsidyFilter__submit:hover input {
  background: #4E726F;
}
.subsidyFilter__submit:hover::after {
  right: 17px;
}

.subsidyResult {
  margin-top: 20px;
}
.subsidyResult a {
  display: flex;
  flex-direction: column;
  gap: 20px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  padding: 30px;
  padding-right: 50px;
  position: relative;
}
.subsidyResult a::after {
  content: "";
  display: inline-block;
  width: 10px;
  aspect-ratio: 1/1;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  position: absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  transition: all 0.25s;
}
.subsidyResult a:hover {
  color: #4E726F;
  border-color: #4E726F;
}
.subsidyResult a:hover::after {
  border-color: #4E726F;
  right: 18px;
}

.subsidyResult__ttl {
  font-size: 2.1rem;
}

.subsidyResult__detail {
  display: flex;
  flex-direction: column;
}

@media screen and (max-width: 768px) {
  #pageSubsidy .footer {
    margin-bottom: 60px;
  }
  .subsidyWrapper {
    display: block;
  }
  .subsidyThumb {
    aspect-ratio: 3/1;
  }
  .subsidyFilter {
    width: 100%;
    margin-top: 5rem;
  }
  .subsidyFilter__btns {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 10;
    padding: 15px 10px;
    margin-top: 40px;
    background: linear-gradient(to bottom, transparent, #fff);
  }
  .subsidyFilter__clear {
    margin: 0;
  }
  .subsidyFilter__submit {
    position: static;
  }
  .subsidyFilter__submit input[type=submit] {
    width: auto;
  }
}
/* -------------------------------
   補助金 詳細ページ
------------------------------- */
.postSubsidyBody {
  margin-top: 4rem;
}

.postSubsidyBody__box {
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.2);
}

.postSubsidyBody__ttl {
  padding: 50px;
}
.postSubsidyBody__ttl h2 {
  font-size: 2.1rem;
  margin-bottom: 1.5em;
}

.postSubsidyBody__content {
  padding: 50px;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.postSubsidyBody__content p + p {
  margin-top: 1em;
}

.postSubsidyBody__notice {
  margin-top: 40px;
}
.postSubsidyBody__notice p + p {
  margin-top: 1em;
}

.postSubsidyBody__link {
  line-height: 1.5;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 8px;
  padding: 1.5em;
  margin-top: 2rem;
}
.postSubsidyBody__link::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 15px;
  background: url("/cmn/img/icon/link.png") no-repeat center/contain;
  flex-shrink: 0;
}

#postSubsidy .sortResult,
#pageSubsidySearched .sortResult {
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  #postSubsidy .subsidyFilter,
  #pageSubsidySearched .subsidyFilter {
    display: none;
  }
  .postSubsidyBody__ttl {
    padding: 25px;
  }
  .postSubsidyBody__content {
    padding: 25px;
  }
}
/* -------------------------------
   記事一覧
------------------------------- */
.topicsHeader {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  row-gap: 30px;
  flex-wrap: wrap;
  margin-bottom: 70px;
}

.topicsHeader__inner {
  font-size: 6.4rem;
  font-weight: 700;
}

.topicsHeader__ttl {
  font-size: max(0.33em, 14px);
  margin-top: 5px;
}

.topicsHeader .subNavi {
  justify-content: left;
  width: auto;
  margin: 0;
}
.topicsHeader .subNavi::after {
  display: none;
}

@media screen and (max-width: 768px) {
  .topicsHeader {
    margin-bottom: 30px;
  }
  .topicsHeader .subNavi {
    box-shadow: 0 10px 40px 0 rgba(0, 0, 0, 0.06);
    border: none;
    width: 100%;
    max-width: 350px;
  }
  .topicsHeader__inner {
    font-size: 4rem;
  }
}
.topicItem {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

.topicItem__link {
  display: flex;
  align-items: center;
  padding: 40px;
  padding-left: 0;
  gap: 30px;
  position: relative;
}
.topicItem__link::after {
  content: "";
  display: block;
  width: 10px;
  aspect-ratio: 1/1;
  border-top: 2px solid rgba(0, 0, 0, 0.2);
  border-right: 2px solid rgba(0, 0, 0, 0.2);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 15px;
  transition: all 0.25s;
}
.topicItem__link:hover {
  color: #4E726F;
}
.topicItem__link:hover::after {
  border-top: 2px solid #4E726F;
  border-right: 2px solid #4E726F;
  right: 12px;
}

.topicItem__thumb {
  width: 160px;
  aspect-ratio: 4/3;
  border-radius: 10px;
  background: no-repeat center/cover;
  flex-shrink: 0;
}

.topicItem__ttl {
  font-size: 2.1rem;
  margin-bottom: 1em;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.topicItem__txt {
  line-height: 1.4;
}

@media screen and (max-width: 768px) {
  .topicItem {
    font-size: 1.2rem;
  }
  .topicItem__thumb {
    width: 90px;
    aspect-ratio: 4/3;
  }
  .topicItem__link {
    gap: 20px;
    padding: 30px 20px;
    padding-left: 0;
  }
  .topicItem__link::after {
    width: 8px;
    right: 0;
  }
  .topicItem__link:hover::after {
    right: 0;
  }
  .topicItem__ttl {
    font-size: 1.6rem;
  }
}
/* -------------------------------
   詳細ページ
------------------------------- */
.postTopicsHead {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 40px;
       column-gap: 40px;
  row-gap: 20px;
  padding-bottom: 70px;
  margin-bottom: 70px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

.postTopicsHead__ttl {
  font-size: min(3vw, 3.6rem);
}

.postTopicsHead__cat {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  -moz-column-gap: 20px;
       column-gap: 20px;
  row-gap: 10px;
  margin-top: 30px;
}
.postTopicsHead__cat a {
  display: inline-block;
  font-size: 1.2rem;
  color: #707070;
  border: 1px solid #707070;
  padding: 1.2em 1.5em;
  border-radius: 30px;
}
.postTopicsHead__cat a:hover {
  color: #fff;
  background: #4E726F;
}

.postTopicsHead__thumb {
  aspect-ratio: 4/3;
  background: no-repeat center/cover;
  border-radius: 10px;
}

.postTopicsBody {
  width: 90%;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .postTopicsHead {
    grid-template-columns: 1fr;
    padding-bottom: 50px;
    margin-bottom: 50px;
  }
  .postTopicsHead__ttl {
    font-size: max(3.5vw, 2.1rem);
  }
  .postTopicsHead__cat {
    margin-top: 20px;
  }
  .postTopicsHead__cat a {
    padding: 1em 1.5em;
  }
  .postTopicsBody {
    width: 100%;
  }
}

/*# sourceMappingURL=styles.css.map */