/*
Theme Name: yourpro
Theme URI: https://keymine.co.jp/
Author: yourpro
Version: 1.0.0
Requires at least: 6.5
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: yourpro
*/

/* font face */
@font-face {
  font-family: "Noto Sans JP";
  src: url("./assets/font/NotoSansJP-Light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  src: url("./assets/font/NotoSansJP-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  src: url("./assets/font/NotoSansJP-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  src: url("./assets/font/NotoSansJP-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  src: url("./assets/font/NotoSansJP-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* Button size utilities */
.wp-block-button.is-size-sm .wp-block-button__link {
  font-size: 14px;
  padding: 12px 24px;
}

.wp-block-button.is-size-lg .wp-block-button__link {
  font-size: 18px;
  padding: 18px 36px;
}

/* Button interaction states */
.wp-block-button .wp-block-button__link {
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.wp-block-button.is-style-primary .wp-block-button__link,
.wp-block-button.yp-btn--primary .wp-block-button__link {
  background: var(--wp--preset--color--accent);
  border: 1px solid var(--wp--preset--color--accent);
  color: var(--wp--preset--color--base);
}

.wp-block-button.is-style-secondary .wp-block-button__link,
.wp-block-button.yp-btn--secondary .wp-block-button__link {
  background: transparent;
  border: 1px solid var(--wp--preset--color--primary);
  color: var(--wp--preset--color--primary);
}

.wp-block-button.is-style-secondary.is-tone-primary-dark .wp-block-button__link {
  border-color: var(--wp--preset--color--primary-dark);
  color: var(--wp--preset--color--primary-dark);
}

.wp-block-button.is-style-secondary .wp-block-button__link.has-primary-dark-color {
  border-color: var(--wp--preset--color--primary-dark);
  color: var(--wp--preset--color--primary-dark);
}

.wp-block-button.is-style-tertiary .wp-block-button__link,
.wp-block-button.yp-btn--tertiary .wp-block-button__link {
  background: var(--wp--preset--color--surface-muted);
  border: 1px solid var(--wp--preset--color--surface-muted);
  color: var(--wp--preset--color--foreground);
}

.wp-block-button.is-style-primary .wp-block-button__link:hover,
.wp-block-button.is-style-primary .wp-block-button__link:focus-visible,
.wp-block-button.yp-btn--primary .wp-block-button__link:hover,
.wp-block-button.yp-btn--primary .wp-block-button__link:focus-visible {
  background: #ee793d;
  border-color: #ee793d;
  color: var(--wp--preset--color--base);
}

.wp-block-button.is-style-primary .wp-block-button__link:active,
.wp-block-button.yp-btn--primary .wp-block-button__link:active {
  background: #d64f09;
  border-color: #d64f09;
}

.wp-block-button.is-style-secondary .wp-block-button__link:hover,
.wp-block-button.is-style-secondary .wp-block-button__link:focus-visible,
.wp-block-button.yp-btn--secondary .wp-block-button__link:hover,
.wp-block-button.yp-btn--secondary .wp-block-button__link:focus-visible {
  background: var(--wp--preset--color--primary);
  border-color: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base) !important;
}

.wp-block-button.is-style-secondary .wp-block-button__link:active,
.wp-block-button.yp-btn--secondary .wp-block-button__link:active {
  background: transparent;
  border-color: var(--wp--preset--color--primary-dark);
  color: var(--wp--preset--color--primary-dark);
}

.wp-block-button.is-style-secondary.is-tone-primary-dark .wp-block-button__link:hover,
.wp-block-button.is-style-secondary.is-tone-primary-dark .wp-block-button__link:focus-visible,
.wp-block-button.is-style-secondary.is-tone-primary-dark .wp-block-button__link:active {
  background: var(--wp--preset--color--primary-dark);
  border-color: var(--wp--preset--color--primary-dark);
  color: var(--wp--preset--color--base) !important;
}

.wp-block-button.is-style-secondary .wp-block-button__link.has-primary-dark-color:hover,
.wp-block-button.is-style-secondary .wp-block-button__link.has-primary-dark-color:focus-visible,
.wp-block-button.is-style-secondary .wp-block-button__link.has-primary-dark-color:active {
  background: var(--wp--preset--color--primary-dark);
  border-color: var(--wp--preset--color--primary-dark);
  color: var(--wp--preset--color--base) !important;
}

.wp-block-button.is-style-tertiary .wp-block-button__link:hover,
.wp-block-button.is-style-tertiary .wp-block-button__link:focus-visible,
.wp-block-button.yp-btn--tertiary .wp-block-button__link:hover,
.wp-block-button.yp-btn--tertiary .wp-block-button__link:focus-visible {
  background: #e5e5e5;
  border-color: #e5e5e5;
  color: var(--wp--preset--color--text-subtle);
}

.wp-block-button.is-style-tertiary .wp-block-button__link:active,
.wp-block-button.yp-btn--tertiary .wp-block-button__link:active {
  background: #efefef;
  border-color: #efefef;
}

.wp-block-button .wp-block-button__link:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 2px;
  box-shadow: none;
}

.wp-block-button .wp-block-button__link[aria-disabled="true"],
.wp-block-button.is-disabled .wp-block-button__link {
  cursor: not-allowed;
  opacity: 0.5;
  pointer-events: none;
}

footer.wp-block-template-part .wp-block-button.is-style-outline .wp-block-button__link:hover,
footer.wp-block-template-part .wp-block-button.is-style-outline .wp-block-button__link:focus-visible {
  background: var(--wp--preset--color--base) !important;
  border-color: var(--wp--preset--color--base) !important;
  color: var(--wp--preset--color--foreground);
}


/* footer */
footer.wp-block-template-part {
  margin-top: 0;
}

footer.wp-block-template-part {
  margin-top: 0;
}

.u-desktop-only {
  display: inherit !important;
}

.u-mobile-only {
  display: none !important;
}

@media (max-width: 1024px) {
  .u-desktop-only {
    display: none !important;
  }

  .u-mobile-only {
    display: inherit !important;
  }

  .footer-fiexd-menu.u-mobile-only {
    position: fixed;
    bottom: 0;
    display: flex !important;
    width: 100%;
    z-index: 40;
  }

  .footer-fiexd-menu.u-mobile-only>div {
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
  }
}

/* page-header */
.page-header>.wp-block-columns>.wp-block-column:first-child {
  position: relative;
}

.page-header>.wp-block-columns>.wp-block-column:nth-child(2) {
  z-index: 1;
}

.page-header>.wp-block-columns>.wp-block-column:first-child::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  height: calc(100% + 3.5rem);
  width: 200%;
  background: var(--wp--preset--color--accent-background);
  transform: translateY(-50%);
  z-index: -1;
}

.page-header.orange>.wp-block-columns>.wp-block-column:first-child::before {
  background: #F7F5EE;
}


@media (max-width: 768px) {

  .page-header>.wp-block-columns>.wp-block-column:first-child,
  .page-header>.wp-block-columns>.wp-block-column:last-child {
    flex-basis: 4.1666666667% !important;
  }

  .page-header>.wp-block-columns>.wp-block-column:first-child::before {
    width: 1600%;
  }

  .page-header>.wp-block-columns>.wp-block-column:nth-child(2)>.wp-block-group:first-child {
    gap: 12px !important;
  }

  .page-header .wp-block-heading {
    font-size: 2.75rem !important;
    line-height: 1.15 !important;
  }

  .page-header>.wp-block-columns>.wp-block-column:nth-child(2)>.wp-block-group:nth-child(2) {
    gap: 12px !important;
    margin-top: 1.25rem;
  }

  .page-header>.wp-block-columns>.wp-block-column:nth-child(2)>.wp-block-columns {
    margin-top: 1.25rem;
  }
}

/* section */
@media (max-width: 768px) {

  section {
    padding: 3rem 1rem !important;
  }

}

/* typography */
.primary-marker mark {
  display: inline-block;
  background: var(--wp--preset--color--primary) !important;
  margin: 0 0.25em;
}

.accent-marker mark {
  display: inline-block;
  background: var(--wp--preset--color--accent) !important;
  margin: 0 0.25em;
}

.white-marker mark {
  display: inline-block;
  background: var(--wp--preset--color--base) !important;
  margin: 0 0.25em;
}

/* Blog */
.blog-cat a {
  display: inline-block;
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
  padding: 4px 8px;
  font-size: 0.75rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 4px;
}

.single-thumbnail img {
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

#ez-toc-container {
  padding: 1.5rem;
  border-radius: 12px;
  margin-bottom: 3rem !important;
  max-width: 720px;
  box-sizing: border-box;
}

#ez-toc-container .ez-toc-title-container {
  margin-bottom: 1rem;
}

.yourpro-blog-supervisor {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 2rem;
  align-items: center;
  padding: 2rem;
  border-radius: 8px;
  background: #f6f4ec;
}

.yourpro-blog-supervisor__media {
  width: 120px;
  aspect-ratio: 1 / 1;
}

.yourpro-blog-supervisor__image,
.yourpro-blog-supervisor__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 999px;
}

.yourpro-blog-supervisor__image-placeholder {
  background: var(--wp--preset--color--accent-background);
}

