/*!
Theme Name: JOBDRAFT B-PLAN
Author: NEXTAS Co., Ltd.
Author URI: -
Description: -
Version: 1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jobdraft-bplan
Tags: custom, block-patterns, block-styles, custom-colors, custom-logo, custom-menu, editor-style, full-site-editing, one-column, template-editing, wide-blocks
*/

/* Theme Custom CSS start */


/**************************************************************
* Light reset
**************************************************************/

h1, h2, h3, h4, h5, h6, p {
  margin: 0;
  padding: 0;
 }
 
ul, ol {
  list-style: none;
  margin-block-start: 0;
  margin-block-end: 0;
  padding-left: 0;
}

dl, dt, dd {
  margin: 0;
}

button, a {
  transition: 0.3s;
}

figure {
  margin: 0;
}

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

/* hovers */
@media (hover: hover) {
  a:hover{
    opacity: 0.7;
  }
}

@media (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
  }
}



 /*************************************************************
* Wordpress Blocks 追加分
**************************************************************/

/* wp-block-embed
************************************************/
.wp-block-embed.is-provider-youtube .wp-block-embed__wrapper {
  padding-top: calc(9/16 * 100%);
}

.wp-block-embed.is-provider-youtube iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
}

/* wp-block-button
************************************************/
@media all and (min-width: 1024px) {
  main .wp-block-button > .wp-block-button__link {
    line-height: 1.7;
  }
}

/* wp-block-navigation
************************************************/
.wp-block-navigation .wp-block-navigation-item__label {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-weight: bolder;
}

.wp-block-button .wp-block-button__link {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-weight: bold;
}

/* //TODO BUTTONS ( reflect this settings on the editor) */
@media all and (max-width: 1023px) {
  .wp-block-navigation .wp-block-navigation-item__label {
    font-size: 1.43rem;
  }
  
  .wp-element-button, .wp-block-button__link {
    padding: calc(0.667em + 8px) calc(1.333em + 8px);
  }
}



/**************************************************************
* WP ユーティリティ関連
**************************************************************/

.has-regular-font-size,
.has-normal-font-size {
  font-size: 1em
}

.has-larger-font-size,
.has-huge-font-size {
  font-size: 2.625em
}

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

.has-text-align-left {
  text-align: left
}

.has-text-align-right {
  text-align: right
}

#end-resizable-editor-section {
  display: none
}

.aligncenter {
  clear: both
}

.items-justified-left {
  justify-content: flex-start
}

.items-justified-center {
  justify-content: center
}

.items-justified-right {
  justify-content: flex-end
}

.items-justified-space-between {
  justify-content: space-between
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important
}

.screen-reader-text:focus {
  background-color: #ddd;
  clip: auto !important;
  -webkit-clip-path: none;
  clip-path: none;
  color: #444;
  display: block;
  font-size: 1em;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000
}



/**************************************************************
* グロバル設定
**************************************************************/

html {
  scroll-behavior: smooth;
}



/**************************************************************
* グロバル要素
**************************************************************/

/* g-header
************************************************/
.g-header {
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  padding-top: 2%;
  padding-bottom: 2%;
}

.g-header .wp-block-navigation-link a {
  transition: all 0.15s ease-out;
  position: relative;
}

.wp-block-navigation .wp-block-navigation-item__content.wp-block-navigation-item__content{
  color: var(--wp--preset--color--foreground);
}

.g-header .wp-block-navigation-link a::before {
  background: var(--wp--preset--color--tertiary);
  content: '';
  width: 100%;
  height: 2px;
  position: absolute;
  left: 0;
  bottom: 0;
  margin: auto;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}

.g-header .wp-block-navigation-link a:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}

.g-header .wp-block-navigation-link a:hover {
  filter:drop-shadow(0 0 3px var(--base-foreground-inverted-color));
}

.g-header__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding-left: 5.333%;
  padding-right: 5.333%;
}

@media all and (max-width: 1023px) {
  .g-header {
    padding-top: 5%;
  }
}

@media all and (min-width: 1024px) {

  .g-header__body {
    display: grid;
    grid-template-columns: 28% 1fr;
  }
}

/* g-logo
************************************************/
.g-logo {
  height: 100%;
}

/* g-nav
************************************************/
.g-nav {
  position: relative;
}

@media (min-width: 375px) {
  .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: flex;
  }
  .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: none;
  }
}

@media all and (max-width: 1023px) {
  .g-nav {
    justify-self: flex-end;
  }

  .g-nav .wp-element-button, .wp-block-button__link {
    height: 60px;
    font-size: 20px;
  }

  .g-nav .wp-block-navigation__responsive-container-open svg rect  {
      fill: var(--wp--preset--color--tertiary);
      width: 30px;
      height: 3px;
      x: 0;
  }

  .g-nav .wp-block-navigation__responsive-close,
  .g-nav .wp-block-navigation__responsive-dialog,
  .g-nav .wp-block-navigation__responsive-container-content {
    height: 100%;
  }

  .g-nav .wp-block-buttons,
  .g-nav .wp-block-button,
  .g-nav .wp-block-button__link .wp-element-button {
    width: 100%;
  }

  .g-nav .wp-block-navigation__responsive-container-close {
    top: 3%;
    right: 5.333%;
  }

  .g-nav .wp-block-navigation__responsive-container-close svg {
    stroke: var(--wp--preset--color--tertiary);
    stroke-width: 1px;
    fill: var(--wp--preset--color--tertiary);
    transform: scale(1.2);
  }

  .g-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10%;
    text-align: center;
  }

  .g-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
    gap: 1.2rem;
    margin-bottom: 1.8rem;
  }

  .g-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
    align-items: center;
  }

  .g-nav .wp-block-button__link .wp-element-button,
  .g-nav .wp-block-button .wp-block-button__link {
    width: 100%;
  }

  .g-nav .wp-block-buttons {
    margin-bottom: 2.25rem;
  }

  /* states */
  html.has-modal-open .g-logo .wp-block-site-logo {
    position: relative;
    z-index: 999999;
  }
}

@media all and (min-width: 1024px) {
  .g-nav {
    position: relative;
    align-self: center;
    justify-self: flex-end;
  }

  .g-nav .wp-block-navigation {
    gap: 40px;
    margin-right: 40px;
    color: var(--wp--preset--color--foreground);
  }

  .g-nav .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: none;
  }
  .g-nav .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: block;
  }
}

/* g-footer
************************************************/
.g-footer {
  position: relative;
  padding-top: clamp(60px, calc(60px + (200 - 60) * ((100vw - 375px) / (1920 - 375))), 200px);
  padding-bottom: clamp(60px, calc(60px + (200 - 60) * ((100vw - 375px) / (1920 - 375))), 200px);
  padding-left: 5%;
  padding-right: 5%;
  color: #ffffff;
  letter-spacing: 0.1em;
  background-color: var(--wp--preset--color--foreground);
}

.g-footer__body {
  position: relative;
}

.g-footer__top-block {
  gap: 10px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--wp--preset--color--inverted-foreground);
}

.g-footer__top-block .wp-block-site-logo {
  text-align: center;
}

.g-footer__top-block .wp-block-site-logo img {
  width: clamp(220px, calc(220px + (320 - 220) * ((100vw - 375px) / (1920 - 375))), 320px);
  filter: invert(100%) brightness(200%);
}

.g-footer__bottom-block {
  padding-top: 5%;
  display: flex;
  font-size: clamp(12px, 0.75rem + ((1vw - 3.2px) * 0.426), 16px);
}

@media all and (max-width: 1449px) {
  .g-footer__bottom-block {
    flex-direction: column;
  }

  .g-footer__bottom-block dl {
    width: clamp(300px, calc(300px + (370 - 300) * ((100vw - 375px) / (1449 - 375))), 370px);
    margin-left: auto;
    margin-right: auto;
  }

  .g-footer__bottom-block  dl:nth-child(2) {
    margin-top: 3.5%;
  }

  .footer-nav {
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 3%;
  }
  
}

@media all and (min-width: 1024px) {
  .g-footer__bottom-block dl dt {
    margin-bottom: clamp(8px, calc(8px + (8 * ((100vw - 375px) / 1545))), 16px);
  }

  .g-footer__top-block {
    display: grid;
    align-items: center;
  }
}

@media all and (min-width: 1450px) {
  .g-footer__top-block .wp-block-site-logo {
    padding-right: 5.7%;
    justify-self: flex-start;
  }

  .g-footer__top-block {
    
    grid-template-columns: 1fr 1fr 1fr;
  }
  
  .g-footer__bottom-block {
    padding-top: 2%;
    gap: 3%;
  }
}



/**************************************************************
* FOOTER
**************************************************************/
.footer-nav {
  display: flex;
  align-items: center;
  gap: 7%;
}

.footer-nav li a {
  color: var(--wp--preset--color--inverted-foreground);
  text-decoration: none;
  font-size: clamp(13px, 0.8125rem + ((1vw - 3.2px) * 0.3125), 16px);
}

@media all and (max-width: 1023px) {
  .footer-nav {
    margin-top: 40px;
    justify-content: center;
  }
}

@media all and (min-width: 1024px) {
  .footer-nav {
    gap: 35px;
  }
}

.wp-block-navigation__responsive-container-close svg, .wp-block-navigation__responsive-container-open svg {
  height: 30px;
  width: 30px;
}



/**************************************************************
* その他の要素
**************************************************************/

@media all and (max-width: 767px) {
  .table-narrowscreen-holder {
    overflow-x: scroll;
  }
  .table-narrowscreen-holder::after {
    content: "横にスクロールできます";
    position: relative;
    display: block;
    width: 100%;
    margin-top: 1.85rem;
    padding-top: 0.5rem;
    text-align: right;
    font-size: 12px;
    font-weight: bold;
    border-top: 2px solid #ffffff;
  }

  .table-narrowscreen-holder table {
    width: 400px !important; /* //FIXME */
  }
}



/**************************************************************
* コンテンツの共通要素
**************************************************************/


/* menu-aside-interface
************************************************/
.menu-aside-interface {
  position: relative;
  width: 100%;
}

.menu-aside-interface__copyright {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-weight: bolder;
  color: var(--wp--preset--color--primary);
  font-size: clamp(12px, calc(1rem + ((1vw - 12px) * 0.5)), 14px);
}

@media all and (max-width: 1023px) {
  ul.menu-aside-interface__sns-list {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1.6rem;
    margin-bottom: 1rem;
    width: 100%;
    border-top: 1px solid #e8e7e5;
    padding-top: 2.25em;
  }

  .menu-aside-interface__sns-list .menu-sns-item {
    flex: 0 0 1.43rem;
  }

  .menu-aside-interface__sns-list .menu-sns-item .sns-youtube-icn {
    display: block;
    width: 25px;
  }

  .menu-aside-interface__copyright {
    font-family: var(--wp--preset--font-family--alphabetic-font);
    font-weight: bolder;
    font-size: clamp(12px, calc(1rem + ((1vw - 12px) * 0.5)), 14px);
    color: var(--wp--preset--color--primary);
  }

  /* states */
  html:not(.has-modal-open) .menu-aside-interface {
    display: none;
  }
}

@media all and (min-width: 1024px) {
  .menu-aside-interface {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 999;
    display: flex;
    flex-flow: row;
    justify-content: center;
    align-items: center;
    gap: 5rem;
    width: 5%;
    height: 100%;
    writing-mode: vertical-rl;
  }

  ul.menu-aside-interface__sns-list {
    position: relative;
    top: -5%;
    display: flex;
    flex-flow: row;
    justify-content: center;
    align-items: center;
    gap: 1.8rem;
    margin-bottom: 1rem;
  }

  .menu-aside-interface__sns-list .menu-sns-item {
    flex: 0 0 1.25rem;
  }

  .menu-aside-interface__sns-list .menu-sns-item .sns-youtube-icn {
    transform-origin: center;
    transform: scale(0.9);
    display: block;
  }

  .menu-aside-interface__copyright {
    position: absolute;
    bottom: 5%;
    left: 0;
    right: 0;
    z-index: 999;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto;
    text-orientation: sideways;
    font-size: 12px;
  }
}


/* segment-heading
************************************************/
.segment-heading > p {
  position: relative;
  display: inline-block;
  margin-bottom: clamp(6px, calc(0.5rem + ((1vw - 3.2px) * 0.3)), 12px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  color: var(--wp--preset--color--primary);
  letter-spacing: 0.1rem;
  line-height: 1.25;
}

.segment-heading > h2 {
  font-size: clamp(10px, calc(1rem + ((1vw - 3.2px) * 0.5)), 20px);
  letter-spacing: 0.15rem;
  color: var(--wp--preset--color--foreground);
}

@media all and (min-width: 1024px) {
  .segment-heading > p {
    line-height: 1;
  }
}


/* horizontal-ticker
************************************************/
.horizontal-ticker {
  overflow: hidden;
}
/* FIXME shitty code */
.horizontal-ticker > span {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9;
  display: block;
  white-space: nowrap;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  /* font-size: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 200px); */
  font-size: clamp(60px, calc(60px + (200 - 60) * ((100vw - 375px) / (1920 - 375))), 200px);
  font-weight: bolder;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: var(--wp--preset--color--secondary);
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: transparent;
}

.editor-styles-wrapper .horizontal-ticker > span {
  font-size: 70px;
}

@media all and (min-width: 1024px) {
  .horizontal-ticker {
    position: relative;
  }

  .horizontal-ticker > span {
    -webkit-text-stroke-width: 2px;
  }
}

/* entry-aside
************************************************/
.entry-aside .wp-block-cover {
  min-height: auto;
  padding-top: clamp(56px, 8vw, 112px);
  padding-bottom: clamp(60px, 10vw, 120px);
  padding-left: 2%;
  padding-right: 2%;
}

.entry-aside .segment-heading > p {
  color: var(--wp--preset--color--inverted-foreground);
  font-size: clamp(40px, calc(2rem + ((1vw - 3.2px) * 1.5)), 80px)!important;
}

.entry-aside .segment-heading {
  display: table;
  margin-bottom: clamp(40px, 10vw, 80px);
  text-align: center;
}

.entry-aside .segment-heading > h2 {
  color: var(--wp--preset--color--inverted-foreground);
  margin-top: 2%;
}

.entry-aside .wp-block-group .wp-block-group {
  display: flex;
  flex-direction: column;
  gap: 9%;
  padding-right: 2%;
  padding-left: 2%;
  row-gap:calc(54px + (90 - 54) * ((100vw - 375px) / (1123 - 375)));
  flex-wrap: nowrap;
}

.entry-aside .wp-block-button__link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(16px, 2vw, 32px);
  width: clamp(300px, 50vw, 578px);
  height: clamp(72px, 9vw, 110px);
  font-size: clamp(12px, 0.75rem + ((1vw - 3.2px) * 0.426), 16px); 
  font-weight: bold;
  padding-left: 0;
  padding-right: 0;
  box-shadow: 11px 11px 0px var(--wp--preset--color--tertiary);
}

.entry-aside [class*="--entry-tel"] .wp-block-button__link .tel-icn svg {
  width: clamp(40px, 5vw, 60px);
}

.entry-aside [class*="--entry-tel"] .wp-block-button__link {
  font-family: var(--wp--preset--font-family--kana-font);
  letter-spacing: 0.1em;
  line-height: 1;
}

