@font-face {
  font-family: "Shippori Mincho";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local("ShipporiMincho-Medium"),
    url(../../img/shippori-mincho-medium.woff2) format("woff2"),
    url(../../img/shippori-mincho-medium.woff) format("woff"),
    url(../../img/shippori-mincho-medium.eot) format("eot");
}
@font-face {
  font-family: Oswald;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local("Oswald-VariableFont_wght"),
    url(../../img/oswald.woff2) format("woff2"),
    url(../../img/oswald.woff) format("woff"), url(../../img/oswald.eot) format("eot");
}
@font-face {
  font-family: "Google play";
  font-style: normal;
  font-weight: 400;
  src: local("ProductSans-Regular"),
    url(../../img/ProductSans-Regular-subset.woff2) format("woff2"),
    url(../../img/ProductSans-Regular-subset.woff) format("woff"),
    url(../../img/ProductSans-Regular-subset.eot) format("eot");
}
@-moz-keyframes fade-in {
  0% {
    opacity: 0;
    height: 0;
  }
  1% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 1;
    height: auto;
  }
}
@-webkit-keyframes fade-in {
  0% {
    opacity: 0;
    height: 0;
  }
  1% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 1;
    height: auto;
  }
}
@-o-keyframes fade-in {
  0% {
    opacity: 0;
    height: 0;
  }
  1% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 1;
    height: auto;
  }
}
@-ms-keyframes fade-in {
  0% {
    opacity: 0;
    height: 0;
  }
  1% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 1;
    height: auto;
  }
}
@keyframes fade-in {
  0% {
    opacity: 0;
    height: 0;
  }
  1% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 1;
    height: auto;
  }
}
@-moz-keyframes fade-out {
  0% {
    opacity: 1;
    height: auto;
  }
  99% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 0;
    height: 0;
  }
}
@-webkit-keyframes fade-out {
  0% {
    opacity: 1;
    height: auto;
  }
  99% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 0;
    height: 0;
  }
}
@-o-keyframes fade-out {
  0% {
    opacity: 1;
    height: auto;
  }
  99% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 0;
    height: 0;
  }
}
@-ms-keyframes fade-out {
  0% {
    opacity: 1;
    height: auto;
  }
  99% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 0;
    height: 0;
  }
}
@keyframes fade-out {
  0% {
    opacity: 1;
    height: auto;
  }
  99% {
    opacity: 0;
    height: auto;
  }
  100% {
    opacity: 0;
    height: 0;
  }
} /*!
 * Bootstrap  v5.2.3 (https://getbootstrap.com/)
 * Copyright 2011-2022 The Bootstrap Authors
 * Copyright 2011-2022 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
 */
:root {
  --bs-blue: #0d6efd;
  --bs-indigo: #6610f2;
  --bs-purple: #6f42c1;
  --bs-pink: #d63384;
  --bs-red: #dc3545;
  --bs-orange: #fd7e14;
  --bs-yellow: #ffc107;
  --bs-green: #198754;
  --bs-teal: #20c997;
  --bs-cyan: #0dcaf0;
  --bs-black: #000;
  --bs-white: #fff;
  --bs-gray: #6c757d;
  --bs-gray-dark: #343a40;
  --bs-gray-100: #f8f9fa;
  --bs-gray-200: #e9ecef;
  --bs-gray-300: #dee2e6;
  --bs-gray-400: #ced4da;
  --bs-gray-500: #adb5bd;
  --bs-gray-600: #6c757d;
  --bs-gray-700: #495057;
  --bs-gray-800: #343a40;
  --bs-gray-900: #212529;
  --bs-primary: #0d6efd;
  --bs-secondary: #6c757d;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  --bs-dark: #212529;
  --bs-primary-rgb: 13, 110, 253;
  --bs-secondary-rgb: 108, 117, 125;
  --bs-success-rgb: 25, 135, 84;
  --bs-info-rgb: 13, 202, 240;
  --bs-warning-rgb: 255, 193, 7;
  --bs-danger-rgb: 220, 53, 69;
  --bs-light-rgb: 248, 249, 250;
  --bs-dark-rgb: 33, 37, 41;
  --bs-white-rgb: 255, 255, 255;
  --bs-black-rgb: 0, 0, 0;
  --bs-body-color-rgb: 33, 37, 41;
  --bs-body-bg-rgb: 255, 255, 255;
  --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto,
    "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif,
    "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;
  --bs-gradient: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.15),
    rgba(255, 255, 255, 0)
  );
  --bs-body-font-family: Shippori Mincho, 游明朝体, Yu Mincho, YuMincho,
    ヒラギノ明朝 ProN W3, Hiragino Mincho ProN, リュウミン R-KL, HG明朝E,
    ＭＳ Ｐ明朝, ＭＳ 明朝, serif;
  --bs-body-font-size: 1rem;
  --bs-body-font-weight: 400;
  --bs-body-line-height: 1.7;
  --bs-body-color: #212529;
  --bs-body-bg: #fff;
  --bs-border-width: 1px;
  --bs-border-style: solid;
  --bs-border-color: #dee2e6;
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
  --bs-border-radius: 4px;
  --bs-border-radius-sm: 0.25rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-border-radius-xl: 1rem;
  --bs-border-radius-2xl: 2rem;
  --bs-border-radius-pill: 50rem;
  --bs-link-color: #d74646;
  --bs-link-hover-color: #888;
  --bs-code-color: #d63384;
  --bs-highlight-bg: #fff3cd;
}
*,
::after,
::before {
  box-sizing: border-box;
}
@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}
body {
  margin: 0;
  font-family: var(--bs-body-font-family);
  font-size: var(--bs-body-font-size);
  font-weight: var(--bs-body-font-weight);
  line-height: var(--bs-body-line-height);
  color: var(--bs-body-color);
  text-align: var(--bs-body-text-align);
  background-color: var(--bs-body-bg);
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}
hr {
  margin: 1rem 0;
  color: inherit;
  border: 0;
  border-top: 1px solid;
  opacity: 0.25;
}
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-weight: 500;
  line-height: 1.2;
}
.h1,
h1 {
  font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
  .h1,
  h1 {
    font-size: 2.5rem;
  }
}
.h2,
h2 {
  font-size: calc(1.325rem + 0.9vw);
}
@media (min-width: 1200px) {
  .h2,
  h2 {
    font-size: 2rem;
  }
}
.h3,
h3 {
  font-size: calc(1.3rem + 0.6vw);
}
@media (min-width: 1200px) {
  .h3,
  h3 {
    font-size: 1.75rem;
  }
}
.h4,
h4 {
  font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
  .h4,
  h4 {
    font-size: 1.5rem;
  }
}
.h5,
h5 {
  font-size: 1.25rem;
}
.h6,
h6 {
  font-size: 1rem;
}
p {
  margin-top: 0;
  margin-bottom: 1rem;
}
abbr[title] {
  text-decoration: underline dotted;
  cursor: help;
  text-decoration-skip-ink: none;
}
address {
  margin-bottom: 1rem;
  font-style: normal;
  line-height: inherit;
}
ol,
ul {
  padding-left: 2rem;
}
dl,
ol,
ul {
  margin-top: 0;
  margin-bottom: 1rem;
}
ol ol,
ol ul,
ul ol,
ul ul {
  margin-bottom: 0;
}
dt {
  font-weight: 700;
}
dd {
  margin-bottom: 0.5rem;
  margin-left: 0;
}
b,
strong {
  font-weight: bolder;
}
.small,
small {
  font-size: 0.875em;
}
.mark,
mark {
  padding: 0.1875em;
  background-color: var(--bs-highlight-bg);
}
sub,
sup {
  position: relative;
  font-size: 0.75em;
  line-height: 0;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
a {
  color: var(--bs-link-color);
  text-decoration: underline;
}
a:hover {
  color: var(--bs-link-hover-color);
}
a:not([href]):not([class]),
a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}
code,
pre {
  font-family: var(--bs-font-monospace);
  font-size: 1em;
}
pre {
  display: block;
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  font-size: 0.875em;
}
pre code {
  font-size: inherit;
  color: inherit;
  word-break: normal;
}
code {
  font-size: 0.875em;
  color: var(--bs-code-color);
  word-wrap: break-word;
}
a > code {
  color: inherit;
}
figure {
  margin: 0 0 1rem;
}
img,
svg {
  vertical-align: middle;
}
table {
  caption-side: bottom;
  border-collapse: collapse;
}
caption {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: #6c757d;
  text-align: left;
}
th {
  text-align: inherit;
  text-align: -webkit-match-parent;
}
tbody,
td,
tfoot,
th,
thead,
tr {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}
label {
  display: inline-block;
}
button {
  border-radius: 0;
}
button:focus:not(:focus-visible) {
  outline: 0;
}
button,
input,
optgroup,
select,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
button,
select {
  text-transform: none;
}
[role="button"] {
  cursor: pointer;
}
select {
  word-wrap: normal;
}
select:disabled {
  opacity: 1;
}
[list]:not([type="date"]):not([type="datetime-local"]):not([type="month"]):not(
    [type="week"]
  ):not([type="time"])::-webkit-calendar-picker-indicator {
  display: none !important;
}
[type="button"],
[type="reset"],
[type="submit"],
button {
  -webkit-appearance: button;
}
[type="button"]:not(:disabled),
[type="reset"]:not(:disabled),
[type="submit"]:not(:disabled),
button:not(:disabled) {
  cursor: pointer;
}
::-moz-focus-inner {
  padding: 0;
  border-style: none;
}
textarea {
  resize: vertical;
}
fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}
legend {
  float: left;
  width: 100%;
  padding: 0;
  margin-bottom: 0.5rem;
  font-size: calc(1.275rem + 0.3vw);
  line-height: inherit;
}
@media (min-width: 1200px) {
  legend {
    font-size: 1.5rem;
  }
}
legend + * {
  clear: left;
}
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-minute,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-year-field {
  padding: 0;
}
::-webkit-inner-spin-button {
  height: auto;
}
[type="search"] {
  outline-offset: -2px;
  -webkit-appearance: textfield;
}
::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-color-swatch-wrapper {
  padding: 0;
}
::file-selector-button {
  font: inherit;
  -webkit-appearance: button;
}
output {
  display: inline-block;
}
iframe {
  border: 0;
}
summary {
  display: list-item;
  cursor: pointer;
}
progress {
  vertical-align: baseline;
}
[hidden] {
  display: none !important;
}
.lead {
  font-size: 1.25rem;
  font-weight: 300;
}
.list-unstyled {
  padding-left: 0;
  list-style: none;
}
.list-inline {
  padding-left: 0;
  list-style: none;
}
.list-inline-item {
  display: inline-block;
}
.list-inline-item:not(:last-child) {
  margin-right: 0.5rem;
}
.figure {
  display: inline-block;
}
.container,
.container-fluid {
  --bs-gutter-x: 60px;
  --bs-gutter-y: 0;
  width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}
@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}
@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }
}
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
}
.row {
  --bs-gutter-x: 60px;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}