.yourpro-blog-supervisor__content {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.yourpro-blog-supervisor__eyebrow,
.yourpro-blog-supervisor__title,
.yourpro-blog-supervisor__intro {
  margin: 0;
}

.yourpro-blog-supervisor__eyebrow {
  color: #a68f3c;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-blog-supervisor__title {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  color: var(--wp--preset--color--foreground);
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.4;
}

.yourpro-blog-supervisor__label,
.yourpro-blog-supervisor__name {
  display: inline;
}

.yourpro-blog-supervisor__intro {
  color: var(--wp--preset--color--foreground);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-blog-cases {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.yourpro-blog-cases__header {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.yourpro-blog-cases__title {
  margin: 0;
  color: var(--wp--preset--color--foreground);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
}

.yourpro-blog-cases__line {
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, var(--wp--preset--color--primary) 0 32%, var(--wp--preset--color--border) 32% 100%);
}

.yourpro-blog-cases__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.yourpro-blog-cases__grid>*,
.case-archive-list .wp-block-post-template>li {
  display: flex;
}

.yourpro-blog-athletes {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 1.5rem;
  border-radius: 16px;
  background: #a68f3c;
}

.yourpro-blog-athletes__title {
  margin: 0;
  color: var(--wp--preset--color--base);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-blog-athletes__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.yourpro-blog-athlete-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem;
  border-radius: 4px;
  background: var(--wp--preset--color--base);
}

.yourpro-blog-athlete-card__header {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  align-items: flex-start;
}

.yourpro-blog-athlete-card__badge,
.yourpro-blog-athlete-card__name,
.yourpro-blog-athlete-card__role,
.yourpro-blog-athlete-card__comment,
.yourpro-blog-athlete-card__comment p {
  margin: 0;
}

.yourpro-blog-athlete-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  background: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--base);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
  white-space: nowrap;
}

.yourpro-blog-athlete-card__name {
  color: var(--wp--preset--color--foreground);
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-blog-athlete-card__role {
  color: var(--wp--preset--color--foreground);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5;
}

.yourpro-blog-athlete-card__comment {
  position: relative;
  padding: 1rem;
  border-radius: 8px;
  background: #f7f5ee;
  color: var(--wp--preset--color--foreground);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-blog-athlete-card__comment::before,
.yourpro-blog-athlete-card__comment::after {
  position: absolute;
  color: #a68f3c;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  opacity: 0.18;
}

.yourpro-blog-athlete-card__comment::before {
  content: "“";
  top: 0.5rem;
  left: 0.5rem;
}

.yourpro-blog-athlete-card__comment::after {
  content: "”";
  right: 0.5rem;
  bottom: 0.25rem;
}

.yourpro-blog-related-posts {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.yourpro-blog-related-posts__header {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.yourpro-blog-related-posts__title {
  margin: 0;
  color: var(--wp--preset--color--foreground);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
}

.yourpro-blog-related-posts__line {
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, var(--wp--preset--color--primary) 0 32%, var(--wp--preset--color--border) 32% 100%);
}

.yourpro-blog-related-posts__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.yourpro-blog-related-card {
  display: flex;
  width: 100%;
  height: 100%;
  min-width: 0;
}

.yourpro-blog-related-card__link {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  color: inherit;
  text-decoration: none;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--wp--preset--color--base);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.yourpro-blog-related-card__link:hover,
.yourpro-blog-related-card__link:focus-visible {
  box-shadow: 0 8px 24px rgba(15, 86, 2, 0.08);
  transform: translateY(-2px);
}

.yourpro-blog-related-card__link:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 2px;
}

.yourpro-blog-related-card__media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--wp--preset--color--surface-muted);
}

.yourpro-blog-related-card__badge {
  position: absolute;
  top: 0.625rem;
  left: 0.625rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.25rem 0.75rem;
  border-radius: 4px;
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-blog-related-card__image,
.yourpro-blog-related-card__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.yourpro-blog-related-card__image-placeholder {
  background: #d9d9d9;
}

.yourpro-blog-related-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  padding: 1rem;
}

.yourpro-blog-related-card__title,
.yourpro-blog-related-card__excerpt {
  margin: 0;
}

.yourpro-blog-related-card__title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  overflow: hidden;
  color: var(--wp--preset--color--foreground);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-blog-related-card__excerpt {
  display: -webkit-box;
  margin-top: 0.75rem;
  -webkit-box-orient: vertical;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  overflow: hidden;
  color: var(--wp--preset--color--muted-foreground);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.7;
}

.blog-archive-list {
  width: 100%;
}

.blog-archive-list__items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.blog-archive-list__item {
  display: flex;
  margin: 0;
  padding: 0;
}

.case-archive-hero>*,
.case-archive>* {
  margin: 0;
}

.case-archive-hero h1 {
  color: var(--wp--preset--color--foreground);
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.3;
}

.yourpro-case-filters {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.yourpro-case-filters__list {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
  align-items: center;
  width: max-content;
  min-width: 100%;
}

.yourpro-case-filters__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.375rem 0.875rem;
  border: 0;
  border-radius: 999px;
  background: var(--wp--preset--color--surface-muted);
  color: var(--wp--preset--color--foreground);
  font-size: 12px;
  flex: 0 0 auto;
  font-weight: 600;
  line-height: 1.5;
  white-space: nowrap;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.yourpro-case-filters__chip:hover,
.yourpro-case-filters__chip:focus-visible {
  background: var(--wp--preset--color--accent-background);
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.yourpro-case-filters__chip:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 2px;
}

.yourpro-case-filters__chip.is-active {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.case-archive-list .wp-block-post-template {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.case-archive-list .wp-block-post-template>li {
  margin: 0;
  padding: 0;
}

.case-archive-list .wp-block-query-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  margin-top: 3rem;
}

.case-archive-list .wp-block-query-pagination-numbers,
.case-archive-list .wp-block-query-pagination-previous,
.case-archive-list .wp-block-query-pagination-next {
  margin: 0;
}

.case-archive-list .wp-block-query-pagination .page-numbers,
.case-archive-list .wp-block-query-pagination-previous,
.case-archive-list .wp-block-query-pagination-next {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  padding: 0.25rem 0.625rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 4px;
  background: var(--wp--preset--color--base);
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
}

.case-archive-list .wp-block-query-pagination .page-numbers.current {
  border-color: var(--wp--preset--color--primary);
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.case-archive-list .wp-block-query-pagination .page-numbers:hover,
.case-archive-list .wp-block-query-pagination .page-numbers:focus-visible,
.case-archive-list .wp-block-query-pagination-previous:hover,
.case-archive-list .wp-block-query-pagination-previous:focus-visible,
.case-archive-list .wp-block-query-pagination-next:hover,
.case-archive-list .wp-block-query-pagination-next:focus-visible {
  border-color: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.post-case-archive-list .wp-block-query-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 3rem;
  padding: 16px 0;
}

.post-case-archive-list .wp-block-query-pagination-numbers,
.post-case-archive-list .wp-block-query-pagination-previous,
.post-case-archive-list .wp-block-query-pagination-next {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 0;
}

.post-case-archive-list .wp-block-query-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 41px;
  min-width: 41px;
  min-height: 41px;
  aspect-ratio: 1 / 1;
  border: 0;
  border-radius: 4px;
  background: var(--wp--preset--color--background, #f7f7f7);
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.post-case-archive-list .wp-block-query-pagination .page-numbers.current {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.post-case-archive-list .wp-block-query-pagination .page-numbers.prev,
.post-case-archive-list .wp-block-query-pagination .page-numbers.next {
  width: 41px;
  min-width: 41px;
  min-height: 41px;
  padding: 0;
  background: transparent;
  color: var(--wp--preset--color--primary-dark);
}

.post-case-archive-list .wp-block-query-pagination .page-numbers.prev::before,
.post-case-archive-list .wp-block-query-pagination .page-numbers.next::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background-color: currentColor;
  mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

.post-case-archive-list .wp-block-query-pagination .page-numbers.prev::before {
  transform: rotate(180deg);
}

.post-case-archive-list .wp-block-query-pagination .page-numbers.is-disabled {
  opacity: 0.45;
  pointer-events: none;
}

.post-case-archive-list .wp-block-query-pagination .page-numbers:hover,
.post-case-archive-list .wp-block-query-pagination .page-numbers:focus-visible {
  background: var(--wp--preset--color--surface-muted);
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.post-case-archive-list .wp-block-query-pagination .page-numbers.current:hover,
.post-case-archive-list .wp-block-query-pagination .page-numbers.current:focus-visible {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.blog-archive-list .wp-block-query-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 3rem;
  padding: 16px 0;
}

.blog-archive-list .wp-block-query-pagination-numbers,
.blog-archive-list .wp-block-query-pagination-previous,
.blog-archive-list .wp-block-query-pagination-next {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 0;
}

.blog-archive-list .wp-block-query-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 41px;
  min-width: 41px;
  min-height: 41px;
  aspect-ratio: 1 / 1;
  border: 0;
  border-radius: 4px;
  background: var(--wp--preset--color--background, #f7f7f7);
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.blog-archive-list .wp-block-query-pagination .page-numbers.current {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.blog-archive-list .wp-block-query-pagination .page-numbers.prev,
.blog-archive-list .wp-block-query-pagination .page-numbers.next {
  width: 41px;
  min-width: 41px;
  min-height: 41px;
  padding: 0;
  background: transparent;
  color: var(--wp--preset--color--primary-dark);
}

.blog-archive-list .wp-block-query-pagination .page-numbers.prev::before,
.blog-archive-list .wp-block-query-pagination .page-numbers.next::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background-color: currentColor;
  mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

.blog-archive-list .wp-block-query-pagination .page-numbers.prev::before {
  transform: rotate(180deg);
}

.blog-archive-list .wp-block-query-pagination .page-numbers.is-disabled {
  opacity: 0.45;
  pointer-events: none;
}

.blog-archive-list .wp-block-query-pagination .page-numbers:hover,
.blog-archive-list .wp-block-query-pagination .page-numbers:focus-visible {
  background: var(--wp--preset--color--surface-muted);
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.blog-archive-list .wp-block-query-pagination .page-numbers.current:hover,
.blog-archive-list .wp-block-query-pagination .page-numbers.current:focus-visible {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.news-archive>* {
  margin: 0;
}

.news-archive-list__items {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--wp--preset--color--border);
  list-style: none;
}

.news-archive-list__item {
  margin: 0;
  padding: 0;
}

.yourpro-news-card {
  border-bottom: 1px solid var(--wp--preset--color--border);
}

.yourpro-news-card__link {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 1.5rem;
  padding: 1.25rem;
  color: inherit;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.yourpro-news-card__link:hover,
.yourpro-news-card__link:focus-visible {
  text-decoration: none;
}

.yourpro-news-card__link:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 4px;
}

.yourpro-news-card__link:hover {
  background: var(--wp--preset--color--surface-muted);
}

.yourpro-news-card__date {
  padding-top: 0.125rem;
  color: var(--wp--preset--color--muted-foreground);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.5;
  white-space: nowrap;
}

.yourpro-news-card__body {
  display: grid;
  gap: 0.5rem;
  min-width: 0;
}

.yourpro-news-card__header {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  min-width: 0;
}

.yourpro-news-card__badge {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  min-height: 1.5rem;
  margin: 0;
  padding: 0.25rem 0.625rem;
  border-radius: 4px;
  background: var(--wp--preset--color--accent-background);
  color: var(--wp--preset--color--primary);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
}

.yourpro-news-card__title {
  min-width: 0;
  margin: 0;
  color: var(--wp--preset--color--foreground);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-news-card__excerpt {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--wp--preset--color--text-subtle);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.6;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}

.yourpro-news-card__more {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 0.25rem;
  color: var(--wp--preset--color--primary);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.5;
  text-decoration: none;
}

.yourpro-news-card__more::after {
  content: "";
  width: 0.875rem;
  height: 0.875rem;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

.news-archive-list .wp-block-query-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 3rem;
  padding: 16px 0;
}

.news-archive-list .wp-block-query-pagination-numbers,
.news-archive-list .wp-block-query-pagination-previous,
.news-archive-list .wp-block-query-pagination-next {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 0;
}

.news-archive-list .wp-block-query-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 41px;
  min-width: 41px;
  min-height: 41px;
  aspect-ratio: 1 / 1;
  border: 0;
  border-radius: 4px;
  background: var(--wp--preset--color--background, #f7f7f7);
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.news-archive-list .wp-block-query-pagination .page-numbers.current {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.news-archive-list .wp-block-query-pagination .page-numbers.prev,
.news-archive-list .wp-block-query-pagination .page-numbers.next {
  width: 41px;
  min-width: 41px;
  min-height: 41px;
  padding: 0;
  background: transparent;
  color: var(--wp--preset--color--primary-dark);
}

.news-archive-list .wp-block-query-pagination .page-numbers.prev::before,
.news-archive-list .wp-block-query-pagination .page-numbers.next::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

.news-archive-list .wp-block-query-pagination .page-numbers.prev::before {
  transform: rotate(180deg);
}

.news-archive-list .wp-block-query-pagination .page-numbers.is-disabled {
  opacity: 0.45;
  pointer-events: none;
}

.news-archive-list .wp-block-query-pagination .page-numbers:hover,
.news-archive-list .wp-block-query-pagination .page-numbers:focus-visible {
  background: var(--wp--preset--color--surface-muted);
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.news-archive-list .wp-block-query-pagination .page-numbers.current:hover,
.news-archive-list .wp-block-query-pagination .page-numbers.current:focus-visible {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
}

.yourpro-case-card {
  display: flex;
  width: 100%;
  height: 100%;
  min-width: 0;
}

.yourpro-case-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--wp--preset--color--base);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.yourpro-case-card__link:hover,
.yourpro-case-card__link:focus-visible {
  box-shadow: 0 8px 24px rgba(15, 86, 2, 0.08);
  transform: translateY(-2px);
}

.yourpro-case-card__link:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 2px;
}

.yourpro-case-card__media {
  position: relative;
  aspect-ratio: 349 / 230;
  overflow: hidden;
}

.yourpro-case-card__badge {
  position: absolute;
  top: 0.625rem;
  left: 0.625rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.25rem 0.75rem;
  border-radius: 4px;
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-case-card__image,
.yourpro-case-card__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.yourpro-case-card__image-placeholder {
  background: #d9d9d9;
}

.yourpro-case-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  padding: 1rem 1rem 1.125rem;
}

.yourpro-case-card__rating,
.yourpro-case-card__title,
.yourpro-case-card__excerpt,
.yourpro-case-card__additional {
  margin: 0;
}

.yourpro-case-card__rating {
  display: inline-flex;
  align-items: center;
  gap: 0.125rem;
  font-size: 1rem;
  line-height: 1;
}

.yourpro-case-card__star.is-filled {
  color: #f6a724;
}

.yourpro-case-card__star.is-empty {
  color: var(--wp--preset--color--border);
}

.yourpro-case-card__title {
  display: -webkit-box;
  margin-top: 0.875rem;
  -webkit-box-orient: vertical;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  overflow: hidden;
  color: var(--wp--preset--color--foreground);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-case-card__excerpt {
  display: -webkit-box;
  margin-top: 0.875rem;
  -webkit-box-orient: vertical;
  line-clamp: 3;
  -webkit-line-clamp: 3;
  overflow: hidden;
  color: var(--wp--preset--color--muted-foreground);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.7;
}

.yourpro-case-card__additional {
  padding-top: 0.875rem;
  margin-top: auto;
  color: #7f7f7f;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}

.post-case-archive-list {
  width: 100%;
}

.post-case-archive-list__items {
  display: flex;
  flex-direction: column;
  gap: 4rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.post-case-archive-list__item {
  margin: 0;
  padding: 0;
}

.yourpro-post-case-card {
  display: flex;
  gap: 4rem;
  align-items: flex-start;
  width: 100%;
}

.yourpro-post-case-card__figure {
  flex: 0 0 280px;
  width: 280px;
  max-width: 280px;
  height: 280px;
  max-height: 280px;
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  background: var(--wp--preset--color--surface-muted);
}

.yourpro-post-case-card__image,
.yourpro-post-case-card__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.yourpro-post-case-card__image-placeholder {
  background: #d9d9d9;
}

.yourpro-post-case-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
}

.yourpro-post-case-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 1rem;
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  background: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--base);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.5;
  white-space: nowrap;
}

.yourpro-post-case-card__title {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: baseline;
  margin: 0 0 1rem;
  color: var(--wp--preset--color--foreground);
  font-weight: 700;
  line-height: 1.3;
}

.yourpro-post-case-card__name {
  font-size: 2rem;
}

.yourpro-post-case-card__suffix {
  color: var(--wp--preset--color--muted-foreground);
  font-size: 0.875rem;
}

.yourpro-post-case-card__text {
  margin: 0;
  color: var(--wp--preset--color--foreground);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
}

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


.single-sidebar {
  max-width: 360px;
}

.single-sidebar .wp-block-categories-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  list-style: none;
  padding: 0;
}

.single-sidebar .wp-block-categories-list .cat-item {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
}

.single-sidebar .wp-block-categories-list a {
  text-decoration: none;

  &:hover {
    text-decoration: underline;
  }
}

.single-news-sidebar .news-sidebar-cta .wp-block-buttons {
  gap: 0.75rem;
}

.single-news-sidebar .news-sidebar-cta .is-style-secondary .wp-block-button__link {
  border-color: currentColor;
  background: transparent;
  color: var(--wp--preset--color--base);
}

.news-sidebar-latest .wp-block-post-template {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.news-sidebar-latest .wp-block-post {
  position: relative;
  margin: 0;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--wp--preset--color--border);
}

.news-sidebar-latest .wp-block-post:last-child {
  border-bottom: 0;
}

.news-sidebar-latest__title {
  margin: 0;
  line-height: 1.6;
}

.news-sidebar-latest__title a {
  color: var(--wp--preset--color--foreground);
  text-decoration: none;
}

.news-sidebar-latest__title a:hover,
.news-sidebar-latest__title a:focus-visible {
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.sidebar-ranking {
  --sidebar-ranking-thumb-width: 112px;
  --sidebar-ranking-rank-width: 28px;
}

.sidebar-ranking .popular-posts {
  width: 100%;
}

.sidebar-ranking .wpp-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: sidebar-ranking;
}

.sidebar-ranking .wpp-list li {
  position: relative;
  display: grid;
  grid-template-columns: var(--sidebar-ranking-thumb-width) minmax(0, 1fr);
  align-items: start;
  gap: 1rem;
  margin: 0;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--wp--preset--color--border);
  counter-increment: sidebar-ranking;
}

.sidebar-ranking .wpp-list li:last-child {
  padding-top: 0;
  border-bottom: 0;
}

.sidebar-ranking .wpp-list li::before {
  content: counter(sidebar-ranking);
  position: absolute;
  top: 0;
  left: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--sidebar-ranking-rank-width);
  height: 24px;
  background: var(--wp--preset--color--primary-dark);
  color: var(--wp--preset--color--base);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
  z-index: 1;
}

.sidebar-ranking .wpp-list li:nth-child(1)::before {
  background: var(--wp--preset--color--accent);
}

.sidebar-ranking .wpp-list li>a:first-child {
  display: block;
  width: 100%;
  text-decoration: none;
}

.sidebar-ranking .wpp-thumbnail {
  display: block;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 107 / 62;
  object-fit: cover;
  border-radius: 4px;
}

.sidebar-ranking .wpp-post-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  overflow: hidden;
  color: var(--wp--preset--color--foreground);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
  text-decoration: none;
}

.sidebar-ranking .wpp-post-title:hover,
.sidebar-ranking .wpp-post-title:focus-visible {
  color: var(--wp--preset--color--primary-dark);
  text-decoration: none;
}

@media (max-width: 1322px) {
  .single-sidebar {
    width: 100%;
    max-width: 720px;
    margin: 0 auto !important;
  }
}

@media (max-width: 781px) {
  .yourpro-case-card {
    min-width: 300px;
  }

  .case-archive-hero h1 {
    font-size: 2rem;
  }

  .yourpro-case-filters__list {
    gap: 0.375rem;
  }

  .yourpro-case-filters__chip {
    min-height: 2rem;
    padding: 0.375rem 0.75rem;
    font-size: 12px;
  }

  .case-archive-list .wp-block-post-template {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .case-archive-list .wp-block-query-pagination {
    margin-top: 2rem;
  }

  .post-case-archive-list__items {
    gap: 2.5rem;
  }

  .post-case-archive-list .wp-block-query-pagination {
    margin-top: 2rem;
  }

  .yourpro-post-case-card {
    flex-direction: column;
    gap: 1.5rem;
  }

  .yourpro-post-case-card__figure {
    flex-basis: auto;
    width: 100%;
    max-width: none;
    height: auto;
    max-height: none;
    aspect-ratio: 1 / 1;
  }

  .yourpro-post-case-card__badge,
  .yourpro-post-case-card__title {
    margin-bottom: 0.75rem;
  }

  .yourpro-post-case-card__name {
    font-size: 1.75rem;
  }

  .yourpro-blog-cases {
    gap: 1.5rem;
  }

  .yourpro-blog-cases__title {
    font-size: 1.5rem;
  }

  .yourpro-blog-cases__grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .yourpro-blog-athletes {
    gap: 1.25rem;
    padding: 1.25rem 1rem;
  }

  .yourpro-blog-athletes__title {
    font-size: 1.125rem;
  }

  .yourpro-blog-athletes__grid {
    grid-template-columns: 1fr;
  }

  .yourpro-blog-related-posts {
    gap: 1.5rem;
  }

  .yourpro-blog-related-posts__title {
    font-size: 1.5rem;
  }

  .yourpro-blog-related-posts__grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .blog-archive-list__items {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .blog-archive-list .wp-block-query-pagination {
    margin-top: 2rem;
  }

  .news-archive-list {
    width: 100%;
  }

  .yourpro-news-card__link {
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding: 1rem 0;
  }

  .yourpro-news-card__date {
    padding-top: 0;
  }

  .yourpro-news-card__header {
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .news-archive-list .wp-block-query-pagination {
    margin-top: 2rem;
  }

  .yourpro-case-card__body {
    padding: 1rem 0.875rem;
  }

  .yourpro-case-card__badge {
    top: 0.5rem;
    left: 0.5rem;
    font-size: 0.75rem;
  }

  .yourpro-case-card__excerpt {
    font-size: 0.875rem;
  }

  .yourpro-case-card__additional {
    font-size: 0.875rem;
  }

  .yourpro-blog-supervisor {
    grid-template-columns: 1fr;
    gap: 1.25rem;
    padding: 1.5rem 1rem;
    align-items: start;
  }

  .yourpro-blog-supervisor__media {
    width: 96px;
    margin: 0 auto;
  }

  .yourpro-blog-supervisor__content {
    width: 100%;
    gap: 0.5rem;
  }

  .yourpro-blog-supervisor__title {
    font-size: 1.375rem;
    gap: 0.25rem 0.5rem;
    line-height: 1.45;
  }

  .yourpro-blog-supervisor__eyebrow {
    font-size: 0.8125rem;
  }

  .yourpro-blog-supervisor__intro {
    line-height: 1.7;
  }

  .yourpro-blog-supervisor__content {
    align-items: center;
  }

  .sidebar-ranking {
    --sidebar-ranking-thumb-width: 104px;
  }

  .sidebar-ranking .wpp-list li {
    gap: 0.875rem;
    padding: 1.25rem 0;
  }

  .sidebar-ranking .wpp-post-title {
    font-size: 1rem;
    line-height: 1.5;
  }

  .single-end-cta .wp-block-buttons {
    flex-direction: column;
  }

  .single-end-cta .wp-block-button {
    width: 100% !important;
  }
}

/* about */
.about-step {
  position: relative;
  overflow: hidden;
}

.about-step::before {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 64px;
  background-color: var(--wp--preset--color--base);
  pointer-events: none;
  z-index: 2;
}

.about-step::before {
  top: -1px;
  height: 72px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  border-radius: 0;
}

.about-step__inner {
  position: relative;
  isolation: isolate;
}

.about-step__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  height: 100%;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.18) 1px, transparent 1px);
  background-size: 16px 16px;
  background-position: center;
  pointer-events: none;
  z-index: 0;
}

.about-step__inner>* {
  position: relative;
  z-index: 1;
}

.about-step__inner .plan-list {
  position: relative;
  z-index: 2;
}

.about-step__inner .plan-list>.wp-block-column {
  position: relative;
}

.about-step__inner .plan-list>.wp-block-column:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -1.5rem;
  width: 24px;
  height: 24px;
  background-color: rgba(255, 255, 255, 0.45);
  transform: translateY(-50%) rotate(90deg);
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 4L20 18H4L12 4Z' fill='black'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 4L20 18H4L12 4Z' fill='black'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.about-survey__h3 mark {
  display: inline-block;
  padding: 6px 12px;
  margin-bottom: 0.25rem;
  background: var(--wp--preset--color--primary) !important;
  border-radius: 9999px;
}

@media (max-width: 781px) {
  .about--hero .wp-block-media-text__media {
    padding: 0 1rem;
  }

  .about--hero .wp-block-media-text__media img {
    aspect-ratio: 1 / 1 !important;
    object-fit: cover;
    border-radius: 8px;
  }

  .about--hero .wp-block-media-text__content {
    padding: 0 1rem;
  }

  .about-step::before,
  .about-step::after {
    height: 24px;
  }

  .about-step::before {
    height: 36px;
  }

  .about-step__inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .about-step__inner .plan-list>.wp-block-column:not(:last-child)::after {
    top: auto;
    right: 50%;
    bottom: -2rem;
    transform: translateX(50%) rotate(180deg);
  }

  .front-step__grid {
    display: flex !important;
    flex-direction: column;
  }

  .card--strength-item {
    padding: 1rem !important;
  }


  .card--strength-item__point p:first-child {
    font-size: 0.75rem !important;
  }

  .card--strength-item__point p:last-child {
    font-size: 2.5rem !important;
  }

  .card--strength-item h3 {
    font-size: 1.25rem !important;
  }

  .card--strength-item>.wp-block-columns {
    gap: 1.5rem;
  }

  .card--strength-item .wp-block-column:has(img) {
    order: -1;
  }
}

/* gene-item */
.gene-item-block .wp-block-column>.wp-block-group {
  height: 100%;
}

/* flow */
.flow-list {
  position: relative;
}

.flow-list::before {
  position: absolute;
  left: 50%;
  top: 0;
  width: 1px;
  height: 100%;
  content: "";
  background: var(--wp--preset--color--primary);
}

/* plan */
.yourpro-plan-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--wp--preset--spacing--md);
}

.yourpro-plan-actions .wp-block-button {
  flex: 1 1 50%;
}

.yourpro-plan-actions .wp-block-button .wp-block-button__link {
  width: 100%;
}

.yourpro-plan-summary {
  position: relative;
  display: flex;
  width: 100%;
  min-height: 370px;
  padding: 3rem;
  --plan-summary-content-offset: calc(8.3333333333% + 1rem);
  --plan-summary-content-width: calc((83.3333333333% - 2rem) * 0.65);
}

.yourpro-plan-summary.has-background-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--plan-summary-bg-image);
  background-position: center right;
  background-repeat: no-repeat;
  background-size: cover;
  z-index: -3;
}

.yourpro-plan-summary::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
}

.yourpro-plan-summary>*,
.yourpro-plan-summary__inner>* {
  margin: 0;
}

.yourpro-plan-summary__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
  width: min(100%, var(--plan-summary-content-width));
  margin-left: var(--plan-summary-content-offset);
}

.yourpro-plan-summary__inner::after {
  content: "";
  display: block;
  width: 100%;
  margin-top: 0.75rem;
  border-bottom: 4px dashed rgba(255, 255, 255, 0.78);
}

.plan-term-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.375rem 0.75rem;
  border-radius: 999px;
  background: var(--wp--preset--color--surface-muted);
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
}