.entry-aside [class*="--entry-tel"] .wp-block-button__link strong {
  display: inline-block;
  font-size: clamp(24px, 1.5rem + ((1vw - 3.2px) * 0.981), 40px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  letter-spacing: 0.05em;
}

.entry-aside .wp-block-buttons .is-style-fill .wp-block-button__link {
  position: relative;
  box-shadow: 18px 4px 0 -11px  var(--wp--preset--color--primary-background), 
              18px 18px 0 -11px  var(--wp--preset--color--primary-background),
              5px 18px 0 -11px  var(--wp--preset--color--primary-background),
              11px 11px var(--wp--preset--color--tertiary);
  font-size: clamp(16px, 2vw, 20px);
  letter-spacing: 0.1em;
  font-family: var(--wp--preset--font-family--kana-font);
  line-height: 1.5;
}

.entry-aside .wp-block-buttons .is-style-fill .wp-block-button__link:before {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px var(--wp--preset--color--inverted-foreground);
  border-right: solid 2px var(--wp--preset--color--inverted-foreground);
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  right: clamp(28px, 5vw, 40px);
  bottom: 0;
  margin: auto;
}

/* hovers */
@media (hover: hover) {
  .entry-aside .wp-block-button__link:hover {
    box-shadow: none;
  }

  .entry-aside .wp-block-buttons .is-style-fill .wp-block-button__link:hover {
    box-shadow: none;
  }
}

@media all and (max-width: 1023px) {
    .entry-aside [class*="--entry-tel"] .wp-block-button__link strong {
      margin-top: 4%;
    }

    .entry-aside [class*="--entry-tel"] .wp-block-button__link .tel-icn {
      margin-left: -4%;
    }
}

@media all and (min-width: 1024px) {
  .entry-aside .wp-block-group .wp-block-group {
    flex-direction: row;
  }

  /* FIXME: refactor here many issues with WP group block default (-13 for top, -2 for about) */
  /* .entry-aside .wp-container-core-group-is-layout-15.wp-container-core-group-is-layout-15,
  .entry-aside .wp-container-core-group-is-layout-4.wp-container-core-group-is-layout-4 {
    flex-direction: row;
  } */

  .entry-aside .wp-block-button__link {
    width: clamp(300px, 40vw, 578px);
    height: clamp(72px, 9vw, 110px);
  }

  .entry-aside [class*="--entry-tel"] .wp-block-button__link .tel-icn {
    margin-left: -2%;
  }

  .entry-aside [class*="--entry-tel"] .wp-block-button__link strong {
    margin-top: 3%;

  }

  @media (hover: hover) {
    .entry-aside [class*="--entry-tel"] .wp-block-button__link:hover {
      transform: none;
      box-shadow: 11px 11px 0px var(--wp--preset--color--tertiary);
      cursor: auto;
    }
  }
}













/*********************************
*  FREE SPACE (OTHER BLOCK)
**********************************/
.free-space {
  position: relative;
  padding-bottom: 20%;
}

.free-space-visual[class*="--1"] {
  position: absolute;
  left: 0;
  width: 70%;
  height: 22%;
}
.free-space-visual[class*="--2"] {
  position: absolute;
  right: 0;
  width: 20%;
  height: 20%;
}

.free-space-visual .wp-block-cover {
  min-height: 100%;
}

.free-space-alphabetic {
  position: absolute;
  top: 0;
  left: 13%;
  text-transform: uppercase;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-weight: bolder;
  font-size: clamp(40px, calc(40px + 60 * ((100vw - 375px) / 1024)), 100px);
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--primary);
  mix-blend-mode: multiply;
}

.free-space__body {
  position: relative;
  max-width: 580px;
  margin-left: auto;
  padding-left: 10%;
}

.free-space__body > h3 {
  display: inline-block;
  margin-bottom: 1.5rem;
  padding-top: 2%;
  padding-bottom: 2%;
  padding-left: 4%;
  padding-right: 4%;
  letter-spacing: 0.1em;
  line-height: 1.25;
  color: var(--wp--preset--color--inverted-foreground);
  background-color: var(--wp--preset--color--foreground);
}

.free-space__body p {
  margin-bottom: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 2;
}

.free-space-english-txt {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  color: var(--wp--preset--color--secondary);
  letter-spacing: 0.05em;
}

.editor-styles-wrapper .free-space .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text {
  color: var(--wp--preset--color--secondary);
}

@media all and (max-width: 768px) {
  .free-space__body {
    padding-top: 80%;
    padding-right: 10%;
  }

  .free-space-visual[class*="--1"] {
    top: 5%;
  }

  .free-space-visual[class*="--2"] {
    top: 12%;
  }
}

@media (min-width: 768px) and (max-width: 1399px) {
  .free-space__body {
    padding-top: 35%;
    padding-right: 25%;
  }

  .free-space-visual[class*="--1"] {
    top: 10%;
  }

  .free-space-visual[class*="--2"] {
    top: 17%;
  }
}

@media all and (min-width: 1400px) {
  .free-space {
    padding-bottom: 10%;
    padding-right: 20%;
  }

  .free-space-visual[class*="--1"] {
    top: 150px;
    width: 50%;
    height: 555px;
  }

  .free-space-visual[class*="--2"] {
    top: 0;
    width: 16.66%;
    height: 555px;
  }

  .free-space__body {
    padding-top: 20%;
    padding-left: 68%;
  }

  .free-space-alphabetic {
    font-size: 8.33vw;
  }
}


/*********************************
*  TABLE
**********************************/
.table {
  position: relative;
  margin-left: 5.333%;
  margin-right: 5.333%;
}

.table .segment-heading {
  text-align: center;
}
.table .segment-heading .wp-block-heading {
  color: #ffffff;
}

.table__body {
  max-width: var(--wp--style--global--wide-size);
  margin-left: auto;
  margin-right: auto;
}

.table__body .wp-block-cover__inner-container {
  padding-top: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 120px);
}

.table__body .segment-heading {
  margin-bottom: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
}

.table-contents {
  padding-left: 5.33%;
  padding-right: 5.33%;
}

.table-contents > p {
  margin-bottom: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  letter-spacing: 0.05em;
}

.table-contents .wp-block-table {
  position: relative;
}

.table-contents .wp-block-table table {
  background-color: #ffffff;
  color: var(--wp--preset--color--foreground);
}

.wp-block-table thead {
  border-bottom: inherit;
}

.table-contents .wp-block-table table th,
.table-contents .wp-block-table table td {
  padding: 0.5rem;
  border: 1px solid var(--wp--preset--color--primary);
}

.table-contents .wp-block-table table th {
  background-color: var(--wp--preset--color--secondary-background);
  font-size: clamp(14px, calc(14px + (20 - 14) * ((100vw - 375px) / (1920 - 375))), 20px);
}
.table-contents .wp-block-table table td {
  text-align: center;
}

.table-contents .wp-block-table table td:first-child{
  text-align: center;
  font-size: clamp(14px, calc(14px + (20 - 14) * ((100vw - 375px) / (1920 - 375))), 20px);
}

@media all and (max-width: 1023px) {
  .table__body .wp-block-cover__inner-container {
    padding-left: 5.333%;
    padding-right: 5.333%;
  }

  .table-contents > p {
    text-align: left;
  }
}

@media all and (min-width: 1024px) {
  .table-contents .wp-block-table table th,
  .table-contents .wp-block-table table td {
    padding: 1rem;
  }
}

/*********************************
*  SNS
**********************************/
.sns {
  padding-top: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
}

.sns .segment-heading {
  margin-bottom: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  text-align: center;
}

.sns__inner {
  position: relative;
  padding-top: 20%;
  padding-bottom: 20%;
  background-color: var(--wp--preset--color--secondary-background);
}

.sns__body {
  padding-left: 5%;
  padding-right: 5%;
}

.sns-contents {
  position: relative;
  margin-top: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 80px);
}

.sns-contents__description {
  position: relative;
  margin-top: 12%;
}
.sns-contents__description > dt {
  margin-bottom: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 30px);
  font-size: clamp(14px, calc(14px + (14 * ((100vw - 375px) / 1545))), 20px);
  color: var(--wp--preset--color--primary);
  letter-spacing: 0.1em;
}
.sns-contents__description > dd {
  font-size: clamp(13px, calc(13px + (13 * ((100vw - 375px) / 1545))), 16px);
  letter-spacing: 0.1em;
}

.twitter-tweet.twitter-tweet-rendered,
.twitter-timeline.twitter-timeline-rendered {
  margin-left: auto;
  margin-right: auto;
}

.twitter-timeline.twitter-timeline-rendered iframe {
  height: 450px!important;
}

@media all and (max-width: 1199px) {
  .sns {
    margin-left: 5.333%;
    margin-right: 5.333%;
  }

  .sns__inner {
    padding-left: 5.333%;
    padding-right: 5.333%;
    clip-path: polygon(0 0, 88% 0, 100% 3%, 100% 100%, 0 100%);
  }

  .sns-contents__description > dt {
    text-align: center;
  }
}

@media all and (min-width: 1200px) {
  .sns__inner {
    padding-top: 6%;
    padding-bottom: 6%;
    clip-path: polygon(0 0, 95% 0, 100% 5%, 100% 100%, 0 100%);
  }

  .sns__body {
    padding-left: 10.7%;
    padding-right: 10.7%;
  }

  .sns-contents {
    display: flex;
    justify-content: space-between;
    flex-flow: row-reverse;
    gap: 1rem;
  }

  .sns-contents > div {
    flex: 0 0 50%;
  }

  .sns-contents > div:nth-child(1) {
    display: flex;
    justify-content: flex-end;
  }

  .sns-contents__description {
    margin-top: 18%;
  }

  .twitter-timeline.twitter-timeline-rendered iframe {
    height: 500px!important;
  }
}


/*********************************
*  BANNERS SPACE
**********************************/
.banners-space {
  padding-top: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  margin-left: 5.333%;
  margin-right: 5.333%;
}

.banners-space .segment-heading {
  margin-bottom: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  text-align: center;
}

.banners-space .segment-heading p {
  line-height: 1;
}

.banners-space__body {
  position: relative;
}

.banners-space__body > div:not(:last-child) {
  margin-bottom: 10px;
}

.banner-block {
  position: relative;
}

.banners-space .banner-block .wp-block-cover {
  min-height: 100px;
}

@media all and (max-width: 1023px) {
  .grids-area + .grids-area {
    margin-top: 12px;
  }
}

@media all and (min-width: 1024px) {
  .banners-space .segment-heading p {
    line-height: 1.25;
  }

  .banners-space .banner-block .wp-block-cover {
    min-height: 210px;
  }

  .banners-space__body > div:not(:last-child) {
    margin-bottom: 20px;
  }
}


/*********************************
*  FAQ
**********************************/
.faq {
  background-color: var(--wp--preset--color--secondary-background);
}

.faq__body {
  display: flex;
  justify-content:space-between;
  max-width: var(--wp--style--global--content-size);
  margin-left: auto;
  margin-right: auto;
  padding-top: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 120px);
  padding-bottom: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
}

.faq_contents {
  position: relative;
  flex: 0 0 77%;
}

.faq-item > h3 {
  margin-bottom: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 40px);
  color: var(--wp--preset--color--foreground);
  font-size: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
  line-height: 1;
}

.faq-item + .faq-item {
  margin-top: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
}

.faq-item__acc button {
  cursor: pointer;
}

.faq-item__acc .kt-blocks-accordion-header {
  font-weight: 700!important;
}

.faq-item__acc button::before,
.faq-item__acc-answer::before {
  padding-right: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 80px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 32px);
}
.faq-item__acc button::before {
  content: "Q";
  color: var(--base-foreground-inverted-color);
  font-weight: 700;
}
.faq-item__acc-answer::before {
  content: "A";
  line-height: 0;
  color: var(--wp--preset--color--primary);
}

.faq-item__acc-answer {
  text-indent: -3.5em;
  padding-left: 3.5em;
}


@media all and (max-width: 1023px) {
  .faq-item__acc-answer {
    text-indent: -2em;
    padding-left: 2em;
  }
}

@media all and (max-width: 1550px) {
  .faq .segment-heading {
    margin-bottom: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
    text-align: center;
  }

  .faq__body {
    display: block;
    margin-left: 5.333%;
    margin-right: 5.333%;
  }
}

/*********************************
*  FLOW
**********************************/
.flow {
  position: relative;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px)),
                    linear-gradient(90deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px));
  background-size: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px) clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px);
  background-repeat: repeat;
  background-position: top left;
}

.flow .segment-heading {
  margin-bottom: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  text-align: center;
}

.flow__body {
  padding-top: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 120px);
}

.flow-entries {
  display: grid;
  gap: clamp(30px, calc(30px + (30 * ((100vw - 375px) / 1545))), 75px);
}

.flow-entry {
  position: relative;
  display: grid;
  /* grid-template-columns: 0.2fr 1fr; */
  /* grid-template-columns: 0.25fr 0.75fr; */
  grid-template-columns: 0.25fr 1fr;
  /* gap: clamp(10px, calc(10px + (10 * ((100vw - 375px) / 1545))), 20px); */
  border-left: 5px solid var(--wp--preset--color--primary);

}

.flow-entry:not(:last-child)::before {
  content: "";
  position: absolute;
  bottom: min(-2vw, -27px);
  left: 50%;
  display: block;
  height: calc(clamp(16px, calc(16px + (25 - 16) * ((100vw - 375px) / (1920 - 375))), 25px) / 2);
  width: clamp(16px, calc(16px + (25 - 16) * ((100vw - 375px) / (1920 - 375))), 25px);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #cccccc;
  transform: translateX(-50%);
}

.flow-entry__time {
  display: flex;
  text-align: center;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(24px, calc(24px + (24 * ((100vw - 375px) / 1545))), 48px);
  font-weight: bolder;
  line-height: 1.25;
  letter-spacing: 0.05em;
  background: var(--wp--preset--color--secondary-background);
  padding-top: clamp(30px, calc(30px + (30 * ((100vw - 375px) / 1545))), 40px);
  padding-bottom: clamp(30px, calc(30px + (30 * ((100vw - 375px) / 1545))), 40px);
  padding-left: clamp(20px, calc(20px + (50 * ((100vw - 375px) / 1545))), 70px);
  color: var(--wp--preset--color--primary);
  height: 100%;
  box-sizing: border-box;
}

.flow-entry__data {
  position: relative;
  --x-width: 50px;
  --x-height: 50px;
  background: var(--wp--preset--color--secondary-background);
  padding-top: clamp(30px, calc(30px + (30 * ((100vw - 375px) / 1545))), 40px);
  padding-bottom: clamp(30px, calc(30px + (30 * ((100vw - 375px) / 1545))), 40px);
  padding-right: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 120px);
  padding-left: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 120px);
  clip-path: polygon(0 0, calc(100% - var(--x-width)) 0, 100% var(--x-width), 100% 100%, 0 100%, 0 var(--x-width));
}

.flow-entry__data > dt {
  margin-bottom: 0.75rem;
  font-size: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 20px);
  font-weight: bold;
  color: var(--wp--preset--color--primary);
}
.flow-entry__data > dd {
  font-size: clamp(12px, calc(12px + (12 * ((100vw - 375px) / 1545))), 16px);
  font-weight: bold;
  line-height: 2;
}


@media all and (max-width: 1023px) {
  .flow-entry:not(:last-child)::before {
    bottom: min(-2vw, -22px);
  }
}

@media all and (max-width: 1023px) {
  .flow__body {
    margin-left: 5.333%;
    margin-right: 5.333%;
  }
}

@media all and (min-width: 1024px) {
  .flow-entry__time {
    align-items: center;
  }
  .flow-entries {
    padding-left: 21.3%;
    padding-right: 21.3%;
  }
  
  .flow-entry {
    align-items: center;
  }
}



/**************************************************************
* 下層ページ共通パーツ
**************************************************************/