.row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}
.col {
  flex: 1 0 0%;
}
.col-3 {
  flex: 0 0 auto;
  width: 25%;
}
.col-4 {
  flex: 0 0 auto;
  width: 33.33333333%;
}
.col-6 {
  flex: 0 0 auto;
  width: 50%;
}
.col-9 {
  flex: 0 0 auto;
  width: 75%;
}
.col-12 {
  flex: 0 0 auto;
  width: 100%;
}
.g-0 {
  --bs-gutter-x: 0;
}
.g-0 {
  --bs-gutter-y: 0;
}
@media (min-width: 576px) {
  .col-sm-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-sm-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-sm-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
}
@media (min-width: 768px) {
  .col-md-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-md-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-md-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-md-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-md-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-md-9 {
    flex: 0 0 auto;
    width: 75%;
  }
}
@media (min-width: 992px) {
  .col-lg {
    flex: 1 0 0%;
  }
  .col-lg-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-lg-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-lg-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-lg-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-lg-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .g-lg-0 {
    --bs-gutter-x: 0;
  }
  .g-lg-0 {
    --bs-gutter-y: 0;
  }
}
.blog-entry-body table,
.table {
  --bs-table-color: var(--bs-body-color);
  --bs-table-bg: transparent;
  --bs-table-border-color: rgba(0, 0, 0, 0.1);
  --bs-table-accent-bg: transparent;
  --bs-table-striped-color: var(--bs-body-color);
  --bs-table-striped-bg: rgba(0, 0, 0, 0.05);
  --bs-table-active-color: var(--bs-body-color);
  --bs-table-active-bg: rgba(0, 0, 0, 0.1);
  --bs-table-hover-color: var(--bs-body-color);
  --bs-table-hover-bg: rgba(0, 0, 0, 0.075);
  width: 100%;
  margin-bottom: 1rem;
  color: var(--bs-table-color);
  vertical-align: top;
  border-color: var(--bs-table-border-color);
}
.blog-entry-body table > :not(caption) > * > *,
.table > :not(caption) > * > * {
  padding: 0.5rem 0.5rem;
  background-color: var(--bs-table-bg);
  border-bottom-width: 1px;
  box-shadow: inset 0 0 0 9999px var(--bs-table-accent-bg);
}
.blog-entry-body table > tbody,
.table > tbody {
  vertical-align: inherit;
}
.blog-entry-body table > thead,
.table > thead {
  vertical-align: bottom;
}
.form-control {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.7;
  color: #212529;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  appearance: none;
  border-radius: 4px;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-control {
    transition: none;
  }
}
.form-control[type="file"] {
  overflow: hidden;
}
.form-control[type="file"]:not(:disabled):not([readonly]) {
  cursor: pointer;
}
.form-control:focus {
  color: #212529;
  background-color: #fff;
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.form-control::-webkit-date-and-time-value {
  height: 1.7em;
}
.form-control::placeholder {
  color: #6c757d;
  opacity: 1;
}
.form-control:disabled {
  background-color: #e9ecef;
  opacity: 1;
}
.form-control::file-selector-button {
  padding: 0.375rem 0.75rem;
  margin: -0.375rem -0.75rem;
  margin-inline-end: 0.75rem;
  color: #212529;
  background-color: #e9ecef;
  pointer-events: none;
  border-color: inherit;
  border-style: solid;
  border-width: 0;
  border-inline-end-width: 1px;
  border-radius: 0;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-control::file-selector-button {
    transition: none;
  }
}
.form-control:hover:not(:disabled):not([readonly])::file-selector-button {
  background-color: #dde0e3;
}
textarea.form-control {
  min-height: calc(1.7em + 0.75rem + 2px);
}
.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%;
}
.input-group > .form-control {
  position: relative;
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
}
.input-group > .form-control:focus {
  z-index: 5;
}
.input-group .btn {
  position: relative;
  z-index: 2;
}
.input-group .btn:focus {
  z-index: 5;
}
.input-group:not(.has-validation) > .dropdown-toggle:nth-last-child(n + 3),
.input-group:not(.has-validation)
  > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(
    .form-floating
  ) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group
  > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(
    .valid-feedback
  ):not(.invalid-tooltip):not(.invalid-feedback) {
  margin-left: -1px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.btn {
  --bs-btn-padding-x: 0.75rem;
  --bs-btn-padding-y: 0.375rem;
  --bs-btn-font-size: 1rem;
  --bs-btn-font-weight: 400;
  --bs-btn-line-height: 1.7;
  --bs-btn-color: #212529;
  --bs-btn-bg: transparent;
  --bs-btn-border-width: 1px;
  --bs-btn-border-color: transparent;
  --bs-btn-border-radius: 4px;
  --bs-btn-hover-border-color: transparent;
  --bs-btn-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15),
    0 1px 1px rgba(0, 0, 0, 0.075);
  --bs-btn-disabled-opacity: 0.65;
  --bs-btn-focus-box-shadow: 0 0 0 0.25rem
    rgba(var(--bs-btn-focus-shadow-rgb), 0.5);
  display: inline-block;
  padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
  font-family: var(--bs-btn-font-family);
  font-size: var(--bs-btn-font-size);
  font-weight: var(--bs-btn-font-weight);
  line-height: var(--bs-btn-line-height);
  color: var(--bs-btn-color);
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  user-select: none;
  border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
  border-radius: var(--bs-btn-border-radius);
  background-color: var(--bs-btn-bg);
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .btn {
    transition: none;
  }
}
.btn:hover {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
}
.btn:focus-visible {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
  outline: 0;
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn.active,
.btn.show,
.btn:first-child:active,
:not(.btn-check) + .btn:active {
  color: var(--bs-btn-active-color);
  background-color: var(--bs-btn-active-bg);
  border-color: var(--bs-btn-active-border-color);
}
.btn.active:focus-visible,
.btn.show:focus-visible,
.btn:first-child:active:focus-visible,
:not(.btn-check) + .btn:active:focus-visible {
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn.disabled,
.btn:disabled,
fieldset:disabled .btn {
  color: var(--bs-btn-disabled-color);
  pointer-events: none;
  background-color: var(--bs-btn-disabled-bg);
  border-color: var(--bs-btn-disabled-border-color);
  opacity: var(--bs-btn-disabled-opacity);
}
.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: #0d6efd;
  --bs-btn-border-color: #0d6efd;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #0b5ed7;
  --bs-btn-hover-border-color: #0a58ca;
  --bs-btn-focus-shadow-rgb: 49, 132, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #0a58ca;
  --bs-btn-active-border-color: #0a53be;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #0d6efd;
  --bs-btn-disabled-border-color: #0d6efd;
}
.fade {
  transition: opacity 0.15s linear;
}
@media (prefers-reduced-motion: reduce) {
  .fade {
    transition: none;
  }
}
.fade:not(.show) {
  opacity: 0;
}
.collapse:not(.show) {
  display: none;
}
.collapsing {
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .collapsing {
    transition: none;
  }
}
.dropdown,
.dropend,
.dropstart,
.dropup {
  position: relative;
}
.dropdown-toggle {
  white-space: nowrap;
}
.dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-bottom: 0;
  border-left: 0.3em solid transparent;
}
.dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropdown-menu {
  --bs-dropdown-zindex: 1000;
  --bs-dropdown-min-width: 10rem;
  --bs-dropdown-padding-x: 0;
  --bs-dropdown-padding-y: 0.5rem;
  --bs-dropdown-spacer: 0.125rem;
  --bs-dropdown-font-size: 1rem;
  --bs-dropdown-color: #212529;
  --bs-dropdown-bg: #fff;
  --bs-dropdown-border-color: var(--bs-border-color-translucent);
  --bs-dropdown-border-radius: 4px;
  --bs-dropdown-border-width: 1px;
  --bs-dropdown-inner-border-radius: 3px;
  --bs-dropdown-divider-bg: var(--bs-border-color-translucent);
  --bs-dropdown-divider-margin-y: 0.5rem;
  --bs-dropdown-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-dropdown-link-color: #212529;
  --bs-dropdown-link-hover-color: #1e2125;
  --bs-dropdown-link-hover-bg: #e9ecef;
  --bs-dropdown-link-active-color: #fff;
  --bs-dropdown-link-active-bg: #0d6efd;
  --bs-dropdown-link-disabled-color: #adb5bd;
  --bs-dropdown-item-padding-x: 1rem;
  --bs-dropdown-item-padding-y: 0.25rem;
  --bs-dropdown-header-color: #6c757d;
  --bs-dropdown-header-padding-x: 1rem;
  --bs-dropdown-header-padding-y: 0.5rem;
  position: absolute;
  z-index: var(--bs-dropdown-zindex);
  display: none;
  min-width: var(--bs-dropdown-min-width);
  padding: var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);
  margin: 0;
  font-size: var(--bs-dropdown-font-size);
  color: var(--bs-dropdown-color);
  text-align: left;
  list-style: none;
  background-color: var(--bs-dropdown-bg);
  background-clip: padding-box;
  border: var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);
  border-radius: var(--bs-dropdown-border-radius);
}
.dropup .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0;
  border-right: 0.3em solid transparent;
  border-bottom: 0.3em solid;
  border-left: 0.3em solid transparent;
}
.dropup .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropend .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0;
  border-bottom: 0.3em solid transparent;
  border-left: 0.3em solid;
}
.dropend .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropend .dropdown-toggle::after {
  vertical-align: 0;
}
.dropstart .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
}
.dropstart .dropdown-toggle::after {
  display: none;
}
.dropstart .dropdown-toggle::before {
  display: inline-block;
  margin-right: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0.3em solid;
  border-bottom: 0.3em solid transparent;
}
.dropstart .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropstart .dropdown-toggle::before {
  vertical-align: 0;
}
.dropdown-item {
  display: block;
  width: 100%;
  padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
  clear: both;
  font-weight: 400;
  color: var(--bs-dropdown-link-color);
  text-align: inherit;
  text-decoration: none;
  white-space: nowrap;
  background-color: rgba(0, 0, 0, 0);
  border: 0;
}
.dropdown-item:focus,
.dropdown-item:hover {
  color: var(--bs-dropdown-link-hover-color);
  background-color: var(--bs-dropdown-link-hover-bg);
}
.dropdown-item.active,
.dropdown-item:active {
  color: var(--bs-dropdown-link-active-color);
  text-decoration: none;
  background-color: var(--bs-dropdown-link-active-bg);
}
.dropdown-item.disabled,
.dropdown-item:disabled {
  color: var(--bs-dropdown-link-disabled-color);
  pointer-events: none;
  background-color: rgba(0, 0, 0, 0);
}
.dropdown-menu.show {
  display: block;
}
.nav {
  --bs-nav-link-padding-x: 1rem;
  --bs-nav-link-padding-y: 0.5rem;
  --bs-nav-link-color: var(--bs-link-color);
  --bs-nav-link-hover-color: var(--bs-link-hover-color);
  --bs-nav-link-disabled-color: #6c757d;
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.nav-link {
  display: block;
  padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
  font-size: var(--bs-nav-link-font-size);
  font-weight: var(--bs-nav-link-font-weight);
  color: var(--bs-nav-link-color);
  text-decoration: none;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .nav-link {
    transition: none;
  }
}
.nav-link:focus,
.nav-link:hover {
  color: var(--bs-nav-link-hover-color);
}
.nav-link.disabled {
  color: var(--bs-nav-link-disabled-color);
  pointer-events: none;
  cursor: default;
}
.nav-tabs-1 {
  --bs-nav-tabs-border-width: 1px;
  --bs-nav-tabs-border-color: #dee2e6;
  --bs-nav-tabs-border-radius: 4px;
  --bs-nav-tabs-link-hover-border-color: #e9ecef #e9ecef #dee2e6;
  --bs-nav-tabs-link-active-color: #495057;
  --bs-nav-tabs-link-active-bg: #fff;
  --bs-nav-tabs-link-active-border-color: #dee2e6 #dee2e6 #fff;
  border-bottom: var(--bs-nav-tabs-border-width) solid
    var(--bs-nav-tabs-border-color);
}
.nav-tabs-1 .nav-link {
  margin-bottom: calc(-1 * var(--bs-nav-tabs-border-width));
  background: 0 0;
  border: var(--bs-nav-tabs-border-width) solid transparent;
  border-top-left-radius: var(--bs-nav-tabs-border-radius);
  border-top-right-radius: var(--bs-nav-tabs-border-radius);
}
.nav-tabs-1 .nav-link:focus,
.nav-tabs-1 .nav-link:hover {
  isolation: isolate;
  border-color: var(--bs-nav-tabs-link-hover-border-color);
}
.nav-tabs-1 .nav-link.disabled,
.nav-tabs-1 .nav-link:disabled {
  color: var(--bs-nav-link-disabled-color);
  background-color: rgba(0, 0, 0, 0);
  border-color: transparent;
}
.nav-tabs-1 .nav-item.show .nav-link,
.nav-tabs-1 .nav-link.active {
  color: var(--bs-nav-tabs-link-active-color);
  background-color: var(--bs-nav-tabs-link-active-bg);
  border-color: var(--bs-nav-tabs-link-active-border-color);
}
.nav-tabs-1 .dropdown-menu {
  margin-top: calc(-1 * var(--bs-nav-tabs-border-width));
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.tab-content > .tab-pane {
  display: none;
}
.tab-content > .active {
  display: block;
}
.navbar {
  --bs-navbar-padding-x: 0;
  --bs-navbar-padding-y: 0.5rem;
  --bs-navbar-color: rgba(0, 0, 0, 0.55);
  --bs-navbar-hover-color: rgba(0, 0, 0, 0.7);
  --bs-navbar-disabled-color: rgba(0, 0, 0, 0.3);
  --bs-navbar-active-color: rgba(0, 0, 0, 0.9);
  --bs-navbar-brand-padding-y: 0.2875rem;
  --bs-navbar-brand-margin-end: 1rem;
  --bs-navbar-brand-font-size: 1.25rem;
  --bs-navbar-brand-color: rgba(0, 0, 0, 0.9);
  --bs-navbar-brand-hover-color: rgba(0, 0, 0, 0.9);
  --bs-navbar-nav-link-padding-x: 0.5rem;
  --bs-navbar-toggler-padding-y: 0.25rem;
  --bs-navbar-toggler-padding-x: 0.75rem;
  --bs-navbar-toggler-font-size: 1.25rem;
  --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  --bs-navbar-toggler-border-color: rgba(0, 0, 0, 0.1);
  --bs-navbar-toggler-border-radius: 4px;
  --bs-navbar-toggler-focus-width: 0.25rem;
  --bs-navbar-toggler-transition: box-shadow 0.15s ease-in-out;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: var(--bs-navbar-padding-y) var(--bs-navbar-padding-x);
}
.navbar > .container,
.navbar > .container-fluid {
  display: flex;
  flex-wrap: inherit;
  align-items: center;
  justify-content: space-between;
}
.navbar-nav {
  --bs-nav-link-padding-x: 0;
  --bs-nav-link-padding-y: 0.5rem;
  --bs-nav-link-color: var(--bs-navbar-color);
  --bs-nav-link-hover-color: var(--bs-navbar-hover-color);
  --bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.navbar-nav .nav-link.active,
.navbar-nav .show > .nav-link {
  color: var(--bs-navbar-active-color);
}
.navbar-nav .dropdown-menu {
  position: static;
}
.card {
  --bs-card-spacer-y: 1rem;
  --bs-card-spacer-x: 1rem;
  --bs-card-title-spacer-y: 0.5rem;
  --bs-card-border-width: 1px;
  --bs-card-border-color: var(--bs-border-color-translucent);
  --bs-card-border-radius: 4px;
  --bs-card-inner-border-radius: 3px;
  --bs-card-cap-padding-y: 0.5rem;
  --bs-card-cap-padding-x: 1rem;
  --bs-card-cap-bg: rgba(0, 0, 0, 0.03);
  --bs-card-bg: #fff;
  --bs-card-img-overlay-padding: 1rem;
  --bs-card-group-margin: 30px;
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: var(--bs-card-height);
  word-wrap: break-word;
  background-color: var(--bs-card-bg);
  background-clip: border-box;
  border: var(--bs-card-border-width) solid var(--bs-card-border-color);
  border-radius: var(--bs-card-border-radius);
}
.card > hr {
  margin-right: 0;
  margin-left: 0;
}
.card > .list-group {
  border-top: inherit;
  border-bottom: inherit;
}
.card > .list-group:first-child {
  border-top-width: 0;
  border-top-left-radius: var(--bs-card-inner-border-radius);
  border-top-right-radius: var(--bs-card-inner-border-radius);
}
.card > .list-group:last-child {
  border-bottom-width: 0;
  border-bottom-right-radius: var(--bs-card-inner-border-radius);
  border-bottom-left-radius: var(--bs-card-inner-border-radius);
}
.accordion {
  --bs-accordion-color: #212529;
  --bs-accordion-bg: #fff;
  --bs-accordion-transition: color 0.15s ease-in-out,
    background-color 0.15s ease-in-out, border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out, border-radius 0.15s ease;
  --bs-accordion-border-color: var(--bs-border-color);
  --bs-accordion-border-width: 1px;
  --bs-accordion-border-radius: 4px;
  --bs-accordion-inner-border-radius: 3px;
  --bs-accordion-btn-padding-x: 1.25rem;
  --bs-accordion-btn-padding-y: 1rem;
  --bs-accordion-btn-color: #212529;
  --bs-accordion-btn-bg: var(--bs-accordion-bg);
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
  --bs-accordion-btn-icon-width: 1.25rem;
  --bs-accordion-btn-icon-transform: rotate(-180deg);
  --bs-accordion-btn-icon-transition: transform 0.2s ease-in-out;
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230c63e4'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
  --bs-accordion-btn-focus-border-color: #86b7fe;
  --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
  --bs-accordion-body-padding-x: 1.25rem;
  --bs-accordion-body-padding-y: 1rem;
  --bs-accordion-active-color: #0c63e4;
  --bs-accordion-active-bg: #e7f1ff;
}
.pagination {
  --bs-pagination-padding-x: 0.75rem;
  --bs-pagination-padding-y: 0.375rem;
  --bs-pagination-font-size: 1rem;
  --bs-pagination-color: var(--bs-link-color);
  --bs-pagination-bg: #fff;
  --bs-pagination-border-width: 1px;
  --bs-pagination-border-color: #dee2e6;
  --bs-pagination-border-radius: 4px;
  --bs-pagination-hover-color: var(--bs-link-hover-color);
  --bs-pagination-hover-bg: #e9ecef;
  --bs-pagination-hover-border-color: #dee2e6;
  --bs-pagination-focus-color: var(--bs-link-hover-color);
  --bs-pagination-focus-bg: #e9ecef;
  --bs-pagination-focus-box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
  --bs-pagination-active-color: #fff;
  --bs-pagination-active-bg: #0d6efd;
  --bs-pagination-active-border-color: #0d6efd;
  --bs-pagination-disabled-color: #6c757d;
  --bs-pagination-disabled-bg: #fff;
  --bs-pagination-disabled-border-color: #dee2e6;
  display: flex;
  padding-left: 0;
  list-style: none;
}
.alert {
  --bs-alert-bg: transparent;
  --bs-alert-padding-x: 1rem;
  --bs-alert-padding-y: 1rem;
  --bs-alert-margin-bottom: 1rem;
  --bs-alert-color: inherit;
  --bs-alert-border-color: transparent;
  --bs-alert-border: 1px solid var(--bs-alert-border-color);
  --bs-alert-border-radius: 4px;
  position: relative;
  padding: var(--bs-alert-padding-y) var(--bs-alert-padding-x);
  margin-bottom: var(--bs-alert-margin-bottom);
  color: var(--bs-alert-color);
  background-color: var(--bs-alert-bg);
  border: var(--bs-alert-border);
  border-radius: var(--bs-alert-border-radius);
}
@keyframes progress-bar-stripes {
  0% {
    background-position-x: 1rem;
  }
}
.progress {
  --bs-progress-height: 1rem;
  --bs-progress-font-size: 0.75rem;
  --bs-progress-bg: #e9ecef;
  --bs-progress-border-radius: 4px;
  --bs-progress-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  --bs-progress-bar-color: #fff;
  --bs-progress-bar-bg: #0d6efd;
  --bs-progress-bar-transition: width 0.6s ease;
  display: flex;
  height: var(--bs-progress-height);
  overflow: hidden;
  font-size: var(--bs-progress-font-size);
  background-color: var(--bs-progress-bg);
  border-radius: var(--bs-progress-border-radius);
}
.list-group {
  --bs-list-group-color: #212529;
  --bs-list-group-bg: #fff;
  --bs-list-group-border-color: rgba(0, 0, 0, 0.125);
  --bs-list-group-border-width: 1px;
  --bs-list-group-border-radius: 4px;
  --bs-list-group-item-padding-x: 1rem;
  --bs-list-group-item-padding-y: 0.5rem;
  --bs-list-group-action-color: #495057;
  --bs-list-group-action-hover-color: #495057;
  --bs-list-group-action-hover-bg: #f8f9fa;
  --bs-list-group-action-active-color: #212529;
  --bs-list-group-action-active-bg: #e9ecef;
  --bs-list-group-disabled-color: #6c757d;
  --bs-list-group-disabled-bg: #fff;
  --bs-list-group-active-color: #fff;
  --bs-list-group-active-bg: #0d6efd;
  --bs-list-group-active-border-color: #0d6efd;
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  border-radius: var(--bs-list-group-border-radius);
}
.list-group-item {
  position: relative;
  display: block;
  padding: var(--bs-list-group-item-padding-y)
    var(--bs-list-group-item-padding-x);
  color: var(--bs-list-group-color);
  text-decoration: none;
  background-color: var(--bs-list-group-bg);
  border: var(--bs-list-group-border-width) solid
    var(--bs-list-group-border-color);
}
.list-group-item:first-child {
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}
.list-group-item:last-child {
  border-bottom-right-radius: inherit;
  border-bottom-left-radius: inherit;
}
.list-group-item.disabled,
.list-group-item:disabled {
  color: var(--bs-list-group-disabled-color);
  pointer-events: none;
  background-color: var(--bs-list-group-disabled-bg);
}
.list-group-item.active {
  z-index: 2;
  color: var(--bs-list-group-active-color);
  background-color: var(--bs-list-group-active-bg);
  border-color: var(--bs-list-group-active-border-color);
}
.list-group-item + .list-group-item {
  border-top-width: 0;
}
.list-group-item + .list-group-item.active {
  margin-top: calc(-1 * var(--bs-list-group-border-width));
  border-top-width: var(--bs-list-group-border-width);
}
.toast {
  --bs-toast-zindex: 1090;
  --bs-toast-padding-x: 0.75rem;
  --bs-toast-padding-y: 0.5rem;
  --bs-toast-spacing: 60px;
  --bs-toast-max-width: 350px;
  --bs-toast-font-size: 0.875rem;
  --bs-toast-bg: rgba(255, 255, 255, 0.85);
  --bs-toast-border-width: 1px;
  --bs-toast-border-color: var(--bs-border-color-translucent);
  --bs-toast-border-radius: 4px;
  --bs-toast-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-toast-header-color: #6c757d;
  --bs-toast-header-bg: rgba(255, 255, 255, 0.85);
  --bs-toast-header-border-color: rgba(0, 0, 0, 0.05);
  width: var(--bs-toast-max-width);
  max-width: 100%;
  font-size: var(--bs-toast-font-size);
  color: var(--bs-toast-color);
  pointer-events: auto;
  background-color: var(--bs-toast-bg);
  background-clip: padding-box;
  border: var(--bs-toast-border-width) solid var(--bs-toast-border-color);
  box-shadow: var(--bs-toast-box-shadow);
  border-radius: var(--bs-toast-border-radius);
}
.toast.showing {
  opacity: 0;
}
.toast:not(.show) {
  display: none;
}
.modal {
  --bs-modal-zindex: 1055;
  --bs-modal-width: 500px;
  --bs-modal-padding: 1rem;
  --bs-modal-margin: 0.5rem;
  --bs-modal-bg: #fff;
  --bs-modal-border-color: var(--bs-border-color-translucent);
  --bs-modal-border-width: 1px;
  --bs-modal-border-radius: 0.5rem;
  --bs-modal-box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --bs-modal-inner-border-radius: calc(0.5rem - 1px);
  --bs-modal-header-padding-x: 1rem;
  --bs-modal-header-padding-y: 1rem;
  --bs-modal-header-padding: 1rem 1rem;
  --bs-modal-header-border-color: var(--bs-border-color);
  --bs-modal-header-border-width: 1px;
  --bs-modal-title-line-height: 1.7;
  --bs-modal-footer-gap: 0.5rem;
  --bs-modal-footer-border-color: var(--bs-border-color);
  --bs-modal-footer-border-width: 1px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--bs-modal-zindex);
  display: none;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
}
.modal-dialog {
  position: relative;
  width: auto;
  margin: var(--bs-modal-margin);
  pointer-events: none;
}
.modal.fade .modal-dialog {
  transition: transform 0.3s ease-out;
  transform: translate(0, -50px);
}
@media (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog {
    transition: none;
  }
}
.modal.show .modal-dialog {
  transform: none;
}
.modal.modal-static .modal-dialog {
  transform: scale(1.02);
}
.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  color: var(--bs-modal-color);
  pointer-events: auto;
  background-color: var(--bs-modal-bg);
  background-clip: padding-box;
  border: var(--bs-modal-border-width) solid var(--bs-modal-border-color);
  border-radius: var(--bs-modal-border-radius);
  outline: 0;
}
.modal-backdrop {
  --bs-backdrop-zindex: 1050;
  --bs-backdrop-bg: #000;
  --bs-backdrop-opacity: 0.5;
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--bs-backdrop-zindex);
  width: 100vw;
  height: 100vh;
  background-color: var(--bs-backdrop-bg);
}
.modal-backdrop.fade {
  opacity: 0;
}
.modal-backdrop.show {
  opacity: var(--bs-backdrop-opacity);
}
.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: var(--bs-modal-padding);
}
@media (min-width: 576px) {
  .modal {
    --bs-modal-margin: 1.75rem;
    --bs-modal-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  }
  .modal-dialog {
    max-width: var(--bs-modal-width);
    margin-right: auto;
    margin-left: auto;
  }
}
.tooltip {
  --bs-tooltip-zindex: 1080;
  --bs-tooltip-max-width: 200px;
  --bs-tooltip-padding-x: 0.5rem;
  --bs-tooltip-padding-y: 0.25rem;
  --bs-tooltip-font-size: 0.875rem;
  --bs-tooltip-color: #fff;
  --bs-tooltip-bg: #000;
  --bs-tooltip-border-radius: 4px;
  --bs-tooltip-opacity: 0.9;
  --bs-tooltip-arrow-width: 0.8rem;
  --bs-tooltip-arrow-height: 0.4rem;
  z-index: var(--bs-tooltip-zindex);
  display: block;
  padding: var(--bs-tooltip-arrow-height);
  margin: var(--bs-tooltip-margin);
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-style: normal;
  font-weight: 400;
  line-height: 1.7;
  text-align: left;
  text-align: start;
  text-decoration: none;
  text-shadow: none;
  text-transform: none;
  letter-spacing: normal;
  word-break: normal;
  white-space: normal;
  word-spacing: normal;
  line-break: auto;
  font-size: var(--bs-tooltip-font-size);
  word-wrap: break-word;
  opacity: 0;
}
.tooltip.show {
  opacity: var(--bs-tooltip-opacity);
}
.tooltip .tooltip-arrow {
  display: block;
  width: var(--bs-tooltip-arrow-width);
  height: var(--bs-tooltip-arrow-height);
}
.tooltip .tooltip-arrow::before {
  position: absolute;
  content: "";
  border-color: transparent;
  border-style: solid;
}
.tooltip-inner {
  max-width: var(--bs-tooltip-max-width);
  padding: var(--bs-tooltip-padding-y) var(--bs-tooltip-padding-x);
  color: var(--bs-tooltip-color);
  text-align: center;
  background-color: var(--bs-tooltip-bg);
  border-radius: var(--bs-tooltip-border-radius);
}
.popover {
  --bs-popover-zindex: 1070;
  --bs-popover-max-width: 276px;
  --bs-popover-font-size: 0.875rem;
  --bs-popover-bg: #fff;
  --bs-popover-border-width: 1px;
  --bs-popover-border-color: var(--bs-border-color-translucent);
  --bs-popover-border-radius: 0.5rem;
  --bs-popover-inner-border-radius: calc(0.5rem - 1px);
  --bs-popover-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-popover-header-padding-x: 1rem;
  --bs-popover-header-padding-y: 0.5rem;
  --bs-popover-header-font-size: 1rem;
  --bs-popover-header-bg: #f0f0f0;
  --bs-popover-body-padding-x: 1rem;
  --bs-popover-body-padding-y: 1rem;
  --bs-popover-body-color: #212529;
  --bs-popover-arrow-width: 1rem;
  --bs-popover-arrow-height: 0.5rem;
  --bs-popover-arrow-border: var(--bs-popover-border-color);
  z-index: var(--bs-popover-zindex);
  display: block;
  max-width: var(--bs-popover-max-width);
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-style: normal;
  font-weight: 400;
  line-height: 1.7;
  text-align: left;
  text-align: start;
  text-decoration: none;
  text-shadow: none;
  text-transform: none;
  letter-spacing: normal;
  word-break: normal;
  white-space: normal;
  word-spacing: normal;
  line-break: auto;
  font-size: var(--bs-popover-font-size);
  word-wrap: break-word;
  background-color: var(--bs-popover-bg);
  background-clip: padding-box;
  border: var(--bs-popover-border-width) solid var(--bs-popover-border-color);
  border-radius: var(--bs-popover-border-radius);
}
.popover .popover-arrow {
  display: block;
  width: var(--bs-popover-arrow-width);
  height: var(--bs-popover-arrow-height);
}
.popover .popover-arrow::after,
.popover .popover-arrow::before {
  position: absolute;
  display: block;
  content: "";
  border-color: transparent;
  border-style: solid;
  border-width: 0;
}
.popover-header {
  padding: var(--bs-popover-header-padding-y) var(--bs-popover-header-padding-x);
  margin-bottom: 0;
  font-size: var(--bs-popover-header-font-size);
  color: var(--bs-popover-header-color);
  background-color: var(--bs-popover-header-bg);
  border-bottom: var(--bs-popover-border-width) solid
    var(--bs-popover-border-color);
  border-top-left-radius: var(--bs-popover-inner-border-radius);
  border-top-right-radius: var(--bs-popover-inner-border-radius);
}
.popover-header:empty {
  display: none;
}
.popover-body {
  padding: var(--bs-popover-body-padding-y) var(--bs-popover-body-padding-x);
  color: var(--bs-popover-body-color);
}
.carousel {
  position: relative;
}
.carousel.pointer-event {
  touch-action: pan-y;
}
.carousel-item {
  position: relative;
  display: none;
  float: left;
  width: 100%;
  margin-right: -100%;
  backface-visibility: hidden;
  transition: transform 0.6s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-item {
    transition: none;
  }
}
.carousel-item-next,
.carousel-item-prev,
.carousel-item.active {
  display: block;
}
.active.carousel-item-end,
.carousel-item-next:not(.carousel-item-start) {
  transform: translateX(100%);
}
.active.carousel-item-start,
.carousel-item-prev:not(.carousel-item-end) {
  transform: translateX(-100%);
}
.carousel-indicators {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  display: flex;
  justify-content: center;
  padding: 0;
  margin-right: 15%;
  margin-bottom: 1rem;
  margin-left: 15%;
  list-style: none;
}
.carousel-indicators [data-bs-target] {
  box-sizing: content-box;
  flex: 0 1 auto;
  width: 30px;
  height: 3px;
  padding: 0;
  margin-right: 3px;
  margin-left: 3px;
  text-indent: -999px;
  cursor: pointer;
  background-color: #fff;
  background-clip: padding-box;
  border: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  opacity: 0.5;
  transition: opacity 0.6s ease;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-indicators [data-bs-target] {
    transition: none;
  }
}
.carousel-indicators .active {
  opacity: 1;
}
@keyframes spinner-border {
  to {
    transform: rotate(360deg);
  }
}
@keyframes spinner-grow {
  0% {
    transform: scale(0);
  }
  50% {
    opacity: 1;
    transform: none;
  }
}
.offcanvas {
  --bs-offcanvas-zindex: 1045;
  --bs-offcanvas-width: 400px;
  --bs-offcanvas-height: 30vh;
  --bs-offcanvas-padding-x: 1rem;
  --bs-offcanvas-padding-y: 1rem;
  --bs-offcanvas-bg: #fff;
  --bs-offcanvas-border-width: 1px;
  --bs-offcanvas-border-color: var(--bs-border-color-translucent);
  --bs-offcanvas-box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}