.plan-term-badge--recommend {
  background: var(--wp--preset--color--accent-background);
  color: var(--wp--preset--color--primary);
}

.plan-term-badge--popular {
  background: #fff1e8;
  color: var(--wp--preset--color--accent);
}

.yourpro-plan-summary__title {
  color: var(--wp--preset--color--foreground);
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.yourpro-plan-summary__excerpt {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-plan-summary__price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.25rem;
  width: 100%;
  color: var(--wp--preset--color--primary-dark);
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.1;
}

.yourpro-plan-summary__price-suffix {
  font-size: 14px;
  font-weight: 500;
}

.yourpro-plan-summary__about {
  width: 100%;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
  max-width: 48rem;
}

.plan-price-prifix {
  font-size: 0.625em;
  font-weight: 700;
}

@media (max-width: 781px) {
  .yourpro-plan-summary {
    min-height: 0;
    padding: 2rem 1.5rem;
    --plan-summary-content-offset: 0;
    --plan-summary-content-width: 100%;
  }

  .yourpro-plan-summary__inner {
    width: 100%;
    margin-left: 0;
    gap: 0.875rem;
  }

  .yourpro-plan-summary__title {
    font-size: 2.25rem;
  }

  .yourpro-plan-summary__price {
    font-size: 2.25rem;
  }

  .yourpro-plan-summary__about {
    font-size: 0.9375rem;
  }
}

.yourpro-plan-sidebar__features {
  margin: 1.5rem 0 0;
  padding: 0;
  list-style: none;
}

.yourpro-plan-sidebar__features li {
  position: relative;
  margin: 0;
  padding: 0.75rem 0 0.75rem 2.25rem;
  border-bottom: 1px solid var(--wp--preset--color--border);
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-plan-sidebar__features li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.5rem;
  height: 1.5rem;
  background-color: var(--wp--preset--color--accent);
  transform: translateY(-50%);
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17L4 12' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17L4 12' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.yourpro-case-hero {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: var(--wp--preset--spacing--xl);
}

.yourpro-case-hero>* {
  margin: 0;
}

.yourpro-case-hero__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-case-hero__title {
  width: 100%;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--wp--preset--color--foreground);
}

.yourpro-case-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}