/* subpage-header
************************************************/
.subpage-header__body {
  position: relative;
  padding-top: clamp(35px, calc(2rem + ((1vw - 3.2px) * 2.2)), 70px);
  padding-bottom: clamp(60px, calc(3rem + ((1vw - 3.2px) * 2)), 120px);
  background-color: var(--wp--preset--color--inverted-foreground);
}

.subpage-header__headings {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.subpage-header__headings > p {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(40px, calc(2rem + ((1vw - 3.2px) * 6)), 120px);
  font-weight: bolder;
  color: var(--wp--preset--color--primary);
  line-height: 1.5;
  letter-spacing: 0.2rem;
}

.subpage-header__headings > h1 {
  width: fit-content;
  margin-bottom: clamp(17px, calc(1rem + ((1vw - 3.2px) * 0.5)), 23px);
  padding-left: 2%;
  padding-right: 2%;
  padding-top: 0.8%;
  padding-bottom: 0.8%;
  font-size: clamp(16px, calc(1rem + ((1vw - 4.5px) * 0.5)), 20px);
  color: var(--wp--preset--color--inverted-foreground);
  line-height: 1.2;
  letter-spacing: 0.15rem;
  background-color: var(--wp--preset--color--foreground);
}

.subpage-header__headings > ul {
  position: relative;
  display: flex;
}

.subpage-header__headings .breadcrumb-link,
.subpage-header__headings .breadcrumb-link a {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  border-bottom: none;
}

.subpage-header__headings > ul > li > span {
  font-size: clamp(12px, calc(1rem + ((1vw - 12px) * 0.25)), 16px);
  letter-spacing: 0.05rem;
}

.subpage-header__headings > ul > li:last-child > span {
  color: var(--wp--preset--color--primary);
  font-family: var(--wp--preset--font-family--alphabetic-font);
}

.breadcrumb-link > a {
  text-decoration: none;
  color: var(--wp--preset--color--foreground);
}

.subpage-header__headings > ul > li ~ li::before {
  content: "";
  position: absolute;
  top: 50%;
  height: 2px;
  background-color: var(--wp--preset--color--foreground);
}

.subpage-header[class*= --about] .subpage-header__visual .wp-block-cover > img {
  object-position: 0%;
}

@media all and (max-width: 1023px) {
  .subpage-header__visual .wp-block-cover {
    min-height: 40vh;
    /* margin-right: 0; */
  }

  .subpage-header__body {
    display: block;
    width: 100%;
  }

  .subpage-header__headings {
    padding-left: 10.666%;
    padding-right: 10.666%;
  }

  .subpage-header__headings > ul {
    gap: 25px;
  }

  .subpage-header__headings > ul > li ~ li::before {
    width: 8px;
    margin-left: -1rem;
    margin-right: 1rem;
  }
}

@media all and (min-width: 1024px) {
  .subpage-header__visual .wp-block-cover {
    height: 66vh;
    margin-right: 5%;
  }

  .subpage-header__body {
    top: -70px;
    display: inline-block;
    width: 50%;
  }

  .subpage-header__headings {
    padding-left: 25%;
  }

  .subpage-header__headings > ul {
    gap: 50px;
  }

  .subpage-header__headings > ul > li ~ li::before {
    width: 16px;
    margin-left: -2.2rem;
    margin-right: 1rem;
  }
}



/**************************************************************
* STATES
**************************************************************/

.is-hidden {
  display: none;
}



/*===========================================================
* TOPページ
============================================================*/

/**************************************************************
* TICKERS
**************************************************************/

.horizontal-ticker.work-underneath-ticker,
.horizontal-ticker.job-underneath-ticker {
  mix-blend-mode: multiply;
}

@media all and (max-width: 1023px) {
  .horizontal-ticker.work-above-ticker {
    top: 0;
  }

  .horizontal-ticker.instagram-above-ticker {
    position: relative;
    top: -25px;
  }

  .horizontal-ticker.work-underneath-ticker,
  .horizontal-ticker.job-underneath-ticker {
    position: relative;
    left: 0;
  }

  .horizontal-ticker.work-underneath-ticker {
    bottom: 1.25rem;
  }

  .horizontal-ticker.job-underneath-ticker {
    bottom: -0.35rem;
  }
}

@media all and (min-width: 1024px) {
  .horizontal-ticker.work-above-ticker {
    top: -130px;
  }

  .horizontal-ticker.instagram-above-ticker {
    top: -1vw;
  }

  .horizontal-ticker.work-underneath-ticker,
  .horizontal-ticker.job-underneath-ticker {
    bottom: 60px;
    bottom: 3.125%;
  }
}

/**************************************************************
* MV
**************************************************************/

.mv {
  position: relative;
}

.mv-copy {
  padding-left: 10%;
  padding-right: 10%;
  color: #ffffff;
}

.mv-copy > * + * {
  margin-top: 20px;
}

.mv-copy > h1 {
  position: relative;
  font-size: clamp(32px, calc(32px + (32 * ((100vw - 375px) / 1545))), 64px);
  color: var(--base-foreground-inverted-color);
  line-height: 1.5625;
  letter-spacing: 0.1em;
}

.mv-copy > p.alphabetic-copy {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(12px, 1rem + ((1vw - 3.2px) * 0.75), 24px);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}


/* //FIXME cover override */
.mv .wp-block-cover__inner-container {
  position: absolute;
  bottom: 56px;
}

@media all and (min-width: 1024px) {
  .mv {
    margin-right: 5%;
  }
}
  

/**************************************************************
* MESSAGE
**************************************************************/

  .message {
  position: relative;
}

.message::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--wp--preset--color--secondary-background);
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.message::after {
  content: "";
  position: absolute;
  z-index: -1;
  background-image: radial-gradient(var(--wp--preset--color--secondary) 15%, transparent 15%);
  background-size: 16px 16px;
}

.message__body {
  display: flex;
  justify-content: center;
  gap: clamp(32px, calc(2rem + ((1vw - 3.2px) * 2)), 120px);
}

.message__body > div {
  /* flex-grow: 1;  */
  flex-grow: 0;
  max-width: 700px;
}

.flex-container {
  display: flex;
  justify-content: space-between; /* Adjust as needed */
}

.message__alphabetic-copy {
  margin-bottom: clamp(35px, calc(2.1875rem + ((1vw - 3.2px) * 0.25)), 40px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(60px, calc(60px + (140 * ((100vw - 375px) / 1545))), 200px);
  font-weight: bolder;
  line-height: 1;
  color: #e8e7e5;
}

.message__heading-block {
  position: relative;
  display: flex;
  justify-content: flex-end;
}

.message__heading-block > h2 {
  display: flex;
  align-items: flex-start;
  flex-flow: column;
  writing-mode: vertical-rl;
  font-size: clamp(20px, calc(20px + (28 * ((100vw - 375px) / 1545))), 48px);
  color: var(--wp--preset--color--inverted-foreground);
}

.message__heading-block > h2 span {
  display: inline-block;
  padding-top: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
  padding-bottom: clamp(8px, calc(0.5rem + ((1vw - 3.2px) * 0.4)), 16px);
  padding-left: clamp(8px, calc(0.5rem + ((1vw - 3.2px)* 0.8)), 12px);
  padding-right: clamp(8px, calc(0.5rem + ((1vw - 3.2px)* 0.8)), 12px);
  letter-spacing: 0.45em;
  background: var(--wp--preset--color--primary);
}

.message__heading-block > h2 span:last-child {
  margin-top: clamp(35px, calc(35px + (80 - 35) * ((100vw - 375px) / (1920 - 375))), 80px);
}

.message__contents {
  display: flex;
  flex-flow: column;
}

.message__contents > p {
  font-size: clamp(13px, calc(0.8125rem + ((1vw - 3.2px) * 0.35)), 20px);
}

.message__contents > figure {
  position: relative;
}

.message__contents > figure > img {
  width: 100%;
}

@media all and (max-width: 1023px) {
  .message {
    padding-top: 16.333%; 
    padding-bottom: 10%;
  }
  .message::before {
    width: 34.75vw;
    height: 34.75vw;
  }
  .message::after {
    display: none;
  }
  .message__body {
    margin-left: 5.333%;
    margin-right: 5.333%;
  }

  .message__heading-block {
    top: -50px;
  }
  .message__heading-block > h2 {
    gap: 8px;
  }

  .message__heading-block > h2 span {
    display: inline-block;
  }

  .message__contents {
    gap: 30px;
    line-height: 2;
    letter-spacing: 0.05rem;
  }
  .message__contents > figure {
    width: 100%;
    top: -3%;
    left: 5%;
  }

  .message__alphabetic-copy {
    position: relative;
    letter-spacing: 0.05em;
  }

}
  
@media all and (min-width: 500px) {
  .message__contents > figure {
    width: 80%;
    left: 20%;
  }
}

@media all and (min-width: 1024px) {
  .message {
    padding-top: 8.333%; 
    padding-bottom: 5.625%;
  }
  .message::before {
    width: 20.75vw;
    height: 20.75vw;
  }
  .message::after {
    right: 0;
    bottom: 10%;
    width: 13.25vw;
    height: 13.25vw;
    background-size: 23px 23px;
  }

  .message__body {
    gap: 5%;
  }

  .message__body > div {
    max-width: 710px;
  }

  .message__heading-block {
    top: -80px;
  }

  .message__heading-block > h2 {
    gap: 20px;
  }

  .message__contents {
    gap: 40px;
    line-height: 2.5;
    letter-spacing: 0.07rem;
  }

  .message__contents > figure {
    width: 60%;
    top: -5%;
    right: 0;
  }
  
}

@media all and (min-width: 1400px) {
  .message__contents > figure {
    width: 60%;
    top: -5%;
    left: 55%;
  }
}


/**************************************************************
* CONCEPT
**************************************************************/

.concept {
  position: relative;
}

.concept__body {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: 5.333%;
  margin-right: 5.333%;
  padding-left: 5.333%;
  padding-right: 5.333%;
  color: #ffffff;
  background-color: var(--wp--preset--color--primary);
}

.concept__body * + * {
  margin-top: 30px;
}

.concept__body .wp-block-heading {
  color: #ffffff;
}

.concept__visual {
  position: absolute !important; /* //FIXME */
  z-index: 9;
}
  
  /* //MEMO refactor core/cover remove the min-height ? */
.concept__visual .wp-block-cover, .wp-block-cover-image {
  min-height: 100%;
}

.concept__visual[class*="--1"] {
  top: 0;
  left: 0;
  width: 56.25vw;
  height: 18.75vw;
}
.concept__visual[class*="--2"] {
  bottom: 0;
  left: 3.125%;
  width: 20vw;
  height: 32vw;
}
.concept__visual[class*="--3"] {
  bottom: 0;
  right: 9.125%;
  width: 15.625vw;
  height: 15.625vw;
  aspect-ratio: 1/1;
}

.concept::before {
  content: "";
  position: absolute;
  z-index: 1;
  background-image: radial-gradient(var(--wp--preset--color--inverted-foreground) 15%, transparent 15%);
  background-size: 16px 16px;
}

.concept-heading {
  margin-bottom: clamp(40px, calc(2.5rem + ((1vw - 3.2px) * 1)), 60px);
  margin-left: auto;
  margin-right: auto;
}
.concept-heading > p {
  letter-spacing: 0.05rem;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(16px, calc(1rem + ((1vw - 3.2px) * 0.4)), 20px);
}

.concept-heading > h2 {
  margin-top: 10px;
  font-size: clamp(20px, calc(20px + (28 * ((100vw - 375px) / 1545))), 48px);
}

.concept__body .wp-block-group > div > p {
  margin-left: auto;
  margin-right: auto;
  letter-spacing: 0.1rem;
  line-height: 2;
  font-size: clamp(13px, calc(13px + (3 * ((100vw - 375px) / 1545))), 16px);
}

.concept__body .wp-block-group > div > p + p {
  margin-top: clamp(20px, calc(1.25rem + ((1vw - 3.2px) * 0.625)), 30px);
}

.concept__body .wp-block-buttons {
  margin-top: clamp(40px, calc(2.5rem + ((1vw - 3.2px) * 2)), 80px);
}

.concept__body  .wp-block-buttons .wp-block-button > .wp-block-button__link {
  width: clamp(300px, calc(300px + (28 * ((100vw - 375px) / 1545))), 328px);
  height: clamp(60px, calc(60px + (4 * ((100vw - 375px) / 1545))), 64px);
  font-size: 20px;
}


@media all and (max-width: 1023px) {
  .concept {
    position: relative;
    padding-top: 10.5%;
    padding-bottom: 25%;
    margin-bottom: 16%;
  }
  .concept::before {
    top: 2%;
    left: 5%;
    width: 30.5vw;
    height: 30.5vw;
  }
  .concept__visual[class*="--1"] {
    top: -1%;
    width: 80vw;
    height: 26.5vw;
  }
  .concept__visual[class*="--2"] {
    left: 0;
    width: 30vw;
    height: 49.25vw;
}
  .concept__visual[class*="--3"] {
      bottom: 5%;
      right: 0;
      width: 26.65vw;
      height: 26.65vw;
  }

  .concept__body {
    padding-top: 25%;
    padding-bottom: 40%;
  }

  .concept-heading {
    width: 95%;
  }

  .concept-heading > h2 {
    letter-spacing: 0.15rem;
  }

}

@media all and (min-width: 1024px) {
  .concept {
    padding-top: 10%;
    padding-bottom: 10.5%;
  }
  .concept::before {
    top: 18%;
    left: 5.5%;
    width: 13.25vw;
    height: 13.25vw;
    background-size: 23px 23px;
  }
  .concept__body {
    min-height: 1000px; /* //FIXME */
  }

  .concept__body .wp-block-group {
    max-width: 1100px;
    padding-top: 6rem;
  }

  .concept-heading {
    width: 100%;
  }

  .concept-heading > h2 {
    letter-spacing: 0.2rem;
  }

  .concept-heading > h2 > br {
    display: none;
  }

  .concept__body .wp-block-group > div > p {
    width: 65%;
  }

  .concept__body .wp-block-buttons > .wp-block-button{
    flex-basis: 30%;
    font-size: 20px;
  }  
}


/**************************************************************
* WORK
**************************************************************/

.work {
  position: relative;
  overflow: hidden;
  width: 100%;
}

.work__body {
  display: grid;
  gap: 0;
}

.work__contents {
  position: relative;
  display: flex;
  flex-flow: column;
  justify-content: center;
}

.work__visuals {
  display: flex;
  gap: 3%;
}

.work-visual {
  flex: 1 1 33.333%;
}
.work-visual[class*="--1"] {
  align-self: flex-start;
}
.work-visual[class*="--2"] {
  align-self: center;
}
.work-visual[class*="--3"] {
  align-self: flex-end;
}
  
/* //MEMO refactor core/cover remove the min-height ? */
.work-visual .wp-block-cover, .wp-block-cover-image {
  min-height: 100%;
}

.work__contents > .segment-heading {
  margin-bottom: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
}

.work__contents> p {
  line-height: 2;
  letter-spacing: 0.1rem;
  font-size: clamp(13px, calc(13px + (3 * ((100vw - 375px) / 1545))), 16px);
}

.work__body .wp-block-buttons {
  margin-top: clamp(40px, calc(2.5rem + ((1vw - 3.2px) * 2)), 80px);
}

.work__body .wp-block-buttons .wp-block-button > .wp-block-button__link {
  width: clamp(300px, calc(300px + (28 * ((100vw - 375px) / 1545))), 328px);
  height: clamp(60px, calc(60px + (4 * ((100vw - 375px) / 1545))), 64px);
  font-size: 20px;
}

.work  .horizontal-ticker span {
  display: inline-block;
}

.instagram  .wp-block-button >　.wp-block-button__link {
  width: clamp(300px, calc(300px + (28 * ((100vw - 375px) / 1545))), 328px);
  height: clamp(60px, calc(60px + (4 * ((100vw - 375px) / 1545))), 64px);
  font-size: 20px;
}

@media all and (max-width: 1023px) {
  .work {
    padding-top: 16%;
    padding-bottom: 16%;
  }

  .work__contents {
    margin-left: 10.666%;
    margin-right: 10.666%;
    padding-top: 12%;
  }

  .work__contents > .segment-heading {
    text-align: center;
  }

  .work__visuals {
    height: 300px;
    gap: 15px;
  }

  .work-visual {
    height: 210px;
  }

  .work__body .wp-block-buttons{
    margin-bottom: 60px;
  }

  .work-visual[class*="--1"],
  .work-visual[class*="--2"],
  .work-visual[class*="--3"] {
    height: 62vw;
  }
}

@media all and (min-width: 1024px) {
  .work {
    padding-top: 15%;
    padding-bottom: 12%;
  }

  .work__body {
    display: grid;
    grid-template-columns: 36.25% 1fr;
    align-items: baseline;
    gap: 8.25%;
    margin-left: 8.33%; /* //MEMO 160px (1fst margin guide line XD) */
    margin-right: 8.33%;
  }

  .work__visuals {
    height: clamp(650px, calc(37.5vw + 70px), 830px);
  }

  .work-visual {
    height: 29.25vw;
  }

  .work__body .wp-block-buttons {
    justify-content: flex-end;
  }
  .work__body .wp-block-buttons > .wp-block-button {
    flex-basis: 30%;
    min-width: 300px;
  }
}
  


/**************************************************************
* JOB
**************************************************************/

.job {
  position: relative;
  padding-top: 6%;
}

.job .segment-heading {
  margin-bottom: clamp(40px, calc(2.5rem + ((1vw - 3.2px) * 2)), 80px);
  text-align: center;
}

.job-features {
  margin-left: 5.333%;
  margin-right: 5.333%;
}

.job-feature-item {
  position: relative;
}

.job-feature-item__title {
  position: relative;
  display: block;
  margin-bottom: 20px;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-weight: bolder;
  font-size: clamp(20px, 2rem + ((1vw - 5.8px) * 5), 80px);
  letter-spacing: 0.05em;
  -webkit-text-stroke-width: 0.5px;
  -webkit-text-stroke-color: #ffffff;
  color: transparent !important; /* //FIXME */
  line-height: 1;
  white-space: normal;
}

.job-feature-item__details {
  padding-top: clamp(30px, calc(1.875rem + ((1vw - 3.2px) * 3.4)), 64px);
  padding-bottom: clamp(30px, calc(1.875rem + ((1vw - 3.2px) * 3.4)), 64px);
  padding-left: clamp(20px, calc(1.25rem + ((1vw - 3.2px) * 2.8)), 48px);
  padding-right: clamp(20px, calc(1.25rem + ((1vw - 3.2px) * 2.8)), 48px);
  background-color: #ffffff;
}

.job-feature-item__details > h3 {
  display: inline-block;
  margin-bottom: 20px;
  padding-left: 5%;
  padding-right: 5%;
  font-size: clamp(20px, calc(1.25rem + ((1vw - 3.2px) * 1.5)), 40px);
  line-height: 1.5; 
  letter-spacing: 0.15rem;
  background-color: var(--wp--preset--color--foreground);
}

.job-feature-item__details > p {
  line-height: 2;
  letter-spacing: 0.1rem;
  font-size: clamp(13px, calc(13px + (3 * ((100vw - 375px) / 1545))), 16px);
}

.job-feature-item__box {
  padding-top: 5%;
  padding-bottom: 5%;
}
  
  /* remove the min-height ? */
.job-feature-item__fig .wp-block-cover, .wp-block-cover-image {
  min-height: 100%;
}

.job-bottom-catch {
  position: relative;
  overflow: hidden;
  padding-top: clamp(70px, calc(4.375rem + ((1vw - 3.2px) * 5)), 120px);
  padding-bottom: clamp(100px, 3rem + ((1vw - 3.2px) * 15), 400px);
}

.job-bottom-catch::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 10%;
  width: 13.25vw;
  height: 13.25vw;
  z-index: -1;
  background-image: radial-gradient(var(--wp--preset--color--secondary) 15%, transparent 15%);
  background-size: 16px 16px;
}