.offcanvas {
  position: fixed;
  bottom: 0;
  z-index: var(--bs-offcanvas-zindex);
  display: flex;
  flex-direction: column;
  max-width: 100%;
  color: var(--bs-offcanvas-color);
  visibility: hidden;
  background-color: var(--bs-offcanvas-bg);
  background-clip: padding-box;
  outline: 0;
  transition: transform 0.3s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .offcanvas {
    transition: none;
  }
}
.offcanvas.show:not(.hiding),
.offcanvas.showing {
  transform: none;
}
.offcanvas.hiding,
.offcanvas.show,
.offcanvas.showing {
  visibility: visible;
}
.placeholder {
  display: inline-block;
  min-height: 1em;
  vertical-align: middle;
  cursor: wait;
  background-color: currentcolor;
  opacity: 0.5;
}
.placeholder.btn::before {
  display: inline-block;
  content: "";
}
@keyframes placeholder-glow {
  50% {
    opacity: 0.2;
  }
}
@keyframes placeholder-wave {
  100% {
    mask-position: -200% 0;
  }
}
.blog-archive-container::after,
.clearfix::after {
  display: block;
  clear: both;
  content: "";
}
.ratio {
  position: relative;
  width: 100%;
}
.ratio::before {
  display: block;
  padding-top: var(--bs-aspect-ratio);
  content: "";
}
.ratio > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.fixed-top {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1030;
}
.fixed-bottom {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1030;
}
.sticky-top {
  position: sticky;
  top: 0;
  z-index: 1020;
}
.vr {
  display: inline-block;
  align-self: stretch;
  width: 1px;
  min-height: 1em;
  background-color: currentcolor;
  opacity: 0.25;
}
.shadow {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}
.border {
  border: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
.border-1 {
  --bs-border-width: 1px;
}
.h-50 {
  height: 50% !important;
}
.flex-grow-1 {
  flex-grow: 1 !important;
}
.flex-shrink-0 {
  flex-shrink: 0 !important;
}
.flex-wrap {
  flex-wrap: wrap !important;
}
.order-1 {
  order: 1 !important;
}
.order-2 {
  order: 2 !important;
}
.m-1 {
  margin: 0.25rem !important;
}
.p-0 {
  padding: 0 !important;
}
.p-1 {
  padding: 0.25rem !important;
}
.gap-5 {
  gap: 3rem !important;
}
.text-center {
  text-align: center !important;
}
.text-decoration-none {
  text-decoration: none !important;
}
.text-uppercase {
  text-transform: uppercase !important;
}
.bg-transparent {
  --bs-bg-opacity: 1;
  background-color: rgba(0, 0, 0, 0) !important;
}
.visible {
  visibility: visible !important;
}
@media (min-width: 576px) {
  .order-sm-1 {
    order: 1 !important;
  }
  .order-sm-2 {
    order: 2 !important;
  }
  .order-sm-3 {
    order: 3 !important;
  }
  .p-sm-0 {
    padding: 0 !important;
  }
}
@media (min-width: 992px) {
  .text-lg-center {
    text-align: center !important;
  }
}
.g-a {
  margin: auto !important;
}
.g {
  margin: 40px !important;
}
.g-h {
  margin-left: 40px !important;
  margin-right: 40px !important;
}
.g-v {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}
.g-h-a {
  margin-left: auto !important;
  margin-right: auto !important;
}
.g-t {
  margin-top: 40px !important;
}
.g-b {
  margin-bottom: 40px !important;
}
.p {
  padding: 40px !important;
}
.p-v {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}
.p-t {
  padding-top: 40px !important;
}
.p-b {
  padding-bottom: 40px !important;
}
.p-l {
  padding-left: 40px !important;
}
@media screen and (min-width: 992px) {
  .g {
    margin: 80px !important;
  }
  .g-h {
    margin-left: 80px !important;
    margin-right: 80px !important;
  }
  .g-v {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
  }
  .g-t {
    margin-top: 80px !important;
  }
  .g-b {
    margin-bottom: 80px !important;
  }
  .p {
    padding: 80px !important;
  }
  .p-v {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }
  .p-t {
    padding-top: 80px !important;
  }
  .p-b {
    padding-bottom: 80px !important;
  }
  .p-l {
    padding-left: 80px !important;
  }
}
.g-v--1 {
  margin-top: -1px !important;
  margin-bottom: -1px !important;
}
.g-b--1 {
  margin-bottom: -1px !important;
}
.g-b--3 {
  margin-bottom: -3px !important;
}
.g-t--5 {
  margin-top: -5px !important;
}
.g-h--10 {
  margin-left: -10px !important;
  margin-right: -10px !important;
}
.g-t--10 {
  margin-top: -10px !important;
}
.g-b--10 {
  margin-bottom: -10px !important;
}
.g-t--15 {
  margin-top: -15px !important;
}
.g-b--15 {
  margin-bottom: -15px !important;
}
.g-t--20 {
  margin-top: -20px !important;
}
.g-b--20 {
  margin-bottom: -20px !important;
}
.g-b--25 {
  margin-bottom: -25px !important;
}
.g-t--30 {
  margin-top: -30px !important;
}
.g-t--40 {
  margin-top: -40px !important;
}
.g-t--50 {
  margin-top: -50px !important;
}
.g-h--90 {
  margin-left: -90px !important;
  margin-right: -90px !important;
}
.g-0 {
  margin: 0 !important;
}
.g-v-0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.g-t-0 {
  margin-top: 0 !important;
}
.g-b-0 {
  margin-bottom: 0 !important;
}
.p-0 {
  padding: 0 !important;
}
.p-h-0 {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.p-v-0 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.p-r-0 {
  padding-right: 0 !important;
}
.g-b-1 {
  margin-bottom: 1px !important;
}
.p-1 {
  padding: 1px !important;
}
.p-v-1 {
  padding-top: 1px !important;
  padding-bottom: 1px !important;
}
.p-t-1 {
  padding-top: 1px !important;
}
.p-b-1 {
  padding-bottom: 1px !important;
}
.p-v-2 {
  padding-top: 2px !important;
  padding-bottom: 2px !important;
}
.p-t-2 {
  padding-top: 2px !important;
}
.g-t-2p {
  margin-top: 2% !important;
}
.g-b-2p {
  margin-bottom: 2% !important;
}
.p-v-2p {
  padding-top: 2% !important;
  padding-bottom: 2% !important;
}
.g-t-20p {
  margin-top: 20% !important;
}
.g-h-3 {
  margin-left: 3px !important;
  margin-right: 3px !important;
}
.g-l-3 {
  margin-left: 3px !important;
}
.p-b-3 {
  padding-bottom: 3px !important;
}
.g-l-3p {
  margin-left: 3% !important;
}
.p-h-3p {
  padding-left: 3% !important;
  padding-right: 3% !important;
}
.g-t-4 {
  margin-top: 4px !important;
}
.g-r-4 {
  margin-right: 4px !important;
}
.g-b-4 {
  margin-bottom: 4px !important;
}
.p-h-4 {
  padding-left: 4px !important;
  padding-right: 4px !important;
}
.p-v-4 {
  padding-top: 4px !important;
  padding-bottom: 4px !important;
}
.g-h-4p {
  margin-left: 4% !important;
  margin-right: 4% !important;
}
.p-v-4p {
  padding-top: 4% !important;
  padding-bottom: 4% !important;
}
.p-b-4p {
  padding-bottom: 4% !important;
}
.g-t-5 {
  margin-top: 5px !important;
}
.g-r-5 {
  margin-right: 5px !important;
}
.g-b-5 {
  margin-bottom: 5px !important;
}
.p-v-5 {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}
.p-t-5 {
  padding-top: 5px !important;
}
.p-r-5 {
  padding-right: 5px !important;
}
.p-b-5 {
  padding-bottom: 5px !important;
}
.p-5p {
  padding: 5% !important;
}
.p-h-5p {
  padding-left: 5% !important;
  padding-right: 5% !important;
}
.p-l-5p {
  padding-left: 5% !important;
}
.g-b-6 {
  margin-bottom: 6px !important;
}
.g-t-6p {
  margin-top: 6% !important;
}
.p-6p {
  padding: 6% !important;
}
.p-h-6p {
  padding-left: 6% !important;
  padding-right: 6% !important;
}
.g-v-7 {
  margin-top: 7px !important;
  margin-bottom: 7px !important;
}
.g-b-7 {
  margin-bottom: 7px !important;
}
.p-h-7p {
  padding-left: 7% !important;
  padding-right: 7% !important;
}
.g-t-8 {
  margin-top: 8px !important;
}
.g-r-8 {
  margin-right: 8px !important;
}
.p-v-8p {
  padding-top: 8% !important;
  padding-bottom: 8% !important;
}
.p-t-8p {
  padding-top: 8% !important;
}
.g-b-9 {
  margin-bottom: 9px !important;
}
.g-b-9p {
  margin-bottom: 9% !important;
}
.p-h-9p {
  padding-left: 9% !important;
  padding-right: 9% !important;
}
.g-h-10 {
  margin-left: 10px !important;
  margin-right: 10px !important;
}
.g-v-10 {
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}
.g-t-10 {
  margin-top: 10px !important;
}
.g-r-10 {
  margin-right: 10px !important;
}
.g-b-10 {
  margin-bottom: 10px !important;
}
.p-10 {
  padding: 10px !important;
}
.p-h-10 {
  padding-left: 10px !important;
  padding-right: 10px !important;
}
.p-v-10 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}
.p-t-10 {
  padding-top: 10px !important;
}
.p-b-10 {
  padding-bottom: 10px !important;
}
.g-v-15 {
  margin-top: 15px !important;
  margin-bottom: 15px !important;
}
.g-t-15 {
  margin-top: 15px !important;
}
.g-r-15 {
  margin-right: 15px !important;
}
.g-b-15 {
  margin-bottom: 15px !important;
}
.g-l-15 {
  margin-left: 15px !important;
}
.p-15 {
  padding: 15px !important;
}
.p-h-15 {
  padding-left: 15px !important;
  padding-right: 15px !important;
}
.p-v-15 {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}
.p-t-15 {
  padding-top: 15px !important;
}
.p-b-15 {
  padding-bottom: 15px !important;
}
.g-v-20 {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}
.g-t-20 {
  margin-top: 20px !important;
}
.g-b-20 {
  margin-bottom: 20px !important;
}
.p-20 {
  padding: 20px !important;
}
.p-h-20 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}
.p-v-20 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}
.p-t-20 {
  padding-top: 20px !important;
}
.p-b-20 {
  padding-bottom: 20px !important;
}
.g-h-25 {
  margin-left: 25px !important;
  margin-right: 25px !important;
}
.g-v-25 {
  margin-top: 25px !important;
  margin-bottom: 25px !important;
}
.g-t-25 {
  margin-top: 25px !important;
}
.g-b-25 {
  margin-bottom: 25px !important;
}
.p-25 {
  padding: 25px !important;
}
.p-h-25 {
  padding-left: 25px !important;
  padding-right: 25px !important;
}
.p-v-25 {
  padding-top: 25px !important;
  padding-bottom: 25px !important;
}
.g-v-30 {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}
.g-t-30 {
  margin-top: 30px !important;
}
.g-b-30 {
  margin-bottom: 30px !important;
}
.p-30 {
  padding: 30px !important;
}
.p-h-30 {
  padding-left: 30px !important;
  padding-right: 30px !important;
}
.p-v-30 {
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}
.p-t-30 {
  padding-top: 30px !important;
}
.p-b-30 {
  padding-bottom: 30px !important;
}
.p-l-30 {
  padding-left: 30px !important;
}
.g-t-40 {
  margin-top: 40px !important;
}
.g-b-40 {
  margin-bottom: 40px !important;
}
.p-h-40 {
  padding-left: 40px !important;
  padding-right: 40px !important;
}
.p-v-40 {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}
.p-t-40 {
  padding-top: 40px !important;
}
.g-t-45 {
  margin-top: 45px !important;
}
.g-v-50 {
  margin-top: 50px !important;
  margin-bottom: 50px !important;
}
.g-t-50 {
  margin-top: 50px !important;
}
.g-b-50 {
  margin-bottom: 50px !important;
}
.p-t-50 {
  padding-top: 50px !important;
}
.g-v-60 {
  margin-top: 60px !important;
  margin-bottom: 60px !important;
}
.g-t-60 {
  margin-top: 60px !important;
}
.g-b-60 {
  margin-bottom: 60px !important;
}
.p-b-60 {
  padding-bottom: 60px !important;
}
.p-b-70 {
  padding-bottom: 70px !important;
}
@media screen and (max-width: 767px) {
  .g-xs-t--10 {
    margin-top: -10px !important;
  }
  .g-xs-h--15 {
    margin-left: -15px !important;
    margin-right: -15px !important;
  }
  .g-xs-t--20 {
    margin-top: -20px !important;
  }
  .g-xs-r--25 {
    margin-right: -25px !important;
  }
  .g-xs-t-0 {
    margin-top: 0 !important;
  }
  .g-xs-r-0 {
    margin-right: 0 !important;
  }
  .g-xs-b-0 {
    margin-bottom: 0 !important;
  }
  .p-xs-0 {
    padding: 0 !important;
  }
  .p-xs-h-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .p-xs-b-0 {
    padding-bottom: 0 !important;
  }
  .p-xs-h-1p {
    padding-left: 1% !important;
    padding-right: 1% !important;
  }
  .p-xs-h-4p {
    padding-left: 4% !important;
    padding-right: 4% !important;
  }
  .p-xs-v-7p {
    padding-top: 7% !important;
    padding-bottom: 7% !important;
  }
  .p-xs-9p {
    padding: 9% !important;
  }
  .g-xs-t-0 {
    margin-top: 0 !important;
  }
  .g-xs-r-0 {
    margin-right: 0 !important;
  }
  .g-xs-b-0 {
    margin-bottom: 0 !important;
  }
  .p-xs-0 {
    padding: 0 !important;
  }
  .p-xs-h-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .p-xs-b-0 {
    padding-bottom: 0 !important;
  }
  .g-xs-b-10 {
    margin-bottom: 10px !important;
  }
  .p-xs-h-10 {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .g-xs-b-15 {
    margin-bottom: 15px !important;
  }
  .g-xs-b-20 {
    margin-bottom: 20px !important;
  }
  .p-xs-b-20 {
    padding-bottom: 20px !important;
  }
  .g-xs-b-25 {
    margin-bottom: 25px !important;
  }
  .g-xs-v-30 {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
  }
  .g-xs-t-30 {
    margin-top: 30px !important;
  }
  .g-xs-b-30 {
    margin-bottom: 30px !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .p-sm-0 {
    padding: 0 !important;
  }
  .p-sm-0 {
    padding: 0 !important;
  }
  .g-sm-v-20 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
  .g-sm-b-35 {
    margin-bottom: 35px !important;
  }
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .g-md-h--20 {
    margin-left: -20px !important;
    margin-right: -20px !important;
  }
  .g-md-b-0 {
    margin-bottom: 0 !important;
  }
  .g-md-b-0 {
    margin-bottom: 0 !important;
  }
  .g-md-v-30 {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
  }
  .g-md-t-30 {
    margin-top: 30px !important;
  }
  .p-md-40 {
    padding: 40px !important;
  }
}
@media screen and (min-width: 1200px) {
  .g-lg-t--20 {
    margin-top: -20px !important;
  }
  .g-lg-h--40 {
    margin-left: -40px !important;
    margin-right: -40px !important;
  }
  .g-lg-t--40 {
    margin-top: -40px !important;
  }
  .g-lg-t--60 {
    margin-top: -60px !important;
  }
  .g-lg-t--90 {
    margin-top: -90px !important;
  }
  .g-lg-t--180 {
    margin-top: -180px !important;
  }
  .g-lg-0 {
    margin: 0 !important;
  }
  .g-lg-t-0 {
    margin-top: 0 !important;
  }
  .g-lg-b-0 {
    margin-bottom: 0 !important;
  }
  .p-lg-v-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .p-lg-t-1 {
    padding-top: 1px !important;
  }
  .p-lg-2p {
    padding: 2% !important;
  }
  .p-lg-3p {
    padding: 3% !important;
  }
  .p-lg-t-7 {
    padding-top: 7px !important;
  }
  .g-lg-0 {
    margin: 0 !important;
  }
  .g-lg-t-0 {
    margin-top: 0 !important;
  }
  .g-lg-b-0 {
    margin-bottom: 0 !important;
  }
  .p-lg-v-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .g-lg-v-20 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
  .g-lg-b-20 {
    margin-bottom: 20px !important;
  }
  .g-lg-t-25 {
    margin-top: 25px !important;
  }
  .g-lg-t-30 {
    margin-top: 30px !important;
  }
  .g-lg-b-30 {
    margin-bottom: 30px !important;
  }
  .p-lg-b-30 {
    padding-bottom: 30px !important;
  }
  .g-lg-t-40 {
    margin-top: 40px !important;
  }
  .p-lg-h-40 {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  .p-lg-h-45 {
    padding-left: 45px !important;
    padding-right: 45px !important;
  }
  .g-lg-t-50 {
    margin-top: 50px !important;
  }
  .p-lg-50 {
    padding: 50px !important;
  }
  .g-lg-t-60 {
    margin-top: 60px !important;
  }
  .g-lg-b-60 {
    margin-bottom: 60px !important;
  }
  .g-lg-t-70 {
    margin-top: 70px !important;
  }
  .p-lg-l-70 {
    padding-left: 70px !important;
  }
  .g-lg-h-80 {
    margin-left: 80px !important;
    margin-right: 80px !important;
  }
  .g-lg-b-80 {
    margin-bottom: 80px !important;
  }
  .p-lg-t-80 {
    padding-top: 80px !important;
  }
  .g-lg-t-90 {
    margin-top: 90px !important;
  }
  .p-lg-h-90 {
    padding-left: 90px !important;
    padding-right: 90px !important;
  }
  .p-lg-t-90 {
    padding-top: 90px !important;
  }
  .p-lg-h-100 {
    padding-left: 100px !important;
    padding-right: 100px !important;
  }
  .p-lg-b-100 {
    padding-bottom: 100px !important;
  }
  .g-lg-l-200 {
    margin-left: 200px !important;
  }
}
.z-2 {
  z-index: 2 !important;
}
.z-100 {
  z-index: 100 !important;
}
.w-a {
  width: auto !important;
}
.h-0 {
  height: 0 !important;
}
.min-w-10 {
  min-width: 10px !important;
}
.w-20 {
  width: 20px !important;
}
.h-20 {
  height: 20px !important;
}
.max-w-50 {
  max-width: 50px !important;
}
.h-50 {
  height: 50px !important;
}
.w-70 {
  width: 70px !important;
}
.w-80 {
  width: 80px !important;
}
.h-80 {
  height: 80px !important;
}
.w-10p {
  width: 10% !important;
}
.max-w-150 {
  max-width: 150px !important;
}
.w-18p {
  width: 18% !important;
}
.w-19p {
  width: 19% !important;
}
.w-200 {
  width: 200px !important;
}
.w-20p {
  width: 20% !important;
}
.max-w-220 {
  max-width: 220px !important;
}
.w-22p {
  width: 22% !important;
}
.w-28p {
  width: 28% !important;
}
.max-w-300 {
  max-width: 300px !important;
}
.w-30p {
  width: 30% !important;
}
.max-w-320 {
  max-width: 320px !important;
}
.max-w-340 {
  max-width: 340px !important;
}
.max-w-350 {
  max-width: 350px !important;
}
.w-35p {
  width: 35% !important;
}
.h-350 {
  height: 350px !important;
}
.max-w-400 {
  max-width: 400px !important;
}
.w-40p {
  width: 40% !important;
}
.max-w-440 {
  max-width: 440px !important;
}
.w-44p {
  width: 44% !important;
}
.max-w-460 {
  max-width: 460px !important;
}
.w-46p {
  width: 46% !important;
}
.max-w-470 {
  max-width: 470px !important;
}
.w-48p {
  width: 48% !important;
}
.max-w-500 {
  max-width: 500px !important;
}
.w-50p {
  width: 50% !important;
}
.max-w-540 {
  max-width: 540px !important;
}
.w-54p {
  width: 54% !important;
}
.max-w-590 {
  max-width: 590px !important;
}
.max-w-600 {
  max-width: 600px !important;
}
.max-w-630 {
  max-width: 630px !important;
}
.max-w-640 {
  max-width: 640px !important;
}
.w-64p {
  width: 64% !important;
}
.max-w-650 {
  max-width: 650px !important;
}
.w-65p {
  width: 65% !important;
}
.w-70p {
  width: 70% !important;
}
.max-w-780 {
  max-width: 780px !important;
}
.w-78p {
  width: 78% !important;
}
.w-80p {
  width: 80% !important;
}
.max-w-80p {
  max-width: 80% !important;
}
.w-81p {
  width: 81% !important;
}
.w-85p {
  width: 85% !important;
}
.max-w-900 {
  max-width: 900px !important;
}
.w-90p {
  width: 90% !important;
}
.max-w-90p {
  max-width: 90% !important;
}
.max-w-1000 {
  max-width: 1000px !important;
}
.w-100p {
  width: 100% !important;
}
.max-w-100p {
  max-width: 100% !important;
}
@media screen and (max-width: 767px) {
  .w-xs-40 {
    width: 40px !important;
  }
  .w-xs-44p {
    width: 44% !important;
  }
  .w-xs-44p {
    width: 44% !important;
  }
  .w-xs-48p {
    width: 48% !important;
  }
  .w-xs-48p {
    width: 48% !important;
  }
  .w-xs-100p {
    width: 100% !important;
  }
  .w-xs-100p {
    width: 100% !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .w-sm-100p {
    width: 100% !important;
  }
  .w-sm-100p {
    width: 100% !important;
  }
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .w-md-45p {
    width: 45% !important;
  }
  .w-md-45p {
    width: 45% !important;
  }
}
@media screen and (min-width: 1200px) {
  .w-lg-14p {
    width: 14% !important;
  }
  .w-lg-14p {
    width: 14% !important;
  }
  .w-lg-15p {
    width: 15% !important;
  }
  .w-lg-15p {
    width: 15% !important;
  }
  .w-lg-18p {
    width: 18% !important;
  }
  .w-lg-18p {
    width: 18% !important;
  }
  .w-lg-22p {
    width: 22% !important;
  }
  .w-lg-22p {
    width: 22% !important;
  }
  .w-lg-29p {
    width: 29% !important;
  }
  .w-lg-29p {
    width: 29% !important;
  }
  .w-lg-30p {
    width: 30% !important;
  }
  .w-lg-30p {
    width: 30% !important;
  }
  .w-lg-37p {
    width: 37% !important;
  }
  .w-lg-37p {
    width: 37% !important;
  }
  .w-lg-400 {
    width: 400px !important;
  }
  .w-lg-45p {
    width: 45% !important;
  }
  .w-lg-45p {
    width: 45% !important;
  }
  .w-lg-46p {
    width: 46% !important;
  }
  .w-lg-46p {
    width: 46% !important;
  }
  .w-lg-50p {
    width: 50% !important;
  }
  .w-lg-50p {
    width: 50% !important;
  }
  .h-lg-500 {
    height: 500px !important;
  }
  .w-lg-60p {
    width: 60% !important;
  }
  .w-lg-60p {
    width: 60% !important;
  }
  .w-lg-67p {
    width: 67% !important;
  }
  .w-lg-67p {
    width: 67% !important;
  }
  .w-lg-70p {
    width: 70% !important;
  }
  .w-lg-70p {
    width: 70% !important;
  }
  .w-lg-80p {
    width: 80% !important;
  }
  .w-lg-80p {
    width: 80% !important;
  }
  .max-w-lg-100p {
    max-width: 100% !important;
  }
}
.min-w-init {
  min-width: initial !important;
}
.text-lts-0 {
  letter-spacing: 0 !important;
}
.text-lts-1 {
  letter-spacing: 1px !important;
}
.fz-10 {
  font-size: 10px !important;
}
.fz-11 {
  font-size: 11px !important;
}
.fz-12 {
  font-size: 12px !important;
}
.fz-13 {
  font-size: 13px !important;
}
.fz-14 {
  font-size: 14px !important;
}
.fz-16 {
  font-size: 16px !important;
}
.fz-17 {
  font-size: 17px !important;
}
.fz-18 {
  font-size: 18px !important;
}
.fz-40 {
  font-size: 40px !important;
}
@media screen and (max-width: 767px) {
  .fz-xs-11 {
    font-size: 11px !important;
  }
  .fz-xs-12 {
    font-size: 12px !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .fz-sm-28 {
    font-size: 28px !important;
  }
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .fz-md-36 {
    font-size: 36px !important;
  }
}
@media screen and (min-width: 1200px) {
  .fz-lg-12 {
    font-size: 12px !important;
  }
  .fz-lg-14 {
    font-size: 14px !important;
  }
  .fz-lg-16 {
    font-size: 16px !important;
  }
  .fz-lg-17 {
    font-size: 17px !important;
  }
  .fz-lg-18 {
    font-size: 18px !important;
  }
  .fz-lg-24 {
    font-size: 24px !important;
  }
  .fz-lg-34 {
    font-size: 34px !important;
  }
}
.fz-50p {
  font-size: 50%;
}
.fz-60p {
  font-size: 60%;
}
.fz-70p {
  font-size: 70%;
}
.fz-80p {
  font-size: 80%;
}
.fz-90p {
  font-size: 90%;
}
.fz-100p {
  font-size: 100%;
}
.fz-110p {
  font-size: 110%;
}
.fz-120p {
  font-size: 120%;
}
.fz-130p {
  font-size: 130%;
}
.fz-140p {
  font-size: 140%;
}
.fz-180p {
  font-size: 180%;
}
.fz-200p {
  font-size: 200%;
}
@media screen and (max-width: 767px) {
  .fz-xs-80p {
    font-size: 80%;
  }
  .fz-xs-90p {
    font-size: 90%;
  }
}
html {
  font-size: 62.5%;
}
body {
  font-feature-settings: "palt";
  font-size: min(3.6vw, 1.4rem);
  color: #4d4d4d;
  word-break: break-all;
}
@media screen and (min-width: 768px) {
  body {
    font-size: 1.4rem;
  }
}
ol,
p,
ul {
  line-height: 1.8;
  margin-bottom: min(2.4vw, 1em);
  font-size: min(3.2vw, 1.4rem);
}
a {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
}
img {
  max-width: 100%;
  height: auto;
}
.container,
.container-fluid {
  padding-left: 9vw;
  padding-right: 9vw;
}
@media screen and (min-width: 768px) {
  .container,
  .container-fluid {
    padding-left: 30px;
    padding-right: 30px;
  }
}
.row {
  margin-left: -9vw;
  margin-right: -9vw;
}
.row > * {
  padding-left: 9vw;
  padding-right: 9vw;
}
@media screen and (min-width: 768px) {
  .row {
    margin-left: -30px;
    margin-right: -30px;
  }
  .row > * {
    padding-left: 30px;
    padding-right: 30px;
  }
}
.g-v {
  margin-top: min(9vw, 90px) !important;
  margin-bottom: min(9vw, 90px) !important;
}
.g-t {
  margin-top: min(9vw, 90px) !important;
}
.g-b {
  margin-bottom: min(9vw, 90px) !important;
}
.p-v {
  padding-top: min(9vw, 90px) !important;
  padding-bottom: min(9vw, 90px) !important;
}
.p-t {
  padding-top: min(9vw, 90px) !important;
}
.p-b {
  padding-bottom: min(9vw, 90px) !important;
}
.g-l-a {
  margin-left: auto;
}
.g-r-a {
  margin-right: auto;
}
.g-t-15p {
  margin-top: 15%;
}
.g-l--5p {
  margin-left: -5%;
}
@media screen and (max-width: 767px) {
  .p-xs-h-4vw {
    padding-left: 4vw;
    padding-right: 4vw;
  }
  .g-xs-h--5vw {
    margin-left: -5vw;
    margin-right: -5vw;
  }
  .g-xs-h--2vw {
    margin-left: -2vw;
    margin-right: -2vw;
  }
}
.caret-right {
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-bottom: 3px solid transparent;
  border-top: 3px solid transparent;
  border-left: 4px solid;
}
.fluid-has-max {
  max-width: 1600px;
}
a.underconstruction {
  cursor: default;
  opacity: 0.38;
}
.whs-nw {
  white-space: nowrap;
}
.word-break-init {
  word-break: initial;
}
.ov-h {
  overflow: hidden;
}
.op-4 {
  opacity: 0.4 !important;
}
.pos-s {
  position: static !important;
}
.pos-a {
  position: absolute !important;
}
.pos-r {
  position: relative !important;
}
.t-0 {
  top: 0 !important;
}
.b-0 {
  bottom: 0 !important;
}
.r-0 {
  right: 0 !important;
}
.l-0 {
  left: 0 !important;
}
.l-50 {
  left: 50% !important;
}
.t-a {
  top: auto !important;
}
.b-a {
  bottom: auto !important;
}
.translate-0 {
  transform: translate(0, 0) !important;
}
.translate-50 {
  transform: translate(-50%, -50%) !important;
}
.translate-y-50 {
  transform: translateY(-50%) !important;
}
.pos-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.scale-15 {
  transform: scale(1.5);
}
.flip-h {
  transform: scale(-1, 1);
}
@media screen and (max-width: 767px) {
  .r-xs-0 {
    right: 0 !important;
  }
  .l-xs-0 {
    left: 0 !important;
  }
}
@media screen and (min-width: 1200px) {
  .pos-lg-a {
    position: absolute !important;
  }
  .b-lg-0 {
    bottom: 0 !important;
  }
  .l-lg-50 {
    left: 50% !important;
  }
}
.d-b {
  display: block !important;
}
.d-i {
  display: inline !important;
}
.d-ib {
  display: inline-block !important;
}
.d-f {
  display: flex !important;
}
.ai-c {
  align-items: center !important;
}
.ai-fs {
  align-items: flex-start !important;
}
.ai-fe {
  align-items: flex-end !important;
}
.jc-c {
  justify-content: center !important;
}
.jc-fe {
  justify-content: flex-end !important;
}
.jc-sb {
  justify-content: space-between !important;
}
.fxw-w {
  flex-wrap: wrap !important;
}
.fxd-rr {
  flex-direction: row-reverse !important;
}
.fxd-c {
  flex-direction: column !important;
}
@media screen and (max-width: 767px) {
  .d-xs-b {
    display: block !important;
  }
  .ai-xs-fs {
    align-items: flex-start !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .d-sm-b {
    display: block !important;
  }
}
@media screen and (min-width: 1200px) {
  .d-lg-f {
    display: flex !important;
  }
  .fxw-lg-w {
    flex-wrap: wrap !important;
  }
  .fxd-lg-r {
    flex-direction: row !important;
  }
}
.order-1 {
  order: 1;
}
.order-2 {
  order: 2;
}
.row.d-f.fxw-w:before {
  content: none !important;
}
.hidden {
  display: none !important;
}
.visible-xs {
  display: none !important;
}
.visible-sm {
  display: none !important;
}
.visible-md {
  display: none !important;
}
.visible-lg {
  display: none !important;
}
.hidden-xs {
  display: block !important;
}
.hidden-sm {
  display: block !important;
}
.hidden-lg {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .visible-xs {
    display: block !important;
  }
  .hidden-xs {
    display: none !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .visible-sm {
    display: block !important;
  }
  .hidden-sm {
    display: none !important;
  }
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .visible-md {
    display: block !important;
  }
}
@media screen and (min-width: 1200px) {
  .visible-lg {
    display: block !important;
  }
  .hidden-lg {
    display: none !important;
  }
}
.clear {
  clear: both !important;
}
.fz-s {
  font-size: min(3vw, 1.1rem) !important;
}
.fz-m {
  font-size: min(3.4vw, 1.4rem) !important;
}
.fz-l {
  font-size: min(4.4vw, 1.9rem) !important;
}
.fz-xl {
  font-size: min(6.6vw, 2.6rem) !important;
}
.bg-transparent {
  background-color: rgba(0, 0, 0, 0) !important;
}
.bg-0-op-90 {
  background-color: rgba(255, 255, 255, 0.9) !important;
}
.bg-1 {
  background-color: #d74646 !important;
}
.bg-2 {
  background-color: #82bcd9 !important;
}
.bg-3 {
  background-color: #e6adad !important;
}
.bg-4 {
  background-color: #adb4d9 !important;
}
.bg-5 {
  background-color: #8fcca3 !important;
}
.bg-6 {
  background-color: #fbf0f0 !important;
}
.bg-7 {
  background-color: #f9f1f1 !important;
}
.bg-8 {
  background-color: #fbf0f0 !important;
}
.bg-9 {
  background-color: #ff0 !important;
}
.bg-10 {
  background-color: #7db3b3 !important;
}
.bg-11 {
  background-color: #f2f2f2 !important;
}
.bg-12 {
  background-color: #ff5252 !important;
}
.bg-13 {
  background-color: #fcfce4 !important;
}
.bg-14 {
  background-color: #6ec295 !important;
}
.bg-15 {
  background-color: #f8f8ea !important;
}
.bg-16 {
  background-color: #74b525 !important;
}
.bg-17 {
  background-color: #def3f3 !important;
}
.bg-18 {
  background-color: #eeebe0 !important;
}
.bg-19 {
  background-color: #d2e8e9 !important;
}
.bg-20 {
  background-color: #fbfac9 !important;
}
.bg-21 {
  background-color: #f5e5e5 !important;
}
.bg-22 {
  background-color: #d9c082 !important;
}
.bg-23 {
  background-color: #faf6ed !important;
}
.bg-24 {
  background-color: #807fce !important;
}
.bg-25 {
  background-color: #e9e9f8 !important;
}
.bg-26 {
  background-color: #8c2788 !important;
}
.bg-27 {
  background-color: #e6eaff !important;
}
.bg-28 {
  background-color: #f7edf8 !important;
}
.bg-29 {
  background-color: #cbb72a !important;
}
.bg-30 {
  background-color: #eee !important;
}
.bg-31 {
  background-color: #eee !important;
}
.bg-gs-11 {
  background-color: #aaa !important;
}
.bg-gs-12 {
  background-color: #bbb !important;
}
.bg-gs-13 {
  background-color: #ccc !important;
}
.bg-gs-14 {
  background-color: #ddd !important;
}
.bg-gs-15 {
  background-color: #eee !important;
}
.bg-gs-16 {
  background-color: #fff !important;
}
@media screen and (max-width: 767px) {
  .bg-xs-transparent {
    background-color: rgba(0, 0, 0, 0) !important;
  }
}
@media screen and (min-width: 1200px) {
  .bg-lg-transparent {
    background: rgba(0, 0, 0, 0) !important;
  }
}
.bg-slant-1 {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: linear-gradient(148deg, #fff 1%, #fff 50%, transparent 50%);
  height: 66.66666666vw;
}
.bg-gradient-1 {
  background-image: linear-gradient(0deg, #fbf0f0 0, #d74646 100%);
}
.bg-gradient-2 {
  background-image: linear-gradient(0deg, #fbf0f0 10%, #f9f1f1 24%);
}
.bg-gradient-v-0 {
  background-image: linear-gradient(0deg, #fff 50%, transparent 49.999%);
}
.bg-gradient-v-1 {
  background-image: linear-gradient(
    0deg,
    rgba(255, 255, 255, 0.5) 50%,
    transparent 49.999%
  );
}
.bg-gradient-v-2 {
  background-image: linear-gradient(0deg, #fbf0f0 92%, transparent 92%);
}
.bg-gradient-v-3 {
  background-image: linear-gradient(0deg, #f9f1f1 92%, transparent 92%);
}
.bg-stripe-v-1 {
  background-image: repeating-linear-gradient(
    90deg,
    transparent,
    transparent 30px,
    rgba(255, 255, 255, 0.1) 30px,
    rgba(255, 255, 255, 0.1) 60px
  );
}
.bg-linework-1 {
  background-image: url(../../img/common/bg-saturated-linework.svg);
  background-position: 50% 50%;
  background-size: cover;
}
@media screen and (min-width: 992px) {
  .bg-linework-1 {
    background-image: url(../../img/common/bg-saturated-linework-h.svg);
  }
}
.bg-oval-tl-0 {
  background-image: url(../../img/common/bg-oval-tl-0.svg);
  background-repeat: no-repeat;
  background-size: cover;
}
.bg-oval-tl-25 {
  background-image: url(../../img/common/bg-oval-tl-25.svg);
  background-repeat: no-repeat;
  background-size: cover;
}
.bg-wave-27 {
  background-image: url(../../img/common/bg-wave-27.png);
  background-position: 50% 0;
  background-repeat: no-repeat;
  background-size: cover;
}
.bg-28-top {
  background-image: url(../../img/common/bg-28-top.png);
  background-repeat: no-repeat;
  background-size: contain;
}
.bg-rect-1 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: min(60vw, 700px);
}
.btn-container-1 {
  position: relative;
  z-index: 2;
  margin-top: 20px;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.btn-container-1 a {
  margin-top: 10px;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) {
  .btn-container-1 {
    margin-top: 50px;
    margin-bottom: 50px;
  }
}
@media screen and (min-width: 992px) {
  .btn-container-1 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
}
.btn-gradient-1 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1;
  text-decoration: none;
  color: #fff;
  font-size: min(4.7vw, 2.6rem);
  max-width: 100%;
  min-width: 210px;
  padding: 0.65em 1.2em;
  transition: 0.3s;
  box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.23);
  text-shadow: -1px -1px 0 rgba(0, 0, 0, 0.13);
  background-image: linear-gradient(
      177deg,
      rgba(197, 240, 206, 0.12) 50%,
      rgba(39, 190, 188, 0.09) 50%
    ),
    linear-gradient(169deg, #c5f0ce, #27bebc);
  border: 1px solid #98d3b8;
}
.btn-gradient-1::before {
  content: "";
  flex-basis: 1em;
}
.btn-gradient-1::after {
  content: "→";
  flex-basis: 1em;
}
.btn-gradient-1:visited {
  color: #fff;
}
.btn-gradient-1:hover {
  box-shadow: 1px 1px rgba(0, 0, 0, 0.1);
  color: #fff;
}
.btn-1 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #d74646;
}
.btn-1::before {
  content: "";
  flex-basis: 1em;
}
.btn-1::after {
  content: "→";
  flex-basis: 1em;
}
.btn-1:visited {
  color: #fff;
}
.btn-1:focus,
.btn-1:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-1 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-1 {
    font-size: 1.3rem;
  }
}
.btn-1:focus,
.btn-1:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-1[disabled]:focus,
.btn-1[disabled]:hover {
  background-color: #d74646;
  color: #fff;
}
.btn-1-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #d74646;
  color: #fff;
}
.btn-1-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-1-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-1-extended:visited {
  color: #fff;
}
.btn-1-extended:focus,
.btn-1-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-1-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-1-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-1-extended:focus,
.btn-1-extended:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-1-extended[disabled]:focus,
.btn-1-extended[disabled]:hover {
  background-color: #d74646;
  color: #fff;
}
.btn-bordered-1-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #d74646;
  background-color: rgba(0, 0, 0, 0);
  color: #d74646;
}
.btn-bordered-1-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-1-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-1-extended:visited {
  color: #fff;
}
.btn-bordered-1-extended:focus,
.btn-bordered-1-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-1-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-1-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-bordered-1-extended:visited {
  color: #d74646;
}
.btn-bordered-1-extended:focus,
.btn-bordered-1-extended:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-1-extended[disabled]:focus,
.btn-bordered-1-extended[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-2 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #82bcd9;
}
.btn-2::before {
  content: "";
  flex-basis: 1em;
}
.btn-2::after {
  content: "→";
  flex-basis: 1em;
}
.btn-2:visited {
  color: #fff;
}
.btn-2:focus,
.btn-2:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-2 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-2 {
    font-size: 1.3rem;
  }
}
.btn-2:focus,
.btn-2:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-2[disabled]:focus,
.btn-2[disabled]:hover {
  background-color: #82bcd9;
  color: #fff;
}
.btn-2-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #82bcd9;
  color: #fff;
}
.btn-2-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-2-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-2-extended:visited {
  color: #fff;
}
.btn-2-extended:focus,
.btn-2-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-2-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-2-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-2-extended:focus,
.btn-2-extended:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-2-extended[disabled]:focus,
.btn-2-extended[disabled]:hover {
  background-color: #82bcd9;
  color: #fff;
}
.btn-bordered-2 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #82bcd9;
  background-color: rgba(0, 0, 0, 0);
  color: #82bcd9;
}
.btn-bordered-2::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-2::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-2:visited {
  color: #fff;
}
.btn-bordered-2:focus,
.btn-bordered-2:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-2 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-2 {
    font-size: 1.3rem;
  }
}
.btn-bordered-2:visited {
  color: #82bcd9;
}
.btn-bordered-2:focus,
.btn-bordered-2:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-2[disabled]:focus,
.btn-bordered-2[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-3 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #e6adad;
}
.btn-3::before {
  content: "";
  flex-basis: 1em;
}
.btn-3::after {
  content: "→";
  flex-basis: 1em;
}
.btn-3:visited {
  color: #fff;
}
.btn-3:focus,
.btn-3:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-3 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-3 {
    font-size: 1.3rem;
  }
}
.btn-3:focus,
.btn-3:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-3[disabled]:focus,
.btn-3[disabled]:hover {
  background-color: #e6adad;
  color: #fff;
}
.btn-3-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #e6adad;
  color: #fff;
}
.btn-3-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-3-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-3-extended:visited {
  color: #fff;
}
.btn-3-extended:focus,
.btn-3-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-3-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-3-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-3-extended:focus,
.btn-3-extended:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-3-extended[disabled]:focus,
.btn-3-extended[disabled]:hover {
  background-color: #e6adad;
  color: #fff;
}
.btn-bordered-3 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #e6adad;
  background-color: rgba(0, 0, 0, 0);
  color: #e6adad;
}
.btn-bordered-3::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-3::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-3:visited {
  color: #fff;
}
.btn-bordered-3:focus,
.btn-bordered-3:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-3 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-3 {
    font-size: 1.3rem;
  }
}
.btn-bordered-3:visited {
  color: #e6adad;
}
.btn-bordered-3:focus,
.btn-bordered-3:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-3[disabled]:focus,
.btn-bordered-3[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-bordered-3-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #e6adad;
  background-color: rgba(0, 0, 0, 0);
  color: #e6adad;
}
.btn-bordered-3-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-3-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-3-extended:visited {
  color: #fff;
}
.btn-bordered-3-extended:focus,
.btn-bordered-3-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-3-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-3-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-bordered-3-extended:visited {
  color: #e6adad;
}
.btn-bordered-3-extended:focus,
.btn-bordered-3-extended:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-3-extended[disabled]:focus,
.btn-bordered-3-extended[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-4 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #adb4d9;
}
.btn-4::before {
  content: "";
  flex-basis: 1em;
}
.btn-4::after {
  content: "→";
  flex-basis: 1em;
}
.btn-4:visited {
  color: #fff;
}
.btn-4:focus,
.btn-4:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-4 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-4 {
    font-size: 1.3rem;
  }
}
.btn-4:focus,
.btn-4:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-4[disabled]:focus,
.btn-4[disabled]:hover {
  background-color: #adb4d9;
  color: #fff;
}
.btn-bordered-4 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #adb4d9;
  background-color: rgba(0, 0, 0, 0);
  color: #adb4d9;
}
.btn-bordered-4::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-4::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-4:visited {
  color: #fff;
}
.btn-bordered-4:focus,
.btn-bordered-4:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-4 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-4 {
    font-size: 1.3rem;
  }
}
.btn-bordered-4:visited {
  color: #adb4d9;
}
.btn-bordered-4:focus,
.btn-bordered-4:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-4[disabled]:focus,
.btn-bordered-4[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-5 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #8fcca3;
}
.btn-5::before {
  content: "";
  flex-basis: 1em;
}
.btn-5::after {
  content: "→";
  flex-basis: 1em;
}
.btn-5:visited {
  color: #fff;
}
.btn-5:focus,
.btn-5:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-5 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-5 {
    font-size: 1.3rem;
  }
}
.btn-5:focus,
.btn-5:hover {
  color: #fff;
  background-color: #0fa0d1;
}
.btn-5[disabled]:focus,
.btn-5[disabled]:hover {
  background-color: #8fcca3;
  color: #fff;
}
.btn-bordered-5-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #8fcca3;
  background-color: rgba(0, 0, 0, 0);
  color: #8fcca3;
}
.btn-bordered-5-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-5-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-5-extended:visited {
  color: #fff;
}
.btn-bordered-5-extended:focus,
.btn-bordered-5-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-5-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-5-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-bordered-5-extended:visited {
  color: #8fcca3;
}
.btn-bordered-5-extended:focus,
.btn-bordered-5-extended:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-5-extended[disabled]:focus,
.btn-bordered-5-extended[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-arrow-6 {
  position: relative;
}
.btn-arrow-6:after {
  content: "";
  display: block;
  width: 9px;
  height: 9px;
  border-top: 1px solid #fbf0f0;
  position: absolute;
  top: 50%;
  transition: 0.2s;
  right: 16px;
  border-right: 1px solid #fbf0f0;
  transform: translateY(-50%) rotate(45deg);
}
.btn-arrow-6:hover::after {
  border-color: #fff;
}
.btn-arrow-7 {
  position: relative;
}
.btn-arrow-7:after {
  content: "";
  display: block;
  width: 9px;
  height: 9px;
  border-top: 1px solid #f9f1f1;
  position: absolute;
  top: 50%;
  transition: 0.2s;
  right: 16px;
  border-right: 1px solid #f9f1f1;
  transform: translateY(-50%) rotate(45deg);
}
.btn-arrow-7:hover::after {
  border-color: #fff;
}
.btn-bordered-10 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #4d4d4d;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #7db3b3;
  background-color: rgba(0, 0, 0, 0);
  color: #7db3b3;
}
.btn-bordered-10::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-10::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-10:visited {
  color: #4d4d4d;
}
.btn-bordered-10:focus,
.btn-bordered-10:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-10 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-10 {
    font-size: 1.3rem;
  }
}
.btn-bordered-10:visited {
  color: #7db3b3;
}
.btn-bordered-10:focus,
.btn-bordered-10:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-10[disabled]:focus,
.btn-bordered-10[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-bordered-14-extended {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  min-width: 210px;
  color: #4d4d4d;
  border: none;
  border-radius: 4px;
  padding: 1em 1.2em;
  font-size: 4.1vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid #6ec295;
  background-color: rgba(0, 0, 0, 0);
  color: #6ec295;
}
.btn-bordered-14-extended::before {
  content: "";
  flex-basis: 1em;
}
.btn-bordered-14-extended::after {
  content: "→";
  flex-basis: 1em;
}
.btn-bordered-14-extended:visited {
  color: #4d4d4d;
}
.btn-bordered-14-extended:focus,
.btn-bordered-14-extended:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-bordered-14-extended {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-bordered-14-extended {
    width: 540px;
    font-size: 1.5rem;
  }
}
.btn-bordered-14-extended:visited {
  color: #6ec295;
}
.btn-bordered-14-extended:focus,
.btn-bordered-14-extended:hover {
  border-color: transparent;
  color: #fff;
  background-color: #0fa0d1;
}
.btn-bordered-14-extended[disabled]:focus,
.btn-bordered-14-extended[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-caret {
  position: relative;
}
.btn-caret::before {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-bottom: 4px solid transparent;
  border-top: 4px solid transparent;
  border-left: 6px solid;
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translateY(-50%);
}
.btn-corner-circle {
  height: 3.4em;
  border-radius: 1.7em;
}
.btn-arrow-none {
  justify-content: center;
}
.btn-arrow-none::after,
.btn-arrow-none::before {
  content: normal;
}
@media screen and (max-width: 767px) {
  .btn-bg-hidden-xs-1 {
    background-color: rgba(0, 0, 0, 0) !important;
  }
}
@media screen and (min-width: 768px) {
  .btn-bg-hidden-xs-1 {
    padding: 20px;
  }
  .btn-bg-hidden-xs-1 [class*="-bordered-"] {
    background-color: #fff;
  }
  .btn-bg-hidden-xs-1 [class*="-bordered-"]:hover {
    background-color: #0fa0d1;
  }
}
.btn-extra-1 {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #4d4d4d;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  position: relative;
  justify-content: center;
  padding-top: 1.2em;
  padding-bottom: 1.2em;
  border: 1px solid #4d4d4d;
  border-radius: 0;
  background-color: rgba(0, 0, 0, 0);
  font-size: min(2.8vw, 1.1rem);
}
.btn-extra-1::before {
  content: "";
  flex-basis: 1em;
}
.btn-extra-1::after {
  content: "→";
  flex-basis: 1em;
}
.btn-extra-1:visited {
  color: #4d4d4d;
}
.btn-extra-1:focus,
.btn-extra-1:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .btn-extra-1 {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .btn-extra-1 {
    font-size: 1.3rem;
  }
}
.btn-extra-1::before {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-bottom: 4px solid transparent;
  border-top: 4px solid transparent;
  border-left: 6px solid;
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translateY(-50%);
}
.btn-extra-1::before {
  border-left-color: #d74646;
}
.btn-extra-1::after {
  content: normal;
}
.btn-extra-1:visited {
  color: #4d4d4d;
}
.btn-extra-1:focus,
.btn-extra-1:hover {
  border-color: #0fa0d1;
  background-color: #0fa0d1;
  color: #fff;
}
.btn-extra-1:focus::before,
.btn-extra-1:hover::before {
  border-left-color: #fff;
}
.btn-extra-1[disabled]:focus,
.btn-extra-1[disabled]:hover {
  color: #c3c3c3;
  border-color: #c3c3c3;
}
.btn-sns {
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(11.6667vw, 48px);
  height: min(11.6667vw, 48px);
  border-radius: 100%;
}
.btn-sns:hover {
  background-color: #71655e;
}
.btn-instagram {
  background-color: #e6adad;
}
.btn-twitter {
  background-color: #82bcd9;
}
.btn-blog {
  background-color: #8fcca3;
}
.blog-entry-body table,
.table-1 {
  width: 100%;
  margin: 0 0 30px;
  border-collapse: collapse;
  border-bottom: 1px solid rgba(0, 0, 0, 0.0666666667);
}
.blog-entry-body table.text-center th,
.table-1.text-center th {
  text-align: center;
}
.blog-entry-body table.text-left th,
.table-1.text-left th {
  text-align: left;
}
.blog-entry-body table.text-right th,
.table-1.text-right th {
  text-align: right;
}
.blog-entry-body table td,
.blog-entry-body table th,
.table-1 td,
.table-1 th {
  padding: 1.5rem;
}
.blog-entry-body table a,
.table-1 a {
  word-break: break-all;
}
@media screen and (max-width: 767px) {
  .blog-entry-body table .thead-hidden-xs,
  .table-1 .thead-hidden-xs {
    display: none;
  }
  .blog-entry-body table.responsive td,
  .blog-entry-body table.responsive th,
  .blog-entry-body table.responsive tr,
  .table-1.responsive td,
  .table-1.responsive th,
  .table-1.responsive tr {
    display: block;
    font-size: min(3vw, 1.1rem) !important;
  }
  .blog-entry-body table.responsive tr,
  .table-1.responsive tr {
    margin-bottom: 2em;
    border: 1px solid rgba(0, 0, 0, 0.0666666667);
  }
  .blog-entry-body table.responsive td,
  .table-1.responsive td {
    border-width: 1px 0 0;
  }
  .blog-entry-body table.responsive [data-label],
  .table-1.responsive [data-label] {
    display: flex;
  }
  .blog-entry-body table.responsive [data-label]:before,
  .table-1.responsive [data-label]:before {
    content: attr(data-label);
    flex: 0 0 36%;
    display: block;
    width: 8em;
    margin: -1.5rem 1.5rem -1.5rem -1.5rem;
    padding: 1.5rem;
    background: #f6f6f6;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .blog-entry-body table,
  .table-1 {
    margin-bottom: 60px;
  }
}
.blog-entry-body table tr,
.table-1 tr {
  border-top: 1px solid rgba(0, 0, 0, 0.0666666667);
}
.blog-entry-body table th,
.table-1 th {
  background-color: rgba(0, 0, 0, 0.0196078431);
}
.table-2 {
  width: 100%;
  margin: 0 0 30px;
  border-collapse: collapse;
  border-bottom: 1px solid rgba(0, 0, 0, 0.0666666667);
  text-align: left;
}
.table-2.text-center th {
  text-align: center;
}
.table-2.text-left th {
  text-align: left;
}
.table-2.text-right th {
  text-align: right;
}
.table-2 td,
.table-2 th {
  padding: 1.5rem;
}
.table-2 a {
  word-break: break-all;
}
@media screen and (max-width: 767px) {
  .table-2 .thead-hidden-xs {
    display: none;
  }
  .table-2.responsive td,
  .table-2.responsive th,
  .table-2.responsive tr {
    display: block;
    font-size: min(3vw, 1.1rem) !important;
  }
  .table-2.responsive tr {
    margin-bottom: 2em;
    border: 1px solid rgba(0, 0, 0, 0.0666666667);
  }
  .table-2.responsive td {
    border-width: 1px 0 0;
  }
  .table-2.responsive [data-label] {
    display: flex;
  }
  .table-2.responsive [data-label]:before {
    content: attr(data-label);
    flex: 0 0 36%;
    display: block;
    width: 8em;
    margin: -1.5rem 1.5rem -1.5rem -1.5rem;
    padding: 1.5rem;
    background: #f6f6f6;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .table-2 {
    margin-bottom: 60px;
  }
}
.table-2 tr {
  border-top: 1px solid rgba(0, 0, 0, 0.0666666667);
}
.table-2 td,
.table-2 th {
  vertical-align: top;
}
.table-2 td + td {
  border-left: 1px solid rgba(0, 0, 0, 0.0666666667);
}
.table-2 thead th {
  background-color: #d74646;
  color: #fff;
}
.table-2 tbody th {
  background-color: #fbf0f0;
}
.table-th-nowrap th {
  white-space: nowrap;
}
.td-price {
  text-align: right;
}
input,
select,
textarea {
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
input[type="checkbox"],
input[type="radio"],
label {
  vertical-align: middle;
}
input[type="checkbox"],
input[type="radio"] {
  margin-top: 0;
  margin-right: 3px;
}
label {
  cursor: pointer;
  font-weight: 400;
}
th label {
  margin-bottom: 0;
  font-weight: 700;
}
label.validate-error {
  display: block;
  font-weight: 400;
  color: red;
  font-size: min(3vw, 1.1rem) !important;
}
.form-label-1 {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  margin-right: 1em;
}
.form th label.text-1 {
  padding: 6px 0;
}
@media screen and (min-width: 768px) {
  .form th {
    width: 30%;
  }
}
.form-control {
  display: inline-block;
  border-radius: 2px;
  border-color: #aaa;
  font-size: 1.5rem;
}
.form-control[readonly] {
  background-color: #fcfdfd;
}
.form-group + .form-group {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px dotted #ccc;
}
.form-group label[for] {
  font-weight: 700;
  font-size: 15px;
}
select.form-control {
  padding-right: 3px;
  padding-left: 3px;
}
.input-group.datetimepicker {
  position: relative;
}
.bootstrap-datetimepicker-widget {
  position: absolute;
  z-index: 99;
  top: 0;
  right: 0;
}
.bootstrap-datetimepicker-widget .datepicker,
.bootstrap-datetimepicker-widget .timepicker {
  margin-top: -5px;
  box-shadow: 0 3px 15px rgba(0, 0, 0, 0.0666666667);
  border: 1px solid rgba(0, 0, 0, 0.1333333333);
  background-color: #fff;
}
.bootstrap-datetimepicker-widget .datepicker {
  width: 260px;
  padding: 12px;
}
.bootstrap-datetimepicker-widget .timepicker {
  width: 152px;
  padding: 0;
}
.bootstrap-datetimepicker-widget thead th {
  border: none;
}
.bootstrap-datetimepicker-widget td,
.bootstrap-datetimepicker-widget th {
  padding: 4px 5px;
}
.text-lts--01em {
  letter-spacing: -0.1em;
}
.text-sans-3 {
  font-family: "Barlow Condensed", "Zen Kaku Gothic New", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
    sans-serif;
}
.text-serif,
.text-serif-1 {
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.ff-googleplay {
  font-family: "Google play", "Shippori Mincho", "游明朝体", "Yu Mincho",
    YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL",
    "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.text-palt-first-letter:first-letter {
  font-feature-settings: "palt";
}
.text-0 {
  color: #4d4d4d !important;
}
.text-1,
.text-1 a {
  color: #d74646 !important;
}
.text-1 a:hover {
  color: #888 !important;
}
.text-2,
.text-2 a {
  color: #82bcd9 !important;
}
.text-2 a:hover {
  color: #888 !important;
}
.text-3,
.text-3 a {
  color: #e6adad !important;
}
.text-3 a:hover {
  color: #888 !important;
}
.text-underline-3 {
  background: linear-gradient(transparent 65%, #e6adad 50%);
}
.text-4,
.text-4 a {
  color: #adb4d9 !important;
}
.text-4 a:hover {
  color: #888 !important;
}
.text-5,
.text-5 a {
  color: #8fcca3 !important;
}
.text-5 a:hover {
  color: #888 !important;
}
.text-6,
.text-6 a {
  color: #fbf0f0 !important;
}
.text-6 a:hover {
  color: #888 !important;
}
.text-7,
.text-7 a {
  color: #f9f1f1 !important;
}
.text-7 a:hover {
  color: #888 !important;
}
.text-8,
.text-8 a {
  color: #fbf0f0 !important;
}
.text-8 a:hover {
  color: #888 !important;
}
.text-underline-8 {
  background: linear-gradient(transparent 65%, #eeeff5 50%);
}
.text-9,
.text-9 a {
  color: #ff0 !important;
}
.text-9 a:hover {
  color: #888 !important;
}
.text-underline-9 {
  background: linear-gradient(transparent 65%, #ff0 50%);
}
.text-10,
.text-10 a {
  color: #7db3b3 !important;
}
.text-10 a:hover {
  color: #888 !important;
}
.text-11,
.text-11 a {
  color: #f2f2f2 !important;
}
.text-11 a:hover {
  color: #888 !important;
}
.text-12,
.text-12 a {
  color: #ff5252 !important;
}
.text-12 a:hover {
  color: #888 !important;
}
.text-underline-12 {
  background: linear-gradient(transparent 65%, #ff5252 50%);
}
.text-13,
.text-13 a {
  color: #fcfce4 !important;
}
.text-13 a:hover {
  color: #888 !important;
}
.text-underline-13 {
  background: linear-gradient(transparent 65%, #fcfce4 50%);
}
.text-14,
.text-14 a {
  color: #6ec295 !important;
}
.text-14 a:hover {
  color: #888 !important;
}
.text-15,
.text-15 a {
  color: #f8f8ea !important;
}
.text-15 a:hover {
  color: #888 !important;
}
.text-16,
.text-16 a {
  color: #74b525 !important;
}
.text-16 a:hover {
  color: #888 !important;
}
.text-17,
.text-17 a {
  color: #def3f3 !important;
}
.text-17 a:hover {
  color: #888 !important;
}
.text-18,
.text-18 a {
  color: #eeebe0 !important;
}
.text-18 a:hover {
  color: #888 !important;
}
.text-19,
.text-19 a {
  color: #d2e8e9 !important;
}
.text-19 a:hover {
  color: #888 !important;
}
.text-20,
.text-20 a {
  color: #fbfac9 !important;
}
.text-20 a:hover {
  color: #888 !important;
}
.text-21,
.text-21 a {
  color: #f5e5e5 !important;
}
.text-21 a:hover {
  color: #888 !important;
}
.text-22,
.text-22 a {
  color: #d9c082 !important;
}
.text-22 a:hover {
  color: #888 !important;
}
.text-23,
.text-23 a {
  color: #faf6ed !important;
}
.text-23 a:hover {
  color: #888 !important;
}
.text-24,
.text-24 a {
  color: #807fce !important;
}
.text-24 a:hover {
  color: #888 !important;
}
.text-25,
.text-25 a {
  color: #e9e9f8 !important;
}
.text-25 a:hover {
  color: #888 !important;
}
.text-26,
.text-26 a {
  color: #8c2788 !important;
}
.text-26 a:hover {
  color: #888 !important;
}
.text-27,
.text-27 a {
  color: #e6eaff !important;
}
.text-27 a:hover {
  color: #888 !important;
}
.text-28,
.text-28 a {
  color: #f7edf8 !important;
}
.text-28 a:hover {
  color: #888 !important;
}
.text-29,
.text-29 a {
  color: #cbb72a !important;
}
.text-29 a:hover {
  color: #888 !important;
}
.text-30,
.text-30 a {
  color: #eee !important;
}
.text-30 a:hover {
  color: #888 !important;
}
.text-31,
.text-31 a {
  color: #eee !important;
}
.text-31 a:hover {
  color: #888 !important;
}
.text-gs-4,
.text-gs-4 a {
  color: #333 !important;
}
.text-gs-4 a:hover {
  color: #888 !important;
}
.text-gs-5,
.text-gs-5 a {
  color: #444 !important;
}
.text-gs-5 a:hover {
  color: #888 !important;
}
.text-gs-7,
.text-gs-7 a {
  color: #666 !important;
}
.text-gs-7 a:hover {
  color: #888 !important;
}
.text-gs-8,
.text-gs-8 a {
  color: #777 !important;
}
.text-gs-8 a:hover {
  color: #888 !important;
}
.text-gs-9,
.text-gs-9 a {
  color: #888 !important;
}
.text-gs-9 a:hover {
  color: #888 !important;
}
.text-gs-10,
.text-gs-10 a {
  color: #999 !important;
}
.text-gs-10 a:hover {
  color: #888 !important;
}
.text-gs-15,
.text-gs-15 a {
  color: #eee !important;
}
.text-gs-15 a:hover {
  color: #888 !important;
}
.text-gs-16,
.text-gs-16 a {
  color: #fff !important;
}
.text-gs-16 a:hover {
  color: #888 !important;
}
.text-italic {
  font-style: italic !important;
}
.text-uppercase {
  text-transform: uppercase !important;
}
.text-right {
  text-align: right !important;
}
.text-left {
  text-align: left !important;
}
.text-center {
  text-align: center !important;
}
.text-lh-1_2 {
  line-height: 1.2 !important;
}
.text-lh-1_3 {
  line-height: 1.3 !important;
}
.text-lh-1_4 {
  line-height: 1.4 !important;
}
.text-lh-1_5 {
  line-height: 1.5 !important;
}
.text-lh-1_6 {
  line-height: 1.6 !important;
}
.text-lh-1_8 {
  line-height: 1.8 !important;
}
.text-lh-1_9 {
  line-height: 1.9 !important;
}
.text-lh-2_4 {
  line-height: 2.4 !important;
}
@media screen and (max-width: 767px) {
  .text-xs-left {
    text-align: left !important;
  }
}
@media screen and (min-width: 1200px) {
  .text-lg-left {
    text-align: left !important;
  }
  .text-lg-center {
    text-align: center !important;
  }
}
.fw-b {
  font-weight: 700 !important;
}
.text-decoration-none {
  text-decoration: none;
}
.label-1 {
  display: inline-block;
  line-height: 1.4;
  margin: 0;
  padding: 0.2em 0.6em;
  border-radius: 2px;
  color: #fff;
  background-color: #d74646;
  font-size: min(3.2vw, 1.2rem);
}
.label-2 {
  display: inline-block;
  line-height: 1.4;
  margin: 0;
  padding: 0.2em 0.6em;
  border-radius: 2px;
  color: #fff;
  background-color: #82bcd9;
  font-size: min(3.2vw, 1.2rem);
}
.label-bordered-2 {
  display: inline-block;
  line-height: 1.4;
  margin: 0;
  padding: 0.2em 0.6em;
  border-radius: 2px;
  color: #82bcd9;
  background-color: rgba(0, 0, 0, 0);
  font-size: min(3.2vw, 1.2rem);
  border: 1px solid #82bcd9;
}
.label-3 {
  display: inline-block;
  line-height: 1.4;
  margin: 0;
  padding: 0.2em 0.6em;
  border-radius: 2px;
  color: #fff;
  background-color: #e6adad;
  font-size: min(3.2vw, 1.2rem);
}
.label-4 {
  display: inline-block;
  line-height: 1.4;
  margin: 0;
  padding: 0.2em 0.6em;
  border-radius: 2px;
  color: #fff;
  background-color: #adb4d9;
  font-size: min(3.2vw, 1.2rem);
}
.labels {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em;
}
.lazyloading {
  opacity: 0;
}
.lazyloaded {
  opacity: 1;
  transition: all 0.5s;
}
@media screen and (max-width: 767px) {
  .img-xs-fullsize-container {
    margin-left: -9vw;
    margin-right: -9vw;
  }
}
.blog-entry-thumbnail img,
.img-responsive {
  display: inline-block;
  max-width: 100%;
  height: auto;
}
.img-hover {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  backface-visibility: hidden;
}
a:hover .img-hover {
  opacity: 0.55;
}
.img-main-container {
  position: relative;
}
.img-main-texts {
  position: absolute;
  z-index: 2;
  bottom: 5%;
  right: 5%;
  width: 55%;
  line-height: 1;
}
.img-main-texts img {
  width: 100%;
  -webkit-filter: drop-shadow(2px 2px 2px rgba(255, 255, 255, 0.9));
  filter: drop-shadow(2px 2px 2px rgba(255, 255, 255, 0.9));
}
.img-main-texts.show {
  animation: texts-in 1s 1s both;
}
@media screen and (min-width: 768px) {
  .img-main-texts {
    width: 30%;
  }
}
@keyframes texts-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.link-box-1 {
  transition: 0.24s;
  display: block;
  color: #4d4d4d;
  text-decoration: none;
}
.link-box-1:hover {
  text-decoration: none;
  color: #888;
}
.link-box-1:hover [class*="text-"] {
  color: #888 !important;
}
.link-box-2 {
  transition: 0.24s;
  display: block;
  margin-bottom: 1.5em;
  color: #4d4d4d;
  text-decoration: none;
}
.link-box-2 img + .texts {
  margin-top: 0.6em;
}
.link-box-2 .texts {
  display: flex;
  align-items: center;
}
.link-box-2 .texts::before {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-bottom: 3px solid transparent;
  border-top: 3px solid transparent;
  border-left: 4px solid;
  border-left-color: #d74646;
  margin-right: 0.5em;
}
.link-box-2:hover {
  text-decoration: none;
  color: #888;
}
.link-box-2:hover [class*="text-"] {
  color: #888 !important;
}
.links-1 {
  list-style: none;
  padding: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.links-1 li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.links-1 .children {
  list-style: none;
  padding-left: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.links-1 .children > li:last-child {
  border: none;
}
.links-1 .children a {
  padding-left: 1.5em;
}
.links-1 a {
  display: block;
  padding: 0.5em;
  text-decoration: none;
  color: #4d4d4d;
}
.links-1 a:hover {
  color: #8fcca3;
  background-color: #eeebe0;
}
.links-toc-1 {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: min(7.6vw, 60px);
  padding: 0;
}
.links-toc-1 a {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #4d4d4d;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  position: relative;
  justify-content: center;
  width: 100%;
  min-width: 0;
  max-width: 320px;
  margin-bottom: 0.5em;
  border: 1px solid;
  background-color: #fff;
  color: #d74646;
  font-size: min(2.9vw, 1.4rem);
}
.links-toc-1 a::before {
  content: "";
  flex-basis: 1em;
}
.links-toc-1 a::after {
  content: "→";
  flex-basis: 1em;
}
.links-toc-1 a:visited {
  color: #4d4d4d;
}
.links-toc-1 a:focus,
.links-toc-1 a:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .links-toc-1 a {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .links-toc-1 a {
    font-size: 1.3rem;
  }
}
.links-toc-1 a::before {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 7px solid;
  position: absolute;
  top: 50%;
  left: 1em;
  transform: translateY(-50%);
}
.links-toc-1 a::after {
  content: normal;
}
.links-toc-1 a:hover {
  color: #bbb;
}
@media screen and (min-width: 768px) {
  .links-toc-1 {
    flex-wrap: nowrap;
  }
  .links-toc-1 a {
    border-radius: 0;
  }
  .links-toc-1 a:hover {
    border-color: #0fa0d1;
    background-color: #0fa0d1;
    color: #fff !important;
  }
  .links-toc-1 li + li a {
    border-left: 0;
  }
  .links-toc-1 li:first-child a {
    border-radius: 4px 0 0 4px;
  }
  .links-toc-1 li:last-child a {
    border-radius: 0 4px 4px 0;
  }
}
.nav-h-1 {
  list-style: none;
  display: flex;
  margin: 0;
  padding: 0;
}
.nav-h-1 > li {
  flex: 1 0 auto;
}
.nav-h-1 > li + li a::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: auto;
  width: 1px;
  background-color: rgba(255, 255, 255, 0.4);
}
.nav-h-1 a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.15em 0.5em;
  background-color: #7db3b3;
  color: #fff;
  text-decoration: none;
}
.nav-h-1 a:hover {
  background-color: #0fa0d1;
}
.nav-flow-step {
  transition: 0.24s;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 10px 0 30px;
  border-radius: 4px;
  color: #4d4d4d;
  background-color: #fff;
  text-decoration: none;
}
.nav-flow-step:hover {
  color: #0fa0d1;
}
.nav-flow-step:hover .image {
  opacity: 0.6;
}
.nav-flow-step:hover [class^="balloon"] {
  background-color: #0fa0d1;
  color: #fff;
}
.nav-flow-step:hover [class^="balloon"]::after {
  background-color: #0fa0d1;
}
.nav-flow-step:hover .nav-flow-arrow {
  border-color: #0fa0d1;
}
.nav-flow .image {
  position: relative;
  transition: 0.24s;
  padding: 6px;
}
.nav-flow .image img {
  border-radius: 100%;
}
.nav-flow .texts {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-right: 1.4em;
}
.nav-flow-arrow {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(50%, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 26px;
  height: 26px;
  border-radius: 100%;
  border: 1px solid #d74646;
  font-size: 10px;
  transition: 0.3s;
}
@media screen and (min-width: 1200px) {
  .nav-flow {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    row-gap: 42px;
  }
  .nav-flow-step {
    margin-bottom: 0;
  }
}
.tab-content > .tab-pane {
  display: block;
  height: 0;
  overflow: hidden;
}
.tab-content > .tab-pane .row {
  padding: 0 3vw;
}
.tab-content > .tab-pane .row .grid {
  margin-bottom: 6vw;
  padding: 0 3vw;
}
.tab-content > .active {
  height: auto;
}
@media screen and (min-width: 768px) {
  .tab-content > .tab-pane .row {
    padding: 0 15px;
  }
  .tab-content > .tab-pane .row .grid {
    margin-bottom: 30px;
    padding: 0 15px;
  }
}
.nav-tabs-1 {
  display: flex;
  justify-content: center;
  border-bottom-color: #aaa;
  text-align: center;
}
.nav-tabs-1 > li {
  float: none;
  display: inline-block;
  max-width: 400px;
  margin-left: 0.4%;
  margin-right: 0.4%;
  margin-bottom: -1px;
  border-bottom: 1px solid #aaa;
  border-radius: 4px 4px 0 0;
}
.nav-tabs-1 > li > a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 9px 15px;
  background-color: #eee;
  color: #999;
  text-shadow: 0 1px 0 #fff;
  text-decoration: none;
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
}
.nav-tabs-1 > li > a:hover {
  border-bottom-color: transparent;
  background-color: #ddd;
  color: #333;
}
.nav-tabs-1 > li.active {
  border-bottom: transparent;
}
.nav-tabs-1 > li.active > a,
.nav-tabs-1 > li.active > a:focus,
.nav-tabs-1 > li.active > a:hover {
  cursor: default;
  border: 1px solid #aaa;
  border-bottom-color: transparent;
  background-color: #fff;
  color: #4d4d4d;
}
@media screen and (min-width: 768px) {
  .nav-tabs-1 > li > a {
    padding-top: 16px;
    padding-bottom: 16px;
  }
}
.list-1 {
  padding-left: 1.4em;
}
.list-1 li {
  margin-bottom: 0.4em;
}
.list-2 {
  list-style: none;
  padding: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.list-2 li {
  padding: 1em 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.list-checked-1 {
  list-style: none;
  padding: 0.9em 1.7em;
  border-radius: 2px;
  line-height: 1.3;
  font-size: min(3vw, 1.4rem);
}
.list-checked-1 li {
  margin: 0.6em 0;
  padding-left: 21px;
  background: url(../../img/common/icon-checked-1.svg) no-repeat 0 0.2em;
}
.list-breadcrumb {
  overflow-x: auto;
  margin-bottom: 1em;
  background-color: #fafafa;
}
.list-breadcrumb ol {
  list-style: none;
  display: flex;
  padding: 1em;
  margin: 0;
  font-size: min(2.4vw, 1rem);
}
.list-breadcrumb ol > li {
  white-space: nowrap;
}
.list-breadcrumb ol > li + li::before {
  content: " / ";
  margin: 0 1em;
}
.title-1 {
  display: flex;
  flex-direction: column;
  margin: 1.3em 0;
  line-height: 1.46;
  font-size: min(6.7vw, 5.5rem);
  text-align: center;
}
.title-1 .small,
.title-1 small {
  margin-top: 0.3em;
  font-size: min(2.777777vw, 1.4rem);
  color: #d74646;
}
@media screen and (min-width: 768px) {
  .title-1 {
    margin: 1.8em 0;
  }
}
.title-2 {
  line-height: 1.46;
  margin: 1.5em 0;
  font-size: min(4.8vw, 2.8rem);
}
.title-3 {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin: 0 0 min(7.2vw, 1.9em);
  padding-top: min(7.2vw, 1.9em);
  padding-left: 1em;
  border-left: 2px solid;
  line-height: 1.36;
  font-weight: 400;
  font-size: min(4.3vw, 2.6rem);
  color: #d74646;
}
.title-3 > br {
  display: none;
}
.title-3 .small,
.title-3 small {
  letter-spacing: 0;
  font-size: min(2.9vw, 1.3rem);
  color: #4d4d4d;
}
.title-4 {
  line-height: 1.76;
  display: flex;
  margin: min(4vw, 1em) auto;
  font-size: min(4.46vw, 2.1rem);
}
.title-4::before {
  content: "";
  width: 6px;
  margin: 0.3em 0.7em 0.3em 0;
  background-color: #d74646;
}
.title-5 {
  line-height: 1.76;
  margin: min(8.2vw, 2em) auto;
  font-size: min(4.46vw, 2.1rem);
  text-align: center;
}
.title-5 .small,
.title-5 small {
  display: block;
  margin-bottom: 0.2em;
  font-size: 50%;
}
.title-6 {
  text-align: center;
  margin: 2em 0 2em;
  padding: 1em 0;
  border-top: 1px solid #d74646;
  border-bottom: 1px solid #eee;
  font-size: min(1.3rem + 0.6vw, 1.75rem);
}
.title-7 {
  margin: 1.5em 0 0.6em;
  font-size: min(1.4rem + 0.6vw, 1.7rem);
  font-weight: 700;
}
.title-7.bordered {
  padding-top: 1.4em;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.title-8 {
  line-height: 1.4;
  margin: 1em 0 0.5em;
  font-size: min(1.1rem + 0.6vw, 1.5rem);
  font-weight: 700;
}
.title-9 {
  line-height: 1.6;
  margin: 1.5em auto;
  font-size: min(6.6667vw, 3.4rem);
}
.title-9 .small,
.title-9 small {
  font-size: 48%;
}
.title-10 {
  display: inline-grid;
  grid-template-areas: "grid-1 grid-small grid-small" "grid-1 grid-2 grid-3";
  line-height: 1;
  margin: 0.64em auto;
  font-size: min(15.555vw, 6.1rem);
}
.title-10-grid-1 {
  grid-area: grid-1;
  padding-right: 0.08em;
}
.title-10-grid-2 {
  grid-area: grid-2;
  display: flex;
  align-items: flex-end;
  font-size: 35%;
}
.title-10-grid-3 {
  grid-area: grid-3;
  display: flex;
  align-items: flex-end;
  font-size: 80%;
}
.title-10 .small,
.title-10 small {
  grid-area: grid-small;
  display: flex;
  align-items: flex-end;
  margin-left: 0.1em;
  font-size: 22.2222%;
}
.title-plan-container {
  position: relative;
  margin-bottom: min(9vw, 40px);
}
.title-plan-container .title {
  font-size: min(8.8vw, 5.9rem);
}
.title-plan-container .lead {
  margin-bottom: 0.1em;
  font-size: min(3vw, 1.4rem);
}
.title-plan-container .price {
  font-size: min(3.36vw, 1.35rem);
}
.title-plan-container .price .num {
  margin-right: 0.1em;
  font-size: min(6.6vw, 4.5rem);
}
.title-plan-container .en {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translateY(31%);
  width: min(38vw, 400px);
  margin: 0;
}
.title-plan-container .en img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .title-plan-container .en {
    transform: none;
  }
}
.title-main-container {
  margin-bottom: 30px;
  padding: 1.1em 2%;
  background-color: #fbf0f0;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .title-main-container {
    margin-bottom: 60px;
  }
}
.title-main-container .title {
  display: flex;
  flex-direction: column;
  margin: 0;
  line-height: 1.45;
  font-size: min(4.2vw, 2.1rem);
  color: #7db3b3;
}
@media screen and (min-width: 768px) {
  .title-main-container {
    padding-top: 2.2em;
    padding-bottom: 2.2em;
  }
}
.border-radius-3 {
  border-radius: 3px !important;
}
.border-radius-4 {
  border-radius: 4px !important;
}
.border-radius-6 {
  border-radius: 6px !important;
}
.border-radius-12 {
  border-radius: 12px !important;
}
.border-circle {
  border-radius: 100% !important;
}
.border-1 {
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
}
.border-b-d {
  border-bottom: 1px dotted #b0a89f !important;
}
.border-b {
  border-bottom: 1px solid !important;
}
.border-t-1 {
  border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
}
.border-b-1 {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1) !important;
}
.border-r-1 {
  border-right: 1px solid rgba(0, 0, 0, 0.1) !important;
}
.border-b-n {
  border-bottom: none !important;
}
@media screen and (max-width: 767px) {
  .border-xs-r-n {
    border-right: none !important;
  }
  .border-xs-l-n {
    border-left: none !important;
  }
}
.border-w-2 {
  border-width: 2px !important;
}
.border-b-w-6 {
  border-bottom-width: 6px !important;
}
.border-w-10 {
  border-width: 10px !important;
}
.border-t-c-fff-055 {
  border-top-color: rgba(255, 255, 255, 0.55) !important;
}
.border-c-1 {
  border-color: #d74646 !important;
}
.border-t-c-1 {
  border-top-color: #d74646 !important;
}
.border-c-2 {
  border-color: #82bcd9 !important;
}
.border-c-3 {
  border-color: #e6adad !important;
}
.border-t-c-3 {
  border-top-color: #e6adad !important;
}
.border-c-4 {
  border-color: #adb4d9 !important;
}
.border-c-5 {
  border-color: #d74646 !important;
}
.border-c-12 {
  border-color: #ff5252 !important;
}
.border-c-21 {
  border-color: #f5e5e5 !important;
}
.border-c-25 {
  border-color: #e9e9f8 !important;
}
.border-gs-5 {
  border-color: #444 !important;
}
.border-gs-16 {
  border-color: #fff !important;
}
.box {
  margin-bottom: 60px;
}
.box::after {
  display: block;
  clear: both;
  content: "";
}
.box > p:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .box {
    margin-bottom: 80px;
  }
}
.box-shadow-1 {
  box-shadow: 0 12px 16px rgba(0, 0, 0, 0.05);
}
.box-plan,
a.box-plan {
  position: relative;
  display: block;
  max-width: 640px;
  margin-bottom: 1.5em;
  color: #4d4d4d;
  text-decoration: none;
  transition: 0.23s;
}
.box-plan .image,
a.box-plan .image {
  position: relative;
  display: block;
  width: min(82vw, 82%);
}
.box-plan .image img,
a.box-plan .image img {
  position: relative;
}
.box-plan .image::before,
a.box-plan .image::before {
  content: "";
  position: absolute;
  top: 18vw;
  left: 18vw;
  width: 100%;
  height: 100%;
}
.box-plan .texts,
a.box-plan .texts {
  position: relative;
  display: flex;
  flex-direction: column;
  width: min(77vw, 77%);
  margin-left: auto;
  padding: min(3.6vw, 1.4em) min(5vw, 1.7em);
  transform: translateY(-42%);
  background-color: #fff;
  transition: 0.44s;
}
.box-plan .title,
a.box-plan .title {
  line-height: 1.1;
  display: flex;
  align-items: flex-end;
  font-size: min(9vw, 3.2rem);
}
.box-plan .lead,
a.box-plan .lead {
  line-height: 1.4;
  margin-top: 0.2em;
  margin-bottom: 0.7em;
  font-size: min(2.3vw, 1.2rem);
  color: #7d7d7d;
}
.box-plan .price,
a.box-plan .price {
  font-size: 200%;
}
.box-plan .price .symbol,
a.box-plan .price .symbol {
  margin-right: 0.3em;
  font-size: 1.4rem;
}
.box-plan .en,
a.box-plan .en {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translate(-20%, 60%);
}
.box-plan-rental .image::before,
a.box-plan-rental .image::before {
  background-color: #fbf0f0;
}
.box-plan-rental .texts,
a.box-plan-rental .texts {
  box-shadow: 0 0 10px rgba(130, 188, 217, 0.5);
}
.box-plan-rental .texts::after,
a.box-plan-rental .texts::after {
  background-color: #82bcd9;
}
.box-plan-rental .label,
a.box-plan-rental .label {
  display: inline-flex;
  margin-left: 0.2em;
  padding-right: 0.3em;
  background-color: #82bcd9;
  letter-spacing: -0.1em;
  color: #fff;
  font-size: 91%;
}
.box-plan-rental .price,
a.box-plan-rental .price {
  color: #82bcd9;
}
.box-plan-purchase .image::before,
a.box-plan-purchase .image::before {
  background-color: #faf6ed;
}
.box-plan-purchase .texts,
a.box-plan-purchase .texts {
  box-shadow: 0 0 10px rgba(217, 192, 130, 0.5);
}
.box-plan-purchase .texts::after,
a.box-plan-purchase .texts::after {
  background-color: #d9c082;
}
.box-plan-purchase .label,
a.box-plan-purchase .label {
  display: inline-flex;
  margin-left: 0.2em;
  padding-left: 0.2em;
  padding-right: 0.3em;
  background-color: #d9c082;
  letter-spacing: -0.1em;
  color: #fff;
  font-size: 91%;
}
.box-plan-purchase .price,
a.box-plan-purchase .price {
  color: #d9c082;
}
.box-plan-mama .image::before,
a.box-plan-mama .image::before {
  background-color: #f9f1f1;
}
.box-plan-mama .texts,
a.box-plan-mama .texts {
  box-shadow: 0 0 10px rgba(230, 173, 173, 0.5);
}
.box-plan-mama .texts::after,
a.box-plan-mama .texts::after {
  background-color: #e6adad;
}
.box-plan-mama .title,
a.box-plan-mama .title {
  align-items: center;
}
.box-plan-mama .en,
a.box-plan-mama .en {
  transform: translate(10%, 60%);
}
.box-plan-mama .label,
a.box-plan-mama .label {
  display: inline-flex;
  margin-right: 0.2em;
  padding: 0.1em 0.3em;
  background-color: #e6adad;
  color: #fff;
  font-size: min(4vw, 1.6rem);
}
.box-plan-mama .price,
a.box-plan-mama .price {
  color: #e6adad;
}
.box-plan-photo .image::before,
a.box-plan-photo .image::before {
  background-color: #fbf0f0;
}
.box-plan-photo .texts,
a.box-plan-photo .texts {
  box-shadow: 0 0 10px rgba(173, 180, 217, 0.5);
}
.box-plan-photo .texts::after,
a.box-plan-photo .texts::after {
  background-color: #adb4d9;
}
.box-plan-photo .en,
a.box-plan-photo .en {
  transform: translate(-30%, 80%);
}
.box-plan-photo .label,
a.box-plan-photo .label {
  display: inline-flex;
  align-items: baseline;
  margin-right: 0.2em;
  padding: 0 0.1em;
  background-color: #adb4d9;
  color: #fff;
  font-size: 91%;
}
.box-plan-photo .price,
a.box-plan-photo .price {
  color: #adb4d9;
}
.box-plan-hakama .image::before,
a.box-plan-hakama .image::before {
  background-color: #f8f8ea;
}
.box-plan-hakama .texts,
a.box-plan-hakama .texts {
  box-shadow: 0 0 10px rgba(110, 194, 149, 0.5);
}
.box-plan-hakama .texts::after,
a.box-plan-hakama .texts::after {
  background-color: #6ec295;
}
.box-plan-hakama .label,
a.box-plan-hakama .label {
  display: inline-flex;
  margin-left: 0.2em;
  padding-right: 0.3em;
  background-color: #6ec295;
  letter-spacing: -0.1em;
  color: #fff;
  font-size: 91%;
}
.box-plan-jounior .image::before,
a.box-plan-jounior .image::before {
  background-color: #f8f8ea;
}
.box-plan-jounior .texts,
a.box-plan-jounior .texts {
  box-shadow: 0 0 10px rgba(203, 183, 42, 0.5);
}
.box-plan-jounior .texts::after,
a.box-plan-jounior .texts::after {
  background-color: #cbb72a;
}
.box-plan-jounior .label,
a.box-plan-jounior .label {
  display: inline-flex;
  margin-left: 0.2em;
  padding-right: 0.3em;
  background-color: #cbb72a;
  letter-spacing: -0.1em;
  color: #fff;
  font-size: 91%;
}
@media screen and (max-width: 576px) {
  .box-plan,
  a.box-plan {
    overflow: hidden;
  }
}
@media screen and (min-width: 1200px) {
  .box-plan,
  a.box-plan {
    margin-left: auto;
    margin-right: auto;
  }
  .box-plan .image,
  a.box-plan .image {
    width: 100%;
  }
  .box-plan .image::before,
  a.box-plan .image::before {
    content: normal;
  }
  .box-plan .texts,
  a.box-plan .texts {
    width: 90%;
    transform: translate(7%, -20%);
    margin-left: auto;
  }
}
a.box-plan .texts::after {
  content: "→";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-50%, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2em;
  height: 2em;
  border-radius: 100%;
  background-color: #d74646;
  font-size: 70%;
  color: #fff;
}
@media screen and (min-width: 992px) {
  a.box-plan:hover {
    opacity: 0.6;
  }
}
.box-plan-image-right,
a.box-plan-image-right {
  margin-left: auto;
}
.box-plan-image-right .image,
a.box-plan-image-right .image {
  margin-left: auto;
}
.box-plan-image-right .image::before,
a.box-plan-image-right .image::before {
  left: -18vw;
}
.box-plan-image-right .texts,
a.box-plan-image-right .texts {
  margin-left: 0;
}
@media screen and (min-width: 1200px) {
  .box-plan-image-right .texts,
  a.box-plan-image-right .texts {
    margin-left: auto;
  }
}
.box-a {
  position: relative;
  margin-bottom: 30px;
  padding: min(1.8vw, 12px) min(5vw, 40px);
  border-radius: 4px;
  border: 1px solid #d74646;
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .box-a {
    margin-bottom: 60px;
  }
}
.box-a-p-t {
  padding-top: min(4.4vw, 2em);
}
.box-a p,
.box-a-g-b {
  margin-bottom: min(4.4vw, 2em);
  font-size: min(2.9vw, 1.3rem);
}
.box-a a[class^="btn-"] {
  padding-top: 1em;
  padding-bottom: 1em;
  font-size: min(3.6vw, 1.5rem);
}
.box-a-num {
  position: absolute;
  top: 0;
  right: min(9%, 30px);
  transform: translateY(-37%);
  line-height: 1;
  font-size: min(21vw, 10.6rem);
  font-style: italic;
  color: #ccc;
}
.box-a-title {
  line-height: 1.76;
  display: flex;
  margin: min(4vw, 1em) auto;
  font-size: min(4.46vw, 2.1rem);
  margin: min(3vw, 1em) auto;
}
.box-a-title::before {
  content: "";
  width: 6px;
  margin: 0.3em 0.7em 0.3em 0;
  background-color: #d74646;
}
.box-a-lead {
  line-height: 1.5;
  font-size: min(4.46vw, 2.1rem) !important;
}
.box-a-block-1 {
  margin-bottom: min(5vw, 40px);
  padding: min(1.8vw, 12px) min(5vw, 40px);
  background-color: #fcfce4;
}
.box-a-block-1-title {
  margin: min(4vw, 2em) auto;
  font-size: min(4vw, 1.8rem);
  color: #d74646;
  text-align: center;
}
.box-b .title {
  grid-area: title;
}
.box-b .image {
  grid-area: image;
}
.box-b .texts {
  grid-area: texts;
}
@media screen and (min-width: 992px) {
  .box-b {
    display: grid;
    grid-gap: 0 40px;
    grid-template-columns: calc(50% - 20px) calc(50% - 20px);
    grid-template-areas: "title image" "texts image";
  }
  .box-b .title {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
  }
}
.box-icons {
  display: flex;
  font-size: min(2.8vw, 1.2rem);
}
.box-icons .icon {
  margin-bottom: 1.2em;
  text-align: center;
}
.box-icons .i {
  margin-left: 10%;
  margin-right: 10%;
  margin-bottom: 0.3em;
}
.box-icons.circle .i {
  overflow: hidden;
  border-radius: 100%;
}
.box-icons.column-3 {
  flex-wrap: wrap;
}
.box-icons.column-3 .icon {
  flex: 0 0 33.3333333333%;
}
.box-icons.column-4 {
  flex-wrap: wrap;
}
.box-icons.column-4 .icon {
  flex: 0 0 25%;
}
@media screen and (max-width: 767px) {
  .box-icons.column-xs-2 {
    flex-wrap: wrap;
  }
  .box-icons.column-xs-2 .icon {
    flex: 0 0 50%;
  }
  .box-icons.column-xs-3 {
    flex-wrap: wrap;
  }
  .box-icons.column-xs-3 .icon {
    flex: 0 0 33.3333333333%;
  }
  .box-icons.column-xs-4 {
    flex-wrap: wrap;
  }
  .box-icons.column-xs-4 .icon {
    flex: 0 0 25%;
  }
}
.box-catalog-pickup {
  position: relative;
  padding: 4% 7%;
  border: 8px solid #adb4d9;
  text-align: left;
}
.box-catalog-pickup-cc {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -60%);
}
.box-catalog-pickup-title {
  letter-spacing: 0.16em;
  font-size: 103%;
  text-align: center;
  text-transform: uppercase;
}
.box-catalog-pickup-columns {
  display: flex;
  justify-content: space-between;
}
.box-catalog-pickup-columns .image {
  flex-basis: 30%;
}
.box-catalog-pickup-columns .texts {
  flex-basis: 63%;
}
.box-catalog-pickup-columns .texts p {
  font-size: 70%;
}
.box-catalog-pickup a[class^="btn-"] {
  max-width: 90%;
  margin: 0.75em 5%;
  padding-top: 1em;
  padding-bottom: 1em;
  font-size: min(3.2vw, 1.4rem);
}
.box-item-1 {
  display: block;
  margin-top: 0.75em;
  margin-bottom: min(8.5vw, 40px);
}
.box-item-1-name {
  display: block;
  line-height: 1.3;
  margin: 0.8em auto;
}
.box-item-1-prices {
  display: flex;
  justify-content: space-between;
  font-size: min(3.2vw, 1.2rem);
  text-align: center;
}
.box-item-1-price-1,
.box-item-1-price-2 {
  display: flex;
  align-items: center;
}
.box-item-1-price-1 .label,
.box-item-1-price-2 .label {
  display: block;
  flex: 0 0 46%;
  max-width: 6.2em;
  font-size: 86%;
  text-align: center;
}
.box-item-1-price-1 .price,
.box-item-1-price-2 .price {
  flex: 1 1 auto;
  margin-left: 0.75em;
}
.box-item-1-price-1 .label {
  background-color: #d74646;
  color: #fff;
}
.box-item-1-price-2 .label {
  background-color: #82bcd9;
  color: #fff;
}
.box-item-1-price-3 .label {
  background-color: #e6adad;
  color: #fff;
}
.box-item-2-prices {
  display: flex;
  justify-content: space-between;
  gap: 4%;
  text-align: center;
  line-height: 1.2;
}
.box-item-2-price-1,
.box-item-2-price-2,
.box-item-2-price-3 {
  flex-basis: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(0, 0, 0, 0.1);
  padding: min(3vw, 18px);
  border-radius: 5px;
}
.box-item-2-price-1 .label,
.box-item-2-price-2 .label,
.box-item-2-price-3 .label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 0.4em;
  padding: 0 0 0.6em;
  border-style: solid;
  border-width: 0 0 2px;
  flex-basis: 100%;
}
.box-item-2-price-1 [class^="btn-"],
.box-item-2-price-2 [class^="btn-"],
.box-item-2-price-3 [class^="btn-"] {
  margin-top: min(3vw, 13px);
  min-width: 0;
  width: 100%;
  padding: 0.6em 0.8em;
  font-size: 90%;
}
.box-item-2-price-1 .label {
  border-color: #d74646;
}
.box-item-2-price-2 .label {
  border-color: #82bcd9;
}
.box-item-2-price-3 .label {
  border-color: #e6adad;
}
.box-aj-1 {
  position: relative;
  margin-top: -4.5em;
  padding: 0 7% 1px;
  border-radius: 4px;
  background-color: #fff;
  text-align: center;
}
.box-aj-1-title {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 4em;
  margin: 0 0 1em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.0666666667);
  font-size: min(4.1vw, 1.8rem);
}
.box-aj-2 {
  display: flex;
  justify-content: space-between;
  margin-bottom: calc(13vw - 1.8em);
}
.box-aj-2 .image {
  box-shadow: 13vw 13vw 0 #f9f1f1;
}
.box-reservation-1 {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 282px;
  margin: 70px auto;
  border-top: 1px solid rgba(0, 0, 0, 0.084);
  background-image: url(../../img/common/bg-reservation-1.png);
  background-position: 50% 50%;
  background-size: cover;
  text-align: center;
}
.box-reservation-1-badge {
  position: absolute;
  top: 22px;
  left: 50%;
  transform: translateX(-158px);
}
@media screen and (min-width: 1200px) {
  .box-reservation-1 p {
    font-size: 1.6rem;
  }
  .box-reservation-1 [class^="btn-"] {
    width: 740px;
    font-size: 2.1rem;
    padding: 22px 35px;
  }
  .box-reservation-1-badge {
    top: 9px;
    transform: translateX(-182px);
  }
}
.box-floating {
  position: fixed;
  z-index: 999;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 400px;
  border-top: 1px solid #7db3b3;
}
.box-floating.slide-floating-banners-style-2 {
  border-top-color: #d49999;
}
.box-floating.slide-floating-banners-style-2 .image {
  background-color: #e6adad;
}
.box-floating.slide-floating-banners-style-2 .box-floating-fraction {
  color: #e6adad;
}
.box-floating.slide-floating-banners-style-2 .title {
  color: #e6adad !important;
}
.box-floating.slide-floating-banners-style-2 a:hover .image {
  background-color: #e09a9a !important;
}
.box-floating a {
  transition: 0.2s;
}
.box-floating a:hover {
  opacity: 0.6;
}
.box-floating .image {
  background-color: #d74646;
}
.box-floating .title {
  color: #d74646;
}
.box-floating-btn-close {
  position: absolute;
  z-index: 10;
  top: 0;
  right: 0;
  transform: translate(-20%, -70%);
  width: 26px;
  height: 26px;
  border-radius: 100%;
  background-color: #f0f0f0;
  transition: 0.3s;
  cursor: pointer;
}
.box-floating-btn-close::after,
.box-floating-btn-close::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  background-color: #000;
  transition: 0.1s;
}
.box-floating-btn-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.box-floating-btn-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.box-floating-btn-close:hover {
  background-color: #333;
}
.box-floating-btn-close:hover::after,
.box-floating-btn-close:hover::before {
  background-color: #fff;
}
.box-floating-fraction {
  position: absolute;
  z-index: 9;
  bottom: auto;
  top: 0;
  left: 1%;
  transform: translateY(-100%);
  width: auto;
  font-size: 11px;
  font-family: Oswald, "Zen Kaku Gothic New", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
    sans-serif;
  color: #7db3b3;
}
.box-floating-title {
  position: absolute;
  z-index: 9;
  top: 0;
  left: 50%;
  transform: translate(-50%, -74%);
  width: 58.13333%;
  max-width: 218px;
}
@media screen and (min-width: 401px) {
  .box-floating {
    transform: translateX(-50%);
    left: 50%;
    bottom: 10px;
    border: 1px solid #7db3b3;
  }
  .box-floating.slide-floating-banners-style-2 {
    border-color: #d49999;
  }
}
@media screen and (min-width: 440px) {
  .box-floating {
    transform: initial;
    left: auto;
    right: 20px;
    bottom: 20px;
  }
}
.has-box-floating .copyright-container {
  padding-bottom: 100px;
}
@media screen and (min-width: 401px) {
  .has-box-floating .copyright-container {
    padding-bottom: 150px;
  }
}
.box-floating-center {
  top: 50%;
  left: 50%;
  right: auto;
  bottom: auto;
  transform: translate(-50%, -50%);
  width: 92%;
  max-width: 400px;
  border: none;
  background-color: rgba(0, 0, 0, 0);
  border-radius: 10px;
  padding: 20px;
  text-align: center;
  box-shadow: none;
  filter: drop-shadow(2px 4px 22px rgba(0, 0, 0, 0.45));
}
.box-floating-center a:hover {
  opacity: 1;
  filter: brightness(1.1);
}
.box-floating-btn-close-center {
  transform: translate(50%, -50%);
  background-color: #fff;
}
.card-h-1 {
  position: relative;
  display: flex;
  margin: 3.5% 0;
  background-color: #fff;
  justify-content: space-between;
  align-items: center;
}
.card-h-1 .image {
  position: relative;
}
.card-h-1 .texts {
  line-height: 1.3;
}
.card-h-1 .texts .title {
  display: block;
  margin-bottom: 0.4em;
}
.card-h-1 .text-p {
  display: block;
  line-height: 1.5;
  font-size: min(2.9vw, 1.3rem);
}
.card-h-1 .image {
  flex: 1 0 33.33333333%;
}
.card-h-1 .texts {
  flex: 1 0 66.6666666%;
  padding: 1em 6.8%;
}
.card-h-1 .texts .title {
  color: #f9f1f1;
}
.card-h-1 .text-p + .text-p {
  margin-top: 1em;
}
a.card-h-1::before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 1em 1em;
  border-color: transparent transparent #e6adad transparent;
}
a.card-h-1:hover img {
  opacity: 0.6;
}
a.card-h-1:hover::before {
  border-color: transparent transparent #d74646 transparent;
}
.card-h-2 {
  position: relative;
  display: flex;
  margin: 3.5% 0;
  background-color: #fff;
}
.card-h-2 .image {
  position: relative;
}
.card-h-2 .texts {
  line-height: 1.3;
}
.card-h-2 .texts .title {
  display: block;
  margin-bottom: 0.4em;
}
.card-h-2 .text-p {
  display: block;
  line-height: 1.5;
  font-size: min(2.9vw, 1.3rem);
}
.card-h-2 .image {
  flex-basis: min(26.6666666%, 90px);
  flex-shrink: 0;
  margin-right: min(7%, 24px);
}
.card-h-2 .text-p + .text-p {
  margin-top: 0.5em;
}
.card-h-2 .text-p.date {
  color: #7db3b3;
}
a.card-h-2:hover img {
  opacity: 0.6;
}
.card-h-3 {
  position: relative;
  display: flex;
  margin: 3.5% 0;
  background-color: #fff;
  justify-content: space-between;
  align-items: center;
  border: 1px solid #d74646;
}
.card-h-3 .image {
  position: relative;
}
.card-h-3 .texts {
  line-height: 1.3;
}
.card-h-3 .texts .title {
  display: block;
  margin-bottom: 0.4em;
}
.card-h-3 .text-p {
  display: block;
  line-height: 1.5;
  font-size: min(2.9vw, 1.3rem);
}
.card-h-3 .image {
  flex-basis: 30%;
}
.card-h-3 .texts {
  flex-basis: 70%;
  padding: 0 4%;
}
.card-h-3 .texts .title {
  margin-bottom: 0;
  color: #d74646;
  font-size: min(4vw, 1.6rem);
}
.card-h-3 .text-p + .text-p {
  margin-top: 1em;
}
a.card-h-3 {
  text-decoration: none;
  color: #4d4d4d;
}
a.card-h-3::before {
  content: "→";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-50%, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2em;
  height: 2em;
  border-radius: 100%;
  background-color: #d74646;
  font-size: 70%;
  color: #fff;
}
a.card-h-3:hover img {
  opacity: 0.6;
}
a.card-h-3:hover::before {
  border-color: transparent transparent #d74646 transparent;
}
.card-h-4 {
  position: relative;
  display: flex;
  margin: 3.5% 0;
  background-color: #fff;
  justify-content: space-between;
  background-color: #fff;
}
.card-h-4 .image {
  position: relative;
}
.card-h-4 .texts {
  line-height: 1.3;
}
.card-h-4 .texts .title {
  display: block;
  margin-bottom: 0.4em;
}
.card-h-4 .text-p {
  display: block;
  line-height: 1.5;
  font-size: min(2.9vw, 1.3rem);
}
.card-h-4 .image {
  flex-basis: 28.5714%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #7db3b3;
  color: #fff;
  font-size: min(4.5vw, 1.7rem);
  font-family: Oswald, "Zen Kaku Gothic New", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
    sans-serif;
}
.card-h-4 .image .date-2::before {
  content: "";
  display: block;
  width: 15px;
  height: 1px;
  margin: 0 auto;
  background-color: #ff0;
  transform: rotate(-22.5deg);
}
.card-h-4 .texts {
  flex-basis: 71.4285%;
  display: flex;
  align-items: center;
}
.card-h-4 .texts .title {
  margin: 0 0.15em 0 0.3em;
  color: #7db3b3;
  font-size: min(8.2vw, 3.6rem);
  line-height: 1;
  white-space: nowrap;
}
.card-h-4 .texts .text {
  font-size: min(3.3vw, 1.3rem);
}
.card-h-4 .text-p + .text-p {
  margin-top: 1em;
}
a.card-h-4 {
  text-decoration: none;
}
.texts a.card-h-4::after,
a.card-h-4 .image,
a.card-h-4 .texts .text,
a.card-h-4 .texts .title {
  transition: 0.24s;
}
a.card-h-4 .texts {
  padding-right: 14px;
  color: #4d4d4d;
}
a.card-h-4 .texts::after {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-bottom: 3px solid transparent;
  border-top: 3px solid transparent;
  border-left: 4px solid;
  position: absolute;
  top: 50%;
  right: 2px;
  transform: translate(0, -50%);
  margin-right: 0.6em;
  border-left-color: #d74646;
}
@media screen and (min-width: 992px) {
  a.card-h-4:hover .image {
    background-color: #0fa0d1 !important;
  }
  a.card-h-4:hover .texts .title {
    color: #0fa0d1;
  }
  a.card-h-4:hover .texts .text {
    color: #aaa;
  }
  a.card-h-4:hover .texts::after {
    border-left-color: #0fa0d1;
  }
}
.separator-1 + .separator-1 {
  margin-top: 60px;
  padding-top: 60px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.grid-1 {
  grid-area: grid-1;
}
.grid-2 {
  grid-area: grid-2;
}
.grid-3 {
  grid-area: grid-3;
}
.grid-all-in-one-price {
  border-radius: 12px;
  padding: min(9%, 50px);
}
@media screen and (min-width: 992px) {
  .grid-all-in-one-price.grid-show {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "grid-2 grid-1" "grid-2 grid-3";
  }
  .grid-all-in-one-price.grid-show .grid-1,
  .grid-all-in-one-price.grid-show .grid-2 {
    align-self: center;
  }
}
.grid-gallery-1 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.slick-slide img {
  margin-left: auto;
  margin-right: auto;
}
.slick-next,
.slick-next:focus,
.slick-next:hover,
.slick-prev,
.slick-prev:focus,
.slick-prev:hover {
  z-index: 1;
  width: 16px;
  height: 27px;
  background-position: 50%;
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  background-size: contain;
}
.slick-next:before,
.slick-next:focus:before,
.slick-next:hover:before,
.slick-prev:before,
.slick-prev:focus:before,
.slick-prev:hover:before {
  content: none;
}
.slick-prev {
  left: 3%;
  background-image: url(../../img/common/arrow_prev.png);
}
.slick-next {
  right: 3%;
  background-image: url(../../img/common/arrow_next.png);
}
.slick-prev:focus,
.slick-prev:hover {
  opacity: 0.8;
  background-image: url(../../img/common/arrow_prev.png);
}
.slick-next:focus,
.slick-next:hover {
  opacity: 0.8;
  background-image: url(../../img/common/arrow_next.png);
}
.slick-dots {
  bottom: 5%;
  display: flex !important;
  justify-content: center;
  margin-bottom: 0;
}
.slick-dots li {
  display: flex;
  align-items: center;
  width: 40px;
  height: 30px;
  margin-left: 10px;
}
.slick-dots li button {
  width: 100%;
  height: 100%;
}
.slick-dots li button::before {
  content: "";
  line-height: 0;
  position: relative;
  display: block;
  width: 100%;
  height: 0;
  border-top: 4px solid;
}
.slide-v-container {
  position: relative;
}
@media screen and (min-width: 1200px) {
  .slide-v-container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 40%;
    height: 650px;
    background-color: #adb4d9;
  }
}
.slide-v {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .slide-v {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.slide-v-pagination {
  position: absolute;
  z-index: 11;
  top: 56.6666666667vw;
  left: auto !important;
  right: 3vw;
  bottom: auto !important;
  transform: translate(0, -50%);
  display: flex;
  flex-direction: column;
  width: 26px !important;
}
@media screen and (min-width: 768px) {
  .slide-v-pagination {
    top: 50%;
  }
}
.slide-catalog-thumbs {
  display: flex;
  flex-direction: column;
  gap: 2%;
  padding: 2%;
}
.slide-catalog-thumbs > div {
  position: relative;
  overflow: hidden;
  height: 18.5%;
  border: 1px solid rgba(0, 0, 0, 0.1);
  cursor: pointer;
}
.slide-catalog-thumbs > div img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.swiper-wrapper {
  transition: 0.2s !important;
}
.swiper-slide {
  overflow: hidden;
}
.swiper-pagination-1 {
  position: absolute;
  z-index: 2;
  bottom: min(1vw, 10px) !important;
  text-align: center;
}
.transition-active .trf-scale {
  transform: scale(1.4);
  transition: transform 14s linear;
}
@media screen and (min-width: 768px) {
  .transition-active .trf-scale {
    transform: scale(1.2);
  }
}
.sl-overlay {
  background-color: #000;
}
.pswp__bg {
  background-color: rgba(0, 0, 0, 0.7);
}
.pswp__caption {
  padding: 1em;
  color: #fff;
}
.pswp__caption br {
  display: none;
}
.pswp__caption hr {
  border: none !important;
}
.pswp__caption__center {
  line-height: 1.4;
  font-size: 11px;
  color: #fff;
  text-align: center;
}
.pswp__button,
.pswp__counter {
  opacity: 1;
}
.pswp__img {
  padding: 0 20px 70px;
}
.pswp-help-container {
  position: fixed;
  z-index: 9999;
  top: 50%;
  left: 50%;
  width: 100px;
  height: 100px;
  margin: -50px 0 0 -50px;
  background: red;
}
.header-alternation-fixed {
  position: relative;
  height: 55px;
}
@media screen and (min-width: 992px) {
  .header-alternation-fixed {
    height: 80px;
  }
}
.site-header {
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  width: 100%;
  height: 55px;
  border-bottom: 0 solid transparent;
  font-size: 12px;
  background-color: #fff;
  transition: all 0.4s ease-out;
}
@media screen and (min-width: 992px) {
  .site-header {
    height: 80px;
  }
}
.header-lazy {
  top: -300px;
}
.contents-fixed .header-lazy {
  top: 0;
}
.header-inner {
  position: relative;
  height: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.header-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(21vw, 100px);
  margin: 0;
  font-size: max(0.5rem, min(1vw, 1.1rem));
  font-family: Oswald, "Zen Kaku Gothic New", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
    sans-serif;
  text-transform: uppercase;
  transition: all 0.2s ease-out;
}
.header-logo a {
  display: flex;
  align-items: center;
  height: 100%;
  color: #222;
  text-decoration: none;
}
.header-logo img {
  transition: all 0.2s ease-out 0.1s;
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .header-logo {
    width: 100px;
  }
}
@media screen and (min-width: 992px) {
  .header-logo {
    left: 2.3%;
    transform: translate(0, -50%);
  }
}
.header-contact-container {
  display: flex;
  height: 26px;
  transition: all 0.3s ease-out;
}
.header-contact-container a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.1;
  min-width: 0;
  padding-left: 1em;
  padding-right: 1em;
  border-radius: 13px 0 0 13px;
  background-color: #d74646;
  color: #fff;
  letter-spacing: 0.06em;
  font-size: min(3vw, 1.3rem);
  text-decoration: none;
}
.header-contact-container a .arrow {
  margin-right: 0.5em;
}
.sp-header-link {
  position: fixed;
  top: 0;
  left: 2.2222222vw;
  display: flex;
  justify-content: center;
  height: 55px;
  z-index: 9999;
}
.sp-header-link.active {
  position: fixed;
}
@media screen and (min-width: 992px) {
  .sp-header-link {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .header-fixed {
    height: 55px;
  }
}
@media screen and (min-width: 768px) {
  .header-fixed .header-logo img {
    transform: scale(0.8);
  }
}
.global-nav {
  display: none;
}
@media screen and (min-width: 992px) {
  .global-nav {
    display: block;
    height: 100%;
  }
  .global-nav a,
  .global-nav li,
  .global-nav ul {
    height: 100%;
  }
  .global-nav ul {
    list-style: none;
    display: flex;
    align-items: center;
    margin: 0 1.2em 0 0;
    padding: 0;
  }
  .global-nav ul a {
    display: flex;
    align-items: center;
    height: 100%;
    padding-left: 1.2em;
    padding-right: 1.2em;
    color: #4d4d4d;
    font-size: min(0.8vw, 1.2rem);
    font-family: Oswald, "Zen Kaku Gothic New", "ヒラギノ角ゴ Pro W3",
      "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
      sans-serif;
    transition: all 0.2s;
    text-decoration: none;
  }
  .global-nav ul a:hover {
    background-color: #0fa0d1;
    color: #fff;
    text-decoration: none;
  }
}
.global-nav-container-sp-fadeout {
  animation: fade-out 0.3s linear 0s both;
}
.global-nav-container-sp-flex {
  display: flex;
  align-items: flex-end;
}
.global-nav-container-sp {
  -webkit-transition: all 0.4s ease-in-out 0s;
  transition: all 0.4s ease-in-out 0s;
  position: fixed;
  top: 0;
  bottom: 0;
  height: 100%;
  left: 0;
  right: 0;
  z-index: -1;
  width: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  background-color: rgba(0, 0, 0, 0.32);
}
.global-nav-container-sp.fade {
  opacity: 0;
}
.global-nav-container-sp.in {
  z-index: 1198;
  animation: fade-in 0.3s linear 0s both;
}
.global-nav-container-sp.in .global-nav-inner {
  transform: translate(0, 0);
}
.global-nav-container-sp .global-nav-inner {
  max-width: 400px;
  margin: 0 auto;
  background-color: #fff;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.4);
  -webkit-transition: all 0.4s ease-in-out 0s;
  transition: all 0.4s ease-in-out 0s;
  transform: translate(0, -10%);
}
.global-nav-sp {
  padding: 15px;
}
.global-nav-sp-close {
  position: absolute;
  top: 6px;
  right: 0;
  width: 30px;
  font-size: 22px;
}
.global-nav-sp .footer-links-container {
  padding: 0 20px;
}
.global-nav-sp .footer-links a {
  font-size: min(3vw, 1.3rem);
  text-align: center;
  color: #4d4d4d;
}
.global-nav-title {
  margin-bottom: 10px;
  padding: 6px 0;
  font-size: 13px;
  text-align: center;
  text-transform: uppercase;
  color: #d74646;
}
.footer {
  position: relative;
  padding-top: 1px;
  font-size: 12px;
  text-align: center;
  background-color: #fbf0f0;
}
.footer-inner {
  padding: min(8vw, 4em) 0;
}
.footer a {
  text-decoration: none;
}
@media screen and (min-width: 992px) {
  .footer-inner {
    display: flex;
    justify-content: space-between;
    padding: 90px 0;
  }
}
.footer-logo {
  width: 43%;
  max-width: 145px;
  margin: 0 auto min(8vw, 4em);
}
.footer-logo a {
  display: block;
  text-decoration: none;
  font-size: min(2.8vw, 1.1rem);
}
.footer-logo a:hover {
  color: #888;
}
.footer-logo img {
  display: block;
  margin: 0 0 0.3em 11%;
}
@media screen and (min-width: 992px) {
  .footer-logo {
    margin-top: 0;
    margin-left: 0;
    margin-right: 11%;
  }
}
.footer-banners {
  padding: 1px 0;
  background-color: #fff;
}
.footer-banners .container > * {
  margin: min(6vw, 50px) auto;
}
@media screen and (min-width: 992px) {
  .footer-banners .container {
    display: flex;
    align-items: center;
  }
  .footer-banners .container > :first-child {
    width: 30%;
  }
  .footer-banners .container > :nth-child(2) {
    width: 40%;
  }
}
.footer-sns {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.footer-sns a {
  margin: 0.5em 1.2em;
}
.copyright-container {
  padding: 1.6em 0;
  background-color: #d74646;
}
.copyright-container a {
  color: #4d4d4d;
  font-size: 90%;
}
.copyright-container a:hover {
  color: #888;
}
@media screen and (min-width: 992px) {
  .copyright-container {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
@media screen and (min-width: 992px) {
  .copyright-inner {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    justify-content: space-between;
  }
  .copyright-inner p {
    margin-bottom: 0;
  }
}
.footer-links-external a {
  color: #fff;
}
.footer-links-external a::before {
  content: "→";
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 2em;
  height: 2em;
  margin-right: 0.8em;
  border-radius: 100%;
  font-size: 70%;
  color: #d74646;
  background-color: #fff;
  transition: 0.2s;
}
.footer-links-external a + a {
  margin-left: 2em;
}
.footer-links-external a:hover {
  color: #bfffff;
}
.footer-links-external a:hover::before {
  background-color: #bfffff;
  color: #fff;
}
.footer-links-small {
  margin: 0 0 1em;
}
.footer-links-small a + a::before {
  content: "";
  margin-left: 0.8em;
  margin-right: 1em;
  border-left: 1px solid rgba(77, 77, 77, 0.4);
}
.footer-links-small a:hover {
  color: #bfffff;
}
.copyright {
  text-align: center;
  font-size: min(2.7vw, 1.1rem);
}
.footer-links {
  font-size: 4.5vw;
}
.footer-links-body {
  display: flex;
  flex-direction: column;
}
.footer-links ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 0;
  padding-left: 0;
  border-bottom: 1px solid #fbf0f0;
  background-color: #fff;
}
.footer-links ul + ul {
  margin-top: -1px;
}
.footer-links li {
  position: relative;
  flex-basis: 50%;
  border-right: 1px solid #fbf0f0;
}
.footer-links li.col-12 {
  flex-basis: 100%;
  border-right: 0;
}
.footer-links a {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: -1px;
  padding: 0.94em 0.1em 0.94em 0.9em;
  transition: all 0.54s;
  border-top: 1px solid #fbf0f0;
  border-bottom: 1px solid #fbf0f0;
  color: #4d4d4d;
  text-decoration: none;
  font-size: min(2.9vw, 1.2rem);
}
.footer-links a::before {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-bottom: 3px solid transparent;
  border-top: 3px solid transparent;
  border-left: 4px solid;
  margin-right: 0.6em;
  border-left-color: #d74646;
}
.footer-links a.plan {
  line-height: 1.4;
  padding-left: calc(0.9em + 4px + 0.6em);
}
.footer-links a.plan::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 5px;
  height: 100%;
  border: 0;
}
.footer-links a.rental::before {
  background-color: #82bcd9;
}
.footer-links a.purchase::before {
  background-color: #d9c082;
}
.footer-links a.mama::before {
  background-color: #e6adad;
}
.footer-links a.photo::before {
  background-color: #adb4d9;
}
.footer-links a.iromuji::before {
  background-color: #807fce;
}
.footer-links a.jounior::before {
  background-color: #cbb72a;
}
.footer-links a:hover {
  color: rgba(77, 77, 77, 0.3);
  text-decoration: none;
}
.footer-links-heading {
  order: 9;
}
.footer-links-heading a {
  justify-content: flex-end;
  margin-top: -1px;
  padding-right: 1em;
  color: #d74646;
  background-color: rgba(0, 0, 0, 0.02);
}
.footer-links-heading a::before {
  content: normal;
}
@media screen and (max-width: 991px) {
  .footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 1.2em;
  }
}
@media screen and (min-width: 992px) {
  .footer-links-container {
    flex-grow: 1;
    display: flex;
    justify-content: space-between;
    gap: 4%;
    margin: 0;
  }
  .footer-links {
    flex: 1 0 0;
    text-align: left;
  }
  .footer-links ul {
    background-color: rgba(0, 0, 0, 0);
  }
  .footer-links li {
    border: 0;
  }
  .footer-links a {
    border-color: #dfeeee;
  }
  .footer-links-heading {
    order: inherit;
  }
  .footer-links-heading a {
    justify-content: flex-start;
    border-bottom: 2px solid #d74646;
    background-color: rgba(0, 0, 0, 0);
    color: #4d4d4d;
  }
  .accordion-light-trigger {
    display: none !important;
  }
}
.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
}
.menu-trigger {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .menu-trigger {
    align-items: flex-start;
  }
}
.menu-trigger-inner {
  position: relative;
  width: min(6.66666666vw, 32px);
  height: 14px;
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #1a1a1a;
  border-radius: 2px;
}
.menu-trigger span:nth-of-type(1) {
  top: 0;
}
.menu-trigger span:nth-of-type(2) {
  top: 4.5px;
  display: none;
}
.menu-trigger span:nth-of-type(3) {
  top: 9px;
}
.menu-trigger-text {
  position: relative;
  width: 100%;
  margin-bottom: -5px;
  text-transform: uppercase;
  color: rgba(26, 26, 26, 0.9);
  font-size: 10px;
  text-align: center;
  letter-spacing: 0;
  transition: all 0.4s;
  transform: scale(0.8);
}
.menu-trigger:hover {
  opacity: 0.7;
}
.menu-trigger.active {
  background-color: rgba(0, 0, 0, 0);
}
.menu-trigger.active:after,
.menu-trigger.active:before {
  top: 0;
  height: 100%;
}
.menu-trigger.active .menu-trigger-text {
  color: #1a1a1a;
}
.menu-trigger.active .menu-trigger-text .text {
  display: none;
}
.menu-trigger.active .menu-trigger-text:after {
  content: "Close";
  font-weight: 700;
}
.menu-trigger.active span {
  background-color: #1a1a1a;
}
.menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(4.5px) rotate(-45deg);
  transform: translateY(4.5px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
  display: none;
}
.menu-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-4.5px) rotate(45deg);
  transform: translateY(-4.5px) rotate(45deg);
}
@-webkit-keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
.accordion-light {
  position: relative;
}
.accordion-light-trigger {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  line-height: 1;
  width: 100%;
  padding: 0.74em 1em;
  background-color: #d74646;
  color: #fff;
  font-size: min(3.2vw, 1.4rem);
  cursor: pointer;
  transition: 0.24s;
}
.accordion-light-trigger .title,
.accordion-light-trigger::after {
  transition: 0.24s;
}
.accordion-light-trigger .title {
  order: 2;
  margin: 0;
  font-size: min(3.8vw, 1.5rem);
}
.accordion-light-trigger::after {
  content: "＋";
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(6vw, 32px);
  height: min(6vw, 32px);
  margin-right: 1.2em;
  border-radius: 10%;
  background-color: #fff;
  color: #d74646;
  font-size: min(2.8vw, 1.1rem);
}
.accordion-light.active .accordion-light-trigger {
  background-color: #fff;
  color: #d74646;
}
.accordion-light.active .accordion-light-trigger::after {
  content: "−";
  background-color: #d74646;
  color: #fff;
}
.accordion-light-1 .accordion-light-trigger {
  justify-content: space-between;
  margin-bottom: 15px;
  padding-bottom: 15px;
  padding-left: 0;
  padding-right: 0;
  border-bottom: 1px solid #8c2788;
  background-color: rgba(0, 0, 0, 0);
  color: #4d4d4d;
}
.accordion-light-1 .accordion-light-trigger .title {
  order: 0;
}
.accordion-light-1 .accordion-light-trigger::after {
  margin: 0;
  color: #8c2788;
  background-color: rgba(0, 0, 0, 0);
  font-size: 120%;
}
.accordion-light-1.active .accordion-light-trigger {
  background-color: rgba(0, 0, 0, 0);
  color: #4d4d4d;
}
.accordion-light-1.active .accordion-light-trigger::after {
  background-color: rgba(0, 0, 0, 0);
  color: #444;
}
.scroll-in {
  opacity: 0;
  transition: 1.2s;
}
.scroll-in-up {
  transform: translate(0, 20px);
  transition-duration: 0.64s;
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.scroll-in._in {
  opacity: 1;
  transform: translate(0);
}
@media screen and (min-width: 1200px) {
  .scroll-in-lg-delay-0 {
    transition-delay: 0s;
  }
  .scroll-in-lg-delay-1 {
    transition-delay: 0.25s;
  }
  .scroll-in-lg-delay-2 {
    transition-delay: 0.5s;
  }
}
.balloon-1 {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #d74646;
  color: #fff;
  transition: 0.24s;
}
.balloon-1::after,
.balloon-1::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.balloon-1::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.balloon-1::after {
  transform: translate(-50%, -2px);
  background-color: #d74646;
  transition: 0.24s;
}
.balloon-5 {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #8fcca3;
  color: #fff;
  transition: 0.24s;
}
.balloon-5::after,
.balloon-5::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.balloon-5::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.balloon-5::after {
  transform: translate(-50%, -2px);
  background-color: #8fcca3;
  transition: 0.24s;
}
.lazy-fixed-cloned {
  position: fixed;
  z-index: 99;
  top: -200px;
  bottom: auto;
  left: 0;
  right: auto;
  width: 100%;
  transition: 0.3s;
}
.lazy-fixed-on .lazy-fixed-cloned {
  top: 55px;
}
.mod-rental .text-plan {
  color: #82bcd9;
}
.mod-rental .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #82bcd9;
  color: #fff;
  transition: 0.24s;
}
.mod-rental .balloon-plan::after,
.mod-rental .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-rental .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-rental .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #82bcd9;
  transition: 0.24s;
}
.mod-rental .links-toc-1 a {
  color: #82bcd9;
}
.mod-rental .box-a {
  border-color: #82bcd9;
}
.mod-rental .box-a-title {
  color: #82bcd9;
}
.mod-rental .box-a-title::before {
  background-color: #82bcd9;
}
.text-rental {
  color: #82bcd9;
}
.mod-mama .text-plan {
  color: #e6adad;
}
.mod-mama .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #e6adad;
  color: #fff;
  transition: 0.24s;
}
.mod-mama .balloon-plan::after,
.mod-mama .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-mama .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-mama .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #e6adad;
  transition: 0.24s;
}
.mod-mama .links-toc-1 a {
  color: #e6adad;
}
.mod-mama .box-a {
  border-color: #e6adad;
}
.mod-mama .box-a-title {
  color: #e6adad;
}
.mod-mama .box-a-title::before {
  background-color: #e6adad;
}
.text-mama {
  color: #e6adad;
}
.mod-photo .text-plan {
  color: #adb4d9;
}
.mod-photo .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #adb4d9;
  color: #fff;
  transition: 0.24s;
}
.mod-photo .balloon-plan::after,
.mod-photo .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-photo .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-photo .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #adb4d9;
  transition: 0.24s;
}
.mod-photo .links-toc-1 a {
  color: #adb4d9;
}
.mod-photo .box-a {
  border-color: #adb4d9;
}
.mod-photo .box-a-title {
  color: #adb4d9;
}
.mod-photo .box-a-title::before {
  background-color: #adb4d9;
}
.text-photo {
  color: #adb4d9;
}
.mod-purchase .text-plan {
  color: #d9c082;
}
.mod-purchase .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #d9c082;
  color: #fff;
  transition: 0.24s;
}
.mod-purchase .balloon-plan::after,
.mod-purchase .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-purchase .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-purchase .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #d9c082;
  transition: 0.24s;
}
.mod-purchase .links-toc-1 a {
  color: #d9c082;
}
.mod-purchase .box-a {
  border-color: #d9c082;
}
.mod-purchase .box-a-title {
  color: #d9c082;
}
.mod-purchase .box-a-title::before {
  background-color: #d9c082;
}
.text-purchase {
  color: #d9c082;
}
.mod-hakama .text-plan {
  color: #6ec295;
}
.mod-hakama .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #6ec295;
  color: #fff;
  transition: 0.24s;
}
.mod-hakama .balloon-plan::after,
.mod-hakama .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-hakama .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-hakama .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #6ec295;
  transition: 0.24s;
}
.mod-hakama .links-toc-1 a {
  color: #6ec295;
}
.mod-hakama .box-a {
  border-color: #6ec295;
}
.mod-hakama .box-a-title {
  color: #6ec295;
}
.mod-hakama .box-a-title::before {
  background-color: #6ec295;
}
.mod-iromuji .text-plan {
  color: #807fce;
}
.mod-iromuji .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #807fce;
  color: #fff;
  transition: 0.24s;
}
.mod-iromuji .balloon-plan::after,
.mod-iromuji .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-iromuji .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-iromuji .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #807fce;
  transition: 0.24s;
}
.mod-iromuji .links-toc-1 a {
  color: #807fce;
}
.mod-iromuji .box-a {
  border-color: #807fce;
}
.mod-iromuji .box-a-title {
  color: #807fce;
}
.mod-iromuji .box-a-title::before {
  background-color: #807fce;
}
.text-iromuji {
  color: #807fce;
}
.mod-jounior .text-plan {
  color: #cbb72a;
}
.mod-jounior .balloon-plan {
  position: relative;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 1.7em;
  border-radius: 3px;
  border: 1px solid transparent;
  background-color: #cbb72a;
  color: #fff;
  transition: 0.24s;
}
.mod-jounior .balloon-plan::after,
.mod-jounior .balloon-plan::before {
  content: "";
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 14.4px;
  height: 12px;
  position: absolute;
  bottom: -12px;
  left: 50%;
}
.mod-jounior .balloon-plan::before {
  transform: translate(-50%, 0);
  background-color: rgba(0, 0, 0, 0);
}
.mod-jounior .balloon-plan::after {
  transform: translate(-50%, -2px);
  background-color: #cbb72a;
  transition: 0.24s;
}
.mod-jounior .links-toc-1 a {
  color: #cbb72a;
}
.mod-jounior .box-a {
  border-color: #cbb72a;
}
.mod-jounior .box-a-title {
  color: #cbb72a;
}
.mod-jounior .box-a-title::before {
  background-color: #cbb72a;
}
.text-jounior {
  color: #cbb72a;
}
.share-btn a,
.share-btn button {
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 10em;
  padding: 0.3em 0.4em;
  border-radius: 100px;
  border: 1px solid;
  background-color: rgba(0, 0, 0, 0);
  color: #d74646;
  text-decoration: none;
  transition: 0.26s;
}
.share-btn a:hover,
.share-btn button:hover {
  background-color: #d74646;
  color: #fff;
}
.share-btn-copyurl {
  position: relative;
}
.share-btn-copyurl-copied {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -130%);
  display: none;
  padding: 0.3em 1.1em;
  font-size: fz(xs);
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
  white-space: nowrap;
  transition: 0.2s;
  opacity: 0;
}
.share-btn-copyurl-copied.done {
  opacity: 1;
}
.bg-iromuji-black {
  background-color: #1a1919;
}
.bg-iromuji-gray {
  background-color: #cccdcb;
}
.bg-iromuji-white {
  background-color: #fff3e7;
}
.bg-iromuji-navy {
  background-color: #121639;
}
.bg-iromuji-green {
  background-color: #0d3621;
}
.bg-iromuji-madder {
  background-color: #88212b;
}
.furisode-iromuji {
  background-color: #f7edf8;
}
.furisode-iromuji > .wrap {
  max-width: 2000px;
  margin-left: auto;
  margin-right: auto;
  background-color: #fff;
}
.iromuji-colors,
.iromuji-fablics,
.iromuji-flowers {
  display: flex;
  flex-wrap: wrap;
  text-align: center;
  text-transform: uppercase;
  font-size: 90%;
}
.iromuji-colors {
  gap: 7%;
}
.iromuji-colors > :first-child {
  margin-left: auto;
}
.iromuji-color {
  width: 25.5%;
  margin-bottom: 26px;
}
.iromuji-color [class^="bg-iromuji-"] {
  overflow: hidden;
  margin-bottom: 0.6em;
  border-radius: 17px 0 17px 0;
}
.iromuji-styles > :nth-child(odd) .texts {
  margin-left: 14%;
}
.iromuji-styles > :nth-child(even) .texts {
  margin-left: 3%;
}
@media screen and (min-width: 1200px) {
  .iromuji-styles {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .iromuji-styles > :nth-child(odd) .texts {
    margin-left: 0;
  }
  .iromuji-styles > :nth-child(even) {
    margin-top: 130px;
  }
  .iromuji-styles > :nth-child(even) .texts {
    margin-left: 60px;
  }
}
.iromuji-style {
  margin-bottom: 3em;
}
.iromuji-style .texts {
  padding-left: 8%;
  padding-bottom: 1px;
  border-left: 2px solid #8c2788;
}
@media screen and (min-width: 1200px) {
  .iromuji-style {
    width: 44%;
  }
}
.iromuji-layout-1-kv {
  display: none;
}
@media screen and (min-width: 1200px) {
  .iromuji-layout-1 {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .iromuji-layout-1-bg {
    background-color: #e6eaff;
  }
  .iromuji-layout-1-kv {
    display: block;
    width: 63%;
  }
  .iromuji-layout-1 .title-plan-container {
    width: 28%;
  }
  .iromuji-layout-1 .title-plan-container .en {
    transform: translate(0, 130%);
  }
}
@media screen and (min-width: 1200px) {
  .iromuji-layout-2 .bg-gs-16,
  .iromuji-layout-2 .bg-wave-27 {
    background: rgba(0, 0, 0, 0) !important;
  }
}
@media screen and (min-width: 1200px) {
  .iromuji-layout-3 {
    display: flex;
    justify-content: space-between;
    margin: -70px auto 120px;
  }
  .iromuji-layout-3 > .title-10 {
    display: none !important;
  }
  .iromuji-layout-3 > .container {
    width: 25.5%;
    padding: 0;
  }
}
.blog-archive-container .blog-entry-thumbnail {
  float: none;
  width: 100%;
  margin: 0 0 15px;
}
@media screen and (min-width: 992px) {
  .blog-archive-container .blog-entry-thumbnail {
    width: 100%;
    margin-right: 0;
  }
}
.blog-archive-container .blog-entry-thumbnail a {
  display: block;
  height: 100%;
  background-color: #8fcca3;
  background-position: 50% 50%;
  background-size: cover;
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
}
.blog-archive-container .blog-entry-thumbnail a:hover {
  opacity: 0.7;
}
.blog-archive-container .blog-entry-heading {
  margin-top: 20px;
  margin-bottom: 20px;
  text-align: left;
}
.blog-archive-container .blog-entry-title {
  margin-bottom: 18px;
  font-size: min(4.1vw, 1.6rem);
  line-height: 1.4;
}
.blog-archive-container .blog-entry-title .small,
.blog-archive-container .blog-entry-title small {
  display: inline-block;
  margin-bottom: 11px;
  font-size: 1.3rem;
  color: #d74646;
}
.blog-archive-container .blog-entry-title a {
  color: #4d4d4d;
  text-decoration: none;
  transition: all 0.2s;
}
.blog-archive-container .blog-entry-title a:hover {
  color: #888;
}
.blog-entry-heading {
  margin-bottom: 40px;
}
.blog-entry-heading p {
  margin-bottom: 10px;
  color: #aaa;
}
@media screen and (min-width: 992px) {
  .blog-entry-heading {
    margin-top: 40px;
    margin-bottom: 60px;
    text-align: center;
  }
}
.blog-entry-body {
  margin-bottom: 20px;
}
.blog-entry-title {
  margin: 0;
  font-size: 18px;
}
.blog-entry-title a {
  color: #4d4d4d;
}
.blog-entry-title a:hover {
  color: #d74646;
}
@media screen and (min-width: 768px) {
  .blog-entry-title {
    font-size: 20px;
  }
}
@media screen and (min-width: 992px) {
  .blog-entry-title {
    font-size: 24px;
  }
}
.blog-entry-content {
  font-size: min(3vw, 1.1rem) !important;
}
.blog-entry-body > .h2,
.blog-entry-body > h2 {
  line-height: 1.76;
  display: flex;
  margin: min(4vw, 1em) auto;
  font-size: min(4.46vw, 2.1rem);
  padding-top: 0.25em;
  padding-bottom: 0.25em;
  border-bottom: 1px solid #d74646;
  color: #d74646;
}
.blog-entry-body > .h2::before,
.blog-entry-body > h2::before {
  content: "";
  width: 6px;
  margin: 0.3em 0.7em 0.3em 0;
  background-color: #d74646;
}
.blog-entry-body > .h3,
.blog-entry-body > h3 {
  line-height: 1.76;
  margin: min(8.2vw, 2em) auto;
  font-size: min(4.46vw, 2.1rem);
  text-align: center;
  padding-bottom: 0.25em;
  border-bottom: 1px solid #d74646;
  color: #d74646;
  text-align: left;
}
.blog-entry-body > .h3 .small,
.blog-entry-body > .h3 small,
.blog-entry-body > h3 .small,
.blog-entry-body > h3 small {
  display: block;
  margin-bottom: 0.2em;
  font-size: 50%;
}
.blog-entry-body img {
  max-width: 100%;
  height: auto;
}
.blog-entry-body .aligncenter {
  margin-right: auto;
  margin-left: auto;
}
.blog-entry-body img.aligncenter {
  display: block;
}
.blog-entry-body .alignright {
  float: right;
  text-align: right;
}
.blog-entry-body img.alignright {
  margin-left: 20px;
}
.blog-entry-body .alignleft {
  float: left;
  text-align: left;
}
.blog-entry-body img.alignleft {
  margin-right: 20px;
}
.blog-entry-thumbnail {
  float: left;
  width: 82px;
  margin-right: 30px;
}
@media screen and (min-width: 992px) {
  .blog-entry-thumbnail {
    width: 112px;
    margin-right: 60px;
  }
}
.navigation {
  display: block;
  text-align: center;
}
.blog-list-1 a {
  font-size: min(3vw, 1.3rem);
}
.blog-sidebar .blog-archives {
  margin-bottom: 30px;
}
.blog-sidebar .blog-archives-title {
  margin-top: 0;
  margin-bottom: 2px;
  padding-bottom: 12px;
  border-bottom: 2px solid #d74646;
  font-size: 16px;
  font-weight: 700;
}
.blog-archives-list,
.blog-archives-list .children {
  list-style: none;
  padding-left: 0;
}
.blog-archives-list .children > li > a,
.blog-archives-list > li > a {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: block;
  padding: 10px 0;
  border-bottom: 1px solid #ddd;
  font-size: 13px;
  color: #4d4d4d;
  text-decoration: none;
}
.blog-archives-list .children > li > a:hover,
.blog-archives-list > li > a:hover {
  background-color: #fafafa;
  color: #999;
  text-decoration: none;
}
.blog-archives-list {
  border-top: 1px solid #ddd;
}
.blog-archives-list .children > li > a {
  padding-left: 12px;
  background: url(../../img/common/arrow_3.png) no-repeat 2px 50%;
  background-size: 4px 5px;
}
.blog-archives-list .children > li > a:hover {
  background-image: url(../../img/common/arrow_2.png);
}
.blog-archives-list .children .children > li > a {
  padding-left: 24px;
}
.faq-container {
  margin-bottom: min(10.4vw, 4em);
}
.faq-container .title-3 {
  margin-bottom: min(5.2vw, 1em);
}
.faq-container .title-4 {
  margin: 1em 0 0;
}
[class^="title-"] + .faq-list {
  margin-top: 2em;
  border-top: 1px solid #8fcca3;
}
.faq-list {
  margin: 0;
  border-bottom: 1px solid #8fcca3;
}
.faq-list-title {
  padding: 0.86em 0 0.86em 2em;
  margin: 0;
  cursor: pointer;
  transition: 0.2s;
}
.faq-list-title::before {
  content: "+";
  display: inline-block;
  width: 2em;
  margin-left: -2em;
  text-align: center;
  color: #d74646;
}
.faq-list-title.active {
  color: #7db3b3;
}
.faq-list-title.active::before {
  content: "−";
}
.faq-list-title:hover {
  background-color: #fbf0f0;
}
.faq-list-texts {
  margin: 0;
  padding: 0.86em 0 0.86em 2em;
  border-top: 1px dotted #ccc;
}
.faq-list-texts p {
  margin: 0;
}
.faq-list-texts p + p {
  margin-top: 0.43em;
}
.faq-anchors {
  padding: min(1vw, 20px) 0;
}
.faq-anchors-title {
  margin-top: 10px;
}
.faq-anchors-list {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin-bottom: 1.5em;
  padding: 0;
}
.faq-anchors-list li {
  flex-basis: 50%;
  padding: 4px 2px;
}
.faq-anchors-list a {
  -webkit-transition: all 0.2s linear 0s;
  transition: all 0.2s linear 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  max-width: 100%;
  min-width: 210px;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.65em 1.2em;
  font-size: 3.2vw;
  font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho,
    "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E",
    "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.4;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #7db3b3;
  position: relative;
  display: block;
  max-width: initial;
  min-width: 0;
  white-space: normal;
  font-size: min(3vw, 1.1rem);
  text-align: left;
  transition: 0.24s;
}
.faq-anchors-list a::before {
  content: "";
  flex-basis: 1em;
}
.faq-anchors-list a::after {
  content: "→";
  flex-basis: 1em;
}
.faq-anchors-list a:visited {
  color: #fff;
}
.faq-anchors-list a:focus,
.faq-anchors-list a:hover {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}
@media screen and (max-width: 310px) {
  .faq-anchors-list a {
    min-width: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .faq-anchors-list a {
    font-size: 1.3rem;
  }
}
.faq-anchors-list a::after {
  content: "";
  display: inline-block;
  height: 0;
  opacity: 0.8;
  vertical-align: middle;
  width: 0;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 4px solid;
  position: absolute;
  top: 50%;
  right: 8%;
  transform: translateY(-50%);
}
.faq-anchors-list a:hover {
  background-color: #0fa0d1;
}
@media screen and (min-width: 992px) {
  .faq-anchors {
    display: flex;
    justify-content: space-between;
  }
  .faq-anchors-division:first-child {
    flex-basis: calc((25% - 3px) * 3);
  }
  .faq-anchors-division:nth-child(2) {
    flex-basis: calc((25% - 3px) * 1);
  }
  .faq-anchors-list li {
    flex: 1 0 auto;
  }
}
@media screen and (max-width: 991px) {
  .furisode-catalog .is-show-banner-furisode {
    display: none;
  }
  .furisode-catalog .is-show-banner-furisode + div {
    margin-top: -30px;
  }
}
