@charset "UTF-8";
/* FONTS */
/* COLORS */
/* BREAKPOINTS */
/* @include circle(100px); */
/*
 * Mixin for placeholder
 * @include placeholderColor(#00ff00);
 */
/* @include absPosition(5px,20x,10px,15px); */
/* @include css3(transition, 0.5s); */
/* @include opacity(0.5); */
/* @include fontsize(12); */
/*	clearfix
================================================== */
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@400;500;700&family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300..700;1,300..700&family=Sawarabi+Mincho&display=swap");
:root {
  --font-Noto-Sans-JP: YakuHanJP, "Noto Sans JP", "Outfit", "Helvetica Neue", Helvetica, "Avenir", 'Noto Sans JP', 'Nunito Sans', 'Open Sans', "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  --black-color: #000;
  /* font scale */
  --fs-xs: clamp(1.06667rem, 0.83333vw, 1.6rem);
  --fs-sm: clamp(1.2rem, 0.9375vw, 1.8rem);
  --fs-md: clamp(1.33333rem, 1.04167vw, 2rem);
  --fs-lg: clamp(1.66667rem, 1.30208vw, 2.5rem);
  --fs-mlg: clamp(2rem, 1.52vw, 3rem);
  --fs-xl: clamp(2.66667rem, 2.08333vw, 4rem);
  --fs-xxl: clamp(4.66667rem, 3.64583vw, 7rem);
  --fs-xxxl: clamp(6.4032rem, 5vw, 9.6rem);
  --fs-xxxxl: clamp(8rem, 6.25vw, 12rem);
  /* spacing scale */
  --space-xs: clamp(0.4rem, 0.5vw, 0.8rem);
  --space-sm: clamp(0.8rem, 0.8vw, 1.2rem);
  --space-s16: clamp(1.06667rem, 0.83333vw, 1.6rem);
  --space-s24: clamp(1.6rem, 1.25vw, 2.4rem);
  --space-md: clamp(1.2rem, 1vw, 2rem);
  --space-lg: clamp(2rem, 1.5vw, 2.8rem);
  --space-s54: clamp(3.6rem, 2.8125vw, 5.4rem);
  --space-s72: clamp(4.8rem, 3.75vw, 7.2rem);
  --space-s120: clamp(8rem, 6.25vw, 12rem);
}

p {
  margin-top: 0;
}

.f-mp {
  font-family: 'M PLUS Rounded 1c', sans-serif;
}

.lang-en {
  font-family: 'Baskervville', serif;
}

ul,
dl,
ol {
  list-style: none;
  padding: 0;
}

input::placeholder,
textarea::placeholder {
  color: #ccc;
}

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

/* IE */
input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
  color: #ccc;
}

/* Edge */
input::-ms-input-placeholder,
textarea::-ms-input-placeholder {
  color: #ccc;
}

@-ms-viewport {
  width: auto;
  initial-scale: 1;
}
html {
  -ms-overflow-style: scrollbar;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 76px;
}

@media (min-width: 960px) {
  html {
    scroll-padding-top: 0;
  }
}
.cf:before,
.cf:after {
  content: " ";
  display: table;
}

.cf:after {
  clear: both;
}

.cf {
  *zoom: 1;
}

.pc-display {
  display: none;
}

.sp-display {
  display: block;
}

@media (min-width: 959px) {
  .pc-display {
    display: block !important;
  }

  .sp-display {
    display: none !important;
  }
}
html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  color: #000;
  letter-spacing: 0.01em;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}

html {
  font-size: 10px;
}

body {
  width: 100%;
  background-color: #F0EEE6;
  font-family: var(--font-Noto-Sans-JP);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: .05em;
  color: var(--black-color);
  -webkit-font-feature-settings: 'palt';
  font-feature-settings: 'palt';
  -webkit-text-size-adjust: 100%;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
  overscroll-behavior-y: none;
  position: relative;
  overflow-x: hidden;
}

.sprite {
  display: block;
  text-indent: -9999px;
  overflow: hidden;
}

*,
html {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

a::after,
a::before {
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

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

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: auto auto 24px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

@keyframes text-fade {
  0%,
    20% {
    opacity: 0;
    transform: translateY(40px);
  }
  40%,
    100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/* アニメーション定義 */
@keyframes FadeOut {
  0%,
    20% {
    opacity: 1;
  }
  40%,
    98% {
    opacity: 0;
  }
  98%,
    100% {
    z-index: -1;
    visibility: hidden;
    opacity: 0;
  }
}
@keyframes FadeIn {
  0%,
    20% {
    opacity: 0;
    transform: translateY(100px);
  }
  /* 少し下から */
  40%,
    100% {
    opacity: 1;
    transform: translateY(0);
  }
}
h1,
h2,
h3,
h4 {
  font-weight: bold;
}

h2 {
  font-size: 3.4rem;
}

@media screen and (max-width: 767px) {
  h2 {
    font-size: 2rem;
  }

  h3 {
    font-size: 1.8rem;
  }
}
h1,
h2,
h3,
h4,
p {
  color: var(--color-black);
}

p {
  font-size: 1.8rem;
  line-height: 1.9;
  font-weight: 400;
  font-feature-settings: "palt";
  color: var(--color-black);
}

@media screen and (max-width: 767px) {
  p {
    font-size: 1.6rem;
  }
}
a.blank svg {
  transform: rotate(-45deg);
}

p a {
  text-decoration: underline;
}

/* ==============================================
   Layout (l-)
   ============================================== */
.l-footer {
  background-color: #545454;
  /* ダークグレーの背景色 */
  color: #ffffff;
  /* 基本の文字色は白 */
  padding: 60px 0 40px;
  /* 上下の余白 */
}

.l-container {
  max-width: 1280px;
  /* 水色のガイドラインの内側の幅（デザインに合わせて調整） */
  margin: 0 auto;
  padding: 0 20px;
  /* スマホなどで画面端にくっつかないための余白 */
}

@media (max-width: 768px) {
  .l-footer {
    background-color: #545454;
    /* ダークグレーの背景色 */
    color: #ffffff;
    /* 基本の文字色は白 */
    padding: 3.2rem 0 2.4rem;
    /* 上下の余白 */
  }

  .l-container {
    max-width: 100%;
    /* 水色のガイドラインの内側の幅（デザインに合わせて調整） */
    padding: 0 1.6rem;
    /* スマホなどで画面端にくっつかないための余白 */
  }
}
.p-hero__under,
.p-concept,
.p-news,
.p-about,
.p-flow,
.p-voice {
  padding: 12rem 0;
}

@media (max-width: 768px) {
  .p-hero__under,
  .p-concept,
  .p-news,
  .p-about {
    padding: 6.4rem 0;
  }
}
.c-mv__container {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background-color: #F0EEE6;
  background-image: url(../img/common/dot.svg);
  background-repeat: repeat;
}
.c-mv__container:before, .c-mv__container:after {
  content: '';
  width: 20rem;
  aspect-ratio: 260 / 277;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}
.c-mv__container:before {
  background: url(../img/common/visual-bg-right.png) no-repeat center/contain;
  transform: translateX(-25vw);
}
.c-mv__container:after {
  background: url(../img/common/visual-bg-left.png) no-repeat center/contain;
  transform: translateX(25vw);
}

@media screen and (max-width: 767px) {
  .c-mv__container:before, .c-mv__container:after {
    content: '';
    width: 10rem;
    aspect-ratio: 260 / 277;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
  }
  .c-mv__container:before {
    background: url(../img/common/visual-bg-right.png) no-repeat center/contain;
    transform: translateX(-35vw);
  }
  .c-mv__container:after {
    background: url(../img/common/visual-bg-left.png) no-repeat center/contain;
    transform: translateX(35vw);
  }
}
.c-section-inner {
  width: 100%;
  max-width: 100rem;
  margin: auto;
  position: relative;
}

.split-layout {
  display: flex;
}

.l-main {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: url(../assets/images/bg-img.jpg) repeat 0 0;
  background-size: contain;
  position: relative;
  z-index: 9;
  padding-bottom: 12rem;
}

.l-main-page {
  background: #fff;
}

.l-inner {
  max-width: 154rem;
  width: 90vw;
  margin: auto;
  padding: 0 4rem;
}

@media (max-width: 768px) {
  .l-inner {
    width: 100%;
    padding: 0 1.6rem;
  }
}
.l-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: white;
}
.l-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100px;
}
.l-header__logo {
  background: url(../assets/images/logo.svg) no-repeat 0 0;
  width: 249px;
  height: 35px;
  text-indent: -9999px;
}
.l-header__nav-list {
  display: flex;
  align-items: center;
  gap: 2.8rem;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 1.6rem;
}
.l-header__nav-list a {
  color: #333;
  text-decoration: none;
}
.l-header__nav-list a.c-btn {
  color: #fff;
}

@media (max-width: 768px) {
  .l-header {
    position: sticky;
    top: 0;
    width: 100%;
  }
  .l-header__inner {
    height: 7.6rem;
  }
  .l-header__logo {
    background: url(../assets/images/logo.svg) no-repeat 0 0;
    width: calc(249px / 2);
    height: calc(35px / 2);
    text-indent: -9999px;
    margin: auto;
  }

  .p-search-box__form {
    grid-template-columns: 1fr;
  }

  .l-split,
  .p-company .l-split {
    grid-template-columns: 1fr;
  }

  .p-properties__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
  /* SIDE
============================================*/
.l-side-menu {
  width: 50vw;
  height: 100vh;
  position: fixed;
  right: -50vw;
  top: 0;
  display: block;
  background: #fff;
  transition: all .3s ease;
  z-index: 900;
}
.l-side-menu .l-side-menu__inner {
  width: 100%;
  height: 100%;
  display: flex;
}
.l-side-menu .l-side-menu__inner ul {
  margin: auto;
  flex-direction: column;
  width: 100%;
}
.l-side-menu .l-side-menu__inner ul li {
  font-size: 1.5rem;
  margin: auto auto 2.4rem;
  width: 100%;
  font-weight: 700;
  text-align: center;
}
.l-side-menu .l-side-menu__inner ul li a {
  text-align: center;
}
.l-side-menu .l-side-menu__inner ul li a.c-btn {
  width: 100%;
}
.l-side-menu .l-side-menu__inner ul li a:not(.c-btn) {
  color: #000;
}

.active .l-side-menu,
.active .search-content {
  right: 0;
  opacity: 1;
  z-index: 8000;
}

.active .l-side-menu ul li a {
  animation: fi .5s;
  -webkit-animation: fi .5s;
  /* Safari & Chrome */
  animation-delay: .3s;
  animation-fill-mode: forwards;
  -webkit-animation-fill-mode: forwards;
}

@media (max-width: 767px) {
  .l-side-menu {
    position: fixed;
    width: 100vw;
    height: 100vh;
    display: block;
    overflow-y: scroll;
    top: 0;
    left: 0;
    background: #fff;
    opacity: 0;
    z-index: -1;
    padding: 88px 16px;
  }
}
.c-button--contact {
  display: block;
  width: 100%;
  background-color: #555;
  color: #fff;
  text-align: center;
  padding: 15px;
  font-weight: bold;
  border-radius: 4px;
}

/* ==============================================
   Component (c-)
   ============================================== */
.c-button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.c-button.c-button__l {
  background: #20006e;
  color: #fff;
  width: 100%;
  max-width: 60rem;
  height: 6rem;
  margin: auto;
}
.c-button.c-button--contact {
  max-width: 50rem;
  font-size: clamp(1.4rem, 1.1vw, 2rem);
}

.c-button:hover {
  opacity: 0.8;
}

@media (max-width: 768px) {
  .c-button {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    cursor: pointer;
    transition: opacity 0.3s ease;
  }
  .c-button.c-button__l {
    background: #20006e;
    color: #fff;
    width: 100%;
    max-width: 100%;
    height: 4.8rem;
    margin: auto;
  }
  .c-button.c-button--contact {
    max-width: 100%;
    font-size: 1.5rem;
  }
}
.c-title {
  position: relative;
  margin: auto auto clamp(6.8rem, 5vw, 10rem);
  height: clamp(9.8rem, 7vw, 13.6rem);
}
.c-title h2 {
  font-size: clamp(2.8rem, 2vw, 4rem);
  color: #20006e;
  display: inline;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
}
.c-title span {
  font-size: clamp(9.8rem, 7vw, 13.6rem);
  color: rgba(0, 0, 0, 0.1);
  font-weight: 700;
  position: absolute;
  top: 40%;
  left: -5px;
  transform: translateY(-50%);
  z-index: 0;
  white-space: nowrap;
  pointer-events: none;
  letter-spacing: -.05em;
}

.c-section-title--small {
  color: #1a005e;
  /* ネイビー系 */
  font-size: 1.25rem;
  border-bottom: 2px solid #ccc;
  padding-bottom: 8px;
  margin-bottom: 16px;
}

@media (max-width: 768px) {
  .c-title {
    position: relative;
    margin: auto auto 3.2rem;
    height: 4.8rem;
  }
  .c-title h2 {
    font-size: 2rem;
    margin: .6rem auto auto auto;
  }
  .c-title span {
    font-size: 4.8rem;
    top: 40%;
    left: -5px;
    transform: translateY(-50%);
    z-index: 0;
    white-space: nowrap;
    pointer-events: none;
    letter-spacing: -.05em;
  }

  .c-section-title--small {
    color: #1a005e;
    /* ネイビー系 */
    font-size: 1.25rem;
    border-bottom: 2px solid #ccc;
    padding-bottom: 8px;
    margin-bottom: 16px;
  }
}
.c-search-box {
  background: rgba(255, 255, 255, 0.9);
  color: #222;
  border-radius: 8px;
  margin: auto auto 2.4rem;
}
.c-search-box__form {
  display: grid;
  grid-template-columns: repeat(3, 1fr) auto;
  gap: 10px;
}
.c-search-box select,
.c-search-box input {
  width: 100%;
  padding: 16px;
  border: 1px solid #f5f5f5;
  border-radius: .4rem;
  background: #fff;
  font-size: 1.8rem;
  font-weight: 700;
}

@media (max-width: 768px) {
  .c-search-box {
    border-radius: 4px;
    margin: auto auto 1.6rem;
  }
  .c-search-box__form {
    display: grid;
    grid-template-columns: repeat(2, 1fr) auto;
    gap: .8rem;
  }
  .c-search-box select,
  .c-search-box input {
    width: 100%;
    padding: .8rem;
    border: 1px solid #f5f5f5;
    border-radius: .4rem;
    background: #fff;
    font-size: 1.5rem;
    font-weight: 700;
  }
}
.c-search__nav {
  background: #fff;
  border-radius: .8rem;
}

@media (max-width: 768px) {
  .c-search__nav {
    border-radius: .4rem;
  }
}
.c-search__nav-tab {
  display: flex;
  width: 100%;
}
.c-search__nav-tab button {
  padding: 2.4rem;
  position: relative;
  width: 50%;
  text-align: center;
  font-size: 2rem;
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  appearance: none;
}
.c-search__nav-tab button.is-active::after {
  height: .8rem;
  width: 100%;
  background: #20006e;
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

@media (max-width: 768px) {
  .c-search__nav-tab {
    display: flex;
    width: 100%;
  }
  .c-search__nav-tab button {
    padding: 2.4rem 1.6rem 1.6rem 1.6rem;
    width: 50%;
    font-size: 1.5rem;
  }
  .c-search__nav-tab button.is-active::after {
    height: .8rem;
    width: 100%;
    background: #20006e;
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
  }
}
.c-search__nav-list {
  padding: 2.4rem;
}

@media (max-width: 768px) {
  .c-search__nav-list {
    padding: 1.6rem;
  }
}
.c-search__nav-list-inner {
  width: 100%;
  display: flex;
  justify-content: space-between;
}

@media (max-width: 768px) {
  .c-search__nav-list-inner {
    flex-wrap: wrap;
    gap: .8rem 0;
  }
}
.c-search__nav-item {
  background: #545454;
  width: 24%;
}
.c-search__nav-item[data-icon="pet"] a::before {
  background: url(../assets/images/pet-w.svg) no-repeat center center;
  background-size: cover;
  width: 2.7rem;
  height: 2.4rem;
}
.c-search__nav-item[data-icon="pin"] a::before {
  background: url(../assets/images/pin-w.svg) no-repeat center center;
  background-size: cover;
  width: 2.3rem;
  height: 2.7rem;
}
.c-search__nav-item[data-icon="train"] a::before {
  background: url(../assets/images/train-w.svg) no-repeat center center;
  background-size: cover;
  width: 2.3rem;
  height: 2.7rem;
}
.c-search__nav-item[data-icon="yen"] a::before {
  background: url(../assets/images/yen-w.svg) no-repeat center center;
  background-size: cover;
  width: 2.7rem;
  height: 2.7rem;
}
.c-search__nav-item a {
  position: relative;
  width: 100%;
  height: 100%;
  display: block;
  color: #fff;
  font-weight: 700;
  padding: 1.6rem;
  font-size: 1.6rem;
  text-align: center;
}
.c-search__nav-item a::before {
  content: '';
  display: block;
  position: absolute;
  left: 1.6rem;
  top: 1.6rem;
}

@media (max-width: 768px) {
  .c-search__nav-item {
    background: #545454;
    width: 100%;
  }
  .c-search__nav-item[data-icon="pet"] a::before {
    background: url(../assets/images/pet-w.svg) no-repeat center center;
    background-size: cover;
    width: 2.7rem;
    height: 2.4rem;
  }
  .c-search__nav-item[data-icon="pin"] a::before {
    background: url(../assets/images/pin-w.svg) no-repeat center center;
    background-size: cover;
    width: 2.3rem;
    height: 2.7rem;
  }
  .c-search__nav-item[data-icon="train"] a::before {
    background: url(../assets/images/train-w.svg) no-repeat center center;
    background-size: cover;
    width: 2.3rem;
    height: 2.7rem;
  }
  .c-search__nav-item[data-icon="yen"] a::before {
    background: url(../assets/images/yen-w.svg) no-repeat center center;
    background-size: cover;
    width: 2.7rem;
    height: 2.7rem;
  }
  .c-search__nav-item a {
    position: relative;
    width: 100%;
    height: 100%;
    display: block;
    color: #fff;
    font-weight: 700;
    padding: 1.6rem;
    font-size: 1.6rem;
    text-align: center;
  }
  .c-search__nav-item a::before {
    content: '';
    display: block;
    position: absolute;
    left: 1.6rem;
    top: 1.6rem;
  }
}
/* ==============================================
   Project (p-footer)
   ============================================== */
/* --- 全体の左右分割 --- */
.p-footer__inner {
  display: flex;
  justify-content: space-between;
  /* 左右に振り分ける */
  gap: 40px;
  /* 左右ブロック間の余白 */
}

/* --- 左側：会社情報 --- */
.p-footer__info {
  width: 30%;
  /* 左側の幅 */
}

.p-footer__logo {
  width: 254px;
  height: 35px;
  background: url(../assets/images/logo-w.svg) no-repeat center center;
  background-size: cover;
  margin-bottom: 24px;
  text-indent: -9999px;
}

.p-footer__address {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  line-height: 1.8;
  margin-bottom: clamp(1.4rem, 1.1vw, 2rem);
}

.p-footer__hours {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  line-height: 1.8;
}

.p-footer__contents {
  width: 65%;
  display: flex;
  flex-direction: column;
  gap: clamp(2.2rem, 1.7vw, 3.2rem);
}

.p-footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.4rem, 1.1vw, 2rem) clamp(2.2rem, 1.7vw, 3.2rem);
}

.p-footer__nav-item a {
  font-size: clamp(1.2rem, 0.9vw, 1.6rem);
  color: #fff;
}

.p-footer__action-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.p-footer__sub-nav {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.4rem, 1.1vw, 2rem) clamp(2.2rem, 1.7vw, 3.2rem);
}