.job-bottom-catch__inner {
  position: relative;
  display: flex;
  justify-content: flex-end;
}

.job-bottom-catch__body {
  position: relative;
  /* //MEMO shared margin changed to css vars? */
  /* padding-left: 8.33%;  */
  /* padding-left: 12.5%; */
}

.job-bottom-catch__text {
  position: relative;
  display: flex;
  align-items: center;
  max-width: 440px;
  font-size: clamp(32px, calc(2rem + ((1vw - 8.2px) * 2.25)), 56px);
  font-weight: bolder;
  color: var(--wp--preset--color--foreground);
  line-height: 1.5;
  z-index: 99;
}

.job-bottom-catch__text::before {
  content: "";
  position: absolute;
  top: -20px;
  left: -14%;
  width:clamp(29px, calc(29px + (58 - 29) * ((100vw - 375px) / (1920 - 375))), 58px);
  height: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  background-image: url(/themes-imagery/jobdraft-bplan/quotation_mark_bg.svg);
  background-repeat: no-repeat;
  background-size: cover;
}

.job-bottom-visuals {
  position: relative;
  display : grid;
  grid-template-columns : repeat(2, 1fr);
  grid-template-rows : repeat(2, 1fr);
  grid-column-gap : 0px;
  grid-row-gap : 0px;
}

.job-bottom-visual[class*="--1"] {
  grid-area: 1 / 1 / 3 / 2;
  width: 33.33vw;
  height: 33.33vw;
}
.job-bottom-visual[class*="--2"] {
  position: absolute;
  bottom: -3vw;
  right: 0;
  grid-area: 1 / 2 / 2 / 3;
  width: 18vw;
  height: 18vw;
} 
.job-bottom-visual[class*="--3"] {
  position: absolute;
  bottom: -4vw;
  right: 8.5vw;
  grid-area: 2 / 2 / 3 / 3;
  width: 12.5vw;
  height: 12.5vw;
}
  
  /* //MEMO remove the min-height ? */
.job-bottom-visual .wp-block-cover,
.job-bottom-visual .wp-block-cover-image {
  min-height: 100%;
}
  
.job-bottom-catch .horizontal-ticker > span {
  top: clamp(0px, calc((20 / 1545) * (100vw - 375px)), 20px);
}

@media all and (max-width: 1550px) {
  .job-feature-item__box {
    padding: 12% 5.33%;
  }

  .job-feature-item__title {
    line-height: 1.2;
    letter-spacing: 0.1em;
  }

  .job-feature-item__fig {
    aspect-ratio: 4 / 3;
    clip-path: polygon(0 0, 90% 0, 100% 15%, 100% 100%, 0 100%);
    margin-bottom: 20px;
  }

  .job-bottom-catch__inner {
    flex-flow: column;
    align-items: center;
    gap: 50px;
  }

  .job-bottom-catch__body {
    padding: 0;
  }

  .job-bottom-catch__text {
    width: 100%;
    max-width: inherit;
    margin-left: 5.333%;
    margin-right: 5.333%;
  }

  .job-bottom-visual[class*="--1"] {
    width: 57.75vw;
    height: 57.75vw;
    transform: translateX(0);
  }

  .job-bottom-visual[class*="--2"] {
    bottom: -5vw;
    width: 30.5vw;
    height: 30.5vw;
  } 

  .job-bottom-visual[class*="--3"] {
    bottom: -6vw;
    right: 13vw;
    width: 21.5vw;
    height: 21.5vw;
  }

  .job-bottom-catch::before {
    top: 0;
    left: 0;
    width: 30.5vw;
    height: 30.5vw;
  }

  .job-bottom-catch__text {
    letter-spacing: 0.05em;
    
  }

  .job-bottom-visual[class*="--1"] {
    transform: translateX(0);
  }

}
@media all and (min-width: 1550px) {
  .job-feature-item__box {
    display: grid;
    grid-template-columns: 640px 1fr;
  }

  .job-feature-item__body {
    position: relative;
    bottom: 30px;
    left: -10vw;
    align-self: flex-end;
    direction: ltr;
    max-width: 100%;
  }

  .job-feature-item:nth-child(even) .job-feature-item__box {
    position: relative;
    grid-auto-flow: column; /* specify the flow direction */
    direction: rtl; /* reverse the direction */
  }
  
  .job-feature-item:nth-child(even) .job-feature-item__body {
    left: inherit;
    right: -22vw;
  }

  .job-feature-item:nth-child(odd) .job-feature-item__title {
    max-width: 100%;
    text-align: right;
  }

  .job-feature-item__fig {
    aspect-ratio: 1 / 1;
    clip-path: polygon(0 0, 87% 0, 100% 13%, 100% 100%, 0 100%);
    margin-bottom: 0;
  }

  .job-feature-item__title {
    -webkit-text-stroke-width: 2px;
  }

  .job-bottom-catch__body {
    display: flex;
    align-items: center;
    padding-top: 3vw;
  }

  .job-bottom-catch::before {
    top: 0;
    left: 0;
    right: inherit;
    bottom: inherit;
    width: 13.25vw;
    height: 13.25vw;
    background-size: 23px 23px;
  }

  .job-bottom-catch__text {
    letter-spacing: 0.1em;
  }

  .job-bottom-visuals {
    width: 63%;
  }

  .job-bottom-visual[class*="--1"] {
    position: relative;
    left: 5vw;
  }
}

@media all and (min-width: 1250px) {
  .job-feature-item:nth-child(odd) .job-feature-item__body {
    left: -50px;
  }
  .job-feature-item:nth-child(even) .job-feature-item__body {
    right: -50px;
  }
}









/**************************************************************
* INTERVIEW
**************************************************************/

.interview {
  position: relative;
  padding-top: clamp(56px, 8vw, 112px);
  padding-bottom: clamp(60px, 10vw, 120px);
  background: #f0f0e7; /* //TODO change to cover? or add backround functionalities to Generic Div Block??　*/
  color: var(--wp--preset--color--foreground);
}

.interview .segment-heading {
  margin-bottom: 80px;
  text-align: center;
}

.interview__body {
  position: relative;
}

.interview-entry {
  display: grid;
  align-items: center;
  counter-increment: interview-entry-counter;
  margin-top: 16%;
}

.interview-entry:first-child {
  margin-top: 0;
}

.interview-entry__fig {
  position: relative;
  overflow: inherit;
  min-height: auto;
}

.interview-entry__fig::before {
  content: 'interview ' counter(interview-entry-counter, decimal-leading-zero);
  display: block;
  font-size: clamp(12px, 0.75rem + ((1vw - 3.2px) * 0.765), 20px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  letter-spacing: 0.05em;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 99;
  writing-mode: vertical-rl;
  text-transform: uppercase;
  color: var(--wp--preset--color--primary);
  transform: translateX(110%);
  font-weight: bolder;
}

.interview-entry__fig img {
  object-position: left top;
}

/* //MEMO remove the min-height ? */
.interview-entry__fig .wp-block-cover,
.interview-entry__fig .wp-block-cover-image {
  min-height: 100%;
}

.interview-entry__fig-catch {
  position: absolute;
  bottom: clamp(20px, 5vw, 32px);
  right: clamp(-18px, 4vw, -26px);
  direction: ltr;
  text-align: end;
}
.interview-entry__fig-catch > p {
  display: table;
  margin-left: auto;
  padding: clamp(4px, 1vw, 8px) clamp(12px, 2vw, 24px);
  line-height: 1.45;
  font-size: 20px;
  background-color: #ffffff;
  color: var(--wp--preset--color--foreground);
  letter-spacing: 0.1em;
}
.interview-entry__fig-catch > p + p {
  margin-top: clamp(4px, 1vw, 8px);
}

.interview-entry__data {
  position: relative;
  align-self: center;
  padding-top: clamp(30px, 5vw, 80px);
  padding-bottom: clamp(30px, 5vw, 80px);
  padding-left: clamp(20px, 5vw, 80px);
  padding-right: clamp(20px, 5vw, 80px);
  background-color: #ffffff;
  direction: ltr;
  letter-spacing: 0.1em;
}

.interview-entry__data::after {
  content: "";
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  height: calc(44px / 2);
  width: 44px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  background-color: #ffffff;
}

.interview-entry .wp-block-heading {
  font-size: 20px;
  text-transform: uppercase;
  color: var(--wp--preset--color--foreground);
}

.interview-entry .wp-block-group p {
  font-size: 12px;
  margin-top: 8px;
}

.interview-entry .wp-block-group p span {
  display: inline-block;
  padding: 6px 8px;
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--inverted-foreground);
  background-color: var(--wp--preset--color--foreground);
}

.interview-entry .wp-block-group p span:last-child {
  margin-top: 4px;
}

.interview-entry__data p {
  font-size: clamp(13px, calc(13px + (16 - 13) * ((100vw - 375px) / (1920 - 375))), 16px);
  margin-top: clamp(20px, 2.5vw, 32px);
}

.interview-entry__data p + p {
  margin-top: clamp(20px, 2.5vw, 32px);
}

@media all and (max-width: 1023px) {
  .interview-entry__data {
    margin-top: 11.5%;
    margin-left: 10%;
    margin-right: 10%;
  }

  .interview-entry__fig {
    margin-left: auto;
    margin-right: auto;
    width: clamp(300px,50vw,550px);
    height: clamp(400px,70vw,733px);
  }
}

@media all and (min-width: 1024px) {
  .interview__body {
    padding-left: 5.33%;
    padding-right: 5.33%;
  }
  .interview-entry {
    grid-template-columns: 28.5% 1fr;
    gap: 7%;
    margin-top: 2.3%;
  }

  .interview-entry__data::after {
    top: 50%;
    left: -23px;
    transform: translateY(-50%);
    height: calc(54px / 2);
    width: 23px;
    clip-path: polygon(0 50%, 100% 0, 100% 100%);
    background-color: #ffffff;
  }

  .interview-entry:nth-child(even) {
    grid-auto-flow: column; /* specify the flow direction */
    direction: rtl; /* reverse the direction */
  }
  .interview-entry:nth-child(even) .interview-entry__fig {
    margin-right: 7.5%;
  }

  .interview-entry:nth-child(even) .interview-entry__data::after{
    top: 50%;
    left: auto;
    right: -23px;
    transform: translateY(-50%);
    height: calc(54px / 2);
    width: 23px;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    background-color: #ffffff;
  }

  .interview-entry__fig {
    width: min(28vw,382px);
    height: clamp(450px,30vw,580px);
  }
}



/**************************************************************
* INSTAGRAM
**************************************************************/

.instagram {
  position: relative;
  z-index: 0;
  padding-top: 15%;
  padding-bottom: 15%;
  overflow: hidden;
  background-color: var(--wp--preset--color--secondary-background);
}

.instagram .horizontal-ticker > span {
  top: -5vw;
}

.instagram .wp-block-button > .wp-block-button__link {
  width: clamp(300px, calc(300px + (28 * ((100vw - 375px) / 1545))), 328px);
  height: clamp(60px, calc(60px + (4 * ((100vw - 375px) / 1545))), 64px);
  font-size: 20px;
}

@media all and (min-width: 320px) and (max-width: 374px) {
  .instagram .horizontal-ticker > span {
    top: -3vw;
  }
}

@media all and (max-width: 767px) {
  .instagram .wp-block-buttons {
    padding-left: 8%;
    padding-right: 8%;
  }

  .instagram .wp-block-button,
  .instagram .wp-block-button .wp-block-button__link {
    display: block;
    width: 100%;
  }
}