.yourpro-case-hero__rating {
  display: inline-flex;
  align-items: center;
  gap: 0.125rem;
  margin: 0;
  font-size: 20px;
  line-height: 1;
}

.yourpro-case-hero__star {
  display: inline-block;
}

.yourpro-case-hero__star.is-filled {
  color: #f6a724;
}

.yourpro-case-hero__star.is-empty {
  color: var(--wp--preset--color--border);
}

.yourpro-case-hero__additional {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-case-hero__media {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 4px;
  overflow: hidden;
}

.yourpro-case-hero__image,
.yourpro-case-hero__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 4px;
}

.yourpro-case-hero__image-placeholder {
  background: #d9d9d9;
}

.yourpro-case-pagination,
.yourpro-post-pagination {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3rem;
  margin-top: var(--wp--preset--spacing--xl);
}

.yourpro-case-pagination__item,
.yourpro-post-pagination__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  gap: 8px;
  min-height: 56px;
  padding: 16px 32px;
  border-radius: 4px;
  color: var(--wp--preset--color--primary-dark);
  font-size: 16px;
  font-weight: 700;
  line-height: normal;
  text-decoration: none;
  white-space: nowrap;
}

.yourpro-case-pagination__item:hover,
.yourpro-case-pagination__item:focus-visible,
.yourpro-post-pagination__item:hover,
.yourpro-post-pagination__item:focus-visible {
  color: var(--wp--preset--color--primary-dark);
  text-decoration: none;
}

.yourpro-case-pagination__item:focus-visible,
.yourpro-post-pagination__item:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 2px;
}

.yourpro-case-pagination__item--archive,
.yourpro-post-pagination__item--archive {
  background: #f7f7f7;
  color: var(--wp--preset--color--foreground);
}

.yourpro-case-pagination__item--archive:hover,
.yourpro-case-pagination__item--archive:focus-visible,
.yourpro-post-pagination__item--archive:hover,
.yourpro-post-pagination__item--archive:focus-visible {
  background: #e5e5e5 !important;
  color: var(--wp--preset--color--foreground);
}