.p-footer__sub-nav-item a {
  font-size: clamp(1.2rem, 0.9vw, 1.6rem);
  color: #fff;
}

.p-footer__contact {
  display: flex;
  gap: clamp(1.73333rem, 1.68831vw, 2.6rem);
  align-items: center;
}

.p-footer__tel a,
.p-footer__mail a {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  font-size: clamp(2.13333rem, 2.07792vw, 3.2rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1;
}

.p-footer__mail a {
  font-size: clamp(1.73333rem, 1.68831vw, 2.6rem);
}

.p-footer__contact-icon {
  width: 2rem;
  /* アイコンのサイズ */
  height: auto;
}

/* コピーライト */
.p-footer__copyright {
  font-size: 1.2rem;
  margin-top: 6.8rem;
  text-align: center;
}

.p-footer__btn-wrapper {
  font-size: clamp(2.13333rem, 2.07792vw, 3.2rem);
  background: #05a55b;
  padding: .8rem 2.4rem;
}
.p-footer__btn-wrapper a {
  color: #fff;
}

@media (max-width: 768px) {
  .p-footer__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    /* 左右に振り分ける */
    gap: 1.6rem;
    /* 左右ブロック間の余白 */
  }
  .p-footer__info {
    width: 100%;
    /* 左側の幅 */
  }
  .p-footer__logo {
    width: calc(254px / 2);
    height: calc(35px / 2);
    margin: auto auto 2.4rem;
  }
  .p-footer__address {
    font-size: 1.5rem;
    line-height: 1.8;
    margin-bottom: .8rem;
    text-align: center;
  }
  .p-footer__hours {
    font-size: 1.5rem;
    line-height: 1.8;
    text-align: center;
    margin: 0 auto;
  }
  .p-footer__contents {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
  }
  .p-footer__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .8rem 1.2rem;
  }
  .p-footer__nav-item a {
    font-size: 1.2rem;
  }
  .p-footer__action-row {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 1.6rem;
  }
  .p-footer__sub-nav {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem 1.2rem;
  }
  .p-footer__sub-nav-item a {
    font-size: 1.2rem;
    color: #fff;
  }
  .p-footer__contact {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    align-items: center;
    margin-bottom: 1.6rem;
  }
  .p-footer__tel a, .p-footer__mail a {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: -0.02em;
    color: #fff;
    line-height: 1;
  }
  .p-footer__contact-icon {
    width: 2rem;
    /* アイコンのサイズ */
    height: auto;
  }
  .p-footer__copyright {
    font-size: 1rem;
    margin-top: 3.2rem;
    text-align: center;
  }
  .p-footer__btn-wrapper {
    font-size: 2.4rem;
    background: #05a55b;
    padding: .8rem 2.4rem;
    width: 100%;
    max-width: 40rem;
    text-align: center;
  }
}
.c-property-card {
  border: .8rem solid #20006e;
  padding-bottom: 1.6rem;
}
.c-property-card__tag {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  padding: .4rem .8rem;
  border: 1px solid #000;
  display: inline-block;
  margin: 0 0 .8rem;
}
.c-property-card__info {
  padding-bottom: 1.6rem;
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  border-bottom: 1px solid #000;
}
.c-property-card__info [data-icon="price"] p::before {
  width: 2rem;
  height: 2rem;
  content: '';
  display: block;
  background: url(../assets/images/yen.svg) no-repeat center center;
  background-size: cover;
}
.c-property-card__info [data-icon="train"] p::before {
  width: 2rem;
  height: 2rem;
  content: '';
  display: block;
  background: url(../assets/images/train.svg) no-repeat center center;
  background-size: contain;
}
.c-property-card__info [data-icon="house"] p::before {
  width: 2rem;
  height: 2rem;
  content: '';
  display: block;
  background: url(../assets/images/house.svg) no-repeat center center;
  background-size: cover;
}
.c-property-card__info p {
  font-size: clamp(1.4rem, 1vw, 2rem);
  line-height: 1.5;
  margin: 0 0 .8rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.c-property-card__content {
  padding: 1.6rem 1.6rem 0 1.6rem;
  margin-bottom: 1.6rem;
}
.c-property-card > p {
  width: 100%;
  padding: 0 1.6rem;
  margin: 0;
  font-size: clamp(1.4rem, 1.1vw, 2rem);
}

@media (max-width: 768px) {
  .c-property-card {
    border: .4rem solid #20006e;
    padding-bottom: 1.6rem;
  }
  .c-property-card__tag {
    font-size: 1.2rem;
    padding: .4rem .8rem;
  }
  .c-property-card__info {
    padding-bottom: 1.2rem;
    font-size: 1.5rem;
    border-bottom: 1px solid #000;
  }
  .c-property-card__info [data-icon="price"] p::before {
    width: 1.4rem;
    height: 1.4rem;
    content: '';
    display: block;
    background: url(../assets/images/yen.svg) no-repeat center center;
    background-size: cover;
  }
  .c-property-card__info [data-icon="train"] p::before {
    width: 1.4rem;
    height: 1.4rem;
    content: '';
    display: block;
    background: url(../assets/images/train.svg) no-repeat center center;
    background-size: contain;
  }
  .c-property-card__info [data-icon="house"] p::before {
    width: 1.4rem;
    height: 1.4rem;
    content: '';
    display: block;
    background: url(../assets/images/house.svg) no-repeat center center;
    background-size: cover;
  }
  .c-property-card__info p {
    font-size: 1.5rem;
    line-height: 1.5;
    margin: 0 0 .4rem;
    display: flex;
    align-items: center;
    gap: .4rem;
  }
  .c-property-card__info p:nth-last-of-type {
    margin: 0;
  }
  .c-property-card__content {
    padding: 1.2rem 1.6rem 0 1.6rem;
    margin-bottom: 1.6rem;
  }
  .c-property-card > p {
    width: 100%;
    padding: 0 1.6rem;
    margin: 0;
    font-size: 1.5rem;
  }
}
.c-tabbar {
  background: #545454;
  width: 100%;
  height: 5.4rem;
  display: block;
  position: fixed;
  bottom: 0;
  z-index: 500;
}
.c-tabbar__menu {
  display: flex;
  width: 100%;
  height: 100%;
  margin: 0;
}
.c-tabbar__menu li {
  width: calc(100% / 3);
  height: 100%;
  position: relative;
}
.c-tabbar__menu li::after {
  width: .1rem;
  height: calc(100% - 3.2rem);
  background: #fff;
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
}
.c-tabbar__menu li:last-child::after {
  display: none;
}
.c-tabbar__menu li a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #fff;
  font-size: 1.3rem;
  text-align: center;
}