@media all and (min-width: 768px) {
  .instagram {
    padding-top: 8%;
    padding-bottom: 5%;
    padding-left: 5.333%;
    padding-right: 5.333%;
  }
}

/* instagram-gallery
********************************/
.instagram-gallery {
  display: flex;
  flex-wrap: wrap;
  list-style: none; /* //FIXME add to rest */
  margin-bottom: 40px;

}

.instagram-gallery__item {
  flex: 0 0 50%;
  transition: opacity 0.3s ease;
}

/* //FIXME add to rest */
.instagram-gallery__item > a img {
  max-width: 100%;
  height: auto;
  display: block;
}


.instagram-gallery__item:nth-child(1) {
  order: 2;
}

.instagram-gallery__item:nth-child(2) {
  order: 3;
}

.instagram-gallery__item:last-child {
  order: 1;
}

.instagram-gallery__item:nth-child(3) {
  order: 4;
}

.instagram-gallery__item:nth-child(4) {
  order: 5;
}

.instagram-gallery__item:nth-child(5) {
  order: 6;
}

.instagram-gallery__item:nth-child(6) {
  order: 7;
}

.instagram-gallery__item:nth-child(7) {
  order: 8;
}

.instagram-gallery__item:nth-child(8) {
  order: 9;
}

.instagram-gallery__item:nth-child(9) {
  order: 10;
}

.instagram-gallery__item > a img {
  aspect-ratio: 1 / 1;
}

.instagram-gallery__item[class*="--cover-item"] {
  overflow: hidden;
  pointer-events: none;
}

.instagram-gallery__item[class*="--cover-item"] a {
  position: relative;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
  background: var(--wp--preset--color--primary);
}

.instagram-gallery__item[class*="--cover-item"] a::before,
.instagram-gallery__item[class*="--cover-item"] a::after {
  content: "";
  position: relative;
  display: block;
}

.instagram-gallery__item[class*="--cover-item"] a::before {
  content: "Instagram";
  margin-bottom: calc(5/16 * 1rem);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: 112.5%;
  font-weight: bold;
  color: #ffffff;
}

.instagram-gallery__item[class*="--cover-item"] a::after {
  width: calc(30/16 * 1rem);
  height: calc(30/16 * 1rem);
  background-repeat: no-repeat;
  background-position: center 0;
  background-size: contain;
  background-image: url(/themes-imagery/jobdraft-bplan/instagram_icn.svg);
}

@media all and (max-width: 767px) {
  .instagram-gallery {
    padding-left: 5%;
    padding-right: 5%;
  }
}

@media all and (min-width: 768px) {
  .instagram-gallery__item {
    flex: 0 0 20%;
  }

  .instagram-gallery__item[class*="--cover-item"] a::after {
    width: calc(35/16 * 1rem);
    height: calc(35/16 * 1rem);
  }

  .instagram-gallery__item:nth-child(1) {
    order: 1;
  }
  
  .instagram-gallery__item:nth-child(2) {
    order: 2;
  }
  
  .instagram-gallery__item:last-child {
    order: 3;
  }
  
  .instagram-gallery__item:nth-child(3) {
    order: 4;
  }
  
  .instagram-gallery__item:nth-child(4) {
    order: 5;
  }
  
  .instagram-gallery__item:nth-child(5) {
    order: 6;
  }
  
  .instagram-gallery__item:nth-child(6) {
    order: 7;
  }
  
  .instagram-gallery__item:nth-child(7) {
    order: 8;
  }
  
  .instagram-gallery__item:nth-child(8) {
    order: 9;
  }
  
  .instagram-gallery__item:nth-child(9) {
    order: 10;
  }
}

/* animations */
.instagram-gallery__item {
  opacity: 0;
}

/* hover */
@media (hover: hover) {
  .instagram-gallery__item[class*="--cover-item"] a {
    transition: transform 0.3s ease-out;
    will-change: transform;
  }

  .instagram-gallery__item[class*="--cover-item"] a:hover {
    transform: scale3d(1.1, 1.1, 1);
    opacity: inherit;
  }

  .instagram-gallery__item a:hover {
    opacity: 1;
    filter: brightness(1.1);
  }
}


/**************************************************************
* DATA
**************************************************************/

.data {
  position: relative;
  padding-top: 16%;
  padding-bottom: 10%;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px)),
  linear-gradient(90deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px));
  background-size: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px) clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px);
  background-repeat: repeat;
  background-position: top left;
}

.data .segment-heading {
  margin-bottom: 80px;
  text-align: center;
}

 /* //FIXME: fix for Grid plugin on frontend and backend change to an other layout plugin? or in house markup */
.editor-styles-wrapper .grids-areas-wrapper {
  margin-bottom: 100px;
}

.data-entries {
  display: grid;
  gap: 2.5rem;
}


.data-entry {
  --x-width: 30px;
  --x-height: 24px;
  position: relative;
  display: flex;
  flex-flow: column;
  align-items: baseline;
  width: 100%;
  height: 100%;
}
/* .data-entry::before {
  content: "";
  position: absolute;
  top: -2px;
  right: -2px;
  z-index: 0;
  display: block;
  width: 33px;
  height: 33px;
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 0%);
  background-color: var(--wp--preset--color--primary);
} */

.data-entry ul > li {
  font-size: clamp(20px, 1.5rem + ((1vw - 3.2px) * 0.75), 32px);
  font-weight: bold;
  line-height: 1.5;
}

.data-entry__body {
  position: relative;
  /* width: calc(100% - 20px); */
  width: 100.1%;
  height: 100%;
  box-sizing: border-box;
  border: 3px solid var(--wp--preset--color--primary);
  box-shadow: 4px 4px 0 0 var(--wp--preset--color--primary);
  clip-path: polygon(0 0, calc(100% - var(--x-width)) 0, 100% var(--x-width), 100% 100%, 0 100%, 0 var(--x-width));
  background-color: #ffffff;
}

.data-entry__body::before {
  content: "";
  position: absolute;
  top: -2px;
  right: -2px;
  z-index: 0;
  display: block;
  width: 33px;
  height: 33px;
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 0%);
  background-color: var(--wp--preset--color--primary);
}

.data-entry__label {
  display: inline-block;
  padding-bottom: 0.5rem;
  font-size: clamp(14px, 1rem + ((1vw - 3.2px) * 0.5), 25px);
  letter-spacing: 0.1em;
  border-bottom: 3px solid currentColor;
}

.data-entry__flex-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  height: 80%;
}

.data .kt-inside-inner-col {
  height: 100%;
}

.data-entry__countup {
  position: relative;
}

.data-entry__countup .value {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(60px, calc(60px + (100 - 60) * ((100vw - 375px) / (1920 - 375))), 100px);
  font-weight: bolder;
  line-height: 1;
  letter-spacing: 0em;
  color: var(--wp--preset--color--primary);
}

.data-entry__countup .prefix {
  display: block;
  margin-bottom: 0.8rem;
  font-family: var(--wp--preset--font-family--kana-font);
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0;
  color: var(--wp--preset--color--foreground);
}

.data-entry__countup .suffix {
  font-family: var(--wp--preset--font-family--kana-font);
  font-size: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  font-weight: bold;
  color: var(--wp--preset--color--foreground);
}

.data-entry__countup .sr-value {
  display: none;
}

.data-entry .data-double-separator {
  font-size: 40px;
  font-weight: bold;
  padding-left: 1rem;
  padding-right: 1rem;
}

.data-entry__icn .wp-block-boldblocks-svg-block {
  height: 100%;
  width: 100%;
}

/* //MEMO: not use currently but kept here for references */
.data-entry__icn[class*="--calendar"]  {background-image: url(/themes-imagery/jobdraft-bplan/data_01_icn.svg);}
.data-entry__icn[class*="--buildings"] {background-image: url(/themes-imagery/jobdraft-bplan/data_02_icn.svg);}
.data-entry__icn[class*="--gender"]    {background-image: url(/themes-imagery/jobdraft-bplan/data_03_icn.svg);}
.data-entry__icn[class*="--briefcase"] {background-image: url(/themes-imagery/jobdraft-bplan/data_04_icn.svg);}
.data-entry__icn[class*="--checkbox"]  {background-image: url(/themes-imagery/jobdraft-bplan/data_05_icn.svg);}

@media all and (max-width: 1023px) {
  .data-entries {
    padding-left: 5.333%;
    padding-right: 5.333%;
  }

  .data-entry__body {
    padding-top: 20px;
    padding-bottom: 20px;
    padding-left: 20px;
    padding-right: 20px;
  }
}


@media all and (min-width: 1024px) {
  .data {
    padding-top: 5%;
    padding-bottom: 5%;
  }

  .data-entry {
    --x-width: 60px;
    --x-height: 48px;
    border-width: 5px;
    /* box-shadow: 8px 8px 0 0 var(--wp--preset--color--primary); */
  }
  .data-entry::before {
    width: 61px;
    height: 61px;
  }

  .data-entry__flex-wrapper {
    padding-bottom: 5rem;
  }

  .data-entry__body {
    /* width: calc(100% - 90px); */
    min-height: 280px; /* //FIXME */
    padding: 40px;
  }
  .data-entry__body::before {
    width: 61px;
    height: 61px;
  }
}

@media (min-width: 768px) and (max-width: 1100px) {
  .data-entries {
    max-width: 800px;
    width: 80%;
    margin: auto;
  }

  .data-entries .grids-section {
    display: block;
  }

  .data-entries .grids-s-w_i {
    display: block;
  }

  .data .data-entries .grids-s-w_i {
    margin-bottom: 12px;
  }
}

@media (max-width: 1100px) {
  .data .kt-row-column-wrap {
    grid-template-columns: minmax(0, 1fr) !important;
    row-gap: 2rem !important;
  }

  .data-entry__flex-wrapper {
    padding-bottom: 5rem;
  }
}

@media (min-width: 768px) and (max-width: 1400px) {
  .data-entries {
    padding-left: 5%;
    padding-right: 5%;
  }
}



/**************************************************************
* BENEFITS
**************************************************************/
.benefits {
  letter-spacing: 0.1em;
  padding-top: clamp(45px, 5vw, 90px);
  padding-bottom: clamp(60px, 10vw, 120px);
  background: var(--wp--preset--color--secondary-background);
}

.benefits .wp-block-cover {
  position: relative;
  width: clamp(300px, 35vw, 580px);
  min-height: clamp(225px, 45vw, 773px);
  overflow: visible;
  margin-top: 8%;
}

.benefits .wp-block-cover::before {
  content: "";
  position: absolute;
  left: -13%;
  top: -17%;
  width: 30.5vw;
  height: 30.5vw;
  z-index: 0;
  background-image: radial-gradient(var(--wp--preset--color--secondary) 15%, transparent 15%);
  background-size: 16px 16px;
}

.benefits .segment-heading > h2 {
  margin-bottom: clamp(16px, 4vw, 32px);
}

.benefits .wp-heading {
  color: var(--wp--preset--color--foreground);
}

.benefits__body {
  position: relative;
}

.benefits h3 {
  font-size: clamp(16px, 2vw, 20px)!important;
  border-bottom: 1px solid var(--wp--preset--color--primary);
  margin-top: clamp(32px, 4vw, 64px);
  padding-bottom: clamp(4px, 1vw, 8px);
  color: var(--wp--preset--color--foreground)!important;
}

.benefits__list {
  margin-top: clamp(16px, 2vw, 32px);
  font-size: clamp(13px, calc(0.8125rem + ((1vw - 3.2px) * 0.25)), 16px);
  font-weight: bold;
  letter-spacing: 0.05em;
}

.benefits__list li {
  position: relative;
  padding-left: 0.7em;
  margin-left: clamp(5px, calc(5px + (10 - 5) * ((100vw - 375px) / (1920 - 375))), 10px);
  line-height: 2;
} 

.benefits__list li::before {
  content: '•';
  position: absolute;
  top: -3px;
  left: 0;
  text-indent: 0;
  font-size: 15px;
}

.benefits__list li::marker{
  margin-right: -0.5em;
} 

.benefits h3:nth-child(3) {
  margin-top: clamp(40px, 5vw, 80px);
}