.yourpro-case-pagination__icon,
.yourpro-post-pagination__icon {
  display: inline-block;
  flex: 0 0 24px;
  width: 24px;
  height: 24px;
  background-color: currentColor;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.yourpro-case-pagination__item--previous .yourpro-case-pagination__icon,
.yourpro-post-pagination__item--previous .yourpro-post-pagination__icon {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15 18L9 12L15 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15 18L9 12L15 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.yourpro-case-pagination__item--next .yourpro-case-pagination__icon,
.yourpro-post-pagination__item--next .yourpro-post-pagination__icon {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.yourpro-case-pagination__item--archive .yourpro-case-pagination__icon,
.yourpro-post-pagination__item--archive .yourpro-post-pagination__icon {
  display: none;
}

.yourpro-case-pagination__item.is-disabled,
.yourpro-post-pagination__item.is-disabled {
  opacity: 0.35;
  pointer-events: none;
}

.yourpro-case-pagination__label,
.yourpro-post-pagination__label {
  line-height: normal;
}

.yourpro-about-charts {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--xl);
}

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

.yourpro-about-charts__title,
.yourpro-about-charts__lead {
  margin: 0;
}

.yourpro-about-charts__title {
  color: var(--wp--preset--color--foreground);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.4;
}

.yourpro-about-charts__lead {
  color: var(--wp--preset--color--muted-foreground);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-about-charts__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4rem;
}

.yourpro-about-chart-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  padding: 3rem 1.5rem;
  border-radius: 8px;
  background: var(--wp--preset--color--base);
  box-shadow: var(--wp--preset--shadow--card-flow-step);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.yourpro-about-chart-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.yourpro-about-chart-card__question {
  width: 100%;
  margin: 0;
  color: var(--wp--preset--color--foreground);
  text-align: center;
}

.yourpro-about-chart-card__question-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
}

.yourpro-about-chart {
  position: relative;
  width: 100%;
  max-width: 200px;
  aspect-ratio: 1 / 1;
}

.yourpro-about-chart__svg {
  display: block;
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.yourpro-about-chart__track,
.yourpro-about-chart__segment {
  fill: none;
  stroke-width: 18;
}

.yourpro-about-chart__track {
  stroke: #f1f3ef;
}

.yourpro-about-chart__segment {
  stroke: var(--chart-color, var(--wp--preset--color--primary));
  transition: stroke-dasharray 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.yourpro-about-chart__center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.yourpro-about-chart__label {
  margin: 0;
  max-width: 8em;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.35;
}

.yourpro-about-chart__value-wrap {
  display: flex;
  align-items: baseline;
  justify-content: center;
}

.yourpro-about-chart__value,
.yourpro-about-chart__unit {
  margin: 0;
}

.yourpro-about-chart__value {
  font-size: 56px;
  font-weight: 400;
  line-height: 1;
}

.yourpro-about-chart__unit {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-about-chart__legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem 1.5rem;
  width: 100%;
}

.yourpro-about-chart__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  line-height: 1.5;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.yourpro-about-chart__legend-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.yourpro-about-chart__legend-dot {
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--chart-color, var(--wp--preset--color--primary));
  flex: 0 0 16px;
}

.yourpro-about-chart__legend-label {
  font-weight: 400;
}

.yourpro-about-chart__legend-value {
  font-weight: 700;
}

.person-archive-list .wp-block-post-template {
  margin: 0;
  padding: 0;
  list-style: none;
}

.person-archive-list .wp-block-post-template>li {
  margin: 0;
  padding: 0;
}

.person-archive-list .wp-block-post-template>li+li {
  margin-top: 3rem;
  padding-top: 3rem;
  border-top: 1px solid var(--wp--preset--color--border);
}

.yourpro-person-card {
  display: grid;
  grid-template-columns: minmax(0, 400px) minmax(0, 1fr);
  gap: 4rem;
  align-items: flex-start;
}

.yourpro-person-card__media {
  position: relative;
  width: 100%;
  max-width: 400px;
  aspect-ratio: 1 / 1;
}

.yourpro-person-card__media::before,
.yourpro-person-card__media::after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 40px;
  height: 40px;
  background: var(--wp--preset--color--base);
}

.yourpro-person-card__media::before {
  bottom: -1px;
  left: -1px;
  clip-path: polygon(0 0, 0 100%, 100% 100%);
}

.yourpro-person-card__media::after {
  top: -1px;
  right: -1px;
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.yourpro-person-card__image,
.yourpro-person-card__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 2px;
}

.yourpro-person-card__image-placeholder {
  background: var(--wp--preset--color--accent-background);
}

.yourpro-person-card__content {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

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

.yourpro-person-card__label,
.yourpro-person-card__title-row,
.yourpro-person-card__title,
.yourpro-person-card__name-en,
.yourpro-person-card__intro,
.yourpro-person-card__career h3,
.yourpro-person-card__career ul,
.yourpro-person-card__quote p {
  margin: 0;
}

.yourpro-person-card__label {
  color: var(--wp--preset--color--primary);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

.yourpro-person-card__title {
  color: var(--wp--preset--color--foreground);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.3;
}

.yourpro-person-card__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.75rem 1rem;
}

.yourpro-person-card__name-en {
  color: #7f7f7f;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.yourpro-person-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.yourpro-person-card__tags li {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.375rem 0.75rem;
  border-radius: 999px;
  background: #a68f3c;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-person-card__intro,
.yourpro-person-card__quote p {
  color: var(--wp--preset--color--foreground);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-person-card__career {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.yourpro-person-card__career h3 {
  color: var(--wp--preset--color--foreground);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}

.yourpro-person-card__career ul {
  padding-left: 1.25rem;
  color: var(--wp--preset--color--foreground);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.yourpro-person-card__career li+li {
  margin-top: 0.25rem;
}

.yourpro-person-card__quote {
  position: relative;
  padding: 1.5rem;
  border-radius: 8px;
  background: var(--wp--preset--color--accent-background);
}

.yourpro-person-card__quote::before,
.yourpro-person-card__quote::after {
  content: "";
  position: absolute;
  width: 21px;
  height: 18px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.yourpro-person-card__quote::before {
  top: 0.75rem;
  left: 1rem;
  background-image: url("data:image/svg+xml,%3Csvg width='21' height='18' viewBox='0 0 21 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath opacity='0.1' d='M4.704 17.616C3.2 17.616 2.032 17.056 1.2 15.936C0.4 14.784 0 13.168 0 11.088C0 8.624 0.608 6.48 1.824 4.656C3.04 2.8 4.848 1.248 7.248 0L8.88 3.12C7.312 3.952 6.128 4.912 5.328 6C4.56 7.088 4.176 8.432 4.176 10.032L4.512 14.448L1.968 11.04C2.384 10.688 2.816 10.416 3.264 10.224C3.712 10 4.192 9.888 4.704 9.888C5.76 9.888 6.656 10.224 7.392 10.896C8.128 11.536 8.496 12.432 8.496 13.584C8.496 14.8 8.144 15.776 7.44 16.512C6.736 17.248 5.824 17.616 4.704 17.616ZM16.704 17.616C15.2 17.616 14.032 17.056 13.2 15.936C12.4 14.784 12 13.168 12 11.088C12 8.624 12.608 6.48 13.824 4.656C15.04 2.8 16.848 1.248 19.248 0L20.88 3.12C19.312 3.952 18.144 4.912 17.376 6C16.608 7.088 16.224 8.432 16.224 10.032L16.512 14.448L13.968 11.04C14.384 10.688 14.816 10.416 15.264 10.224C15.712 10 16.192 9.888 16.704 9.888C17.76 9.888 18.656 10.224 19.392 10.896C20.128 11.536 20.496 12.432 20.496 13.584C20.496 14.8 20.144 15.776 19.44 16.512C18.736 17.248 17.824 17.616 16.704 17.616Z' fill='%2338AA23'/%3E%3C/svg%3E");
}

.yourpro-person-card__quote::after {
  right: 1rem;
  bottom: 0.5rem;
  background-image: url("data:image/svg+xml,%3Csvg width='21' height='18' viewBox='0 0 21 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath opacity='0.1' d='M1.632 17.568L0 14.496C1.568 13.632 2.736 12.656 3.504 11.568C4.304 10.48 4.704 9.136 4.704 7.536L4.32 3.168L6.912 6.576C6.528 6.896 6.096 7.168 5.616 7.392C5.168 7.584 4.688 7.68 4.176 7.68C3.152 7.68 2.256 7.344 1.488 6.672C0.72 6 0.336 5.104 0.336 3.984C0.336 2.736 0.688 1.76 1.392 1.056C2.128 0.352 3.056 0 4.176 0C5.712 0 6.864 0.559999 7.632 1.68C8.432 2.8 8.832 4.384 8.832 6.432C8.832 8.896 8.224 11.072 7.008 12.96C5.824 14.816 4.032 16.352 1.632 17.568ZM13.632 17.568L11.952 14.496C13.552 13.632 14.736 12.656 15.504 11.568C16.304 10.48 16.704 9.136 16.704 7.536L16.32 3.168L18.912 6.576C18.528 6.896 18.096 7.168 17.616 7.392C17.168 7.584 16.688 7.68 16.176 7.68C15.152 7.68 14.256 7.344 13.488 6.672C12.72 6 12.336 5.104 12.336 3.984C12.336 2.736 12.688 1.76 13.392 1.056C14.128 0.352 15.056 0 16.176 0C17.712 0 18.864 0.559999 19.632 1.68C20.432 2.8 20.832 4.384 20.832 6.432C20.832 8.896 20.224 11.072 19.008 12.96C17.824 14.816 16.032 16.352 13.632 17.568Z' fill='%2338AA23'/%3E%3C/svg%3E");
}

.plan-list .card--plan-item {
  position: relative;
  height: 100%;
}

.card--plan-item>.wp-block-group {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.card--plan-item .fixed-badge {
  position: absolute;
  top: -2rem;
  left: 50%;
  transform: translate(-50%, -50%);
}

.card--plan-item .wp-block-buttons {
  margin-top: auto;
  padding-top: 2.5rem;
  width: 100%;
}

.plan-price-prifix {
  font-size: 0.75em;
}

.is-arrow-right .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
}

.is-arrow-right .wp-block-button__link::after {
  display: inline-block;
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  flex: 0 0 1.5rem;
  background-color: currentColor;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 18L15 12L9 6' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

/* accordion */
.faq-common {
  width: 100%;
}

.faq-common .wp-block-accordion-item {
  margin-top: 0;
  margin-bottom: 0;
  padding: 1rem 0;
}

.faq-common .wp-block-accordion-heading {
  margin: 0;
}

.faq-common .wp-block-accordion-heading__toggle {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  padding: 1rem 0;
  border: 0;
  background: transparent;
  color: var(--wp--preset--color--foreground);
  text-align: left;
  cursor: pointer;
}

.faq-common .wp-block-accordion-heading__toggle-title {
  display: flex;
  flex: 1 1 auto;
  align-items: flex-start;
  gap: 1rem;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3333;
}

.faq-common .wp-block-accordion-heading__toggle-title::before {
  content: "Q";
  flex: 0 0 auto;
  color: var(--wp--preset--color--primary);
  font-size: 18px;
  font-weight: 700;
  line-height: 24px;
}

.faq-common .wp-block-accordion-heading__toggle-icon {
  display: flex;
  flex: 0 0 24px;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--wp--preset--color--primary);
  font-size: 0;
  line-height: 1;
  transform: none !important;
}

.faq-common .wp-block-accordion-heading__toggle-icon::before {
  content: "+";
  font-size: 32px;
  font-weight: 300;
  line-height: 1;
  transform: rotate(0);
}

.faq-common .wp-block-accordion-item.is-open .wp-block-accordion-heading__toggle-icon::before {
  content: "−";
}

.faq-common .wp-block-accordion-item.is-open>.wp-block-accordion-heading .wp-block-accordion-heading__toggle-icon {
  transform: none !important;
}

.faq-common .wp-block-accordion-panel {
  margin-top: 0;
  padding: 0 0 1rem 1.875rem;
}

.faq-common .wp-block-accordion-panel p {
  margin: 0;
  color: var(--wp--preset--color--foreground);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75;
}

/* cta */
.cta-consult {
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.14) 1px, transparent 1px);
  background-size: 16px 16px;
  background-position: center;
}

.cta-line__inner .wp-block-button,
.cta-consult .wp-block-button {
  transition: all 0.2s ease;
}

.cta-consult .wp-block-button:hover .wp-block-button__link {
  background-color: var(--wp--preset--color--base) !important;
  color: var(--wp--preset--color--primary-dark) !important;
}

.cta-consult .wp-block-button.is-style-fill:hover .wp-block-button__link {
  opacity: 0.8;
}

.cta-line__inner .wp-block-button:hover {
  opacity: 0.8;
}

.cta-line__inner {
  width: 100%;
  max-width: 1114px;
  margin-right: auto;
  margin-left: auto;
}

.cta-line__icon {
  display: flex;
  flex: 0 0 51px;
  align-items: center;
  justify-content: center;
  width: 51px;
  height: 51px;
}

.cta-line__copy {
  flex: 0 1 auto;
}

.cta-line__copy>* {
  margin: 0;
}

.cta-line__actions {
  flex: 0 0 auto;
}

.cta-line__button .wp-block-button__link {
  padding: 12px 24px;
  white-space: nowrap;
}

@media (max-width: 781px) {
  .yourpro-plan-actions {
    flex-direction: column;
  }

  .yourpro-plan-actions .wp-block-button {
    width: 100%;
    flex-basis: 100%;
  }

  .cta-consult .wp-block-buttons {
    width: 100%;
  }

  .cta-consult .wp-block-button {
    width: 100%;
  }

  .cta-consult .wp-block-button .wp-block-button__link {
    width: 100%;
  }

  .cta-line__inner {
    flex-direction: column !important;
    align-items: center !important;
  }

  .cta-line__copy {
    width: 100%;
    max-width: 293px;
    text-align: center;
  }

  .cta-line__actions,
  .cta-line__actions .wp-block-button,
  .cta-line__actions .wp-block-button__link {
    width: 100%;
  }

  .yourpro-person-card {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .yourpro-person-card__media {
    max-width: none;
  }

  .yourpro-person-card__title {
    font-size: 1.5rem;
  }

  .yourpro-person-card__name-en {
    font-size: 0.875rem;
  }

  .yourpro-case-hero__title {
    font-size: 28px;
  }

  .yourpro-case-hero__meta {
    gap: 0.75rem;
  }

  .yourpro-case-pagination,
  .yourpro-post-pagination {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .yourpro-case-pagination__item,
  .yourpro-post-pagination__item {
    width: 100%;
    padding-right: 1.5rem;
    padding-left: 1.5rem;
  }

  .yourpro-about-charts__grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .yourpro-about-chart-card {
    padding: 2rem 1rem;
  }

  .yourpro-about-chart-card__question-text {
    font-size: 18px;
  }

  .yourpro-about-chart__value {
    font-size: 48px;
  }

  .yourpro-about-chart__legend {
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
  }
}

/* header */
.yourpro-header {
  position: relative;
  z-index: 40;
}

.yourpro-header__inner {
  width: 100%;
  gap: 2rem;
}

.yourpro-header__brand {
  gap: 0.875rem;
  min-width: 0;
  flex-shrink: 0;
}

.yourpro-header__brand .wp-block-site-logo {
  margin: 0;
  flex-shrink: 0;
}

.yourpro-header__brand .wp-block-site-title {
  margin: 0;
  min-width: 0;
}

.yourpro-header__brand .wp-block-site-title a {
  color: var(--wp--preset--color--foreground);
  text-decoration: none;
}

.yourpro-header__actions {
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: flex-end;
  gap: 1.5rem;
  min-width: 0;
}

.yourpro-header__nav {
  flex: 1 1 auto;
  min-width: 0;
}

.yourpro-header__nav .wp-block-navigation__container {
  gap: 1.5rem;
}

.yourpro-header__nav .wp-block-navigation-item__content {
  color: var(--wp--preset--color--foreground);
  font-weight: 600;
  text-decoration: none;
}

.yourpro-header__buttons {
  gap: 0.75rem;
  flex-wrap: nowrap !important;
}

.yourpro-header__buttons .wp-block-button {
  flex: 0 0 auto;
}

.yourpro-header__buttons .wp-block-button__link {
  white-space: nowrap;
}

.yourpro-header__nav .wp-block-navigation__responsive-container-open,
.yourpro-header__nav .wp-block-navigation__responsive-container-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 48px;
  min-height: 48px;
  padding: 0;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 4px;
  color: var(--wp--preset--color--foreground);
  background: var(--wp--preset--color--base);
}

.yourpro-header__nav .wp-block-navigation__responsive-container-open:not(.always-shown) {
  display: none;
}

.yourpro-header__nav .wp-block-navigation__responsive-container-close {
  position: absolute;
  top: 0;
  right: 0;
}

.yourpro-header__mobile-drawer-ctas {
  display: none;
  flex-direction: column;
  width: 100%;
  gap: 0.75rem;
  padding-top: 1rem;
  border-top: 1px solid var(--wp--preset--color--border);
}

.yourpro-header__mobile-drawer-ctas .wp-block-button,
.yourpro-header__mobile-drawer-ctas .wp-block-button__link {
  width: 100%;
}

.yourpro-header__mobile-drawer-ctas .wp-block-button__link {
  justify-content: center;
}

@media (max-width: 1280px) {
  .yourpro-header__mobile-drawer-ctas {
    display: flex;
  }

  .yourpro-header__cta--desktop-only {
    display: none !important;
  }

  .yourpro-header__inner {
    gap: 1rem;
  }

  .yourpro-header__actions {
    width: auto;
    gap: 0.75rem;
    flex: 0 1 auto;
  }

  .yourpro-header__nav {
    order: 2;
    flex: 0 0 auto;
  }

  .yourpro-header__buttons {
    order: 1;
  }

  .yourpro-header__cta--primary .wp-block-button__link {
    padding-right: 1rem;
    padding-left: 1rem;
  }

  .yourpro-header__nav>.wp-block-navigation__container,
  .yourpro-header__nav>.wp-block-page-list,
  .yourpro-header__nav .wp-block-navigation__responsive-container:not(.is-menu-open) {
    display: none;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: inline-flex;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container {
    padding: 1.5rem;
    background: var(--wp--preset--color--base);
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container-content {
    align-items: stretch;
    gap: 1.5rem;
    padding-bottom: 4rem;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-page-list,
  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item,
  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-page-list li {
    width: 100%;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 0;
    color: var(--wp--preset--color--foreground);
    font-size: 1.125rem;
    font-weight: 700;
    line-height: 1.5;
    text-decoration: none;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-icon {
    display: none;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .wp-block-navigation__submenu-container,
  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container {
    position: static !important;
    width: 100%;
    min-width: 0;
    margin: 0;
    padding-top: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 0.5rem !important;
    padding-left: 1rem !important;
    border: 0;
    box-shadow: none;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container .wp-block-navigation-item {
    border-bottom: 0;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
    padding: 0.75rem 0;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--wp--preset--color--muted-foreground);
  }
}

@media (max-width: 781px) {
  .yourpro-header {
    padding: 0.5rem 1rem !important;
  }

  .yourpro-header__nav .wp-block-navigation__container {
    gap: 0.25rem !important;
  }

  .yourpro-header__nav .wp-block-navigation__responsive-container {
    padding: 0.5rem 1rem;
  }
}

/* Hyperlink Block */
.wp-block-tiptip-hyperlink-group-block {
  text-decoration: initial;
}

/* Front page */
.front-page section {
  position: relative;
}

.front-label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.front-hero .front-label {
  display: flex;
  justify-content: center;
  width: stretch;
  padding: 6px 12px;
  margin-bottom: 1rem;
  text-align: center;
  border: 1px solid var(--wp--preset--color--primary);
  border-radius: 9999px;
}

.front-section-heading {
  text-align: center;
}

.front-hero {
  overflow: hidden;
  isolation: isolate;
}

.front-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(360px, 0.48fr) minmax(560px, 0.52fr);
  align-items: center;
  width: min(100%, 1920px);
  min-height: clamp(560px, 44.45vw, 640px);
  margin-right: auto;
  margin-left: auto;
  padding-right: clamp(3rem, 8vw, 10rem);
  padding-left: clamp(3rem, 8vw, 10rem);
}

.front-hero::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -5%;
  z-index: 0;
  width: min(60vw, 1920px);
  height: min(84vw, 1280px);
  background-image: url("./assets/images/front-hero__bg.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transform: translate(0, -50%);
  mix-blend-mode: multiply;
  pointer-events: none;
}

.front-hero__content {
  padding-left: 10%;
}

.front-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0;
  padding: 4px 8px;
  border: 1px solid var(--wp--preset--color--primary);
  border-radius: 9999px;
  line-height: 1.45;
}

.front-hero__title {
  margin: 0;
  font-size: clamp(2.75rem, 4.2vw, 5.25rem) !important;
  line-height: 1.18;
  letter-spacing: -0.02em;
}

.front-hero__highlight {
  display: inline-block;
  margin-right: 0.08em;
  margin-left: 0.08em;
  padding: 0 0.08em 0.08em;
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--base);
  line-height: 1.08;
}

.front-hero__lead {
  margin: 0;
  font-size: clamp(1rem, 1.5vw, 1.375rem);
  line-height: 1.5;
}

.front-hero__buttons .wp-block-button__link {
  min-width: 0;
}

.front-hero__mainvisual {
  transform: scale(1.25) translateX(15%);
  transform-origin: 50% 40%;
  position: relative;
}

.front-hero__asset {
  position: absolute;
  margin: 0;
}

.front-hero__asset img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.front-hero__asset--shape {
  top: 0;
  left: 2.15%;
  z-index: 0;
  width: 97.85%;
  height: 100%;
  opacity: 0.92;
}

.front-hero__asset--panel-line {
  top: 0.2%;
  left: 2.15%;
  z-index: 2;
  width: 97.85%;
  height: 99.8%;
}

.front-hero__asset--food {
  top: -7.4%;
  left: -38.8%;
  z-index: 2;
  width: 188.9%;
  height: 110.1%;
  mix-blend-mode: color-dodge;
  opacity: 0.85;
}

.front-hero__asset--ball-shadow {
  top: 77%;
  left: 1.2%;
  z-index: 4;
  width: 7.1%;
  height: 2.2%;
}

.front-hero__asset--soccer {
  top: 6.45%;
  left: -1.35%;
  z-index: 6;
  width: 58.5%;
  height: 62.1%;
}

.front-hero__asset--soccer-shadow {
  top: 49%;
  left: 25.9%;
  z-index: 5;
  width: 6%;
  height: 1.1%;
}

.front-hero__asset--soccer-shadow-small {
  top: 49.1%;
  left: 43.6%;
  z-index: 5;
  width: 2.8%;
  height: 1.1%;
}

.front-hero__asset--baseball {
  top: 13.3%;
  left: -2.95%;
  z-index: 7;
  width: 29.5%;
  height: 66.4%;
  transform: rotate(-2deg);
}

.front-hero__asset--nutritionist {
  top: 32.1%;
  left: 11%;
  z-index: 8;
  width: 61%;
  height: 51.5%;
}

.front-hero__asset--ball {
  top: 67.4%;
  left: -1.7%;
  z-index: 9;
  width: 11%;
  height: 11.1%;
}

.front-stats__items {
  gap: 1rem;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  color: var(--wp--preset--color--base);
}

.front-stats__items>.wp-block-column {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 300px;
  max-width: 300px;
  min-height: 85px;
  padding: 0;
}

.front-stats__items>.wp-block-column+.wp-block-column::before {
  content: none;
}

.front-stats .wp-block-image {
  max-width: 280px;
}

.front-stat-card {
  position: relative;
  width: 100%;
  min-height: 85px;
  display: grid;
  align-content: center;
  color: var(--wp--preset--color--base);
  text-align: center;
}

.front-stat-card::before,
.front-stat-card::after {
  content: "";
  position: absolute;
  top: 0;
  width: 36px;
  height: 85px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.front-stat-card::before {
  left: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='36' height='85' viewBox='0 0 36 85' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M28.5811 77.2154C25.0453 76.0804 21.5103 76.424 19.3003 77.8708C20.1384 80.2891 22.7349 82.5893 26.2721 83.7199C29.8065 84.8518 33.3423 84.5114 35.5515 83.0629C34.7134 80.6462 32.1161 78.3415 28.5811 77.2154Z' fill='white'/%3E%3Cpath d='M25.892 73.3836C27.6259 71.5765 28.4803 68.4424 27.9036 65.1161C27.3277 61.7911 25.473 59.1624 23.2399 58.0985C21.5077 59.9039 20.6493 63.0394 21.2275 66.3658C21.8036 69.6893 23.6598 72.3226 25.892 73.3836Z' fill='white'/%3E%3Cpath d='M13.9886 63.509C10.9364 61.5674 7.4724 61.0512 4.95996 61.9184C5.07878 64.4579 6.90631 67.3029 9.95866 69.2447C13.0102 71.1849 16.4734 71.7007 18.9865 70.8322C18.867 68.2913 17.0401 65.4507 13.9886 63.509Z' fill='white'/%3E%3Cpath d='M16.2111 45.863C14.315 47.2733 13.0272 50.0686 13.0446 53.2587C13.0612 56.4489 14.3774 59.1897 16.2884 60.523C18.185 59.1096 19.4722 56.3174 19.4549 53.1256C19.4375 49.9371 18.1212 47.1977 16.2111 45.863Z' fill='white'/%3E%3Cpath d='M11.2763 40.6827C13.61 40.2045 16.0174 38.2219 17.432 35.33C18.8505 32.438 18.8955 29.408 17.7796 27.3984C15.4443 27.8782 13.0364 29.8592 11.6218 32.7544C10.2049 35.6432 10.1575 38.6745 11.2763 40.6827Z' fill='white'/%3E%3Cpath d='M7.85929 33.3747C9.61851 31.9551 10.7403 29.2386 10.5977 26.1877C10.4572 23.1367 9.08984 20.5669 7.20669 19.3594C5.44726 20.7775 4.32326 23.4924 4.46663 26.5449C4.60569 29.5943 5.97532 32.167 7.85929 33.3747Z' fill='white'/%3E%3Cpath d='M25.4904 13.5327C23.3392 13.3163 20.6572 14.3876 18.5405 16.5186C16.4244 18.6495 15.4393 21.2706 15.7704 23.3181C17.9231 23.5345 20.6038 22.4633 22.7199 20.3322C24.836 18.2016 25.8218 15.5834 25.4904 13.5327Z' fill='white'/%3E%3Cpath d='M19.0855 11.3809C20.0015 8.79913 19.7538 6.24149 18.6245 4.66156C16.7045 5.30314 14.8678 7.21756 13.9501 9.80096C13.0333 12.3796 13.282 14.9389 14.4128 16.5188C16.3313 15.8742 18.1678 13.9626 19.0855 11.3809Z' fill='white'/%3E%3Cpath d='M29.4775 6.34708C31.4568 4.37207 32.3873 1.9387 32.0854 0.0271655C30.0851 -0.180167 27.5862 0.805176 25.6046 2.78163C23.6274 4.755 22.6993 7.19166 22.9983 9.09846C25.0001 9.30888 27.4999 8.32354 29.4775 6.34708Z' fill='white'/%3E%3Cpath d='M7.14412 43.5324C5.41333 40.8507 2.81152 39.2192 0.448584 39.0725C-0.424685 41.2336 -0.0305895 44.2453 1.69795 46.9239C3.42649 49.6042 6.03035 51.2371 8.39349 51.3824C9.26472 49.2196 8.87267 46.2094 7.14412 43.5324Z' fill='white'/%3E%3C/svg%3E");
}

.front-stat-card::after {
  right: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='36' height='85' viewBox='0 0 36 85' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.97123 77.2154C3.43602 78.3415 0.839525 80.6462 0 83.0629C2.20915 84.5114 5.74435 84.8518 9.28099 83.7199C12.8176 82.5893 15.4139 80.2891 16.252 77.8708C14.0414 76.424 10.5079 76.0804 6.97123 77.2154Z' fill='white'/%3E%3Cpath d='M7.64831 65.1159C7.07159 68.4422 7.92624 71.5763 9.66072 73.3834C11.8924 72.3224 13.7499 69.6893 14.325 66.3658C14.9018 63.0394 14.0442 59.9039 12.3114 58.0985C10.0781 59.1624 8.22504 61.7911 7.64831 65.1159Z' fill='white'/%3E%3Cpath d='M21.564 63.509C18.5123 65.4507 16.6847 68.2913 16.5647 70.8322C19.0786 71.7007 22.5432 71.1849 25.5931 69.2447C28.6461 67.3029 30.4752 64.4579 30.5939 61.9184C28.0814 61.0512 24.617 61.5674 21.564 63.509Z' fill='white'/%3E%3Cpath d='M19.3412 45.863C17.4308 47.1977 16.1123 49.9371 16.0988 53.1256C16.0808 56.3174 17.3678 59.1093 19.2614 60.523C21.1746 59.1897 22.4903 56.4489 22.5068 53.2587C22.5248 50.0686 21.2378 47.2733 19.3412 45.863Z' fill='white'/%3E%3Cpath d='M17.7748 27.3984C16.6573 29.4082 16.7011 32.438 18.1185 35.33C19.5346 38.2219 21.9421 40.2045 24.2772 40.6827C25.3947 38.6745 25.3464 35.643 23.9304 32.7542C22.5172 29.8592 20.1084 27.8782 17.7748 27.3984Z' fill='white'/%3E%3Cpath d='M27.694 33.3747C29.5771 32.1669 30.9467 29.5942 31.0864 26.5447C31.229 23.4922 30.1058 20.7773 28.3455 19.3591C26.4624 20.5669 25.0958 23.1364 24.9545 26.1875C24.8105 29.2385 25.9354 31.9551 27.694 33.3747Z' fill='white'/%3E%3Cpath d='M19.7811 23.3181C20.1128 21.2706 19.1262 18.6492 17.0118 16.5186C14.8945 14.3878 12.2137 13.3163 10.0602 13.5327C9.73134 15.5834 10.715 18.2016 12.8324 20.3322C14.9485 22.4632 17.6276 23.5345 19.7811 23.3181Z' fill='white'/%3E%3Cpath d='M21.1404 16.5188C22.2697 14.9389 22.5191 12.3798 21.6014 9.80096C20.6854 7.21776 18.8487 5.30314 16.9279 4.66156C15.7986 6.24149 15.5507 8.79913 16.4669 11.3809C17.386 13.9626 19.2196 15.8742 21.1404 16.5188Z' fill='white'/%3E%3Cpath d='M12.5533 9.09846C12.8538 7.19166 11.9257 4.7552 9.94783 2.78163C7.96692 0.805176 5.46818 -0.180167 3.46764 0.0271655C3.16578 1.93849 4.09693 4.37207 6.07477 6.34708C8.05261 8.32374 10.5513 9.30909 12.5533 9.09846Z' fill='white'/%3E%3Cpath d='M35.1034 39.0723C32.7411 39.2192 30.1385 40.8505 28.4085 43.5322C26.6785 46.2094 26.2881 49.2194 27.159 51.3819C29.5213 51.2366 32.1268 49.6037 33.8539 46.9235C35.5824 44.2451 35.9757 41.2336 35.1034 39.0723Z' fill='white'/%3E%3C/svg%3E");
}

.front-stat-card p {
  margin: 0;
}

.front-stat-card__label--small {
  font-size: 0.875rem !important;
}

.front-stat-card__value {
  display: flex;
  gap: 0.125rem;
  align-items: baseline;
  justify-content: center;
  margin-top: 0 !important;
  color: inherit !important;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.front-stat-card__prefix {
  margin-right: 0.25rem;
}

.front-stat-card__number {
  font-size: 3rem;
  letter-spacing: -0.03em;
}

.front-stat-card__unit {
  font-size: 1.5rem;
}

.front-stats__note {
  width: 100%;
  max-width: none;
  margin: 1.5rem auto 0;
  color: var(--wp--preset--color--base) !important;
  line-height: 1.5;
  opacity: 0.8;
}

.home-case-list,
.home-blog-list {
  width: 100%;
}

.home-case-list__grid,
.home-blog-list__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.front-supported {
  overflow: hidden;
}

.front-logo-marquee {
  width: 100%;
  overflow: hidden;
  padding-top: 1rem;
  padding-bottom: 1rem;
  background: var(--wp--preset--color--base);
}

.front-logo-strip {
  display: flex;
  width: max-content;
  max-width: none;
  flex-wrap: nowrap;
  gap: 0;
  animation: front-logo-marquee var(--front-logo-duration, 36s) linear infinite;
  animation-play-state: paused;
  will-change: transform;
}

.front-logo-marquee.is-ready .front-logo-strip {
  animation-play-state: running;
}

.front-logo-set {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: nowrap;
  gap: 3rem;
  align-items: center;
  padding-right: 3rem;
}

.front-logo-set .wp-block-image {
  flex: 0 0 auto;
  margin: 0;
}

.front-logo-set img {
  display: block;
  width: auto;
  max-width: 163px;
  height: 120px;
  object-fit: contain;
}

@keyframes front-logo-marquee {
  to {
    transform: translate3d(calc(-1 * var(--front-logo-distance, 50%)), 0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .front-logo-strip {
    animation: none;
  }
}

.front-pickup {
  --wp--style--block-gap: 3rem;
}

.front-pickup .wp-block-columns {
  position: relative;
  overflow: hidden;
  min-height: 303px;
  border-radius: 4px;
}

.front-pickup .wp-block-columns::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 48px);
  z-index: 1;
  width: 48px;
  background: #a68f3c;
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
  pointer-events: none;
}

.front-pickup .wp-block-column {
  position: relative;
  z-index: 0;
}

.front-pickup .wp-block-column:nth-child(2) {
  z-index: 2;
}

.front-pickup__image {
  height: 100%;
  min-height: 303px !important;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #dfead9 0%, #f6f5ef 100%);
}

.front-pickup__image img {
  width: 100%;
  height: 100%;
  min-height: 303px;
  object-fit: cover;
}

.front-pickup__content {
  min-height: 303px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 24px !important;
}

.front-pickup__content p,
.front-pickup__content h3 {
  margin-top: 0;
  margin-bottom: 0;
}

.front-pickup__content p:not(.front-badge) {
  font-size: 0.875rem !important;
  font-weight: 500;
  line-height: 1.5;
}

.front-pickup__content p.has-xs-font-size:not(.front-badge) {
  font-size: 0.75rem !important;
  font-weight: 400;
}

.front-pickup__content h3 {
  font-size: 1.5rem !important;
  font-weight: 700;
  line-height: 1.5;
}

.front-pickup__content .wp-block-buttons {
  margin-top: auto;
}

.front-pickup__content .wp-block-button__link {
  min-width: 170px;
  min-height: 41px;
  padding: 12px 24px !important;
  border-color: currentColor;
  font-size: 0.875rem;
  line-height: 1.2;
}

.pickup-content .wp-block-button__link:hover,
.pickup-content .wp-block-button__link:focus-visible {
  background: var(--wp--preset--color--base);
  border-color: var(--wp--preset--color--base);
  color: #a68f3c !important;
}

.front-pickup__content .is-arrow-right .wp-block-button__link::after {
  width: 1rem;
  height: 1rem;
  flex-basis: 1rem;
}

.front-badge {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  background: var(--wp--preset--color--foreground);
  color: var(--wp--preset--color--base);
  font-size: 0.75rem !important;
  font-weight: 700;
  line-height: 1.5;
}

.front-pickup>.wp-block-buttons .wp-block-button__link {
  min-width: 320px;
  min-height: 56px;
  padding: 16px 32px !important;
  border-color: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--accent);
  font-size: 1rem;
  font-weight: 700;
}

.front-pickup>.wp-block-buttons .wp-block-button__link:hover,
.front-pickup>.wp-block-buttons .wp-block-button__link:focus-visible {
  background-color: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--base) !important;
}

.front-pickup>.wp-block-buttons {
  margin-top: 3rem;
}

.front-icon-card,
.front-feature-card {
  height: 100%;
  padding: 2rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 8px;
  background: var(--wp--preset--color--base);
}

.front-feature-card {
  box-shadow: var(--wp--preset--shadow--card-flow-step);
}

.front-icon-card__mark,
.front-about__step-icon {
  flex: 0 0 auto;
  margin: 0;
  color: var(--wp--preset--color--primary);
  font-weight: 800;
  line-height: 1;
}

.front-icon-card__mark {
  font-size: 2rem;
}

.front-about__steps {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  width: 100%;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.front-about__step {
  width: min(62.5%, 750px);
  min-height: 148px;
  gap: 3rem;
  align-items: center;
  overflow: hidden;
}

.front-about__step:nth-child(1) {
  margin-left: 16.666%;
}

.front-about__step:nth-child(2) {
  margin-left: 20.833%;
}

.front-about__step:nth-child(3) {
  margin-left: 25%;
}

.front-about__step>.wp-block-outermost-icon-block {
  flex: 0 0 72px;
  width: 72px;
}

.front-about__step>.wp-block-group {
  flex: 1 1 auto;
}

.front-about__step h3 {
  margin: 0 0 1rem;
  font-size: 1.25rem !important;
  line-height: 1.5;
}

.front-about__step p {
  margin: 0;
  line-height: 1.5;
}

.front-about__step-icon {
  min-width: 3rem;
  font-size: 2rem;
}

.front-about .front-section-heading {
  position: relative;
  z-index: 0;
}

.front-about .front-section-heading::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 244px;
  height: 244px;
  background-image: url("data:image/svg+xml,%3Csvg width='244' height='244' viewBox='0 0 244 244' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M182 2H242V62M62 2H2V62M182 242H242V182M62 242H2V182' stroke='%23EBF6E9' stroke-width='4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transform: translate(-50%, -50%);
  z-index: -1;
}

.front-reasons {
  background: var(--wp--preset--color--base);
}

.front-reasons__layout {
  align-items: flex-start;
}

.front-reasons__heading {
  position: relative;
  display: flex;
  justify-content: end;
  min-height: 20rem;
  padding-top: 1rem;
  padding-right: 4rem;
}

.front-reasons__heading::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 7.75rem;
  left: 0;
  height: 20rem;
  background: #f7f9f6;
  transform: translateY(-50%);
  z-index: 0;
}

.front-reasons__heading>* {
  position: relative;
  z-index: 1;
}

.front-reasons__heading .front-label {
  writing-mode: horizontal-tb;
  align-self: flex-start;
  margin: 0 1rem 0 0;
  font-size: 0.875rem;
}

.front-reasons__title {
  margin: 2rem 0 0;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-size: 2rem !important;
  line-height: 1.08 !important;
  letter-spacing: 0.04em;
}

.front-reason-list {
  width: 100%;
}

.front-reason-item {
  position: relative;
  overflow: visible;
  border-radius: 8px;
}

.front-reason-item+.front-reason-item::before {
  content: "";
  position: absolute;
  top: 0;
  right: 1.5rem;
  left: 1.5rem;
  height: 1px;
  background: var(--wp--preset--color--border);
}

.front-reason-item__index {
  flex: 0 0 5rem;
  text-align: center;
}

.front-reason-item__label,
.front-reason-item__num {
  margin: 0;
  font-weight: 700;
  line-height: 1;
}

.front-reason-item__label {
  letter-spacing: 0.04em;
}

.front-reason-item__num {
  font-size: 3.5rem;
  font-weight: 300;
}

.front-reason-item__body {
  flex: 1 1 auto;
}

.front-reason-item__body>* {
  margin-top: 0;
  margin-bottom: 0;
}

.front-comparison-table {
  overflow-x: auto;
}

.front-comparison-table table {
  min-width: 760px;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 8px;
  background: var(--wp--preset--color--base);
}

.front-comparison-table th,
.front-comparison-table td {
  padding: 1rem;
  border-color: var(--wp--preset--color--border);
  vertical-align: top;
}

.front-comparison-table th {
  background: var(--wp--preset--color--surface-muted);
}

.front-supervision,
.front-plan {
  background-image: radial-gradient(circle, rgba(209, 233, 204, 1) 1px, transparent 1px);
  background-size: 16px 16px;
  background-position: center;
}

.front-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
}

.front-photo-grid .wp-block-image {
  aspect-ratio: 1 / 1;
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  margin: 0;
}

.front-photo-grid .wp-block-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.front-chip-list {
  gap: 0.5rem;
}

.front-chip-list p {
  margin: 0;
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  background: #a68f3c;
  color: var(--wp--preset--color--base);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.5;
}

.front-check-list {
  display: grid;
  gap: 0.5rem;
  padding: 1.5rem;
  border-radius: 8px;
  background: var(--wp--preset--color--base);
  list-style: none;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
}

.front-check-list li {
  position: relative;
  margin: 0;
  padding-left: 2.5rem;
}

.front-check-list li::before {
  content: "";
  position: absolute;
  top: 0.125rem;
  left: 0;
  width: 1.5rem;
  height: 1.5rem;
  background-color: var(--wp--preset--color--accent);
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17L4 12' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17L4 12' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

.front-check-list li+li {
  margin-top: 0;
}

@media (max-width: 1280px) {
  .front-photo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1024px) {
  .front-hero__content {
    padding-left: 0;
  }

  .front-hero__inner {
    grid-template-columns: 1fr;
    min-height: 0;
    padding: 5rem 2rem 0;
  }

  .front-hero__visual {
    position: relative;
    top: auto;
    left: auto;
    width: min(100%, 760px);
    aspect-ratio: 884 / 853;
    min-height: 0;
    margin: -2rem auto 0;
  }

  .home-blog-list__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 781px) {
  .front-page section {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }

  .front-page .front-section-heading h2 {
    font-size: 1.75rem !important;
  }

  .front-voice .front-section-heading h2,
  .front-about .front-section-heading h2,
  .front-worries .front-section-heading h2 {
    font-size: 1.5rem !important;
  }

  .front-worries__grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
  }

  .front-about .front-section-heading h2 br {
    display: none;
  }

  .front-page .front-hero {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }

  .front-hero>div {
    margin-right: 0 !important;
    margin-left: 0 !important;
    gap: 0;
  }

  .front-hero__inner {
    padding: 4rem 1.25rem 0;
  }

  .front-hero__eyebrow {
    width: fit-content;
    max-width: 100%;
    font-size: 0.6875rem !important;
    text-align: left;
  }

  .front-hero__title {
    font-size: clamp(2rem, 10vw, 3rem) !important;
    line-height: 1.18;
  }

  .front-hero__lead {
    font-size: 1rem;
  }

  .front-hero__buttons {
    width: 100%;
  }

  .front-hero__buttons .wp-block-button {
    width: 100%;
  }

  .front-hero__buttons .wp-block-button__link {
    width: 100%;
  }

  .front-hero__content {
    margin-top: -2.5rem !important;
    position: relative;
    padding: 0 1rem;
    z-index: 1;
  }

  div:has(>.front-hero__mainvisual) {
    order: -1;
  }

  .front-hero__mainvisual {
    transform: scale(1.4) translateX(15%);
    transform-origin: 60% 40%;
  }

  .front-hero__mainvisual:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 68%, rgba(255, 255, 255, 1) 80%);
    z-index: 1;
  }

  .front-hero::before {
    top: -14%;
    left: -56%;
    width: 150vw;
    height: 110vw;
  }

  .front-hero__asset--food {
    display: none;
  }

  .front-hero .wp-block-buttons {
    flex-direction: column;
    gap: 0.5rem;
  }

  .front-hero .wp-block-buttons .wp-block-button {
    width: 100%;
    max-width: 360px;
  }

  .front-hero div:has(>.front-label) {
    display: flex;
    flex-direction: column;
  }

  .front-hero .front-label {
    margin-top: 1rem;
    padding: 0;
    border: none;
    text-align: left;
    order: 10;
  }

  .front-stats__items,
  .home-blog-list__grid {
    grid-template-columns: 1fr;
  }

  .home-case-list__grid {
    display: flex;
    overflow-x: auto;
    margin-inline: -1rem;
    padding-inline: 1rem;
  }

  .front-stats__items {
    gap: 1.5rem;
    flex-direction: column;
    align-items: center !important;
  }

  .front-stats__items>.wp-block-column+.wp-block-column::before {
    content: none;
  }
	.front-stats > div{
		gap:0.875rem;
	}

  .front-stats .wp-block-image {
    width: 30%;
    max-width: 200px;
    min-width: 160px;

  }

  .front-stat-card__value {
    white-space: normal;
  }

  .front-logo-strip {
    animation-duration: 28s;
  }

  .front-logo-set {
    gap: 2rem;
    padding-right: 2rem;
  }

  .front-logo-set img {
    max-width: 128px;
    height: 96px;
  }

  .front-pickup .wp-block-columns {
    min-height: 0;
    gap: 0;
  }

  .front-pickup .wp-block-columns::before {
    content: none;
  }

  .front-pickup__image {
    min-height: 10rem !important;
  }

  .front-pickup__content {
    min-height: 0;
  }

  .pickup-content {
    padding: 1rem !important;
  }

  .front-pickup .wp-block-heading {
    font-size: 1.25rem !important;
  }

  .front-pickup>.wp-block-buttons .wp-block-button,
  .front-pickup>.wp-block-buttons .wp-block-button__link {
    width: 100%;
  }

  .front-pickup>.wp-block-buttons .wp-block-button__link {
    min-width: 0;
  }

  .front-icon-card {
    padding: 1rem 0.75rem;
  }

  .front-icon-card p {
    font-size: 0.875rem !important;
  }

  .front-icon-card br {
    display: none;
  }

  .front-feature-card,
  .front-about__step {
    padding: 1.5rem;
  }

  .front-about .front-section-heading::before {
    width: 12rem;
    height: 12rem;
  }

  .front-about__steps {
    margin-top: 0;
    margin-bottom: 0;
  }

  .front-about__step {
    width: 100%;
    min-height: 0;
    margin-left: 0 !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.5rem !important;
  }

  .front-about__step>.wp-block-outermost-icon-block {
    flex-basis: auto;
    width: 64px;
  }

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

  .front-reasons__heading {
    min-height: auto;
    justify-content: flex-start;
    padding: 2rem 0rem;
  }

  .front-reasons__heading::before {
    right: auto;
    width: 14rem;
    height: 100%;
    margin-left: calc(3rem * -1);
  }

  .front-reasons__title {
    writing-mode: initial;
    margin-top: 1.5rem;
  }

  .front-reason-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem !important;
  }

  .front-reason-item__index {
    flex-basis: auto;
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    text-align: left;
  }

  .front-reason-item__num {
    font-size: 2.75rem;
  }

  .front-photo-grid {
    display: flex !important;
  }

  .front-reasons>div,
  .front-supervision>div {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }

  .front-supervision .front-supervision__content {
    margin-right: 0 !important;
    padding: 0 !important;
    width: 100%;
  }
	
	.front-difference-table{
		overflow-x:auto;
	}
	
	.front-difference-table img{
		min-width:781px;
	}
}

/* Contact Form 7 */
.wpcf7 {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}

.wpcf7-form>p {
  margin: 0;
}

.wpcf7-form>p+p {
  margin-top: 1.5rem;
}

.wpcf7-form label {
  display: block;
}

.wpcf7-form .form-label {
  display: inline-flex;
  align-items: center;
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.wpcf7-form .required::after {
  content: "必須";
  display: inline-block;
  margin-left: 0.5rem;
  padding: 0.125rem 0.375rem;
  font-size: 0.75rem;
  color: var(--wp--preset--color--base);
  background: var(--wp--preset--color--accent);
  border-radius: 4px;
}

.wpcf7-form .wpcf7-form-control-wrap {
  display: block;
}

.wpcf7-form input:not([type="submit"]),
.wpcf7-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 4px;
  box-sizing: border-box;
  background: var(--wp--preset--color--base);
  color: var(--wp--preset--color--foreground);
  font: inherit;
}

.wpcf7-form textarea {
  min-width: 100%;
  max-width: 100%;
  min-height: 5em;
  max-height: 20em;
  resize: vertical;
}

.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder {
  color: var(--wp--preset--color--muted-foreground);
}

.wpcf7-form .wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 200px;
  padding: 0.75rem 1.5rem;
  background: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--base);
  font-weight: 700;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.wpcf7-form .wpcf7-submit:hover {
  opacity: 0.9;
}

.wpcf7-form .wpcf7-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.wpcf7-acceptance input[type="checkbox"] {
  width: auto;
}

.wpcf7-form .wpcf7-spinner {
  margin: 0.5rem 0 0;
}

.wpcf7-form .wpcf7-not-valid-tip {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--wp--preset--color--accent);
}

.wpcf7-form .wpcf7-response-output {
  margin: 1rem 0 0;
  padding: 0.75rem 1rem;
  border-radius: 4px;
}

.single-case-layout .form-sidebar {
  max-width: 320px;
}

.single-case-layout__mobile-sidebar {
  display: none;
  margin-top: 1.5rem;
  margin-bottom: 2rem;
}

.single-case-layout__mobile-sidebar .form-sidebar {
  max-width: none;
}

/* 404 */
.not-found-hero .wp-block-search__inside-wrapper {
  overflow: hidden;
  background: var(--wp--preset--color--base);
}

.not-found-hero .wp-block-search__input {
  min-height: 56px;
  border: 0;
  background: transparent;
  font: inherit;
}

.not-found-hero .wp-block-search__button {
  min-height: 48px;
  margin: 4px;
  padding: 0 1.25rem;
  border: 0;
  border-radius: 4px;
  background: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--base);
}

.not-found-hero .wp-block-search__button:hover,
.not-found-hero .wp-block-search__button:focus-visible {
  background: #ee793d;
}

/* 微調整 */
@media (max-width: 1059px) {
  .single-case-layout .form-sidebar {
    width: 100%;
    max-width: none;
  }
}

@media (max-width: 781px) {
  .wpcf7-form .wpcf7-submit {
    width: 100%;
  }

  .single-case-layout .form-sidebar {
    width: 100%;
  }

  .single-case-layout__mobile-sidebar {
    display: block;
  }

  .single-case-layout__sidebar,
  .single-case-layout__gap,
  .single-case-layout__cta,
  .single-case-layout__cta-separator {
    display: none !important;
  }
}