.c-form__item {
  padding-bottom: var(--space-lg);
  padding-left: var(--space-md);
  padding-right: var(--space-md);
  margin-bottom: var(--space-lg);
  font-size: var(--fs-md);
  display: flex;
  gap: 0 4rem;
  border-bottom: #545454 1px solid;
}
.c-form__label {
  font-weight: 700;
  width: 20%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.c-form__radio--field {
  background: #fafafa;
  border: 1px solid #545454;
  border-radius: 1.4rem;
}
.c-form__radio--field label {
  padding: var(--space-s16) var(--space-s24);
  display: flex;
  align-items: center;
  border-bottom: 1px solid #545454;
  gap: 0 var(--space-md);
}
.c-form__radio--field label:last-of-type {
  border-bottom: none;
}
.c-form__radio--field label input[type="radio"] {
  -webkit-appearance: none;
  height: 3rem;
  width: 3rem;
  border: 1px solid #000;
  position: relative;
}
.c-form__radio--field label input[type="radio"]::before {
  content: "";
  display: block;
  position: absolute;
  width: 50%;
  height: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
}
.c-form__radio--field label input[type="radio"]:checked::before {
  background: #000;
}
.c-form__field {
  width: 80%;
}
.c-form__tag--required {
  color: #fff;
  background: #f00;
  padding: .8rem;
}
.c-form input[type="text"],
.c-form input[type="tel"],
.c-form input[type="email"],
.c-form textarea {
  border: #545454 1px solid;
  background: #fafafa;
  border-radius: 1.4rem;
  padding: 1.2rem;
  font-size: var(--fs-md);
  width: 100%;
}
.c-form textarea {
  height: 150px;
}
.c-form__privacy p {
  text-align: center;
  margin-bottom: var(--space-s54);
}
.c-form__submit {
  display: flex;
  justify-content: center;
}
.c-form__submit button {
  padding: var(--space-s24) var(--space-s24);
  font-size: var(--fs-lg);
  font-weight: 700;
  border-radius: 1.8rem;
  width: 100%;
  max-width: 55.6rem;
}
.c-form__submit button::after {
  border: none;
}

@media (max-width: 768px) {
  .c-form__item {
    display: block;
    padding: 2.4rem 0 2.4rem 0;
    font-size: 1.5rem;
    margin: 0;
  }
  .c-form__item:first-of-type {
    padding-top: 0;
  }
  .c-form__label {
    width: 100%;
    display: flex;
    justify-content: start;
    align-items: center;
    gap: 0 .6rem;
    margin-bottom: .8rem;
  }
  .c-form__radio--field {
    background: #fafafa;
    border: 1px solid #545454;
    border-radius: 1.4rem;
  }
  .c-form__radio--field label {
    padding: 1.2rem;
    border-bottom: 1px solid #545454;
    gap: 0 .8rem;
  }
  .c-form__radio--field label input[type="radio"] {
    -webkit-appearance: none;
    height: 2.4rem;
    width: 2.4rem;
    flex-shrink: 0;
  }
  .c-form__radio--field label input[type="radio"]:checked::before {
    background: #000;
  }
  .c-form__field {
    width: 100%;
  }
  .c-form__tag--required {
    color: #fff;
    background: #f00;
    padding: .4rem .8rem;
    font-size: 1.3rem;
  }
  .c-form input[type="text"],
  .c-form input[type="tel"],
  .c-form input[type="email"],
  .c-form textarea {
    border: #545454 1px solid;
    background: #fafafa;
    border-radius: .6rem;
    padding: .8rem;
    font-size: 1.5rem;
    width: 100%;
  }
  .c-form textarea {
    height: 150px;
  }
  .c-form__privacy p {
    text-align: center;
    margin-bottom: 2.4rem;
  }
  .c-form__submit {
    display: flex;
    justify-content: center;
  }
  .c-form__submit button {
    padding: var(--space-s24) var(--space-s24);
    font-size: var(--fs-lg);
    font-weight: 700;
    border-radius: 1.8rem;
    width: 100%;
    max-width: 55.6rem;
  }
  .c-form__submit button::after {
    border: none;
  }
}
* {
  box-sizing: border-box;
}

.c-btn {
  border: 0;
  background: #545454;
  color: #fff;
  padding: 1.2rem 1.6rem;
  border-radius: 4px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  font-size: 1.8rem;
  position: relative;
}
.c-btn::after {
  width: calc(100% - .8rem);
  height: calc(100% - .8rem);
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  border: 1px solid #fff;
  border-radius: 4px;
}

.p-hero {
  background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.2)), url(../assets/images/pc-main-visual.jpg) center/cover no-repeat;
  color: #fff;
  padding: 11rem 0 14rem;
  min-height: 54rem;
  max-height: 72rem;
  height: 100vh;
  display: flex;
  font-family: "Sawarabi Mincho", serif;
  text-shadow: #000 1px 0 10px;
}
.p-hero h1 {
  margin: 0 0 .8rem;
  font-size: clamp(40px, 3.125vw, 60px);
}
.p-hero p {
  margin: 0;
  font-size: clamp(20px, 2.08vw, 40px);
}
.p-hero__inner {
  max-width: 154rem;
  width: 90vw;
  margin: auto auto;
  padding: 0 4rem;
}
.p-hero__under {
  position: relative;
}
.p-hero__under .l-inner {
  z-index: 10;
  position: relative;
}
.p-hero__under::after {
  background: rgba(0, 0, 0, 0.3);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin: auto;
  content: '';
  z-index: 1;
}
.p-hero__under::before {
  background: url(../assets/images/bg-img-04.svg) no-repeat center center;
  content: '';
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  margin: auto;
  z-index: 2;
}
.p-hero__title {
  text-align: center;
  color: #fff;
  margin: auto auto 4.8rem;
}
.p-hero__title h2 {
  font-size: clamp(2.5rem, 3.125vw, 4rem);
  margin: 0;
}
.p-hero__title span {
  font-size: clamp(1.875rem, 3.125vw, 2.5rem);
}

@media (max-width: 768px) {
  .p-hero {
    background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.2)), url(../assets/images/pc-main-visual.jpg) center/cover no-repeat;
    color: #fff;
    padding: 11rem 0 14rem;
    min-height: 54rem;
    max-height: 72rem;
    height: 100vh;
    display: flex;
    font-family: "Sawarabi Mincho", serif;
    text-shadow: #000 1px 0 10px;
  }
  .p-hero h1 {
    margin: 0 0 .8rem;
    font-size: 3.2rem;
    text-align: center;
  }
  .p-hero p {
    margin: 0;
    font-size: 1.5rem;
    text-align: center;
  }
  .p-hero__inner {
    width: 100%;
    margin: auto auto;
    padding: 0 1.6rem;
  }
  .p-hero__under {
    position: relative;
  }
  .p-hero__under .l-inner {
    z-index: 10;
    position: relative;
  }
  .p-hero__under::after {
    background: rgba(0, 0, 0, 0.3);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    margin: auto;
    content: '';
    z-index: 1;
  }
  .p-hero__under::before {
    background: url(../assets/images/bg-img-04.svg) no-repeat center center;
    content: '';
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    margin: auto;
    z-index: 2;
  }
  .p-hero__title {
    margin: auto auto 3.2rem;
    text-align: center;
  }
  .p-hero__title h2 {
    font-size: 2.4rem;
  }
  .p-hero__title span {
    font-size: 1.5rem;
  }
}
.p-search-box__outer {
  margin: auto auto 4rem;
}

@media (max-width: 768px) {
  .p-search-box__outer {
    margin: auto auto 3.2rem;
  }
}
.p-line-banner {
  max-width: 100%;
  height: auto;
  display: block;
}

.p-concept__images {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  column-gap: 2.4rem;
  margin: auto auto 4.8rem;
}
.p-concept__title {
  font-size: clamp(4.8rem, 5.7vw, 8.4rem);
  line-height: 1;
  margin: 0;
  color: #fff;
  text-shadow: #000 1px 0 10px;
}
.p-concept__title span {
  font-size: clamp(2.4rem, 2.8vw, 4.2rem);
  display: inline-block;
  line-height: 1;
  text-shadow: none;
  color: #000;
}
.p-concept__lead {
  font-size: clamp(2rem, 2vw, 3.5rem);
}

@media (max-width: 768px) {
  .p-concept__images {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: .8rem;
    margin: auto auto 2.4rem;
  }
  .p-concept__title {
    font-size: 2.4rem;
    line-height: 1;
    margin: 0 0 .8rem;
    color: #fff;
    text-shadow: #000 1px 0 10px;
  }
  .p-concept__title span {
    font-size: 2rem;
    display: inline-block;
    line-height: 1;
    text-shadow: none;
    color: #000;
    margin-top: .8rem;
  }
  .p-concept__lead {
    font-size: 1.5rem;
  }
}
.p-recommend {
  position: relative;
  z-index: 1;
}
.p-recommend::before {
  background: url(../assets/images/bg-img-05.svg) no-repeat center center;
  content: '';
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  margin: auto;
  z-index: -1;
}
.p-recommend__cta {
  text-align: center;
}
.p-recommend__cta .c-button {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  font-weight: 700;
  position: relative;
}
.p-recommend__cta .c-button::after {
  background: url(../assets/images/arrow.svg) no-repeat center center;
  background-size: cover;
  width: 1.2rem;
  height: 2.3rem;
  content: '';
  position: absolute;
  top: 0;
  right: 1.6rem;
  bottom: 0;
  margin: auto;
}
.p-recommend__list {
  margin: auto auto 4.8rem;
}
.p-recommend__item {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  column-gap: 1.6rem;
}
.p-recommend__search {
  margin: 8rem auto 12rem auto;
  background: #fff;
  padding: 6rem 4.8rem 6rem 4.8rem;
  border: .8rem solid #20006e;
}
.p-recommend__sub-title {
  text-align: center;
  font-size: clamp(2rem, 1.4vw, 2.5rem);
  margin: auto auto 3.2rem auto;
  font-weight: 400;
}
.p-recommend__tags {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 2.4rem;
}
.p-recommend__tags .p-tag {
  font-size: clamp(2rem, 1.4vw, 2.5rem);
  padding: 1.6rem .8rem 1.6rem .8rem;
  border: 1px solid #000;
  text-align: center;
  line-height: 1;
}