@media all and (max-width: 1023px) {
  .benefits .segment-heading {
    text-align: center;
  }

  .benefits .has-text-align-left{
    text-align: center;
  }

  .benefits__body {
    flex-direction: column-reverse;
    padding-right: 10%;
    padding-left: 10%;
  }

  .benefits__body > div {
    max-width: 500px;
    width: 100%;
  }

  .benefits .wp-block-cover {
    margin-top: 21.5%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media all and (min-width: 1024px) {
  .benefits .wp-block-cover::before {
    left: -18%;
    top: -10%;
    width: 13.25vw;
    height: 13.25vw;
    background-size: 23px 23px;
  }

  .benefits .wp-block-group.is-layout-constrained.wp-block-group-is-layout-constrained {
    margin-left: 8.333%;
    margin-right: 8.333%;
  }

  .benefits__body.is-layout-flex {
    flex-wrap: nowrap;
    gap:min(11vw, 214px);
    align-items: start;
    justify-content: flex-start;
  }

  .benefits__body > div:last-child {
    width: 43.2%;
  }

  .benefits .has-text-align-left br {
    display: none;
  }

  .benefits__list {
    column-count: 2;
  }

  .benefits__list li::before {
    top: 0px;
  }
}



/**************************************************************
* NEWS
**************************************************************/

.news {
  padding-top: 16%;
  padding-bottom: 16%;
}

.news__body > div:nth-child(2) {
  flex: 0 0 73%;
  min-height: 200px;
}

.news__body.is-layout-flex {
  gap: 11.4%;
  align-items: start;
  padding-left: 5%;
  padding-right: 5%;
}

.news__body .segment-heading > p, .news__body .segment-heading > h2  {
  text-align: left;
}

.news-list li{
  border-bottom: 1px solid #E8E7E5;
}

.news-list li:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.news-item {
  margin-block-start: 0;
  margin-block-end: 0;
  font-weight: bold;
}

.news-item:first-child {
  margin-top: 0;
}

.news-item dt {
  display: flex;
  align-items: center; 
  letter-spacing: 0.1em;
  line-height: 2;
  font-size: clamp(16px, calc(16px + (4 * ((100vw - 375px) / 1545))), 20px);
}


.news-item dd dl {
  margin-block-start: 0;
  margin-block-end: 0;
}

.news-item__category {
  display: inline-block;
  color: var(--wp--preset--color--inverted-foreground);
  background-color: var(--wp--preset--color--foreground);
  padding-top: 1%;
  padding-bottom: 1%;
  line-height: 1;
  max-width: 64px;
  width: 100%;
  text-align: center;
  font-size: 12px;
}

.news-item__category.new-recruit {
  background-color: var(--wp--preset--color--primary);
}

.news-item__category.event {
  background-color: var(--wp--preset--color--foreground);
}

.news-item__category.carrer {
  background-color: var(--wp--preset--color--secondary);
}


.news-item dd {
  margin-inline-start: 0;
}

.news-item dd .news-item__title {
  font-size: clamp(14px, calc(14px + (18 - 14) * ((100vw - 375px) / (1920 - 375))), 18px);
}

.news-item dd dl dd {
  margin-top: clamp(12px, 3vw, 17px);
  font-size: clamp(13px, calc(13px + (16 - 13) * ((100vw - 375px) / (1920 - 375))), 16px);
}

@media all and (max-width: 1123px) {
  .news .segment-heading {
    text-align: center;
  }

  .news__body .segment-heading > p, .news__body .segment-heading > h2 {
    text-align: center;
  }

  .news__body.is-layout-flex {
    display: block;
    padding-right: 10%;
    padding-left: 10%;
  }

  .news-list {
    margin-top: 10%;
  }

  .news-list li{
    padding-top: 7%;
    padding-bottom: 7%;
  }

  .news-item__category {
    margin-left: 5%;
  }

  .news-item dd {
    margin-top: 5%;
  }
}

@media all and (min-width: 1124px) {
  .news {
    padding-top: 6.3%;
    padding-bottom: 6.3%;
  }

  .news-list li {
    padding-top: 3.5%;
    padding-bottom: 3.5%;
  }

  .news-list li:first-child {
    padding-top: 0;
  }

  .news-item {
    display: flex;
    align-items: start;
    gap: 3%;
  }

  .news-item dt {
    width: 30%;
  }

  .news-item__category {
    max-width: 115px;
    padding-top: 2.3%;
    padding-bottom: 2.3%;
    margin-left: 13%;
    padding-left: 2px;
    padding-right: 2px;
  }

  .news-item dd {
    width: 63%;
  }

  .news-item dd dl dt {
    width: 100%;
  }

  .news-item dd dl dd {
    width: 100%;
  }
}





/*============================================================
* ABOUTページ
============================================================*/

/**************************************************************
* PHILOSOPHY
**************************************************************/
.philosophy {
  position: relative;
}

.philosophy > span {
  position: absolute;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(40px, calc(40px + (160 * ((100vw - 375px) / 1545))), 200px);
  -webkit-text-stroke-color: var(--wp--preset--color--secondary);
  color: transparent !important;
  line-height: 1;
  text-transform: uppercase;
  z-index: 9;
}

.philosophy__body {
  position: relative;
  display: flex;
  justify-content: flex-end;
  gap: 80px;
}

.philosophy__contents {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.philosophy__visuals {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 0px;
  grid-row-gap: 0px;
}

.philosophy-visual .wp-block-cover,
.philosophy-visual .wp-block-cover-image {
  min-height: 100%;
}

.philosophy-visual[class*="--1"] {
  grid-area: 1 / 1 / 3 / 2;
}

.philosophy-visual[class*="--2"] {
  position: absolute;
  bottom: 2vw;
  right: 0;
  grid-area: 2 / 2 / 3 / 3;
}

.philosophy__heading {
  margin-left: 10px;
  margin-bottom: clamp(40px, calc(2rem + ((1vw - 3.2px) * 2)), 80px);
}

.philosophy__heading > h3 {
  position: relative;
  font-size: clamp(32px, calc(32px + (24 * ((100vw - 375px) / 1545))), 56px);
  color: var(--wp--preset--color--foreground);
  letter-spacing: 0.2rem;
}

.philosophy__heading > p {
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(12px, calc(1rem + ((1vw - 12px) * 0.5)), 20px);
  color: var(--wp--preset--color--primary);
  letter-spacing: 0.05rem;
}

.philosophy__heading > h3::before {
  content: "";
  position: absolute;
  top: 0px;
  left: -20%;
  background-image: url(/themes-imagery/jobdraft-bplan/quotation_mark_bg.svg);
  background-repeat: no-repeat;
  background-size: cover;
  width: clamp(29px, calc(29px + (58 - 29) * ((100vw - 375px) / (1920 - 375))), 58px);
  height: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
}

.philosophy__contents > p {
  line-height: 2;
  letter-spacing: 0.05rem;
}

@media all and (max-width: 1023px) {
  .philosophy {
    margin-left: 0;
    margin-top: 10px;
    margin-bottom: 90px;
  }

  .philosophy > span {
    bottom: -3.5%;
    right: 2.5%;
    -webkit-text-stroke-width: 1.5px;
    letter-spacing: 0.15rem;
  }

  .philosophy__body {
    flex-direction: column;
  }

  .philosophy__body::after {
    bottom: 20%;
    right: 24%;
    width: 30vw;
    height: 30vw;
    background-size: 16px 16px;
  }

  .philosophy__heading > h3 {
    line-height: 1.5;
  }

  .philosophy__contents {
    width: inherit;
    padding: 0;
    margin-left: 10.666%;
    margin-right: 10.666%;
  }

  .philosophy-visual[class*="--1"] {
    width: 54.5vw;
    height: 54.5vw;
  }
  
  .philosophy-visual[class*="--2"] {
    width: 27.5vw;
    height: 21.5vw;
  }
}
@media all and (min-width: 1024px) {
  .philosophy {
    margin-left: 6%;
    /* margin-bottom: 270px; */
    margin-bottom: 5%;
  }

  .philosophy > span {
    bottom: -20%;
    right: 5%;
    -webkit-text-stroke-width: 2px;
    letter-spacing: 0.3rem;
  }
  .philosophy__heading > h3 {
    line-height: 2;
  }

  .philosophy__contents {
    width: 33vw;
    padding-top: 3vw;
    padding-bottom: 3vw;
    padding-left: 1.5vw;
  }

  .philosophy-visual[class*="--1"] {
    width: 31.5vw;
    height: 31.5vw;
  }
  
  .philosophy-visual[class*="--2"] {
    width: 15.9vw;
    height: 12.35vw;
  }
}

/**************************************************************
* GREETING
**************************************************************/
.greeting {
  margin-bottom: clamp(60px, calc(60px + (52 * ((100vw - 375px) / 1545))), 112px);
}

.greeting__inner {
  position: relative;
  max-width: var(--wp--style--global--content-size);
  margin-left: auto;
  margin-right: auto;
}

.greeting__visual {
  position: relative;
  margin-left: auto;
  z-index: 99;
}

.greeting__visual .wp-block-cover, .greeting__visual .wp-block-cover-image {
  position: relative;
  min-height: 100%;
  justify-content: flex-end;
  z-index: 9;
}

.greeting__heading-block {
  position: relative;
  display: flex;
  max-width: 700px;
}

.greeting__heading-block > h3 {
  position: absolute;
  display: flex;
  align-items: flex-start;
  flex-flow: column;
  gap: clamp(8px, calc(0.5rem + ((1vw - 3.2px) * 0.4)), 16px);
  font-size: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 40px);
}

.greeting__heading-block > h3 span {
  display: inline-block;
  padding-top: clamp(8px, calc(0.5rem + ((1vw - 3.2px) * 0.4)), 16px);
  padding-bottom: clamp(8px, calc(0.5rem + ((1vw - 3.2px) * 0.4)), 16px);
  padding-left: clamp(8px, calc(0.5rem + ((1vw - 3.2px) * 0.8)), 24px);
  padding-right: clamp(8px, calc(0.5rem + ((1vw - 3.2px) * 0.8)), 24px);
  letter-spacing: 0.15em;
  color: var(--wp--preset--color--inverted-foreground);
  background-color: var(--wp--preset--color--foreground);
}

.greeting__body {
  max-width: var(--wp--style--global--wide-size);
  margin-left: auto;
  margin-right: auto;
  padding-top: 120px;
  padding-bottom: 120px;
  background-color: var(--wp--preset--color--primary);
}

.greeting__body .greeting__inner {
  position: relative;
  z-index: 999;
}

.greeting__contents {
  background-color: var(--wp--preset--color--inverted-foreground);
}

.greeting__contents > p {
  line-height: 2;
  letter-spacing: 0.05rem;
}
.greeting__contents > p + p {
  margin-top: clamp(20px, calc(20px + (20 * ((100vw - 375px) / 1545))), 40px);
}

.greeting__contents > p[class*="greeting-signature"] {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-size: clamp(12px, calc(12px + (8 * ((100vw - 375px) / 1545))), 20px);
  letter-spacing: 0.1rem;
}

.greeting__contents > p[class*="greeting-signature"] > span {
  margin-left: clamp(12px, calc(12px + (12 * ((100vw - 375px) / 1545))), 24px);
  font-size: clamp(20px, calc(20px + (12 * ((100vw - 375px) / 1545))), 32px);
}

@media all and (max-width: 1023px) {
  .greeting__body {
    margin-left: 5.333%;
    margin-right: 5.333%;
    padding-top: calc(67.5vw + 90px);
    padding-bottom: 60px;
  }

  .greeting__contents {
    width: inherit;
    padding: 40px 5.333%;
    margin-left: 5.333%;
    margin-right: 5.333%;
  }

  .greeting__visual {
    position: absolute;
    right: 0;
    width: 90vw;
    height: 67.5vw;
    transform: translateY(-28px);
  }

  .greeting__visual::after {
    bottom: -27%;
    right: 0;
    width: 43vw;
    height: 43vw;
    background-size: 16px 16px;
  }

  .greeting__heading-block > h3 {
    top: -36vw;
    left: -6%;
  }
  .greeting__contents > p[class*="greeting-signature"] {
    padding-right: 5px;
  }
}

@media all and (min-width: 1024px) {
  .greeting__body {
    max-width: var(--wp--style--global--wide-size);
    margin-left: 0;
    margin-right: 5.333%;
    padding-top: 120px;
    padding-bottom: 120px;
    background-color: var(--wp--preset--color--primary);
  }

  .greeting__contents {
    width: 65%;
    padding: 80px;
  }

  .greeting__visual {
    width: 55.9vw;
    height: 34.6vw;
    transform: translateY(200px);
  }

  .greeting__heading-block > h3 {
    top: -13.5vw;
    left: 0;
  }
}
@media all and (min-width: 1024px) and (max-width: 1600px) {
  .greeting {
    overflow-x: hidden;
  }
}
@media all and (min-width: 1730px) {
  .greeting__body {
    margin-left: 5.333%;
  }
}
/**************************************************************
* FEATURE
**************************************************************/
.feature {
  padding-top: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(70px, calc(70px + (90 * ((100vw - 375px) / 1545))), 160px);
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px)),
                    linear-gradient(90deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px));
  background-size: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px) clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px);
  background-repeat: repeat;
  background-position: top left;
}

.feature .segment-heading {
  text-align: center;
}

.feature__body > ul {
  counter-reset: number 0;
  margin-top: clamp(75px, calc(75px + (92 * ((100vw - 375px) / 1545))), 167px);
}

.feature__body > ul > li {
  position: relative;
  display: flex;
  justify-content: center;
  gap: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  border: solid 4px var(--wp--preset--color--primary);
  background-color: var(--wp--preset--color--inverted-foreground);
  box-shadow: 40px 40px 0px var(--wp--preset--color--primary);
  padding: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
}

.feature__body > ul > li::before {
  counter-increment: number 1;
  content: "0" counter(number);
  position: absolute;
  top: 0;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 120px);
  color: var(--wp--preset--color--primary);
  line-height: 0;
}

.feature__body > ul > li:nth-child(even) {
  border: solid 4px var(--wp--preset--color--secondary);
  box-shadow: 40px 40px 0px var(--wp--preset--color--secondary);
}

.feature__body > ul > li:nth-child(even)::before {
  color: var(--wp--preset--color--secondary);
}

.feature__body > ul > li + li {
  margin-top: clamp(88px, calc(88px + (112 * ((100vw - 375px) / 1545))), 200px);
}

.feature-item__fig {
  position: relative;
}

.feature-item__fig .wp-block-cover, .feature-item__fig .wp-block-cover-image {
  min-height: 100%;
}

.feature-item__data {
  width: 100%;
}

.feature-item__title > h3 {
  display: inline;
  font-size: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
  font-weight: 700;
  color: var(--wp--preset--color--foreground);
  text-decoration: underline;
  text-decoration-color: var(--wp--preset--color--primary);
  text-decoration-thickness: 3px; 
  text-underline-offset: 15px; 
  word-break: break-word;
  letter-spacing: 0.1rem;
  line-height: 2;
  
}

.feature__body > ul > li:nth-child(even) > .feature-item__data > .feature-item__title > h3 {
  text-decoration-color: var(--wp--preset--color--secondary);
}

.feature-item__data > p {
  margin-top: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
  line-height: 2;
  letter-spacing: 0.05rem;
}

.feature-item__data > p[class="notes"] {
  margin-top: clamp(8px, calc(8px + (16 * ((100vw - 375px) / 1545))), 24px);
  font-size: 12px;
}

@media all and (max-width: 1023px) {
  .feature__body {
    margin-left: 5.333%;
    margin-right: 5.333%;
  }
  .feature__body > ul {
    width: calc(100% - 10px);
  }

  .feature__body > ul > li {
    flex-direction: column-reverse;
    border: solid 2px var(--wp--preset--color--primary);
    box-shadow: 10px 10px 0px var(--wp--preset--color--primary);
  }

  .feature__body > ul > li:nth-child(even) {
    border: solid 2px var(--wp--preset--color--secondary);
    box-shadow: 10px 10px 0px var(--wp--preset--color--secondary);
  }

  .feature__body > ul > li::before {
    left: 0;
  }

  .feature-item__fig {
    height: 52vw;
  }

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

  .feature-item__title > h3 {
    text-decoration-thickness: 1.5px;
    text-underline-offset: 10px;
    line-height: 3;
    letter-spacing: 0.05rem;
  }
  
}
@media all and (min-width: 1024px) {
  .feature__body {
    max-width: var(--wp--style--global--content-size);
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }

  .feature__body > ul {
    width: calc(100% - 40px);
  }

  .feature__body > ul > li {
    flex-direction: row-reverse;
    margin-left: 82px;
    box-shadow: 20px 20px 0px var(--wp--preset--color--primary);
  }

  .feature__body > ul > li:nth-child(even) {
    flex-direction: row;
    box-shadow: 20px 20px 0px var(--wp--preset--color--secondary);
  }

  .feature__body > ul > li::before {
    left: -4.3vw;
    letter-spacing: 0.03em;
  }

  .feature-item__data {
    max-width: 506px;
  }

  .feature-item__fig {
    width: 28.3vw;
    height: 21.2vw;
  }
}
@media all and (min-width: 1400px) {
  .feature__body > ul > li {
    box-shadow: 40px 40px 0px var(--wp--preset--color--primary);
  }

  .feature__body > ul > li:nth-child(even) {
    box-shadow: 40px 40px 0px var(--wp--preset--color--secondary);
  }

  .feature-item__data {
    padding-top: 30px;
  }
}

/**************************************************************
* OFFICE
**************************************************************/
.office {
  padding-top: clamp(56px, calc(56px + (56 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 120px);
  background-color: var(--wp--preset--color--secondary-background);
}

.office .segment-heading {
  text-align: center;
}

.office__body {
  margin-top: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
}
.office-entries {
  display: flex;
  justify-content: center;
}

.office-entry__fig .wp-block-cover, .office-entry__fig .wp-block-cover-image {
  min-height: 100%;
}

.office-entry__data {
  margin-top: clamp(16px, calc(16px + (8 * ((100vw - 375px) / 1545))), 24px);
  text-align: center;
  letter-spacing: 0.05rem;
}

.office-entry__data > h3 {
  font-size: clamp(14px, calc(14px + (6 * ((100vw - 375px) / 1545))), 20px);
  color: var(--wp--preset--color--foreground);
}

.office-entry__data > p {
  font-size: 12px;
  color: var(--wp--preset--color--primary);
  font-family: var(--wp--preset--font-family--alphabetic-font);
}

@media all and (max-width: 1023px) {
  .office-entries {
    flex-direction: column;
    gap: 40px;
    margin-left: 10.666%;
    margin-right: 10.666%;
  }

  .office-entry__data > h3 {
    margin-bottom: 3px;
  }

  .office-entry__fig {
    width: 100%;
    height: 78.65vw;
  }
}
@media all and (min-width: 1024px) {
  .office-entry__fig {
    width: 23vw;
    height: 23vw;
  }

  .office-entry__data > h3 {
    margin-bottom: 7px;
  }
}

/**************************************************************
* ABOUT
**************************************************************/
.about {
  position: relative;
  overflow-x: hidden;
  padding-top: clamp(53px, calc(53px + (59 * ((100vw - 375px) / 1545))), 112px);
  padding-bottom: clamp(60px, calc(60px + (180 * ((100vw - 375px) / 1545))), 240px); 
}

.about .segment-heading {
  text-align: center;
}

.about::before {
  content: "";
  position: absolute;
  z-index: 1;
  background-image: radial-gradient(var(--wp--preset--color--secondary) 15%, transparent 15%);
  background-size: 16px 16px;
}

.about__body .wp-block-flexible-table-block-table {
  margin-top: clamp(40px, calc(40px + (40 * ((100vw - 375px) / 1545))), 80px);
  margin-bottom: clamp(57px, calc(57px + (53 * ((100vw - 375px) / 1545))), 110px);
}

.about__body .wp-block-flexible-table-block-table table {
  position: relative;
  border-collapse: collapse;
}

.about__body .wp-block-flexible-table-block-table table tr {
  position: relative;
}

.about__body .wp-block-flexible-table-block-table table td {
  padding-top: calc(40 / 16* 1rem);
  padding-bottom: calc(40 / 16* 1rem);
  vertical-align: top;
}

.about__body .wp-block-flexible-table-block-table table tr td {
  position: relative;
  padding-top: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px);
  padding-bottom: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px);
  padding-left: 0;
  padding-right: 0;
  border: none;
  letter-spacing: 0.05rem;
}