@media (max-width: 768px) {
  .p-recommend {
    position: relative;
    z-index: 1;
  }
  .p-recommend::before {
    background: url(../assets/images/bg-img-05.svg) no-repeat center center;
    content: '';
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    margin: auto;
    z-index: -1;
  }
  .p-recommend__cta {
    text-align: center;
  }
  .p-recommend__cta .c-button {
    font-size: 1.5rem;
  }
  .p-recommend__cta .c-button::after {
    background: url(../assets/images/arrow.svg) no-repeat center center;
    background-size: cover;
    width: .8rem;
    height: 1.8rem;
    content: '';
    position: absolute;
    top: 0;
    right: 1.6rem;
    bottom: 0;
    margin: auto;
  }
  .p-recommend__list {
    margin: auto auto 2.4rem;
  }
  .p-recommend__item {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
  .p-recommend__search {
    margin: 4rem auto 0 auto;
    background: #fff;
    padding: 1.6rem;
    border: .4rem solid #20006e;
  }
  .p-recommend__sub-title {
    font-size: 1.5rem;
    margin: auto auto 1.6rem auto;
  }
  .p-recommend__tags {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .8rem;
  }
  .p-recommend__tags .p-tag {
    font-size: 1.2rem;
    padding: 1.2rem .8rem;
    border: 1px solid #000;
    text-align: center;
    line-height: 1;
  }
}
.p-news__list {
  display: block;
  margin: auto auto 4.8rem;
  width: 80%;
  border-top: 1px dashed #545454;
}
.p-news__item {
  border-bottom: 1px dashed #545454;
}
.p-news__item-content {
  padding: 2.4rem 4.8rem 2.4rem 4.8rem;
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  color: #000;
  display: flex;
}
.p-news__item-content span {
  margin: 0;
}
.p-news__item-date {
  width: 14rem;
}
.p-news__item-label {
  width: 7rem;
}
.p-news__cta {
  text-align: center;
}
.p-news__cta .c-button {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  font-weight: 700;
  position: relative;
}
.p-news__cta .c-button::after {
  background: url(../assets/images/arrow.svg) no-repeat center center;
  background-size: cover;
  width: 1.2rem;
  height: 2.3rem;
  content: '';
  position: absolute;
  top: 0;
  right: 1.6rem;
  bottom: 0;
  margin: auto;
}

@media (max-width: 768px) {
  .p-news__list {
    margin: auto auto 2.4rem;
    width: 100%;
  }
  .p-news__item-content {
    padding: 1.6rem;
    font-size: 1.5rem;
    flex-wrap: wrap;
    gap: .8rem;
  }
  .p-news__item-content span {
    margin: 0;
  }
  .p-news__item-date {
    width: 9rem;
  }
  .p-news__item-label {
    width: calc(100% - 9.8rem);
  }
  .p-news__cta {
    text-align: center;
  }
  .p-news__cta .c-button {
    font-size: 1.5rem;
  }
  .p-news__cta .c-button::after {
    background: url(../assets/images/arrow.svg) no-repeat center center;
    background-size: cover;
    width: .8rem;
    height: 1.6rem;
    content: '';
    position: absolute;
    top: 0;
    right: 1.6rem;
    bottom: 0;
    margin: auto;
  }
}
.p-about {
  background: rgba(0, 0, 0, 0.3);
  position: relative;
}
.p-about .c-title {
  margin-bottom: clamp(4.8rem, 3.8vw, 7.4rem);
}
.p-about .c-title h2 {
  color: #fff;
}
.p-about__cta {
  text-align: center;
}
.p-about__cta .c-button {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  font-weight: 700;
  position: relative;
}
.p-about__cta .c-button::after {
  background: url(../assets/images/arrow.svg) no-repeat center center;
  background-size: cover;
  width: 1.2rem;
  height: 2.3rem;
  content: '';
  position: absolute;
  top: 0;
  right: 1.6rem;
  bottom: 0;
  margin: auto;
}
.p-about::before {
  content: "";
  position: absolute;
  top: 10%;
  left: 0;
  width: 100%;
  height: 80%;
  background-color: #444;
  z-index: 1;
  clip-path: polygon(0 20%, 100% 0, 100% 80%, 0 100%);
}
.p-about__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 60px;
  position: relative;
  z-index: 10;
}
.p-about__media {
  width: 50%;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(12, 1fr);
}
.p-about__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
}
.p-about__image--main {
  grid-column: 1 / 10;
  grid-row: 1 / 10;
  aspect-ratio: 4 / 5;
}
.p-about__image--sub {
  grid-column: 6 / 13;
  grid-row: 7 / 13;
  aspect-ratio: 1 / 1;
  z-index: 2;
}
.p-about__content {
  width: 50%;
  position: relative;
  z-index: 2;
  color: #fff;
}
.p-about__points {
  margin-bottom: 4.8rem;
}
.p-about__point {
  font-size: clamp(2rem, 2vw, 3.5rem);
  font-weight: 700;
  margin-bottom: 1.6rem;
}
.p-about__description {
  font-size: clamp(1.875rem, 1.4vw, 2.5rem);
}

@media (max-width: 768px) {
  .p-about {
    background: rgba(0, 0, 0, 0.3);
    position: relative;
  }
  .p-about .c-title {
    margin-bottom: 3.2rem;
    width: 100%;
  }
  .p-about .c-title h2 {
    color: #fff;
    font-size: 2rem;
  }
  .p-about__cta {
    text-align: center;
  }
  .p-about__cta .c-button {
    font-size: 1.5rem;
  }
  .p-about__cta .c-button::after {
    width: .8rem;
    height: 1.6rem;
  }
  .p-about::before {
    content: "";
    position: absolute;
    top: 10%;
    left: 0;
    width: 100%;
    height: 80%;
    background-color: #444;
    z-index: 1;
    clip-path: polygon(0 20%, 100% 0, 100% 80%, 0 100%);
  }
  .p-about__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 2.4rem;
  }
  .p-about__media {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: repeat(12, 1fr);
  }
  .p-about__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
  }
  .p-about__image--main {
    grid-column: 1 / 10;
    grid-row: 1 / 10;
    aspect-ratio: 4 / 5;
  }
  .p-about__image--sub {
    grid-column: 6 / 13;
    grid-row: 7 / 13;
    aspect-ratio: 1 / 1;
    z-index: 2;
  }
  .p-about__content {
    width: 100%;
  }
  .p-about__points {
    margin-bottom: 2.4rem;
  }
  .p-about__point {
    font-size: 1.8rem;
    margin-bottom: 1.2rem;
  }
  .p-about__description {
    font-size: 1.5rem;
    margin-bottom: 2.4rem;
  }
}
.p-flow__list {
  display: flex;
  gap: 3.2rem;
}
.p-flow__item {
  width: 20%;
  background: #fff;
  border: 2px solid #545454;
  padding: 2.4rem;
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  position: relative;
}
.p-flow__number {
  position: absolute;
  top: clamp(-2.4rem, -1.75vw, -3.4rem);
  left: clamp(-2.4rem, -1.75vw, -3.4rem);
  width: clamp(4.8rem, 3.5vw, 6.8rem);
  height: clamp(4.8rem, 3.5vw, 6.8rem);
  background: #545454;
  color: #fff;
  text-align: center;
  line-height: clamp(4.8rem, 3.5vw, 6.8rem);
  font-size: clamp(2.4rem, 1.8vw, 3rem);
  border-radius: clamp(2.4rem, 1.75vw, 3.4rem);
}
.p-flow__icon {
  width: 100%;
  height: 8rem;
  margin: 0 auto 0;
}
.p-flow__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.p-flow__text {
  margin: 0 auto;
}

@media (max-width: 768px) {
  .p-flow {
    width: auto;
  }
  .p-flow__list {
    display: grid;
    grid-auto-columns: 20rem;
    grid-auto-flow: column;
    overflow-x: scroll;
    gap: 1.6rem;
    scroll-snap-type: x mandatory;
    padding-left: 1.2rem;
    padding-top: 1.2rem;
    margin: 0;
  }
  .p-flow__item {
    width: 20rem;
    height: 20rem;
    background: #fff;
    border: 2px solid #545454;
    padding: 1.6rem 1.6rem 1.6rem 1.6rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    position: relative;
  }
  .p-flow__number {
    position: absolute;
    top: -1.2rem;
    left: -1.2rem;
    width: 2.4rem;
    height: 2.4rem;
    background: #545454;
    color: #fff;
    text-align: center;
    line-height: 2.4rem;
    font-size: 1.2rem;
    border-radius: 1.2rem;
  }
  .p-flow__icon {
    width: 100%;
    height: 6rem;
    margin: 0 auto 0;
  }
  .p-flow__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  .p-flow__text {
    margin: 1.2rem auto;
    font-size: 1.5rem;
  }
}
.p-voice .c-title {
  margin-bottom: clamp(4.8rem, 3.8vw, 7.4rem);
}
.p-voice .l-inner {
  display: flex;
  gap: clamp(6.4rem, 5.4vw, 10.4rem);
}
.p-voice__img-wrapper {
  width: 50%;
}
.p-voice__body {
  width: 50%;
}
.p-voice__cta {
  text-align: center;
}
.p-voice__cta .c-button {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  font-weight: 700;
  position: relative;
}
.p-voice__cta .c-button::after {
  background: url(../assets/images/arrow.svg) no-repeat center center;
  background-size: cover;
  width: 1.2rem;
  height: 2.3rem;
  content: '';
  position: absolute;
  top: 0;
  right: 1.6rem;
  bottom: 0;
  margin: auto;
}
.p-voice__description {
  font-size: clamp(1.875rem, 1.4vw, 2.5rem);
}

@media (max-width: 768px) {
  .p-voice .c-title {
    margin-bottom: 1.2rem;
  }
  .p-voice .l-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 2.4rem;
  }
  .p-voice__img-wrapper {
    width: 100%;
    margin: auto;
  }
  .p-voice__body {
    width: 100%;
  }
  .p-voice__cta {
    text-align: center;
  }
  .p-voice__cta .c-button {
    font-size: 1.5rem;
    font-weight: 700;
    position: relative;
  }
  .p-voice__cta .c-button::after {
    background: url(../assets/images/arrow.svg) no-repeat center center;
    background-size: cover;
    width: .8rem;
    height: 1.6rem;
    content: '';
    position: absolute;
    top: 0;
    right: 1.6rem;
    bottom: 0;
    margin: auto;
  }
  .p-voice__description {
    font-size: 1.5rem;
  }
}
.c-section-header__title {
  margin: 0 0 20px;
  font-size: 28px;
  color: #2f1f85;
  letter-spacing: 0.05em;
  text-align: center;
}

.l-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: center;
}

.p-properties__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.p-property-card {
  border: 2px solid #2f1f85;
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
}
.p-property-card__img {
  height: 150px;
  background: #d8d8d8;
  background-size: cover;
  background-position: center;
}
.p-property-card__info {
  padding: 10px;
  font-size: 13px;
}
.p-property-card__title {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
}

.c-panel {
  border: 2px solid #2f1f85;
  border-radius: 6px;
  padding: 16px;
  background: #fff;
}

.p-company {
  background: linear-gradient(150deg, #f2f2f2 50%, #2e2e2e 50%);
  color: #fff;
}
.p-company .l-split {
  grid-template-columns: 1.2fr 1fr;
}
.p-company__gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.p-company__gallery div {
  height: 120px;
  border-radius: 4px;
  background-size: cover;
  background-position: center;
}

.c-breadcrumb {
  display: block;
  background: #545454;
  padding: 2.4rem;
  width: 100%;
  margin: auto auto 4rem;
}
.c-breadcrumb__inner {
  max-width: 168vw;
  margin: auto;
}
.c-breadcrumb__list {
  display: flex;
  gap: 0 1.6rem;
}
.c-breadcrumb__list li {
  display: flex;
  align-items: center;
  gap: 0 1.6rem;
  font-size: 1.5rem;
  color: #fff;
}
.c-breadcrumb__list li img {
  width: auto;
  height: 1.6rem;
}
.c-breadcrumb__list li + li::before {
  content: '';
  background: url(../assets/images/arrow.svg) no-repeat center center;
  background-size: cover;
  width: .8rem;
  height: 1.6rem;
  display: block;
}
.c-breadcrumb__list li a,
.c-breadcrumb__list li span {
  color: #fff;
  font-size: 1.5rem;
}

@media screen and (max-width: 768px) {
  .c-breadcrumb {
    display: block;
    background: #545454;
    padding: .8rem 1.6rem;
    width: 100%;
    margin: auto auto 4rem;
  }
  .c-breadcrumb__inner {
    max-width: 100%;
    margin: auto;
  }
  .c-breadcrumb__list {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
  }
  .c-breadcrumb__list li {
    display: flex;
    align-items: center;
    gap: 0 .8rem;
    font-size: 1.2rem;
    color: #fff;
  }
  .c-breadcrumb__list li img {
    width: auto;
    height: 1.2rem;
  }
  .c-breadcrumb__list li + li::before {
    content: '';
    background: url(../assets/images/arrow.svg) no-repeat center center;
    background-size: cover;
    width: .6rem;
    height: 1.2rem;
    display: block;
  }
  .c-breadcrumb__list li a,
  .c-breadcrumb__list li span {
    color: #fff;
    font-size: 1.2rem;
  }
}
.p-property-detail__header {
  display: flex;
  align-items: center;
  gap: 0 1.6rem;
  padding-bottom: .8rem;
  margin-bottom: 2.4rem;
  border-bottom: 1px solid #000;
}
.p-property-detail__header-new {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  color: #fff;
  background: #f00;
  padding: .4rem .8rem;
  border-radius: clamp(1.4rem, 1.1vw, 2rem);
  font-weight: 700;
}
.p-property-detail__header-category {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  padding: .4rem .8rem;
  border: 1px solid #000;
}
.p-property-detail__point {
  display: flex;
  align-items: stretch;
  border: 1px solid #142d63;
  margin-bottom: 40px;
}
.p-property-detail__point-label {
  background-color: #142d63;
  color: #fff;
  font-weight: bold;
  padding: 2rem 4rem;
  flex-shrink: 0;
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-property-detail__point-text {
  font-size: clamp(1.875rem, 1.4vw, 2.5rem);
  padding: 1.6rem 2.4rem;
  margin: 0;
  display: flex;
  align-items: center;
}
.p-property-detail__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: clamp(4.8rem, 3.3333vw, 6.4rem);
}
.p-property-detail__gallery {
  width: 50%;
}
.p-property-detail__info {
  width: 50%;
}
.p-property-detail__contact-box {
  border: 1px solid #ccc;
  padding: 2.4rem;
  margin-bottom: 4rem;
}
.p-property-detail__tel-wrapper {
  display: flex;
  justify-content: left;
  align-items: baseline;
  gap: 1.2rem;
  margin-top: 1.6rem;
}
.p-property-detail__tel-link {
  font-size: clamp(2.5rem, 2.08vw, 4rem);
  font-weight: 700;
  color: #000;
  position: relative;
  display: flex;
  align-items: center;
  gap: .8rem;
}
.p-property-detail__tel-link::before {
  background: url(../assets/images/tel-b.svg) no-repeat center center;
  content: '';
  width: clamp(1.6rem, 1.45vw, 2.8rem);
  height: clamp(2rem, 1.875vw, 3.6rem);
  background-size: cover;
  display: block;
}
.p-property-detail__tel-note {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  font-weight: 700;
}
.p-property-detail__section {
  margin-bottom: 40px;
}
.p-property-detail__section-title {
  font-size: clamp(2rem, 1.5625vw, 3rem);
  font-weight: 700;
  padding-bottom: 1rem;
  border-bottom: 1px solid #ddd;
  position: relative;
  color: #20006e;
}
.p-property-detail__section-title::before {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 10rem;
  height: 1px;
  background: #20006e;
}

@media screen and (max-width: 768px) {
  .p-property-detail__header {
    display: flex;
    align-items: center;
    gap: 0 .8rem;
    flex-wrap: wrap;
  }
  .p-property-detail__header-new {
    font-size: 1.2rem;
    padding: .4rem .8rem;
    border-radius: 1.2rem;
  }
  .p-property-detail__header-category {
    font-size: 1.2rem;
  }
  .p-property-detail__title {
    display: block;
    width: 100%;
    margin: .4rem 0 0 0;
    font-size: 2.4rem;
  }
  .p-property-detail__point {
    flex-direction: column;
    align-items: stretch;
    margin-bottom: 2.4rem;
  }
  .p-property-detail__point-label {
    text-align: center;
    padding: .8rem 1.6rem;
    font-size: 1.5rem;
  }
  .p-property-detail__point-text {
    font-size: 1.5rem;
    padding: 1.6rem;
    margin: 0;
  }
  .p-property-detail__inner {
    flex-direction: column;
  }
  .p-property-detail__gallery {
    width: 100%;
  }
  .p-property-detail__info {
    width: 100%;
  }
  .p-property-detail__contact-box {
    padding: 1.6rem;
    margin-bottom: 2.4rem;
  }
  .p-property-detail__tel-wrapper {
    gap: .8rem;
    margin-top: 1.6rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .p-property-detail__tel-link {
    font-size: 2rem;
    gap: .6rem;
  }
  .p-property-detail__tel-link::before {
    background: url(../assets/images/tel-b.svg) no-repeat center center;
    content: '';
    width: 1.6rem;
    height: 1.2rem;
  }
  .p-property-detail__tel-note {
    font-size: 1.4rem;
  }
  .p-property-detail__section {
    margin-bottom: 2.4rem;
  }
  .p-property-detail__section-title {
    font-size: 2rem;
  }
}
.p-property-table {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.p-property-table dt,
.p-property-table dd {
  padding: clamp(1.33333rem, 1.04167vw, 2rem) 0.8rem clamp(1.33333rem, 1.04167vw, 2rem) 0.8rem;
  text-align: left;
  vertical-align: middle;
  margin: 0;
}
.p-property-table__head {
  background-color: #ecedf5;
  width: 30%;
  font-weight: bold;
  font-size: clamp(1.2rem, 0.9375vw, 1.8rem);
  border-bottom: 1px solid #20006e;
}
.p-property-table__data {
  border-bottom: 1px solid #ddd;
  width: 20%;
  font-size: clamp(1.2rem, 0.9375vw, 1.8rem);
}

.p-property-info {
  margin-bottom: 20rem;
}
.p-property-info .p-property-table {
  margin-bottom: 6.4rem;
}
.p-property-info .p-property-table__head {
  width: 14%;
}
.p-property-info .p-property-table__data {
  width: 36%;
}
.p-property-info .p-property-map {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #e0e0e0;
  margin-bottom: 6.4rem;
}
.p-property-info .c-button {
  margin: auto;
  display: block;
}

@media screen and (max-width: 768px) {
  .p-property-info {
    margin-bottom: 20rem;
  }
  .p-property-info .p-property-table {
    margin-bottom: 6.4rem;
  }
  .p-property-info .p-property-table__head {
    width: 28%;
  }
  .p-property-info .p-property-table__data {
    width: 72%;
  }
  .p-property-info .p-property-map {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #e0e0e0;
    margin-bottom: 6.4rem;
  }
  .p-property-info .c-button {
    margin: auto;
    display: block;
  }
}
/* ==============================================
Project (p-property-detail) - Swiperギャラリー
============================================== */
/* メイン画像 */
.p-property-detail__main-slider {
  position: relative;
  background-color: #e0e0e0;
  aspect-ratio: 16 / 9;
  overflow: visible;
}

.p-property-detail__main-slider .swiper-slide {
  height: 100%;
}

.p-property-detail__main-slider img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: #fff;
}

/* 枚数カウンター（swiper-pagination-fraction が入る） */
.p-property-detail__img-counter {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4.8rem;
  background: #666;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 1.6rem;
  color: #fff;
  font-weight: 700;
  z-index: 2;
  letter-spacing: 0.02em;
}

.p-property-detail__img-counter .swiper-pagination-current,
.p-property-detail__img-counter .swiper-pagination-total {
  font-variant-numeric: tabular-nums;
  margin: 0 .3rem;
}

/* サムネ＋矢印エリア */
.p-property-detail__thumb-area {
  margin-top: 1.6rem;
  display: flex;
  align-items: center;
  gap: 1.2rem;
  background: #eef0f6;
  padding: 1.6rem;
}

.p-property-detail__thumb-slider {
  width: 100%;
}

.p-property-detail__thumb-slider .swiper-slide {
  border-radius: .2rem;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  cursor: pointer;
  opacity: 0.8;
  transition: opacity 0.2s, transform 0.2s;
}

.p-property-detail__thumb-slider .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.p-property-detail__thumb-slider .swiper-slide-thumb-active {
  opacity: 1;
  outline: 2px solid #111;
  outline-offset: -2px;
}

/* Swiper矢印（既存classを使う） */
.p-property-detail__thumb-area .swiper-button-prev,
.p-property-detail__thumb-area .swiper-button-next {
  position: static;
  width: 4.8rem;
  height: 6.4rem;
  margin: 0;
  flex: 0 0 auto;
  background: rgba(0, 0, 0, 0.08);
  border-radius: .2rem;
}

.p-property-detail__thumb-area .swiper-button-prev::after,
.p-property-detail__thumb-area .swiper-button-next::after {
  font-size: var(--fs-md);
  color: #111;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .p-property-detail__img-counter {
    position: absolute;
    height: 4rem;
    padding: 0 1.2rem;
    margin-bottom: -4rem;
  }

  .p-property-detail__thumb-area {
    margin-top: 5.6rem;
    display: flex;
    align-items: center;
    gap: .8rem;
    background: #eef0f6;
    padding: .8rem;
  }

  .p-property-detail__thumb-slider {
    width: 100%;
  }

  .p-property-detail__thumb-slider .swiper-slide {
    border-radius: .2rem;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    cursor: pointer;
    opacity: 0.8;
    transition: opacity 0.2s, transform 0.2s;
  }

  .p-property-detail__thumb-slider .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .p-property-detail__thumb-slider .swiper-slide-thumb-active {
    opacity: 1;
    outline: 2px solid #111;
    outline-offset: -2px;
  }

  .p-property-detail__thumb-area .swiper-button-prev::after,
  .p-property-detail__thumb-area .swiper-button-next::after {
    font-size: 1.5rem;
  }
}
.p-property-comment__inner {
  display: flex;
  gap: 0 1.6rem;
}
.p-property-comment__profile {
  width: 10rem;
}
.p-property-comment__profile p {
  font-size: 1.2rem;
  text-align: center;
  line-height: 1.4;
}
.p-property-comment__thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  background: #f1f1f1;
}
.p-property-comment__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-property-comment__content {
  position: relative;
  display: inline-block;
  padding: 1.6rem;
  border: 2px solid #ccc;
  border-radius: 8px;
  text-align: left;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
  width: calc(100% - 11.6rem);
}
.p-property-comment__content p {
  font-size: 1.4rem;
  line-height: 1.8;
}
.p-property-comment__content p:last-child {
  margin: 0;
}
.p-property-comment__content::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  border-style: solid;
  border-width: 10px 10px 10px 0;
  border-color: transparent #ccc transparent transparent;
  translate: -100% -50%;
}
.p-property-comment__content ::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  border-style: solid;
  border-width: 7.2px 7.2px 7.2px 0;
  border-color: transparent #fff transparent transparent;
  translate: -100% -50%;
}

@media (max-width: 768px) {
  .p-property-comment__inner {
    display: flex;
    gap: 0 .8rem;
  }
  .p-property-comment__profile {
    width: 8rem;
  }
  .p-property-comment__profile p {
    font-size: 1.2rem;
    text-align: center;
    line-height: 1.4;
  }
  .p-property-comment__thumb {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    overflow: hidden;
    background: #f1f1f1;
  }
  .p-property-comment__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p-property-comment__content {
    position: relative;
    display: inline-block;
    padding: 1.6rem;
    border: 2px solid #ccc;
    border-radius: 8px;
    text-align: left;
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 1.5;
    color: #000000;
    width: calc(100% - 8.8rem);
  }
  .p-property-comment__content p {
    font-size: 1.2rem;
  }
  .p-property-comment__content p:last-child {
    margin: 0;
  }
  .p-property-comment__content::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    border-style: solid;
    border-width: 10px 10px 10px 0;
    border-color: transparent #ccc transparent transparent;
    translate: -100% -50%;
  }
  .p-property-comment__content ::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    border-style: solid;
    border-width: 7.2px 7.2px 7.2px 0;
    border-color: transparent #fff transparent transparent;
    translate: -100% -50%;
  }
}
.p-contact-form {
  padding-bottom: 20rem;
}
.p-contact-form__title {
  background: #545454;
  text-align: center;
  height: clamp(12rem, 9.375vw, 18rem);
  display: flex;
  margin-bottom: clamp(8rem, 6.25vw, 12rem);
}
.p-contact-form__title h1 {
  margin: auto;
  color: #fff;
  font-size: var(--fs-xxl);
  font-weight: 400;
}
.p-contact-form__content {
  border: 1px solid #545454;
  padding: clamp(4.66667rem, 3.64583vw, 7rem);
}

@media (max-width: 768px) {
  .p-contact-form {
    padding-bottom: 8rem;
  }
  .p-contact-form__title {
    height: 7.2rem;
    display: flex;
    margin-bottom: 4.8rem;
  }
  .p-contact-form__title h1 {
    font-size: 3.2rem;
  }
  .p-contact-form__content {
    border: 1px solid #545454;
    padding: 2.4rem 1.6rem;
  }
}
.p-company__message {
  display: flex;
  flex-direction: column;
  gap: clamp(4.8rem, 3.3333vw, 6.4rem);
  padding: var(--space-s72);
  background: #545454;
  position: relative;
  margin: var(--space-s120) auto var(--space-s120);
}
.p-company__message-title {
  margin-bottom: clamp(8rem, 6.25vw, 12rem);
}
.p-company__message-title h2 {
  font-size: var(--fs-xl);
  text-align: center;
  font-weight: 700;
  margin: 0 auto;
  color: #fff;
}
.p-company__message-inner {
  display: grid;
  grid-template-columns: 2fr 3fr;
  column-gap: var(--space-s72);
}
.p-company__message-photo {
  aspect-ratio: 1 / 1;
  background: #e0e0e0;
}
.p-company__message-text p {
  font-size: var(--fs-lg);
  line-height: 2.5;
  color: #fff;
}
.p-company__message-decoration {
  position: absolute;
  pointer-events: none;
  /* 装飾テキストがクリックなどの邪魔をしないように */
  bottom: 0;
  right: 0;
  line-height: 1;
}
.p-company__message-decoration::before {
  content: attr(data-text);
  width: 7em;
  color: #fff;
  opacity: 0.1;
  font-size: clamp(10.66667rem, 8.33333vw, 16rem);
  font-weight: 700;
}
.p-company__message-decoration p {
  display: flex;
  gap: .5em;
  align-items: baseline;
  color: #fff;
  font-weight: 900;
  font-size: clamp(3.33333rem, 2.60417vw, 5rem);
  position: absolute;
  bottom: 1rem;
  right: 1em;
  margin: 0;
}
.p-company__message-decoration p span {
  font-size: clamp(2rem, 1.5625vw, 3rem);
  font-weight: 400;
}
.p-company__info {
  margin-bottom: var(--space-s120);
}
.p-company__info-title {
  font-size: var(--fs-xl);
  color: #20006e;
  font-weight: 700;
  text-align: center;
  position: relative;
}
.p-company__info-title::before {
  content: '';
  display: block;
  width: calc(50% - 4em);
  height: 1px;
  background: #20006e;
  position: absolute;
  bottom: 0;
  top: 0;
  left: 0;
  margin: auto;
}
.p-company__info-title::after {
  content: '';
  display: block;
  width: calc(50% - 4em);
  height: 1px;
  background: #20006e;
  position: absolute;
  bottom: 0;
  top: 0;
  right: 0;
  margin: auto;
}
.p-company__info-list dl {
  display: grid;
  grid-template-columns: 1fr 3fr;
  font-size: clamp(2rem, 1.5625vw, 3rem);
}
.p-company__info-list dl dt {
  font-weight: 700;
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  background: #c8c8c8;
  padding: var(--space-lg) var(--space-s54);
}
.p-company__info-list dl dt:nth-of-type(2n) {
  background: #fff;
}
.p-company__info-list dl dd {
  font-size: clamp(1.4rem, 1.1vw, 2rem);
  margin: 0;
  background: #c8c8c8;
  padding: var(--space-lg) var(--space-s54);
}
.p-company__info-list dl dd:nth-of-type(2n) {
  background: #fff;
}
.p-company__map {
  margin-bottom: 20rem;
}
.p-company__map-title {
  font-size: var(--fs-xl);
  color: #20006e;
  font-weight: 700;
  text-align: center;
  position: relative;
}
.p-company__map-title::before {
  content: '';
  display: block;
  width: calc(50% - 4em);
  height: 1px;
  background: #20006e;
  position: absolute;
  bottom: 0;
  top: 0;
  left: 0;
  margin: auto;
}
.p-company__map-title::after {
  content: '';
  display: block;
  width: calc(50% - 4em);
  height: 1px;
  background: #20006e;
  position: absolute;
  bottom: 0;
  top: 0;
  right: 0;
  margin: auto;
}
.p-company__map-content p {
  font-size: clamp(2rem, 1.5625vw, 3rem);
  text-align: center;
  padding-bottom: var(--space-s72);
  border-bottom: 1px solid #20006e;
  margin-bottom: 1.6em;
}
.p-company__map-content #map {
  width: 100%;
  aspect-ratio: 16 / 9;
  display: block;
  position: relative;
}
.p-company__map-content #map iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