.about__body .wp-block-flexible-table-block-table table tr td a {
  color: var(--wp--preset--color--foreground);
  text-decoration: none;
}

.about__body .wp-block-flexible-table-block-table table tr td:first-child {
  color: var(--wp--preset--color--primary);
  vertical-align: top;
}

.about__body .wp-block-flexible-table-block-table table tr:not(:last-child) td:nth-child(1):after,
.about__body .wp-block-flexible-table-block-table table tr:not(:last-child) td:nth-child(2):after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
  display: block;
  border-bottom: 1px solid var(--wp--preset--color--primary);
}

.about-office__header {
  position: relative;
  margin-bottom: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
  text-align: center;
  letter-spacing: 0.05rem;
}

.about-office__header > h3 {
  position: relative;
  font-size: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 20px);
  color: var(--wp--preset--color--primary);
  letter-spacing: 0.1rem;
  line-height: 4;
  z-index: 9;
}

.about-office__header > span {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  font-size: clamp(30px, calc(30px + (18 * ((100vw - 375px) / 1545))), 48px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  letter-spacing: 0.05rem;
  color: var(--wp--preset--color--secondary-background);
}

.about-office__header > p {
  position: relative;
  font-size: clamp(12px, calc(12px + (8 * ((100vw - 375px) / 1545))), 16px);
  letter-spacing: 0.05rem;
}

.about-office__header > p > i > svg {
  height: clamp(16px, calc(16px + (9 * ((100vw - 375px) / 1545))), 24px);
  vertical-align: text-bottom;
  margin-right: clamp(12px, calc(12px + (12 * ((100vw - 375px) / 1545))), 24px);
}

@media all and (max-width: 1023px) {
  .about::before {
    top: 0;
    left: 0;
    width: 27vw;
    height: 27vw;
    background-size: 16px 16px;
  }

  .about__body {
    margin-left: 5.333%;
    margin-right: 5.333%;
  }

  .about__body .wp-block-flexible-table-block-table table tr td:first-child {
    width: calc(240 / 675 * 100%);
  }

  .about__mainoffice {
    margin-bottom: 57px;
  }

  .about__office + .about__office {
    margin-top: 57px;
  }
  
  .about-office__header > h3 {
    line-height: 3;
  }

  .about__body .wp-block-flexible-table-block-table table tr td {
    line-height: 1.5;
  }

  .about__body .wp-block-flexible-table-block-table table tr td strong {
    display: block;
  }

  .about__body .wp-block-flexible-table-block-table table tr td strong[class*="--tel"],
  .about__body .wp-block-flexible-table-block-table table tr td strong[class*="--address"] {
    margin-bottom: 1rem;
  }

  .about__body .wp-block-flexible-table-block-table table tr td br {
    display: none;
  }
}

@media all and (min-width: 1024px) {
  .about::before {
    top: 0;
    left: 0;
    width: 16vw;
    height: 16vw;
    background-size: 23px 23px;
  }

  .about__body .wp-block-flexible-table-block-table table {
    max-width: 855px;
    width: 95%;
    margin-left: auto;
    margin-right: auto;
  }

  .about__body .wp-block-flexible-table-block-table table tr td strong + strong {
    margin-left: 20px;
  }
  

  .about__body .wp-block-flexible-table-block-table table tr td:first-child {
    width: calc(200 / 855 * 100%);
  }

  .about__mainoffice {
    margin-bottom: 115px;
  }

  .about__mainoffice .about-office__header {
    margin-bottom: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 24px);
  }
  
  .about__mainoffice .about-office__header > h3 {
    font-size: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
    line-height: 6.5;
  }
  
  .about__mainoffice .about-office__header > span {
    font-size: clamp(30px, calc(30px + (90 * ((100vw - 375px) / 1545))), 120px);
  }

  .about__mainoffice .about-office__header > p {
    font-size: clamp(12px, calc(12px + (8 * ((100vw - 375px) / 1545))), 20px);
  }

  .about__offices {
    display: flex;
    justify-content: center;
    gap: 40px;
    max-width: var(--wp--style--global--wide-size);
    width: 95%;
    margin-left: auto;
    margin-right: auto;
  }

  .about__office {
    width: 34%;
  }
}


/*============================================================
* WORKページ
============================================================*/

.services {
  position: relative;
  padding-top: 4rem;
}

.services__body {
  margin-bottom: clamp(60px, calc(60px + (60 * ((100vw - 375px) / 1545))), 120px);
  margin-left: 5.333%;
  margin-right: 5.333%;
  padding-top: clamp(80px, calc(80px + (120 * ((100vw - 375px) / 1545))), 200px);
  padding-bottom: clamp(80px, calc(80px + (120 * ((100vw - 375px) / 1545))), 200px);
  background-color: var(--wp--preset--color--secondary-background);
}

.services-intro {
  position: relative;
  display: grid;
  gap: 1rem;
  margin-bottom: 12%;
  padding-left: 5.33%;
  padding-right: 5.33%;
}
.services-intro::before {
  content: "";
  position: absolute;
  z-index: -1;
  background-image: radial-gradient(var(--wp--preset--color--secondary) 15%, transparent 15%);
  background-size: 16px 16px;
}

.services-intro__copy {
  display: contents;
}

.services-intro__copy .wp-block-heading {
  z-index: 9;
  font-size: clamp(20px, calc(20px + (28 * ((100vw - 375px) / 1545))), 48px);
  line-height: 1.5;
  letter-spacing: 0.1em;
  color: var(--wp--preset--color--foreground);
}

.services-intro__txt {
  margin-left: auto;
  margin-right: 0;
  font-weight: bold;
  line-height: 2;
  font-size: clamp(13px, calc(13px + (3 * ((100vw - 375px) / 1545))), 16px);
  letter-spacing: 0.1em;
}

.services-items {
  position: relative;
  display: grid;
}

.services-item {
  position: relative;
  z-index: 9;
  display: grid;
  padding-top: 40px;
  padding-bottom: 40px;
}
.services-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--wp--preset--color--primary-background);
}


.services-item__alphabetic-label {
  position: absolute;
  top: 0;
  display: block;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(32px, calc(32px + (88 * ((100vw - 375px) / 1545))), 120px);
  letter-spacing: 0.05em;
  font-weight: bolder;
  line-height: 1;
  color: transparent !important; /* //FIXME */
  text-transform: uppercase;
  -webkit-text-stroke-color: var(--wp--preset--color--secondary);
  transform: translateY(-50%);
}

.services-item:nth-child(even) .services-item__alphabetic-label {
  order: 0;
} 

.services-item__fig {
  position: relative;
  clip-path: polygon(0 0, 87% 0, 100% 13%, 100% 100%, 0 100%);
}

.services-item__data {
  display: flex;
  flex-flow: column;
  justify-content: center;
}

.services-item__details {
  position: relative;
}

.services-item__details > p {
  line-height: 2;
  letter-spacing: 0.1em;
  font-size: clamp(13px, calc(13px + (3 * ((100vw - 375px) / 1545))), 16px);
}
.services-item__details p + p {
  margin-top: 1rem;
}
.services-item__details > h3 {
  margin-bottom: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
}

.services-item__details > h3 > span {
  display: inline-block;
  padding-bottom: 0.125em;
  padding-left: 5%;
  padding-right: 5%;
  font-size: clamp(16px, calc(16px + (16 * ((100vw - 375px) / 1545))), 32px);
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--inverted-foreground);
  background-color: var(--wp--preset--color--foreground);
}

.services-item__details > h3 > span + br + span {
  margin-top: clamp(4px, calc(4px + (4 * ((100vw - 375px) / 1545))), 8px);
}

@media all and (max-width: 1123px) {
  .services {
    overflow: hidden;
  }
  .services-intro__copy .wp-block-heading{
    letter-spacing: 0.15em;
  }

  .services-intro {
    padding-left: 10%;
    padding-right: 10%;
  }
  .services-intro::before {
    top: -27%;
    left: 0;
    width: 30vw;
    height: 30vw;
  }

  .services-items,
  .services-item {
    padding-left: 5%;
    padding-right: 5%;
  }

  .services-items {
    gap: 100px;
  }

  .services-item {
    position: relative;
    gap: 40px;
  }

  .services-item__fig {
    height: clamp(160px, calc(160px + (200 * ((100vw - 375px) / 1545))), 360px);
  }

  .services-item__fig .wp-block-cover {
    min-height: 100%;
  }

  .services-item__alphabetic-label {
    -webkit-text-stroke-width: 1.5px;
  }

  .services-item:nth-child(odd) .services-item__alphabetic-label {
    right: 0;
  } 
  .services-item:nth-child(even) .services-item__alphabetic-label {
    left: -0.25em;
  } 
  
}

@media all and (min-width: 1124px) {
  .services__body {
    padding-left: 8.6%;
    padding-right: 8.6%;
  }

  .services-items {
    gap: 75px;
  }

  .services-item {
    gap: 2rem;
  }

  .services-items {
  position: relative;
  display: grid;
  gap: 75px;
}

  .services-intro {
    display: flex;
    gap: inherit;
    margin-bottom: 6.25%;
  }
  
  .services-intro::before {
    top: -75%;
    left: -1%;
    width: 9.15vw;
    height: 9.15vw;
    background-size: 23px 23px;
  }
  /* .services-intro::before {
    background-size: 16px 23px;
  } */

  .services-items {
    gap: 200px;
  }
  
  .services-intro__txt {
    flex: 1;
    margin-left: 8rem;
  }

  .services-item {
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .services-item:nth-child(odd) {
    padding-right: 6.25%;
  }
  .services-item:nth-child(even) {
    padding-left: 6.25%;
  }

  .services-item:nth-child(odd) .services-item__fig {
    left: -2rem;
  } 
  .services-item:nth-child(even) .services-item__fig {
    right: -2rem;
    order: 1;
  }

  .services-item__alphabetic-label {
    -webkit-text-stroke-width: 2px;
  }
  
  .services-item:nth-child(odd) .services-item__alphabetic-label {
    right: -2.5rem;
  } 
  .services-item:nth-child(even) .services-item__alphabetic-label {
    left: -2.5rem;
  } 
}


/*============================================================
* ENTRYページ
============================================================*/

/* CAREERS
**************************************************************/

.careers {
  background-color: var(--wp--preset--color--secondary-background);
  padding-top: clamp(60px, calc(60px + (120 - 60) * ((100vw - 375px) / (1920 - 375))), 120px);
  padding-bottom: clamp(60px, calc(60px + (120 - 60) * ((100vw - 375px) / (1920 - 375))), 120px);
  padding-left: 5%;
  padding-right: 5%;
}

.careers .segment-heading {
  text-align: center;
}

.careers__body {
  margin-top: clamp(40px, calc(40px + (80 - 40) * ((100vw - 375px) / (1920 - 375))), 80px);
}

.careers__list ul {
  list-style: disc;
  margin-left: 20px;
}

.careers__list .kt-accordion-pane {
  background-color: var(--wp--preset--color--inverted-foreground);
  margin-top: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
}

.careers__list .kt-accordion-pane:first-child {
  margin-top: 0;
}

.careers__list .wp-block-kadence-pane .kt-accordion-header-wrap .kt-blocks-accordion-header {
  padding-top: clamp(12px, calc(12px + (24 - 12) * ((100vw - 375px) / (1920 - 375))), 24px);
  padding-bottom: clamp(12px, calc(12px + (24 - 12) * ((100vw - 375px) / (1920 - 375))), 24px);
  padding-left: clamp(18px, calc(18px + (64 - 18) * ((100vw - 375px) / (1920 - 375))), 64px);
  padding-right: clamp(18px, calc(18px + (64 - 18) * ((100vw - 375px) / (1920 - 375))), 64px);
  line-height: 2.5em;
  cursor: pointer;
} 

.careers__list .kt-blocks-accordion-title {
  font-size: clamp(16px, calc(16px + (32 - 16) * ((100vw - 375px) / (1920 - 375))), 32px);
  font-family: var(--wp--preset--font-family--kana-font);
  font-weight: bold;
}

.careers__list .kt-accordion-panel-inner {
  padding-top: clamp(32px, calc(32px + (64 - 32) * ((100vw - 375px) / (1920 - 375))), 64px);
  padding-bottom: clamp(32px, calc(32px + (64 - 32) * ((100vw - 375px) / (1920 - 375))), 64px);
  padding-left: clamp(18px, calc(18px + (64 - 18) * ((100vw - 375px) / (1920 - 375))), 64px);
  padding-right: clamp(18px, calc(18px + (64 - 18) * ((100vw - 375px) / (1920 - 375))), 64px);
}

.careers__list .kt-accordion-panel-inner dl {
  padding-top: clamp(16px, calc(16px + (32 - 16) * ((100vw - 375px) / (1920 - 375))), 32px);
  padding-bottom: clamp(16px, calc(16px + (32 - 16) * ((100vw - 375px) / (1920 - 375))), 32px);
  border-bottom: 1px solid var(--wp--preset--color--secondary-background);
  font-size: clamp(13px, calc(13px + (16 - 13) * ((100vw - 375px) / (1920 - 375))), 16px);
}

.careers__list .kt-accordion-panel-inner dl:first-child {
  padding-top: 0;
}

.careers__list .kt-accordion-panel-inner dl:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.careers__list .kt-accordion-panel-inner dl dt {
  color: var(--wp--preset--color--primary);
  font-size: clamp(13px, calc(13px + (16 - 13) * ((100vw - 375px) / (1920 - 375))), 16px);
}

.careers__list .kt-accordion-panel-inner dl dd {
  font-size: clamp(13px, calc(13px + (16 - 13) * ((100vw - 375px) / (1920 - 375))), 16px);
}

@media all and (max-width: 1023px) {
  .careers__list .kt-accordion-panel-inner dl dd {
    margin-top: 5.3%;
  }
}

@media all and (min-width: 1024px) {
  .careers__body {
    max-width: 1100px;
    width: 100%;  
    margin-left: auto;
    margin-right: auto;
  }

  .careers__list .kt-accordion-panel-inner dl {
    display: flex;
  }

  .careers__list .kt-accordion-panel-inner dl dt {
    width: 17.3%;
  } 

  .careers__list .kt-accordion-panel-inner dl dd {
    width: 82.7%;
  }
}

/* PROCESS
**************************************************************/
.process {
  padding-top: clamp(60px, calc(60px + (120 - 60) * ((100vw - 375px) / (1920 - 375))), 120px);
  padding-bottom: clamp(60px, calc(60px + (120 - 60) * ((100vw - 375px) / (1920 - 375))), 120px);
  padding-left: 5%;
  padding-right: 5%;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px)),
                    linear-gradient(90deg, transparent calc(100% - 1px), var(--wp--preset--color--secondary-background) calc(100% - 1px));
  background-size: clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px) clamp(15px, calc(15px + (15 * ((100vw - 375px) / 1545))), 30px);
  background-repeat: repeat;
  background-position: top left;
}