@media (max-width: 768px) {
  .p-company__message {
    display: block;
    flex-wrap: wrap;
    flex-direction: column;
    gap: clamp(4.8rem, 3.3333vw, 6.4rem);
    padding: 1.6rem 1.6rem 8rem 1.6rem;
    background: #545454;
    position: relative;
    margin: auto auto 8rem;
  }
  .p-company__message-title {
    margin-bottom: 2.4rem;
  }
  .p-company__message-title h2 {
    font-size: 2.4rem;
  }
  .p-company__message-inner {
    display: flex;
    flex-wrap: wrap;
    grid-template-columns: none;
    gap: 2.4rem 0;
  }
  .p-company__message-photo {
    width: 100%;
  }
  .p-company__message-text {
    width: 100%;
  }
  .p-company__message-text p {
    font-size: 1.5rem;
  }
  .p-company__message-decoration {
    bottom: 1.6rem;
    right: 1.6rem;
  }
  .p-company__message-decoration::before {
    content: attr(data-text);
    width: auto;
    color: #fff;
    opacity: 0.1;
    font-size: 4.8rem;
    font-weight: 700;
  }
  .p-company__message-decoration p {
    font-size: 2rem;
    position: absolute;
    bottom: 1rem;
    right: 1em;
    margin: 0;
  }
  .p-company__message-decoration p span {
    font-size: 1.5rem;
    font-weight: 400;
  }
  .p-company__info {
    margin-bottom: 8rem;
  }
  .p-company__info-title h2 {
    font-size: 2.8rem;
  }
  .p-company__info-title::before {
    width: calc(50% - 2.5em);
  }
  .p-company__info-title::after {
    width: calc(50% - 2.5em);
  }
  .p-company__info-list dl {
    display: block;
    font-size: 1.5rem;
  }
  .p-company__info-list dl dt {
    font-size: 1.5rem;
    padding: 1.6rem 1.6rem .8rem 1.6rem;
  }
  .p-company__info-list dl dt:nth-of-type(2n) {
    background: #fff;
  }
  .p-company__info-list dl dd {
    font-size: 1.5rem;
    padding: 0 1.6rem 1.6rem 1.6rem;
  }
  .p-company__info-list dl dd:nth-of-type(2n) {
    background: #fff;
  }
  .p-company__map {
    margin-bottom: 8rem;
  }
  .p-company__map-title {
    font-size: 2.8rem;
  }
  .p-company__map-title::before {
    width: calc(50% - 2.5em);
  }
  .p-company__map-title::after {
    width: calc(50% - 2.5em);
  }
  .p-company__map-content p {
    font-size: 1.5rem;
    padding-bottom: 1.6rem;
    margin-bottom: 1.6em;
  }
}
.p-aboutus__point {
  padding-top: var(--space-s54);
  position: relative;
}
.p-aboutus__point::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 150%;
  height: 50%;
  background-color: #c8c8c8;
  clip-path: polygon(0 50%, 50% 0, 100% 0, 0 100%);
}
.p-aboutus__point::after {
  background: url(../assets/images/pc-about-bg.png) no-repeat center center/cover;
  content: '';
  width: 100%;
  aspect-ratio: 3 / 2;
  display: block;
  position: absolute;
  top: 20%;
  left: 0;
  margin: auto;
}
.p-aboutus__hero {
  width: 100%;
  height: calc(100dvh - 164px);
  background: url(../assets/images/pc-about-hero-img.jpg) no-repeat center center/cover;
}
.p-aboutus__hero-title {
  color: #fff;
  font-size: clamp(4rem, 3.125vw, 6rem);
  font-weight: 400;
  text-align: center;
  margin-top: clamp(16rem, 12.5vw, 24rem);
  line-height: 1;
}
.p-aboutus__title {
  text-align: center;
  margin: auto auto 4.8rem;
  position: relative;
  z-index: 1;
}
.p-aboutus__title h2 {
  font-size: clamp(2.5rem, 3.125vw, 4rem);
  margin: 0;
}
.p-aboutus__title span {
  font-size: clamp(2rem, 1.5625vw, 3rem);
}
.p-aboutus__point-item {
  position: relative;
  z-index: 1;
  margin-bottom: clamp(18.66667rem, 14.58333vw, 28rem);
}
.p-aboutus__point-item:nth-of-type(2n) .p-about__point-item-inner {
  flex-direction: row-reverse;
}
.p-aboutus__point-item-inner {
  display: flex;
  gap: var(--space-s72);
  justify-content: center;
  margin-bottom: var(--space-s72);
}
.p-aboutus__point-text {
  width: 50%;
}
.p-aboutus__point-text h3 {
  position: relative;
  font-size: clamp(3.6rem, 3.50649vw, 5.4rem);
  font-weight: 700;
  color: #20006e;
  margin-top: 0;
  margin-bottom: var(--space-s54);
}
.p-aboutus__point-text h3 span {
  color: #000;
}
.p-aboutus__point-text h3::before {
  content: attr(data-title);
  display: block;
  line-height: 1;
  font-family: "Sawarabi Mincho", serif;
}
.p-aboutus__point-text p {
  font-size: var(--fs-lg);
  line-height: 2.5;
}
.p-aboutus__point-img {
  width: 50%;
}
.p-aboutus__point-tag {
  display: flex;
  gap: 0 var(--space-s54);
}
.p-aboutus__point-tag a {
  font-size: var(--fs-lg);
  color: #fff;
  padding: 1em;
  background: #545454;
}

@media (max-width: 768px) {
  .p-aboutus__point {
    padding-top: var(--space-s54);
    position: relative;
  }
  .p-aboutus__point::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 150%;
    height: 20%;
    background-color: #c8c8c8;
    clip-path: polygon(0 50%, 50% 0, 100% 0, 0 100%);
  }
  .p-aboutus__point::after {
    background: url(../assets/images/pc-about-bg.png) no-repeat center center/cover;
    content: '';
    width: 100%;
    aspect-ratio: 3 / 2;
    display: block;
    position: absolute;
    top: 20%;
    left: 0;
    margin: auto;
  }
  .p-aboutus__hero {
    width: 100%;
    height: calc(100dvh - 164px);
    background: url(../assets/images/pc-about-hero-img.jpg) no-repeat center center/cover;
  }
  .p-aboutus__hero-title {
    font-size: clamp(2.85714rem, 10.25641vw, 4rem);
    margin-top: clamp(16rem, 12.5vw, 24rem);
    line-height: 1.5;
  }
  .p-aboutus__title {
    margin: auto auto 4.8rem;
    position: relative;
    z-index: 1;
  }
  .p-aboutus__title h2 {
    font-size: clamp(2rem, 7.17949vw, 2.8rem);
    margin: 0;
  }
  .p-aboutus__title span {
    font-size: clamp(1.28571rem, 4.61538vw, 1.8rem);
  }
  .p-aboutus__point-item {
    position: relative;
    z-index: 1;
    margin-bottom: 7.2rem;
  }
  .p-aboutus__point-item:nth-of-type(2n) .p-about__point-item-inner {
    flex-direction: row-reverse;
  }
  .p-aboutus__point-item-inner {
    flex-wrap: wrap;
    gap: 2.4rem 0;
    margin-bottom: 2.4rem;
  }
  .p-aboutus__point-text {
    width: 100%;
  }
  .p-aboutus__point-text h3 {
    font-size: clamp(2.14286rem, 7.69231vw, 3rem);
    margin-bottom: 0;
  }
  .p-aboutus__point-text h3 span {
    color: #000;
  }
  .p-aboutus__point-text p {
    font-size: 1.5rem;
    line-height: 2.5;
  }
  .p-aboutus__point-img {
    width: 100%;
  }
  .p-aboutus__point-img img {
    margin-bottom: 2.4rem;
  }
  .p-aboutus__point-img p {
    margin-bottom: 0;
  }
  .p-aboutus__point-tag {
    display: flex;
    flex-wrap: wrap;
    gap: 1.6rem;
  }
  .p-aboutus__point-tag a {
    width: calc(50% - .8rem);
    font-size: 1.2rem;
    padding: 1em 0;
    text-align: center;
  }
}
.p-page__title {
  margin-top: var(--space-s120);
  margin-bottom: var(--space-s120);
  text-align: center;
}
.p-page__title h1 {
  font-size: var(--fs-xl);
  line-height: 1;
  margin: 0;
}
.p-page__title span {
  font-size: var(--fs-lg);
  margin-top: var(--fs-md);
  font-weight: 700;
  display: inline-block;
}
.p-page__content h2 {
  font-size: var(--fs-mlg);
  margin: 0 0 1em 0;
}
.p-page__content p {
  font-size: var(--fs-lg);
  margin: 0 0 2.2em 0;
}

.p-news__hero {
  padding-top: var(--fs-xxxxl);
  padding-bottom: var(--fs-xxxxl);
}
.p-news__hero-title {
  font-size: var(--fs-xxl);
  margin: 0;
  line-height: 1;
}
.p-news__hero span {
  font-size: var(--fs-md);
}
.p-news__container {
  display: flex;
  justify-content: space-between;
  gap: 0 4em;
}
.p-news__side {
  width: 24%;
  max-width: 36em;
}
.p-news__side-content {
  margin-bottom: 4.8em;
}
.p-news__side-content h2 {
  font-size: var(--fs-mlg);
  padding-bottom: .4em;
  margin-bottom: .8em;
  border-bottom: 1px solid #000;
  display: block;
}
.p-news__side-content p {
  line-height: 1;
  margin: 0 0 1rem 0;
}
.p-news__side-content select,
.p-news__side-content ::picker(select) {
  appearance: base-select;
  width: 100%;
  font-size: var(--fs-md);
}
.p-news__side-list-item {
  padding: 1rem 0 1rem 0;
  display: block;
}
.p-news__side-list-item a {
  padding: 0 0 0 3.2em;
  position: relative;
  line-height: 1;
  font-size: var(--fs-sm);
  color: #000;
  width: 100%;
  display: block;
}
.p-news__side-list-item a::after {
  width: 1.4rem;
  height: .1rem;
  content: '';
  background: #000;
  position: absolute;
  top: 0;
  bottom: 0;
  left: .4em;
  margin: auto;
}
.p-news__content {
  width: calc(76% - 4em);
}
.p-news__content-list {
  border-top: 1px solid #606060;
}
.p-news__content-list .-item {
  padding: 2.4rem 0;
  display: flex;
  gap: 0 2.4rem;
  border-bottom: 1px solid #606060;
}
.p-news__content-list .-thumb {
  width: 180px;
  height: 12rem;
  overflow: hidden;
  position: relative;
  background: #ddd;
  flex-shrink: 0;
}
.p-news__content-list .-thumb img {
  object-fit: cover;
}
.p-news__content-list .-text {
  display: flex;
  flex-direction: column;
  gap: 1.2rem 0;
}
.p-news__content-list .-text p {
  padding-right: 4.8rem;
  font-size: var(--fs-md);
  position: relative;
  color: #000;
  margin: 0;
}
.p-news__content-list .-text p::after {
  content: '';
  background: url(../assets/images/arrow-b.svg) no-repeat center center;
  background-size: cover;
  width: 2.1rem;
  height: 1.7rem;
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  right: 0;
}
.p-news__content-list .-meta {
  display: flex;
  gap: 0 .8rem;
}
.p-news__content-list .-meta span {
  font-size: var(--fs-sm);
  color: #000;
}
.p-news__content-list .-meta .-category {
  color: #fff;
  background: #606060;
  border-radius: 1.2rem;
  padding: .2rem 1.2rem;
}
.p-news__content-heading {
  border-bottom: 1px solid #000;
  padding-bottom: 1.6rem;
}

.page-list .c-breadcrumb {
  margin: 0;
}

.p-list__hero {
  background: url(../assets/images/property-list-img.jpg) no-repeat center center;
  background-size: cover;
  width: 100%;
  height: 30rem;
  margin-bottom: var(--fs-xxxl);
}
.p-list__hero-inner {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
}
.p-list__hero-text {
  background: #606060;
  padding: 2rem;
}
.p-list__hero-text h1, .p-list__hero-text p {
  margin: 0;
  color: #fff;
}
.p-list__hero-text h1 {
  font-size: var(--fs-xl);
}
.p-list__hero-text p {
  font-size: var(--fs-lg);
}
.p-list__heading h2 {
  font-weight: 400;
  font-size: var(--fs-lg);
  padding-bottom: 1em;
  border-bottom: 1px solid #000;
  margin-bottom: 4rem;
}
.p-list__heading h2 span {
  font-size: var(--fs-xl);
}
.p-list__container {
  display: flex;
  gap: 0 4rem;
}
.p-list__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6.4rem;
}
.p-list__meta .-text p {
  font-size: var(--fs-lg);
}
.p-list__meta .-text p > span {
  font-size: var(--fs-xl);
  font-weight: 700;
}
.p-list__meta .-navigation {
  display: flex;
  gap: 0 1em;
}
.p-list__meta .-navigation .-num {
  display: flex;
  align-items: center;
  gap: 0 1em;
}
.p-list__meta .-navigation .-num span {
  display: block;
  font-size: var(--fs-md);
  width: 4em;
}
.p-list__meta .-navigation select {
  appearance: base-select;
  width: 100%;
  font-size: var(--fs-lg);
}
.p-list__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8rem 4rem;
  width: 100%;
}
.p-list__list .-card {
  width: calc(50% - 2rem);
}
.p-list__list .-card a {
  color: #000;
}
.p-list__list .-card .-heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.6rem;
}
.p-list__list .-card .-heading h3 {
  font-size: var(--fs-md);
  font-weight: 700;
  padding-bottom: .6em;
  border-bottom: 1px solid #000;
  margin: 0;
}
.p-list__list .-card .-heading span {
  padding: 4px;
  background: #606060;
  color: #fff;
  font-size: var(--fs-md);
  width: 12rem;
  text-align: center;
  height: 3.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}
.p-list__list .-card .-img {
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
}
.p-list__list .-card .-content > span {
  font-size: var(--fs-sm);
}
.p-list__list .-card .-content > p {
  font-size: var(--fs-md);
}
.p-list__list .-card .-content .-info {
  display: flex;
  gap: 0 .8rem;
}
.p-list__list .-card .-content .-info > div {
  background: #606060;
  width: 50%;
  padding: .8rem;
}
.p-list__list .-card .-content .-info > div span, .p-list__list .-card .-content .-info > div p {
  color: #fff;
}
.p-list__list .-card .-content .-info > div span {
  font-size: var(--fs-sm);
  margin: 0;
}
.p-list__list .-card .-content .-info > div p {
  font-size: var(--fs-mlg);
  font-weight: 700;
  text-align: right;
  display: block;
  margin: 0;
}
.p-list__side {
  min-width: 30rem;
}
.p-list__side .-block {
  display: flex;
  gap: 2.4rem 0;
  flex-direction: column;
}
.p-list__side .-block .-heading h3 {
  font-size: var(--fs-mlg);
  font-weight: 700;
  padding-bottom: 1.6rem;
  position: relative;
  margin: 0;
}
.p-list__side .-block .-heading h3::before {
  width: 100%;
  height: 1px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  content: '';
}
.p-list__side .-block .-heading h3:after {
  width: 30%;
  height: 8px;
  background: #606060;
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  content: '';
}
.p-list__side .-block .-content {
  margin-bottom: 4rem;
}
.p-list__side .-block .-content select {
  appearance: base-select;
  width: 42%;
  font-size: var(--fs-md);
  border-radius: 0;
}
.p-list__side .-block .-content .-p01 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.p-list__side .-block .-content .-p01 span {
  width: 14%;
  text-align: center;
  display: block;
  font-size: var(--fs-md);
}
.p-list__side .-block .-content .-p02 {
  display: flex;
  flex-wrap: wrap;
  gap: 3.2rem;
}
.p-list__side .-block .-content .-p02 .-check {
  width: calc(50% - 1.6rem);
}

/*!
 * Hamburgers
 * @description Tasty CSS-animated hamburgers
 * @author Jonathan Suh @jonsuh
 * @site https://jonsuh.com/hamburgers
 * @link https://github.com/jonsuh/hamburgers
 */
.hamburger {
  padding: 4px 4px;
  cursor: pointer;
  transition-property: opacity, filter;
  transition-duration: 0.15s;
  transition-timing-function: linear;
  font: inherit;
  color: inherit;
  text-transform: none;
  background-color: transparent;
  border: 0;
  margin: 0;
  overflow: visible;
  z-index: 9999 !important;
  position: fixed;
  top: 38px;
  margin: auto;
  right: 16px;
  width: 36px;
  height: 24px;
  padding: 0;
}

@media only screen and (max-width: 1000px) {
  .hamburger {
    display: inline-block;
    top: 26px;
  }
}
.hamburger-box {
  width: 36px;
  height: 24px;
  display: inline-block;
  position: relative;
}

.hamburger-inner {
  display: block;
  top: 50%;
  margin-top: -2px;
}
.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
  width: 36px;
  height: 4px;
  background-color: #030303;
  border-radius: 4px;
  position: absolute;
  transition-property: transform;
  transition-duration: 0.15s;
  transition-timing-function: ease;
}
.hamburger-inner::before, .hamburger-inner::after {
  content: "";
  display: block;
}
.hamburger-inner::before {
  top: -10px;
}
.hamburger-inner::after {
  bottom: -10px;
}

/*
 * 3DX
 */