.process .segment-heading {
  text-align: center;
}

.process-steps {
  counter-reset: number 0;
}

.process-step {
  position: relative;
  display: flex;
  margin-top: clamp(40px, calc(40px + (80 - 40) * ((100vw - 375px) / (1920 - 375))), 80px);
}

.process-step::after {
  content: "";
  position: absolute;
  bottom: min(-4vw, -27px);
  left: 50%;
  transform: translateX(-50%);
  height: calc(clamp(16px, calc(16px + (25 - 16) * ((100vw - 375px) / (1920 - 375))), 25px) / 2);
  width: clamp(16px, calc(16px + (25 - 16) * ((100vw - 375px) / (1920 - 375))), 25px);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #cccccc;
}

.process-step:last-child::after {
  display: none;
}

.process-step__no {
  text-transform: uppercase;
  background-color: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--inverted-foreground);
  font-size: clamp(12px, calc(12px + (20 - 12) * ((100vw - 375px) / (1920 - 375))), 20px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  text-align: center;
  padding-top: clamp(20px, calc(20px + (50 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  padding-right: 3px;
  border: 3px solid var(--wp--preset--color--primary);
}

.process-step__no::after{
  counter-increment: number 1;      
  content: counter(number ,decimal-leading-zero);
  font-size: clamp(24px, calc(24px + (64 - 24) * ((100vw - 375px) / (1920 - 375))), 64px);
}

.process-step__no p {
  font-weight: bolder;
  font-family: var(--wp--preset--font-family--alphabetic-font);
}

.process-step__contents {
  position: relative;
  --x-width: clamp(26px, calc(26px + (40 - 26) * ((100vw - 375px) / (1920 - 375))), 40px);
  --x-height: clamp(26px, calc(26px + (40 - 26) * ((100vw - 375px) / (1920 - 375))), 40px);
  padding-top: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  padding-bottom: clamp(24px, calc(24px + (48 - 24) * ((100vw - 375px) / (1920 - 375))), 48px);
  padding-left: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  padding-right: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  letter-spacing: 0.1em;
  background-color: var(--wp--preset--color--primary-background);
  clip-path: polygon(0 0, calc(100% - var(--x-width)) 0, 100% var(--x-width), 100% 100%, 0 100%, 0 var(--x-width));
  border: 3px solid var(--wp--preset--color--primary);
  border-left: none;
}

.process-step__contents::before {
  content: "";
  position: absolute;
  top: -2px;
  right: -2px;
  z-index: 1;
  display: block;
  width: clamp(28px, calc(28px + (42 - 28) * ((100vw - 375px) / (1920 - 375))), 42px);
  height: clamp(28px, calc(28px + (42 - 28) * ((100vw - 375px) / (1920 - 375))), 42px);
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 0%);
  background-color: var(--wp--preset--color--primary);
}

.process-step__contents .wp-block-heading {
  font-size: clamp(16px, calc(16px + (20 - 16) * ((100vw - 375px) / (1920 - 375))), 20px);
  color: var(--wp--preset--color--foreground);
}

.process-step__contents p {
  margin-top: clamp(8px, calc(8px + (16 - 8) * ((100vw - 375px) / (1920 - 375))), 16px);
  font-size: clamp(13px, calc(13px + (16 - 13) * ((100vw - 375px) / (1920 - 375))), 16px);
  color: var(--wp--preset--color--foreground);
}

.process-step:last-child {
  display: block;
  color: var(--wp--preset--color--inverted-foreground);
  text-align: center;
  border: none;
}

.process-step:last-child .process-step__contents {
  padding-top: clamp(20px, calc(20px + (30 - 20) * ((100vw - 375px) / (1920 - 375))), 30px);
  padding-bottom: clamp(20px, calc(20px + (30 - 20) * ((100vw - 375px) / (1920 - 375))), 30px);
  padding-left: clamp(40px, calc(40px + (240 - 40) * ((100vw - 375px) / (1920 - 375))), 240px);
  padding-right: clamp(40px, calc(40px + (240 - 40) * ((100vw - 375px) / (1920 - 375))), 240px);
  background-color: var(--wp--preset--color--primary);
}

.process-step:last-child .process-step__contents .wp-block-heading {
  display: inline-block;
  font-size: clamp(20px, calc(20px + (40 - 20) * ((100vw - 375px) / (1920 - 375))), 40px);
  color: var(--wp--preset--color--inverted-foreground);
  border-bottom: 2px solid var(--wp--preset--color--inverted-foreground);
  line-height: 1.4;
  margin-left: auto;
  margin-right: auto;
}

.process-step:last-child .process-step__contents::before {
  display: none;
}

.process-step:last-child .process-step__contents p {
  margin-top: 0;
  text-align: left;
  color: var(--wp--preset--color--inverted-foreground);
}

.process-step:last-child .process-step__contents p:nth-child(2) {
  margin-top: clamp(9px, calc(9px + (18 - 9) * ((100vw - 375px) / (1920 - 375))), 18px);
}

@media all and (max-width: 1023px) {
  .process-step__no {
    width: 21.3%;
  }

  .process-step__no p {
    margin-bottom: -13%;
  }

  .process-step__contents {
    width: 78.7%;
  }

  .process-step:last-child .process-step__contents {
    width: auto;
    border-left:2px solid var(--wp--preset--color--inverted-foreground);
  }
}

@media all and (min-width: 1024px) {
  .process__body {
    max-width: 1100px;
    width: 100%;  
    margin-left: auto;
    margin-right: auto;
  }

  .process-step::after {
    bottom: max(-4vw, -50px);
  }

  .process-step__no {
    width: 19%;
  }

  .process-step__no p {
    margin-bottom: -9%;
  }

  .process-step__contents {
    width: 81%;
  }

  .process-step:last-child .process-step__contents {
    width: auto;
  }
}


/* FORM
**************************************************************/
.form {
  background-color: var(--wp--preset--color--secondary-background);
  padding-top: clamp(60px, calc(60px + (120 - 60) * ((100vw - 375px) / (1920 - 375))), 120px);
  padding-bottom: clamp(60px, calc(60px + (120 - 60) * ((100vw - 375px) / (1920 - 375))), 120px);
  padding-left: 5%;
  padding-right: 5%;
}

.form .segment-heading {
  text-align: center;
}

.form__body p {
  font-size: clamp(16px, calc(16px + (13 - 16) * ((100vw - 375px) / (1920 - 375))), 13px);
  margin-top: clamp(20px, calc(20px + (32 - 20) * ((100vw - 375px) / (1920 - 375))), 32px);
  padding-left: 5.3%;
  padding-right: 5.3%;
  letter-spacing: 0.1em;
}

.form [class*="--entry-tel"] .wp-block-button__link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(16px, 2vw, 32px);
  width: clamp(300px, 50vw, 578px);
  height: clamp(72px, 9vw, 110px);
  font-size: clamp(12px, 0.75rem + ((1vw - 3.2px) * 0.426), 16px); 
  font-weight: bold;
  margin-top: clamp(24px, calc(24px + (40 - 24) * ((100vw - 375px) / (1920 - 375))), 40px);
  padding-left: 0;
  padding-right: 0;
  font-family: var(--wp--preset--font-family--kana-font);
  letter-spacing: 0.1em;
}

.form [class*="--entry-tel"] .wp-block-button__link .tel-icn svg {
  width: clamp(40px, 5vw, 60px);
}

.form [class*="--entry-tel"] .wp-block-button__link strong {
  display: inline-block;
  font-size: clamp(24px, 1.5rem + ((1vw - 3.2px) * 0.981), 40px);
  font-family: var(--wp--preset--font-family--alphabetic-font);
  letter-spacing: 0.05em;
  line-height: 0.5;
}

.form-area {
  margin-top: clamp(48px, calc(48px + (88 - 48) * ((100vw - 375px) / (1920 - 375))), 88px);
}

/* hovers */
@media (hover: hover) {
  .form [class*="--entry-tel"] .wp-block-buttons .is-style-fill .wp-block-button__link:hover {
    box-shadow: none;
  }
}

@media all and (max-width: 1023px) {
  .form [class*="--entry-tel"] .wp-block-button__link strong {
    margin-top: 4%;
  }

  .form [class*="--entry-tel"] .wp-block-button__link .tel-icn {
    margin-left: -4%;
  }
}

@media all and (min-width: 1024px) {
  .form__body {
    max-width: 1100px;
    width: 100%;  
    margin-left: auto;
    margin-right: auto;
  }

  .form__body p {
    max-width: 687px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    letter-spacing: 0.05em;
    text-align: center;
  }

  .form [class*="--entry-tel"] .wp-block-button__link {
    width: clamp(300px, 40vw, 578px);
    height: clamp(72px, 9vw, 110px);
  }

  .form [class*="--entry-tel"] .wp-block-button__link .tel-icn {
    margin-left: -2%;
  }

  .form [class*="--entry-tel"] .wp-block-button__link strong {
    margin-top: 5%;
  }

  
  @media (hover: hover) {
    .form [class*="--entry-tel"] .wp-block-button__link:hover {
      transform: none;
      box-shadow: 8px 8px 0px var(--wp--preset--color--tertiary);
      cursor: auto;
    }
  }
}

/**************************************************************
* Utility
**************************************************************/

/* u-hide-**
**************************************/
.u-hide-sp,
.u-hide-pc {
  display: none !important;
}

@media screen and (max-width: 1023px) {
  .u-hide-pc {
    display: block !important;
  }
}

@media screen and (min-width: 1024px) {
  .u-hide-sp {
    display: block !important;
  }
}



/**************************************************************
* 管理画面固定ページの見た目修正 (Wordpress FSE editor)
**************************************************************/

/* 固定ページ　エディター画面のOVERRIDE */
body:is(.post-type-page) .editor-styles-wrapper .block-editor-block-list__layout.is-root-container > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  max-width: 100% !important;
}

.editor-styles-wrapper {
  overflow-x: hidden;
  padding: 10px;
}

.editor-styles-wrapper .wp-block-site-logo .custom-logo-link {
  width: 100%; /* fix for logo block */
}

.editor-styles-wrapper .subpage-header__body .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text a {
  text-decoration: none;
  color: var(--wp--preset--color--foreground);
}

.editor-styles-wrapper .free-space-alphabetic {
  line-height: 1;
}

.editor-styles-wrapper .faq-item__acc-answer::before {
  content: "";
  padding-right: 0;
}

.editor-styles-wrapper .faq-item__acc button::before {
  content: "";
}

.editor-styles-wrapper .faq .block-editor-inserter__toggle.components-button.has-icon {
  position: absolute;
  background-color: #fff;
  right: 10px;
  bottom: 10px;
}

.editor-styles-wrapper .faq-item__acc-answer {
  text-indent: 0;
  padding-left: 0;
}

.editor-styles-wrapper .data .data-entry__icn {
  width: 70px;
  height: 70px;
  position: absolute;
  bottom: 0;
  right: 0;
}

.editor-styles-wrapper .benefits .benefits__body.is-layout-flex {
  gap: 0;
}

.editor-styles-wrapper .flow .flow-entries {
  padding-left: 5%;
  padding-right: 5%;
}

.editor-styles-wrapper .flow .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text {
  text-align: center;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(24px, calc(24px + (24 * ((100vw - 375px) / 1545))), 48px);
  font-weight: bolder;
  line-height: 1.25;
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--primary);
}

.edit-post-visual-editor .editor-styles-wrapper .wp-block-button[class*="--entry-tel"] {
  pointer-events: none;
}

.editor-styles-wrapper .message::after {
  display: none;
}

@media all and (min-width: 1024px) {
  .editor-styles-wrapper .subpage-header__body {
    width: 80%;
  }
}

@media screen and (min-width: 1124px) {
  .editor-styles-wrapper .services-item:nth-child(odd) .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text {
    right: -2.5rem;
  }
  .editor-styles-wrapper .services-item:nth-child(even) .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text {
    left: -2.5rem;
  }
}



/* ============================================================
*  TOPページ
============================================================ */
body.editor-styles-wrapper .message .message__heading-block > h2 > span,
.editor-styles-wrapper .message .message__heading-block > h2 > span {
  background-color: var(--wp--preset--color--primary);
}

body.editor-styles-wrapper .interview .interview-entry .wp-block-group > p > span,
.editor-styles-wrapper .interview .interview-entry .wp-block-group > p > span {
  background-color: var(--wp--preset--color--foreground);
}

.editor-styles-wrapper .concept::before {
  z-index: -1;
}

.editor-styles-wrapper .about::before {
  z-index: -1;
}

.editor-styles-wrapper .job .job-bottom-visual[class*="--3"] {
  right: 0;
}

.editor-styles-wrapper .interview .interview-entry__fig-catch {
  bottom: auto;
}

.editor-styles-wrapper .services .services-intro__txt {
  margin-left: 0;
}

.editor-styles-wrapper .data .data-entry__flex-wrapper {
  padding-bottom: 0;
}

.editor-styles-wrapper .data .data-entry__icn {
  width: 50px;
  height: 50px;
  transform: translate(90%, 95%);
}



/* ============================================================
*  ABOUTページ
============================================================ */
body.editor-styles-wrapper .greeting .greeting__heading-block > h3 span,
.editor-styles-wrapper .greeting .greeting__heading-block > h3 span {
  background-color: var(--wp--preset--color--foreground);
}  

.editor-styles-wrapper .about__offices .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text {
  line-height: 1;
}



/* ============================================================
*  WORKページ
============================================================ */
body.editor-styles-wrapper .services .services-item__details > h3 > span,
.editor-styles-wrapper .services .services-item__details > h3 > span {
  background-color: var(--wp--preset--color--foreground);
}

.editor-styles-wrapper .services-item .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.is-selected.wp-block-oem-generic-span-block.rich-text {
  position: absolute;
  top: 0;
  display: block;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(32px, calc(32px + (88 * ((100vw - 375px) / 1545))), 120px);
  letter-spacing: 0.05em;
  font-weight: bolder;
  line-height: 1;
  color: transparent !important;
  text-transform: uppercase;
  -webkit-text-stroke-color: var(--wp--preset--color--secondary);
  transform: translateY(-50%);
  -webkit-text-stroke-width: 2px;
}

.editor-styles-wrapper .services-item .block-editor-rich-text__editable.block-editor-block-list__block.wp-block.wp-block-oem-generic-span-block.rich-text {
  position: absolute;
  top: 0;
  display: block;
  font-family: var(--wp--preset--font-family--alphabetic-font);
  font-size: clamp(32px, calc(32px + (88 * ((100vw - 375px) / 1545))), 120px);
  letter-spacing: 0.05em;
  font-weight: bolder;
  line-height: 1;
  color: transparent !important;
  text-transform: uppercase;
  -webkit-text-stroke-color: var(--wp--preset--color--secondary);
  transform: translateY(-50%);
  -webkit-text-stroke-width: 2px;
}



/* ============================================================
*  ENTRYページ
============================================================ */
body.editor-styles-wrapper .process .process-step::after,
.editor-styles-wrapper .process .process-step::after {
  display: none;
}