.hamburger--3dx .hamburger-box {
  perspective: 72px;
}
.hamburger--3dx .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dx .hamburger-inner::before, .hamburger--3dx .hamburger-inner::after {
  transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dx.is-active .hamburger-inner {
  background-color: transparent;
  transform: rotateY(180deg);
}
.hamburger--3dx.is-active .hamburger-inner::before {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--3dx.is-active .hamburger-inner::after {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
}

/*
 * 3DX Reverse
 */
.hamburger--3dx-r .hamburger-box {
  perspective: 72px;
}
.hamburger--3dx-r .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dx-r .hamburger-inner::before, .hamburger--3dx-r .hamburger-inner::after {
  transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dx-r.is-active .hamburger-inner {
  background-color: transparent;
  transform: rotateY(-180deg);
}
.hamburger--3dx-r.is-active .hamburger-inner::before {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--3dx-r.is-active .hamburger-inner::after {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
}

/*
 * 3DY
 */
.hamburger--3dy .hamburger-box {
  perspective: 72px;
}
.hamburger--3dy .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dy .hamburger-inner::before, .hamburger--3dy .hamburger-inner::after {
  transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dy.is-active .hamburger-inner {
  background-color: transparent;
  transform: rotateX(-180deg);
}
.hamburger--3dy.is-active .hamburger-inner::before {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--3dy.is-active .hamburger-inner::after {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
}

/*
 * 3DY Reverse
 */
.hamburger--3dy-r .hamburger-box {
  perspective: 72px;
}
.hamburger--3dy-r .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dy-r .hamburger-inner::before, .hamburger--3dy-r .hamburger-inner::after {
  transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dy-r.is-active .hamburger-inner {
  background-color: transparent;
  transform: rotateX(180deg);
}
.hamburger--3dy-r.is-active .hamburger-inner::before {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--3dy-r.is-active .hamburger-inner::after {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
}

/*
 * 3DXY
 */
.hamburger--3dxy .hamburger-box {
  perspective: 72px;
}
.hamburger--3dxy .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dxy .hamburger-inner::before, .hamburger--3dxy .hamburger-inner::after {
  transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dxy.is-active .hamburger-inner {
  background-color: transparent;
  transform: rotateX(180deg) rotateY(180deg);
}
.hamburger--3dxy.is-active .hamburger-inner::before {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--3dxy.is-active .hamburger-inner::after {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
}

/*
 * 3DXY Reverse
 */
.hamburger--3dxy-r .hamburger-box {
  perspective: 72px;
}
.hamburger--3dxy-r .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dxy-r .hamburger-inner::before, .hamburger--3dxy-r .hamburger-inner::after {
  transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.hamburger--3dxy-r.is-active .hamburger-inner {
  background-color: transparent;
  transform: rotateX(180deg) rotateY(180deg) rotateZ(-180deg);
}
.hamburger--3dxy-r.is-active .hamburger-inner::before {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--3dxy-r.is-active .hamburger-inner::after {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
}

/*
 * Arrow
 */
.hamburger--arrow.is-active .hamburger-inner::before {
  transform: translate3d(-7.2px, 0, 0) rotate(-45deg) scale(0.7, 1);
}
.hamburger--arrow.is-active .hamburger-inner::after {
  transform: translate3d(-7.2px, 0, 0) rotate(45deg) scale(0.7, 1);
}

/*
 * Arrow Right
 */
.hamburger--arrow-r.is-active .hamburger-inner::before {
  transform: translate3d(7.2px, 0, 0) rotate(45deg) scale(0.7, 1);
}
.hamburger--arrow-r.is-active .hamburger-inner::after {
  transform: translate3d(7.2px, 0, 0) rotate(-45deg) scale(0.7, 1);
}

/*
 * Arrow Alt
 */
.hamburger--arrowalt .hamburger-inner::before {
  transition: top 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.hamburger--arrowalt .hamburger-inner::after {
  transition: bottom 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.hamburger--arrowalt.is-active .hamburger-inner::before {
  top: 0;
  transform: translate3d(-7.2px, -9px, 0) rotate(-45deg) scale(0.7, 1);
  transition: top 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22);
}
.hamburger--arrowalt.is-active .hamburger-inner::after {
  bottom: 0;
  transform: translate3d(-7.2px, 9px, 0) rotate(45deg) scale(0.7, 1);
  transition: bottom 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22);
}

/*
 * Arrow Alt Right
 */
.hamburger--arrowalt-r .hamburger-inner::before {
  transition: top 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.hamburger--arrowalt-r .hamburger-inner::after {
  transition: bottom 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.hamburger--arrowalt-r.is-active .hamburger-inner::before {
  top: 0;
  transform: translate3d(7.2px, -9px, 0) rotate(45deg) scale(0.7, 1);
  transition: top 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22);
}
.hamburger--arrowalt-r.is-active .hamburger-inner::after {
  bottom: 0;
  transform: translate3d(7.2px, 9px, 0) rotate(-45deg) scale(0.7, 1);
  transition: bottom 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22);
}

/*
 * Arrow Turn
 */
.hamburger--arrowturn.is-active .hamburger-inner {
  transform: rotate(-180deg);
}
.hamburger--arrowturn.is-active .hamburger-inner::before {
  transform: translate3d(8px, 0, 0) rotate(45deg) scale(0.7, 1);
}
.hamburger--arrowturn.is-active .hamburger-inner::after {
  transform: translate3d(8px, 0, 0) rotate(-45deg) scale(0.7, 1);
}

/*
 * Arrow Turn Right
 */
.hamburger--arrowturn-r.is-active .hamburger-inner {
  transform: rotate(-180deg);
}
.hamburger--arrowturn-r.is-active .hamburger-inner::before {
  transform: translate3d(-8px, 0, 0) rotate(-45deg) scale(0.7, 1);
}
.hamburger--arrowturn-r.is-active .hamburger-inner::after {
  transform: translate3d(-8px, 0, 0) rotate(45deg) scale(0.7, 1);
}

/*
 * Boring
 */
.hamburger--boring .hamburger-inner, .hamburger--boring .hamburger-inner::before, .hamburger--boring .hamburger-inner::after {
  transition-property: none;
}
.hamburger--boring.is-active .hamburger-inner {
  transform: rotate(45deg);
}
.hamburger--boring.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
}
.hamburger--boring.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
}

/*
 * Collapse
 */
.hamburger--collapse .hamburger-inner {
  top: auto;
  bottom: 0;
  transition-duration: 0.13s;
  transition-delay: 0.13s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--collapse .hamburger-inner::after {
  top: -20px;
  transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0.1s linear;
}
.hamburger--collapse .hamburger-inner::before {
  transition: top 0.12s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--collapse.is-active .hamburger-inner {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
  transition-delay: 0.22s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--collapse.is-active .hamburger-inner::after {
  top: 0;
  opacity: 0;
  transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0.1s 0.22s linear;
}
.hamburger--collapse.is-active .hamburger-inner::before {
  top: 0;
  transform: rotate(-90deg);
  transition: top 0.1s 0.16s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.25s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Collapse Reverse
 */
.hamburger--collapse-r .hamburger-inner {
  top: auto;
  bottom: 0;
  transition-duration: 0.13s;
  transition-delay: 0.13s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--collapse-r .hamburger-inner::after {
  top: -20px;
  transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0.1s linear;
}
.hamburger--collapse-r .hamburger-inner::before {
  transition: top 0.12s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--collapse-r.is-active .hamburger-inner {
  transform: translate3d(0, -10px, 0) rotate(45deg);
  transition-delay: 0.22s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--collapse-r.is-active .hamburger-inner::after {
  top: 0;
  opacity: 0;
  transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0.1s 0.22s linear;
}
.hamburger--collapse-r.is-active .hamburger-inner::before {
  top: 0;
  transform: rotate(90deg);
  transition: top 0.1s 0.16s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.25s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Elastic
 */
.hamburger--elastic .hamburger-inner {
  top: 2px;
  transition-duration: 0.275s;
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.hamburger--elastic .hamburger-inner::before {
  top: 10px;
  transition: opacity 0.125s 0.275s ease;
}
.hamburger--elastic .hamburger-inner::after {
  top: 20px;
  transition: transform 0.275s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.hamburger--elastic.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(135deg);
  transition-delay: 0.075s;
}
.hamburger--elastic.is-active .hamburger-inner::before {
  transition-delay: 0s;
  opacity: 0;
}
.hamburger--elastic.is-active .hamburger-inner::after {
  transform: translate3d(0, -20px, 0) rotate(-270deg);
  transition-delay: 0.075s;
}

/*
 * Elastic Reverse
 */
.hamburger--elastic-r .hamburger-inner {
  top: 2px;
  transition-duration: 0.275s;
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.hamburger--elastic-r .hamburger-inner::before {
  top: 10px;
  transition: opacity 0.125s 0.275s ease;
}
.hamburger--elastic-r .hamburger-inner::after {
  top: 20px;
  transition: transform 0.275s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.hamburger--elastic-r.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(-135deg);
  transition-delay: 0.075s;
}
.hamburger--elastic-r.is-active .hamburger-inner::before {
  transition-delay: 0s;
  opacity: 0;
}
.hamburger--elastic-r.is-active .hamburger-inner::after {
  transform: translate3d(0, -20px, 0) rotate(270deg);
  transition-delay: 0.075s;
}

/*
 * Emphatic
 */
.hamburger--emphatic {
  overflow: hidden;
}
.hamburger--emphatic .hamburger-inner {
  transition: background-color 0.125s 0.175s ease-in;
}
.hamburger--emphatic .hamburger-inner::before {
  left: 0;
  transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, left 0.125s 0.175s ease-in;
}
.hamburger--emphatic .hamburger-inner::after {
  top: 10px;
  right: 0;
  transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, right 0.125s 0.175s ease-in;
}
.hamburger--emphatic.is-active .hamburger-inner {
  transition-delay: 0s;
  transition-timing-function: ease-out;
  background-color: transparent;
}
.hamburger--emphatic.is-active .hamburger-inner::before {
  left: -72px;
  top: -72px;
  transform: translate3d(72px, 72px, 0) rotate(45deg);
  transition: left 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.hamburger--emphatic.is-active .hamburger-inner::after {
  right: -72px;
  top: -72px;
  transform: translate3d(-72px, 72px, 0) rotate(-45deg);
  transition: right 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1);
}

/*
 * Emphatic Reverse
 */
.hamburger--emphatic-r {
  overflow: hidden;
}
.hamburger--emphatic-r .hamburger-inner {
  transition: background-color 0.125s 0.175s ease-in;
}
.hamburger--emphatic-r .hamburger-inner::before {
  left: 0;
  transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, left 0.125s 0.175s ease-in;
}
.hamburger--emphatic-r .hamburger-inner::after {
  top: 10px;
  right: 0;
  transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, right 0.125s 0.175s ease-in;
}
.hamburger--emphatic-r.is-active .hamburger-inner {
  transition-delay: 0s;
  transition-timing-function: ease-out;
  background-color: transparent;
}
.hamburger--emphatic-r.is-active .hamburger-inner::before {
  left: -72px;
  top: 72px;
  transform: translate3d(72px, -72px, 0) rotate(-45deg);
  transition: left 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.hamburger--emphatic-r.is-active .hamburger-inner::after {
  right: -72px;
  top: 72px;
  transform: translate3d(-72px, -72px, 0) rotate(45deg);
  transition: right 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1);
}

/*
 * Minus
 */
.hamburger--minus .hamburger-inner::before, .hamburger--minus .hamburger-inner::after {
  transition: bottom 0.08s 0s ease-out, top 0.08s 0s ease-out, opacity 0s linear;
}
.hamburger--minus.is-active .hamburger-inner::before, .hamburger--minus.is-active .hamburger-inner::after {
  opacity: 0;
  transition: bottom 0.08s ease-out, top 0.08s ease-out, opacity 0s 0.08s linear;
}
.hamburger--minus.is-active .hamburger-inner::before {
  top: 0;
}
.hamburger--minus.is-active .hamburger-inner::after {
  bottom: 0;
}

/*
 * Slider
 */
.hamburger--slider .hamburger-inner {
  top: 2px;
}
.hamburger--slider .hamburger-inner::before {
  top: 10px;
  transition-property: transform, opacity;
  transition-timing-function: ease;
  transition-duration: 0.15s;
}
.hamburger--slider .hamburger-inner::after {
  top: 20px;
}
.hamburger--slider.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--slider.is-active .hamburger-inner::before {
  transform: rotate(-45deg) translate3d(-5.14286px, -6px, 0);
  opacity: 0;
}
.hamburger--slider.is-active .hamburger-inner::after {
  transform: translate3d(0, -20px, 0) rotate(-90deg);
}

/*
 * Slider Reverse
 */
.hamburger--slider-r .hamburger-inner {
  top: 2px;
}
.hamburger--slider-r .hamburger-inner::before {
  top: 10px;
  transition-property: transform, opacity;
  transition-timing-function: ease;
  transition-duration: 0.15s;
}
.hamburger--slider-r .hamburger-inner::after {
  top: 20px;
}
.hamburger--slider-r.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(-45deg);
}
.hamburger--slider-r.is-active .hamburger-inner::before {
  transform: rotate(45deg) translate3d(5.14286px, -6px, 0);
  opacity: 0;
}
.hamburger--slider-r.is-active .hamburger-inner::after {
  transform: translate3d(0, -20px, 0) rotate(90deg);
}

/*
 * Spin
 */
.hamburger--spin .hamburger-inner {
  transition-duration: 0.22s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin .hamburger-inner::before {
  transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in;
}
.hamburger--spin .hamburger-inner::after {
  transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin.is-active .hamburger-inner {
  transform: rotate(225deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--spin.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
  transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out;
}
.hamburger--spin.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
  transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Spin Reverse
 */
.hamburger--spin-r .hamburger-inner {
  transition-duration: 0.22s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin-r .hamburger-inner::before {
  transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in;
}
.hamburger--spin-r .hamburger-inner::after {
  transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin-r.is-active .hamburger-inner {
  transform: rotate(-225deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--spin-r.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
  transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out;
}
.hamburger--spin-r.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(90deg);
  transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Spring
 */
.hamburger--spring .hamburger-inner {
  top: 2px;
  transition: background-color 0s 0.13s linear;
}
.hamburger--spring .hamburger-inner::before {
  top: 10px;
  transition: top 0.1s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spring .hamburger-inner::after {
  top: 20px;
  transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spring.is-active .hamburger-inner {
  transition-delay: 0.22s;
  background-color: transparent;
}
.hamburger--spring.is-active .hamburger-inner::before {
  top: 0;
  transition: top 0.1s 0.15s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
  transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--spring.is-active .hamburger-inner::after {
  top: 0;
  transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
  transform: translate3d(0, 10px, 0) rotate(-45deg);
}

/*
 * Spring Reverse
 */
.hamburger--spring-r .hamburger-inner {
  top: auto;
  bottom: 0;
  transition-duration: 0.13s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spring-r .hamburger-inner::after {
  top: -20px;
  transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0s linear;
}
.hamburger--spring-r .hamburger-inner::before {
  transition: top 0.1s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spring-r.is-active .hamburger-inner {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
  transition-delay: 0.22s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--spring-r.is-active .hamburger-inner::after {
  top: 0;
  opacity: 0;
  transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0s 0.22s linear;
}
.hamburger--spring-r.is-active .hamburger-inner::before {
  top: 0;
  transform: rotate(90deg);
  transition: top 0.1s 0.15s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Stand
 */
.hamburger--stand .hamburger-inner {
  transition: transform 0.075s 0.15s cubic-bezier(0.55, 0.055, 0.675, 0.19), background-color 0s 0.075s linear;
}
.hamburger--stand .hamburger-inner::before {
  transition: top 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--stand .hamburger-inner::after {
  transition: bottom 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--stand.is-active .hamburger-inner {
  transform: rotate(90deg);
  background-color: transparent;
  transition: transform 0.075s 0s cubic-bezier(0.215, 0.61, 0.355, 1), background-color 0s 0.15s linear;
}
.hamburger--stand.is-active .hamburger-inner::before {
  top: 0;
  transform: rotate(-45deg);
  transition: top 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--stand.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(45deg);
  transition: bottom 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Stand Reverse
 */
.hamburger--stand-r .hamburger-inner {
  transition: transform 0.075s 0.15s cubic-bezier(0.55, 0.055, 0.675, 0.19), background-color 0s 0.075s linear;
}
.hamburger--stand-r .hamburger-inner::before {
  transition: top 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--stand-r .hamburger-inner::after {
  transition: bottom 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--stand-r.is-active .hamburger-inner {
  transform: rotate(-90deg);
  background-color: transparent;
  transition: transform 0.075s 0s cubic-bezier(0.215, 0.61, 0.355, 1), background-color 0s 0.15s linear;
}
.hamburger--stand-r.is-active .hamburger-inner::before {
  top: 0;
  transform: rotate(-45deg);
  transition: top 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--stand-r.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(45deg);
  transition: bottom 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Squeeze
 */
.hamburger--squeeze .hamburger-inner {
  transition-duration: 0.075s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--squeeze .hamburger-inner::before {
  transition: top 0.075s 0.12s ease, opacity 0.075s ease;
}
.hamburger--squeeze .hamburger-inner::after {
  transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--squeeze.is-active .hamburger-inner {
  transform: rotate(45deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--squeeze.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
  transition: top 0.075s ease, opacity 0.075s 0.12s ease;
}
.hamburger--squeeze.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
  transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/*
 * Vortex
 */
.hamburger--vortex .hamburger-inner {
  transition-duration: 0.2s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
.hamburger--vortex .hamburger-inner::before, .hamburger--vortex .hamburger-inner::after {
  transition-duration: 0s;
  transition-delay: 0.1s;
  transition-timing-function: linear;
}
.hamburger--vortex .hamburger-inner::before {
  transition-property: top, opacity;
}
.hamburger--vortex .hamburger-inner::after {
  transition-property: bottom, transform;
}
.hamburger--vortex.is-active .hamburger-inner {
  transform: rotate(765deg);
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
.hamburger--vortex.is-active .hamburger-inner::before, .hamburger--vortex.is-active .hamburger-inner::after {
  transition-delay: 0s;
}
.hamburger--vortex.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
}
.hamburger--vortex.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(90deg);
}

/*
 * Vortex Reverse
 */
.hamburger--vortex-r .hamburger-inner {
  transition-duration: 0.2s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
.hamburger--vortex-r .hamburger-inner::before, .hamburger--vortex-r .hamburger-inner::after {
  transition-duration: 0s;
  transition-delay: 0.1s;
  transition-timing-function: linear;
}
.hamburger--vortex-r .hamburger-inner::before {
  transition-property: top, opacity;
}
.hamburger--vortex-r .hamburger-inner::after {
  transition-property: bottom, transform;
}
.hamburger--vortex-r.is-active .hamburger-inner {
  transform: rotate(-765deg);
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
.hamburger--vortex-r.is-active .hamburger-inner::before, .hamburger--vortex-r.is-active .hamburger-inner::after {
  transition-delay: 0s;
}
.hamburger--vortex-r.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
}
.hamburger--vortex-r.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
}
