/* ========== child_top ========== */
.child_top {
    height: 800px;
}
.child_top .ttl_box {
    display: inline-flex;
    flex-direction: column;
    align-items: baseline;
}
.child_top .title-en01 {
    display: inline-block;
}
.child_top .title-en02{
    display: inline-block;
}
.child_top .title-ja{
    display: inline-block;
}
.child_top .parent{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-template-rows:repeat(6,clamp(60px,10vw,120px)); /* 高さを行単位で制御 */
  gap: clamp(8px,1.2vw,16px);
  box-sizing: border-box;
}
.child_top .div1 { grid-area: 1 / 1 / 4 / 3; }
.child_top .div2 { grid-area: 1 / 3 / 4 / 5; }
.child_top .div3 { grid-area: 4 / 1 / 7 / 5; }
.child_top .div4 { grid-area: 1 / 5 / 7 / 7; }
.child_top .parent img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  box-shadow: var(--shadow);
  border-radius: var(--radius);
}
.child_top .div1 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
}
.child_top .title-ja {
    background-color: #fff;
    border: 2px solid #000;
    padding: 0 15px;
    margin-top: 0px;
    letter-spacing: 1px;
    position: relative;
    top: -5px;
    font-weight: 500;
}
.child_top .title-en02 {
    color: #fff;
    background-color: #000;
    padding: 0 25px;
}

/* ========== enployee ========== */
.type_list.section {
    position: relative;
    padding-top: 120px;
    padding-bottom: 120px;
}
.type_list .container {
  width: 700px;
}
.type_list .area {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 25px;
}
.employee-archive .slash01 {
    clip-path: polygon(0 55%, 100% 0%, 100% 45%, 0% 100%);
    height: 500px;
    width: 100%;
    background-color: hsl(0deg 0% 0% / 3%);
    position: absolute;
    top: -28%;
    z-index: -1;
}
.employee-archive .slash02 {
    clip-path: polygon(0 0, 100% 55%, 100% 100%, 0 45%);
    height: 500px;
    width: 100%;
    background-color: hsl(0deg 0% 0% / 3%);
    position: absolute;
    bottom: -10%;
    z-index: -1;
}
.type_list .card {
    width: 330px;
    height: 145px;
    position: relative;
    border-radius: var(--radius);
}
.type_list .card img {}
.type_list .card .type_name {
    color: #fff;
}
.type_list .card.is-office { background: url(../img/child/interview/interview-back-01.webp) center / cover no-repeat; }
.type_list .card.is-pachinko { background: url(../img/child/interview/interview-back-02.webp) center / cover no-repeat; }
.type_list .card.is-rental { background: url(../img/child/interview/interview-back-03.webp) center / cover no-repeat; }
.type_list .card.is-hotel { background: url(../img/child/interview/interview-back-04.webp) center / cover no-repeat; }
.type_list .card.is-food { background: url(../img/child/interview/interview-back-05.webp) center / cover no-repeat; }
.type_list .card.is-services-area { background: url(../img/child/interview/interview-back-06.webp) center / cover no-repeat; }
.type_list .card.is-game { background: url(../img/child/interview/interview-back-07.webp) center / cover no-repeat; }
.type_list .card.is-banpaku { background: url(../img/child/interview/interview-back-08.webp) center / cover no-repeat; }
.type_list .card-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
}
.type_list .card-icon img {
    width: 70px;
    height: auto;
}
.type_list .modal-contents .img_box {
    overflow: hidden;
}
.type_list .modal-contents .box {
    width: 420px;
    height: 475px;
    border-radius: var(--radius);
}
.type_list .modal-contents .message {
    position: absolute;
    top: 36%;
    left: 26%;
}
.type_list .modal-contents .ttl {
    background-color: #000;
    padding: 5px 8px;
    text-shadow: none;
    display: inline-block;
    color: #fff;
}
.type_list .modal-contents .hashtag {
    background-color: #fff;
    padding: 3px 5px;
    border: 1px solid #000;
}
.type_list .modal-contents .circleText {
  overflow: visible;
  animation: rotation 18s linear infinite;
}
.type_list .modal-contents .circleText__circle {
  fill: none;
}
.type_list .modal-contents .circleText__text {
    fill: #000;
    font-size: 22px;
    letter-spacing: 0.05em;
    font-weight: bold;
}
@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.type_list .modal-contents .circleText {
    width: 100px;
}
.type_list .modal-contents.item { background-color: var(--bg, transparent); }

.type_list .area{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: clamp(12px, 2vw, 20px);
}

.type_list .card{
  position: relative;
  display: grid;
  place-items: center;
  padding: clamp(18px, 3vw, 28px);
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,.12);
  border: 0;
  width: 100%;
  cursor: pointer;
  overflow: hidden;
}
.type_list .card-bglabel{
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.type_list .card-bglabel__en {
    position: absolute;
    left: clamp(14px, 2.2vw, 20px);
    top: 12px;
    font-weight: 800;
    letter-spacing: .06em;
    font-size: clamp(18px, 3.6vw, 28px);
    opacity: .3;
    white-space: nowrap;
}
.type_list .card-bglabel__num {
    position: absolute;
    left: clamp(14px, 2.2vw, 20px);
    top: clamp(34px, 5.4vw, 58px);
    font-weight: 800;
    font-size: clamp(30px, 7.6vw, 72px);
    line-height: 1;
    opacity: .2;
}
.type_list .card-inner{
  position: relative;
  display: grid;
  place-items: center;
  gap: 10px;
  z-index: 1;
}
.type_list .card-icon img{
  width: clamp(36px, 5vw, 60px);
  height: auto;
  display: block;
}
.type_list .type_name{
  font-weight: 700;
}
html.is-modal-open{ overflow: hidden; }
.type_list .modal{
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  pointer-events: none;
}
.type_list .modal[aria-hidden="true"]{
  visibility: hidden;
}
.type_list .modal.is-open{
  pointer-events: auto; 
  visibility: visible;
}
.type_list .modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.7);
    opacity: 0;
    transition: opacity .5s ease;
}
.type_list .modal.is-open .modal__overlay{
  opacity: 1;
}
.type_list .modal__dialog{
  transform: translateY(12px) scale(.98);
  opacity: 0;
  transition: transform .5s cubic-bezier(.2,.8,.2,1), 
              opacity .5s ease;
}
.type_list .modal.is-open .modal__dialog{
  transform: translateY(0) scale(1);
  opacity: 1;
}
@media (prefers-reduced-motion: no-preference){
  .type_list .modal.is-open .modal__dialog{
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}
.type_list .modal__close {
    position: absolute;
    left: 5%;
    top: 10%;
    display: none;
    padding: 10px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    z-index: 2;
}
.type_list .modal.is-open .modal__close{ display: inline-grid; }
.type_list .modal__close .icon-close {
    width: 50px;
    height: 50px;
    display: block;
    fill: #fff;
}
.type_list .modal__close:hover{ filter: brightness(.95); }
.type_list .modal-items{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: clamp(14px, 2vw, 22px);
}
.type_list .modal__body.is-single .modal-items{
  grid-template-columns: 1fr;
  max-width: 720px;
  margin-inline: auto;
}
.type_list .modal-contents.item{
  display: block;
  text-decoration: none;
}
.type_list .modal-contents .box {
    position: relative;
    border-radius: 14px;
    background-color: transparent;
    transform: translateY(8px);
    opacity: 0;
    transition: transform .5s cubic-bezier(.2,.8,.2,1), opacity .5s ease;
}
.type_list .modal.is-open .modal-contents .box{
  transform: translateY(0);
  opacity: 1;
}
.type_list .modal-contents .img_box img{
  display:block; width:100%; height:auto;
}
.type_list .modal-contents .message {
    writing-mode: vertical-rl;
    text-orientation: upright;
    line-height: 0;
    height: 160px;
    width: 85px;
}
.type_list .modal-contents .message p {
  font-size: clamp(0.938rem, 0.876rem + 0.21vw, 1.063rem);
}
.type_list .modal-contents .text-box{
  position:absolute; z-index:1;
}
.type_list .modal-contents .text-bottomleft{ left: 12px; bottom: 12px; }
.type_list .modal-contents .text-topleft {
    right: 5%;
    bottom: 5%;
    z-index: 1;
}
.type_list .modal-contents .text-topleft .circle-name {
}
.type_list .modal__close:focus-visible,
.type_list .card:focus-visible{
  outline: 3px solid rgba(0, 140, 255, .6);
  outline-offset: 2px;
}
/* =========================
   セクション：single_top
   ========================= */
.employee_single .single_top {
    padding-bottom: 120px;
}
.employee_single .single_top .container {
    width: 90%;
    margin: inherit;
    margin-left: auto;
}
.employee_single .single_top .area {
    position: relative;
    height: 685px;
}
.employee_single .single_top .back_color {
    height: 285px;
    width: 100%;
    position: absolute;
    right: 0;
    top: 25%;
    border-radius: 3rem 0 0 3rem;
    z-index: -1;
}
.employee_single .single_top .ttl_box {
    display: inline-flex;
    position: absolute;
    top: 60px;
    left: 5%;
    flex-direction: column;
    align-items: center;
}
.employee_single .single_top .ex_box {
    display: inline-flex;
    position: absolute;
    flex-direction: column;
    top: 260px;
    left: 5%;
}
.employee_single .single_top .ex_box .sub_ttl {}
.employee_single .single_top .ex_box .ex {
    width: 80%;
}
.employee_single .single_top .img_box {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 50%;
}
.employee_single .single_top .img_box img {
    border-radius: 2rem 0 0 2rem;
}
.employee_single .single_top .number_box {
    display: inline-block;
    position: absolute;
    top: 0px;
    right: 1%;
}
.employee_single .single_top .number_box .number {
    display: inline-block;
    font-size: clamp(4.063rem, 2.297rem + 5.95vw, 7.5rem);
    font-weight: 900;
    -webkit-text-stroke: 7px black;
    text-stroke: 7px black;
    paint-order: stroke;
    color: #fff;
    letter-spacing: 0px;
}
.employee_single .single_top .ttl_box .ttl02 {
    background-color: #fff;
    border: 1px solid #000;
    padding: 0 8px;
}
.employee_single .single_top .ttl_box .ttl03 {
    color: #fff;
}
.employee_single .section02 {}
.employee_single .section02 .area {
    height: auto;
}
.employee_single .section02 .box01 {
    position: relative;
    height: auto;
}
.employee_single .section02 .message {
    font-size: clamp(1.25rem, 0.865rem + 1.3vw, 2rem);
    letter-spacing: clamp(0.125rem, 0.029rem + 0.32vw, 0.313rem);
}
.employee_single .section02 .box01 .ex_box.tate {
    position: relative;
    z-index: 4;
    top: 10%;
    left: 10%;
}
.employee_single .section02 .box01 .tag_box {
    position: relative;
    z-index: 3;
    bottom: -25%;
}
.employee_single .section02 .box01 .tag_box .ttl {
    background-color: #000;
    color: #fff;
    display: inline;
    padding: 5px 10px;
}
.employee_single .hashtags {
    padding-top: 8px;
}
.employee_single .hashtags li {
    margin-bottom: 8px;
}
.employee_single .hashtags li span {
    background-color: #fff;
    border: 1px solid #000;
    padding: 0 10px;
}
.employee_single .section02 .box01 .img_box {
    position: absolute;
    bottom: 0%;
    left: 5%;
}
.employee_single .section02 .box01 .img_box img {
  display: block;
  max-width: 100%;
  height: auto;
}
.employee_single .section02 .box01 .img_box .person-img {
    position: relative;
    z-index: 1;
    width: 90%;
    left: 20%;
    top: 0%;
}
.employee_single .section02 .box01 .img_box .person-img img {}
.employee_single .section02 .box01 .img_box .person-shapes {
    position: absolute;
    inset: 0;
    z-index: 0;
    object-fit: contain;
    left: 15%;
    top: 10%;
}
.employee_single .section02 .box01 .img_box .person-shapes img {}
.employee_single .section02 .box02 {
    padding: 75px 0px;
    width: 40%;
    margin: 0 auto;
}
.employee_single .section02 .box02 .ttl_box {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}
.employee_single .section02 .history_box {
  position: relative;
  padding: 8px 0;
}
.employee_single .section02 .history-list {
    list-style: none;
    margin: 0;
    padding: 0;
    margin-top: 5px;
}
.employee_single .section02 .history-list li {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 0 18px;
    height: auto;
}
.employee_single .section02 .history-list li::after {
    content: "";
    position: absolute;
    left: 112px;
    top: 42px;
    bottom: -4px;
    border-left: 5px dotted var(--accent);
    opacity: .65;
}
.employee_single .section02 .history-list li:last-child::after { content: none; }
.employee_single .section02 .history-list .year {
    width: 100px;
    flex-shrink: 0;
    font-weight: 800;
    letter-spacing: 2px;
    display: flex;
    align-items: center;
    height: 30px;
}
.employee_single .section02 .history-list .text {
    position: relative;
    padding-left: 14px;
    line-height: 1.2;
    font-weight: 600;
    height: 30px;
    display: flex;
    align-items: center;
}
.employee_single .section02 .history-list .text::before {
  content: "";
  position: absolute;
  left: 0;
  top: .25em;
  bottom: .25em;
  width: 4px;
  border-radius: 2px;
  background: var(--accent);
}
.employee_single .section03 {
    padding-top: 120px;
    position: relative;
}
.employee_single .section03 .slash01 {}
.employee_single .section03 .slash02 {}
.employee_single .section03 .img_box img {
    border-radius: 15px;
    box-shadow: 3px 3px 19px #c9c9c9;
    aspect-ratio: 6/4;
    object-fit: cover;
}
.employee_single .section03 .area {}
.employee_single .section03 .area .box {}
.employee_single .section03 .area .box01 {}
.employee_single .section03 .area .box01 .ttl {
    letter-spacing: 1px;
    font-size: clamp(1.25rem, 1.065rem + 0.62vw, 1.625rem);
}
.employee_single .section03 .area .box01 .txt_box {
    line-height: 2;
    padding-top: 35px;
}
.employee_single .section03 .area .box01 .txt_box p {
    font-size: clamp(13px, calc((100vw - var(--vw-min)) * 0.00233 + 13px), 15px);
    line-height: 2.3;
}
.employee_single .section03 .area .box02 {}
.employee_single .section03 .area .box02 .img_box {}
.section03.main_draft .area {
    position: relative;
    gap: 40px;
    align-items: flex-start;
    padding-top: 120px;
}
.section03.main_draft .area > * {
  position: relative;
  z-index: 1;
}
.section03.main_draft .area::before {
    content: "";
    position: absolute;
    top: -60%;
    left: 50%;
    width: 100vw;
    height: 200%;
    transform: translateX(-50%);
    background: linear-gradient(
    var(--angle, 120deg),
    transparent 0 45%,
    rgb(var(--bar, 178 69 214) / .04) 45% 60%,
    transparent 60% 100%
  );
    pointer-events: none;
    z-index: 0;
}
.section03.main_draft .area:nth-child(even) .box01  {
  order: 2;
}
.section03.main_draft .area:nth-child(even) .box02  {
  order: 1;
}
.section03.main_draft .area.bar-slash {
    --angle: 170deg;
}
.section03.main_draft .area.bar-forward {
    --angle: 10deg;
}
/* エリア別（area01〜area05）個別編集したい時に */
.employee_single .section03 .area01 {}
.employee_single .section03 .area02 {}
.employee_single .section03 .area03 {}
.employee_single .section03 .area04 {}
.employee_single .section03 .area05 {}

/* 最下部のスライド */
.bottom_section {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 150px;
    padding-bottom: 85px;
}
.bottom_section .slide-wrapper {
    position: relative;
    width: 100%;
    height: 685px;
    transition: background-color 0.5s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    border-radius: 200px;
}
.bottom_section .slide-wrapper .slide_ttl {
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
}
.bottom_section .slide-wrapper .slide_ttl p {}
.bottom_section .slide-wrapper .slide_ttl .ttl {
    background-color: #fff;
    border: 1px solid #000;
    padding: 1px 6px;
    font-weight: 600;
    letter-spacing: 1px;
}
.bottom_section .swiper {
    width: 100%;
    height: 90%;
}
.bottom_section .swiper-slide {
    width: 100%;
    height: auto;
    border-radius: 20px;
    color: #fff;
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 20px;
    box-sizing: border-box;
    position: relative;
    overflow: visible;
}
.bottom_section .swiper-slide img {
    width: 100%;
    border-radius: 10px;
    height: auto;
    display: block;
    object-fit: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.bottom_section .swiper-slide .slide-img {
    position: absolute;
    top: 48%;
    left: 50%;
    width: 100%;
    height: auto;
    transform: translate(-50%, -50%);
    transition: opacity 0.5s ease;
    border-radius: 10px;
    z-index: 1;
}

.bottom_section .swiper-slide .center-img {
  opacity: 0;
  z-index: 2;
}

.bottom_section .swiper-slide .side-img {
  opacity: 1;
  z-index: 1;
}
.swiper-slide.swiper-slide-active .center-img {
  opacity: 1;
}

.swiper-slide.swiper-slide-active .side-img {
  opacity: 0;
}
.bottom_section .nav-buttons {
    position: absolute;
    bottom: -10%;
    right: 40%;
    display: flex;
    flex-direction: row;
    z-index: 10;
}
.swiper-button-next:after, .swiper-button-prev:after {
  display: none;
}
.bottom_section .swiper-button-prev, .bottom_section .swiper-button-next {
    flex-direction: column;
    font-size: 14px;
    gap: 2px;
}
.bottom_section .swiper-button-prev, .bottom_section .swiper-button-next span {
  color: #000;
}
.bottom_section .swiper-button-prev {
  position: relative;
}
.bottom_section .swiper-button-next {
  position: relative;
}
.bottom_section .swiper-button-prev, .bottom_section .swiper-button-next {
    width: 95px;
    height: 95px;
    padding: 10px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.bottom_section .swiper-button-prev img, .bottom_section .swiper-button-next img {
    width: 30px;
    height: auto;
}
.bottom_section .swiper-slide {
    transform: scale(0.8);
    opacity: 1;
    transition: transform 0.3s ease, opacity 0.3s ease;
}
.bottom_section .swiper-slide.swiper-slide-active {
    transform: scale(1.3);
    opacity: 1;
}
.bottom_section .swiper-slide .slide-number {
    position: absolute;
    top: 25%;
    left: 10%;
    font-size: 60px;
    font-weight: bold;
    text-shadow: -1px -1px 0 black,
     1px -1px 0 black,
    -1px  1px 0 black,
     1px  1px 0 black;
    z-index: 5;
}
.bottom_section .swiper-slide .text-box {
  position: absolute;
  padding: 5px 10px;  border-radius: 5px;
  font-size: 14px;
  z-index: 2;
}
.bottom_section .swiper-slide .text-center {
    top: 42%;
    left: 18%;
    width: 110px;
    display: flex;
    justify-content: flex-end;
    height: 165px;
}
.bottom_section .swiper-slide .text-center p {
    writing-mode: vertical-rl;
    color: #000;
    height: auto;
    display: inline-block;
    height: 165px;
}
.bottom_section .swiper-slide .text-topleft {
    right: 0%;
    top: 30%;
    z-index: 0;
}
.bottom_section .swiper-slide .text-bottomleft {
    bottom: 22%;
    left: 10%;
    z-index: 3;
}
.bottom_section .swiper-slide.swiper-slide-active .text-bottomleft {
    bottom: 17%;
    left: 10%;
    z-index: 3;
}
.bottom_section .swiper-slide .text-bottomleft .ttl {
    background-color: #000;
    margin-bottom: 2px;
    display: inline-block;
    padding: 3px 5px;
    font-size: 10px;
}
.bottom_section .text-bottomleft ul {
  display: none;
  transform: translateY(10px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.swiper-slide.swiper-slide-active .text-bottomleft ul {
  display: block;
  transform: translateY(0);
}
.bottom_section .swiper-slide .text-bottomleft ul li {
    color: #000;
}
.bottom_section .swiper-slide .text-bottomleft ul li span {
    background-color: #fff;
    padding: 1px 3px;
    display: inline-block;
    letter-spacing: 1px;
    font-weight: 800;
    margin-bottom: 0px;
    border: 1px solid #000;
}
.bottom_section .custom-link-btn {
    position: absolute;
    top: 10%;
    left: 10%;
    z-index: 20;
    color: #fff;
    padding: 10px 20px;
    border: 2px solid #fff;
    text-decoration: none;
    font-weight: bold;
    box-shadow: 0 2px 6px rgba(0,0,0,0.2);
    transform: skewY(-8deg);
}

.bottom_section .circle-name {
  padding: 5%;
}

.bottom_section .block {
    width: 75px;
    height: 75px;
    margin: auto;
}

.bottom_section .circleText {
  overflow: visible;
  animation: rotation 18s linear infinite;
}
.bottom_section .circleText__circle {
  fill: none;
}
.bottom_section .circleText__text {
    fill: #000;
    font-size: 20px;
    letter-spacing: 0.05em;
    font-weight: bold;
}

@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* ========== concept ========== */
.concept_top {
    height: 860px;
}
.concept_top .parent {
    height: 800px;
}
.concept_top .div1 {
    align-items: flex-start;
    width: 75%;
    margin: 0 auto;
}
.concept_top .color_belt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1150px;
    z-index: -1;
    overflow: hidden;
}
.concept_top .color_belt img {
    width: 100%;
    height: 100%;
    display: block;
}
.concept_top .color_belt::after {
    content: "";
    position: absolute;
    inset: 0;
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 0.5) 85%, rgba(255, 255, 255, 1) 98%);
}
.concept_page .section {}
.concept_page .section .container{}
.concept_page .section .area {
    justify-content: space-between;
    align-items: stretch;
}
.concept_page .section .area .box{
    flex: 1;
    position: relative;
}
.concept_page .section .area .box01{}
.concept_page .section .area .box02{}
.concept_page .section .ex {
    line-height: 3;
    font-weight: 500;
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 16px;
    text-decoration-thickness: .5px;
    letter-spacing: 3px;
}
.concept_page .section .ex .color_txt{}
.concept_page .section .area .middle {
    line-height: 2.1;
    letter-spacing: 8px;
}
.concept_page .section .area .middle .copy {
    color: #fff;
    padding: 4px 2px;
    border-radius: 6px;
    letter-spacing: 8px;
}
.concept_page .section .ttl_box {
    margin-bottom: 25px;
}
.concept_page .section .ttl_box .chapter {
    margin-bottom: 8px;
    font-weight: 900;
}
.concept_page .section .ttl_box .ttl {
    text-shadow: none;
    letter-spacing: 4px;
    font-weight: 500;
}

.concept_page .section02 {
    position: relative;
}
.concept_page .section02 .container {
    padding-top: 200px;
}
.concept_page .section02 .area{}
.concept_page .section02 .area .box{}
.concept_page .section02 .area .box01{}
.concept_page .section02 .area .box02{}
.concept_page .section02 .ex{}
.concept_page .section02 .ex .color_txt {
    color: var(--pink);
}
.concept_page .section02 .area .middle {
    margin: 25px 0;
}
.concept_page .section02 .area .middle .copy {
    background-color: var(--pink);
}
.concept_page .section02 .ttl_box{}
.concept_page .section02 .ttl_box .chapter {
    color: var(--pink);
}
.concept_page .section02 .ttl_box .ttl{}
.concept_page .section02 .ttl_box .ttl{}
.concept_page .section02 .img_box {
    position: relative;
    width: 75%;
    margin: 0 auto;
}
.concept_page .section02 .img_box img {
    box-shadow: 0 0 13px #575757;
    position: absolute;
    border-radius: 15px;
    height: fit-content;
    object-fit: cover;
    cursor: pointer;
    will-change: transform, box-shadow, opacity;
}
.concept_page .section02 .img_box img:nth-child(1) {
    transform: rotate(8deg);
    left: 10%;
}
.concept_page .section02 .img_box img:nth-child(2) {
  transform: rotate(-2deg);
}

.concept_page .section03 {
    position: relative;
}
.concept_page .section03 .container {
    padding-top: 120px;
}
.concept_page .section03 .area{
  gap: 60px;
}
.concept_page .section03 .area .box{}
.concept_page .section03 .area .box01{}
.concept_page .section03 .area .box02{}
.concept_page .section03 .ex{}
.concept_page .section03 .ex .color_txt{
  color: var(--sky);
}

.concept_page .section03 .area .middle {
    line-height: 2.1;
    margin-bottom: 12px;
}
.concept_page .section03 .area .middle .copy {
    background-color: var(--sky);
}
.concept_page .section03 .ttl_box{}
.concept_page .section03 .ttl_box .chapter{
  color: var(--sky);
}
.concept_page .section03 .ttl_box .ttl{}
.concept_page .section03 .ttl_box .ttl{}
.concept_page .section03 .area .box01 .img_box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
}
.concept_page .section03 .area .box01 .img_box .left {}
.concept_page .section03 .area .box01 .img_box .right {}
.concept_page .section03 .img_box img {
    box-shadow: 0 0 13px #575757;
    border-radius: 15px;
    height: auto;
    object-fit: cover;
    cursor: pointer;
}
.concept_page .section03 .img_box img:nth-child(1) {
    margin-bottom: 60px;
}
.concept_page .section03 .img_box img:nth-child(2) {
}
.concept_page .section03 .img_box img:nth-child(3) {
}

.concept_page .section04 {
    position: relative;
}
.concept_page .section04 .container {
    padding-top: 140px;
}
.concept_page .section04 .area{}
.concept_page .section04 .area .box{}
.concept_page .section04 .area .box01{}
.concept_page .section04 .area .box02{}
.concept_page .section04 .ex{}
.concept_page .section04 .ex .color_txt{
  color: var(--brown);
}
.concept_page .section04 .area .middle {
    margin: 25px 0;
}
.concept_page .section04 .area .middle .copy{
  background-color: var(--brown);
}
.concept_page .section04 .ttl_box{}
.concept_page .section04 .ttl_box .chapter {
    color: var(--brown);
}
.concept_page .section04 .ttl_box .ttl{}
.concept_page .section04 .ttl_box .ttl{}
.concept_page .section04 .img_box {
    position: relative;
    width: 100%;
    margin: 0 auto;
}
.concept_page .section04 .img_box img {
    box-shadow: 0 0 13px #575757;
    position: absolute;
    border-radius: 15px;
    height: fit-content;
    object-fit: cover;
    cursor: pointer;
    will-change: transform, box-shadow, opacity;
}
.concept_page .section04 .img_box img:nth-child(1) {
    transform: rotate(-4deg);
    left: 10%;
    top: 50px;
}
.concept_page .section04 .img_box img:nth-child(2) {
    transform: rotate(1deg);
    left: 10%;
    top: 10px;
}
.concept_page .section05 {
    background: url(../img/child/concept/concept-chapter04-01-3.webp) center / cover no-repeat;
    height: 400px;
    margin-top: 120px;
}
.concept_page .section05 .area {
    position: relative;
    height: 100%;
}
.concept_page .section05 .copy {
    display: inline-block;
    position: absolute;
    bottom: 5%;
    right: 5%;
    font-weight: 400;
    color: #fff;
    letter-spacing: 8px;
    line-height: 1.6;
    font-weight: 600;
}
.concept_page .section02 .slash01 {
    clip-path: polygon(0 55%, 100% 0%, 100% 45%, 0% 100%);
    height: 800px;
    width: 100%;
    background-color: #ca3e8f08;
    position: absolute;
    top: 35%;
    z-index: -1;
}
.concept_page .section03 .slash01 {
    clip-path: polygon(0 85%, 100% 0%, 100% 15%, 0% 100%);
    height: 500px;
    width: 100%;
    background-color: #079fba0a;
    position: absolute;
    top: 27%;
    z-index: -1;
}
.concept_page .section03 .slash02 {
    clip-path: polygon(0 0, 100% 85%, 100% 100%, 0 15%);
    height: 500px;
    width: 100%;
    background-color: #079fba0a;
    position: absolute;
    bottom: 0%;
    z-index: -1;
}
.concept_page .section04 .slash01 {
    clip-path: polygon(0 65%, 100% 0%, 100% 35%, 0% 100%);
    height: 500px;
    width: 100%;
    background-color: #8b623a08;
    position: absolute;
    top: 22%;
    z-index: -1;
}
.concept_page .section04 .slash02 {
    clip-path: polygon(0 80%, 100% 0%, 100% 20%, 0% 100%);
    height: 406px;
    width: 100%;
    background-color: #8b623a08;
    position: absolute;
    top: 47%;
    z-index: -1;
}
.concept_page .section04 .slash03 {
    clip-path: polygon(0 90%, 100% 0%, 100% 10%, 0% 100%);
    height: 363px;
    width: 100%;
    background-color: #8b623a08;
    position: absolute;
    top: 60%;
    z-index: -1;
}

/* ========== page-project.php ========== */
.project_top {
    height: 100%;
}
.project_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.project_top {
    margin-top: -80px;
    background-color: var(--blue);
}
.project_top .area:nth-child(1) {
    position: relative;
    height: 100%;
    z-index: 2;
}
.project_top .area:nth-child(1) .ttl_box {
    position: absolute;
    top: 40%;
    left: 5%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.project_top .area:nth-child(1) .title-en01 {}
.project_top .area:nth-child(1) .title-ja {}
.project_top .area:nth-child(1) .title-en02 {}
.project_top .area:nth-child(1) .img_box {
    display: flex;
    justify-content: space-between;
    height: 560px;
}
.project_top .area:nth-child(1) .img_box img {
}
.project_top .title-en02 {
    color: #000;
    background-color: transparent;
    padding: 0;
}
.project_top .area:nth-child(1) .img_box .top_01 {
    width: 38%;
    object-fit: cover;
    height: auto;

}
.project_top .area:nth-child(1) .img_box .top_02 {
    width: 60%;
    object-fit: cover;
    height: 100%;
}
.project_top {}


.project_top .area:nth-child(1) {}
.project_top .area:nth-child(1) .ttl_box {}
.project_top .area:nth-child(1) .title-en01 {}
.project_top .area:nth-child(1) .title-ja {}
.project_top .area:nth-child(1) .title-en02 {}

.project_top .area:nth-child(1) .img_box .top_01 {}
.project_top .area:nth-child(1) .img_box .top_02 {}
.project_page .link_area {
    justify-content: space-between;
    align-items: center;
    background-color: var(--blue);
    padding: 60px 5%;
    width: 100%;
}
.project_page .circle_block01 .block {
    width: 650px;
    height: auto;
    opacity: .4;
}
.project_page .circle_block01 {
    position: fixed;
    top: 50%;
    right: 0%;
    z-index: 1;
}
.project_page .link_area .txt_box {
    color: #fff;
    width: 30%;
}
.project_page .link_area .txt_box .ttl {
    text-shadow: none;
}
.project_page .link_area .txt_box .ex {
    padding-top: 20px;
}
.project_page .link_area .link_box {
    display: flex;
    width: 60%;
    gap: 15px;
    position: relative;
    z-index: 2;
}
.project_page .link_area .link_box a {}
.project_page .link_area .link_box a .card {
    position: relative;
}
.project_page .link_area .link_box a .img_box {}
.project_page .link_area .link_box a .img_box img {
    border-radius: 10px;
}
.project_page .link_area .link_box a .txt_box {
    gap: 8px;
    position: absolute;
    bottom: 5%;
    left: 5%;
    color: #000;
}
.project_page .link_area .link_box a .txt_box .tag {
    background-color: var(--blue);
    display: inline-block;
    padding: 2px 5px;
    margin-bottom: 5px;
    color: #fff;
}
.project_page .link_area .link_box a .txt_box .name {
    background-color: var(--blue);
    display: inline-block;
    padding: 2px 5px;
    white-space: nowrap;
    color: #fff;
}
.project_top .circle_block01 {
    position: fixed;
    top: 0%;
    right: -10%;
    z-index: 0;
}
.project_top .circle_block01 .circle-name{}
.project_top .circle_block01 .circle-name .block{
    width: 700px;
    height: 700px;
    margin: auto;
    opacity: .4;
}
.project_page .circle_block01 .circleText {
    font-size: 20px;
    letter-spacing: 3px;
    fill: #ffffff6e;
}
.project_page .circle_block01 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.project_top .circle_block01 .circle-name .circleText{}
.project_top .circle_block01 .circle-name .circleText .circle{}
.project_top .circle_block01 .circle-name .circleText .circleText__text{}
.project_section {
    position: relative;
}
.project_section  .slash01 {
    clip-path: polygon(0 40%, 100% 0%, 100% 60%, 0% 100%);
    height: 800px;
    width: 100%;
    background-color: hsl(
211deg 100% 29% / 2%);
    position: absolute;
    top: -7%;
    z-index: -1;
}
.project_section .slash02 {
    clip-path: polygon(0 0, 100% 55%, 100% 100%, 0 45%);
    height: 500px;
    width: 100%;
    background-color: hsl(
211deg 100% 29% / 2%);
    position: absolute;
    top: 23%;
    z-index: -1;
}
.project_section .slash03 {
    clip-path: polygon(0 90%, 100% 0%, 100% 10%, 0% 100%);
    height: 430px;
    width: 100%;
    background-color: hsl(
211deg 100% 29% / 2%);
    position: absolute;
    top: 43%;
    z-index: -1;
}
.project_section .slash04 {
    clip-path: polygon(0 0, 100% 55%, 100% 100%, 0 45%);
    height: 700px;
    width: 100%;
    background-color: hsl(
211deg 100% 29% / 2%);
    position: absolute;
    bottom: 15%;
    z-index: -1;
}
.project_section .slash05 {
    clip-path: polygon(0 90%, 100% 0%, 100% 10%, 0% 100%);
    height: 560px;
    width: 100%;
    background-color: hsl(
211deg 100% 29% / 2%);
    position: absolute;
    bottom: -8%;
    z-index: -1;
}
.project_section .slash06 {
    clip-path: polygon(0 90%, 100% 0%, 100% 10%, 0% 100%);
    height: 560px;
    width: 100%;
    background-color: hsl(
211deg 100% 29% / 2%);
    position: absolute;
    bottom: -11%;
    z-index: -1;
}
.project_section .container{}
.project_section .area{}
.project_section .area .box{}
.project_section .area .box01 {}
.project_section .area .box01 .ttl_box{}
.project_section .area .box01 .ttl_box .copy{}
.project_section .area .box01 .ttl_box .ttl{}
.project_section .area .box01 .ttl_box .ttl .number{}
.project_section .area .box01 .index_box{}
.project_section .area .box01 .index_box .card{}
.project_section .area .box01 .index_box .card .img_box{}
.project_section .area .box01 .index_box .card .img_box img{}
.project_section .area .box01 .index_box .card .img_box img{}
.project_section .area .box01 .index_box .name_box{}
.project_section .area .box01 .index_box .name_box .tag{}
.project_section .area .box01 .index_box .name_box .name{}
.project_section .area .box02 {}
.project_section .area .box02 .img-box{}
.project_section .area .box02 .img-box img:nth-child(1){}
.project_section .area .box02 .img-box img:nth-child(2){}

.project_section .area_00 {
    padding: 120px 0 0;
}
.project_section .area_00 .box{}
.project_section .area_00 .box01 {
    width: 50%;
}
.project_section .area_00 .box01 .ttl_box {
    border-bottom: 1px solid var(--blue);
}
.project_section .area_00 .box01 .ttl_box .copy{}
.project_section .area_00 .box01 .ttl_box .ttl {
    text-shadow: none;
    padding-bottom: 10px;
    font-size: clamp(1.25rem, 1.096rem + 0.52vw, 1.563rem);
}
.project_section .area_00 .box01 .ttl_box .ttl .number {
    font-size: clamp(1.25rem, 1.096rem + 0.52vw, 1.563rem);
}
.project_section .area_00 .box01 .index_box {
    padding-top: 50px;
}
.project_section .area_00 .box01 .index_box .card {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
}
.project_section .area_00 .box01 .index_box .card .img_box{}
.project_section .area_00 .box01 .index_box .card .img_box img {
    width: 65px;
    height: 65px;
    object-fit: contain;
}
.project_section .area_00 .box01 .index_box .name_box{}
.project_section .area_00 .box01 .index_box .name_box .tag{}
.project_section .area_00 .box01 .index_box .name_box .name{}
.project_section .area_00 .box02 {
    width: 50%;
}
.project_section .area_00 .box02 .img-box {
    position: relative;
    width: 95%;
    margin: 0 auto;
    left: -10px;
}
.project_section .area_00 .box02 .img-box img {
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 15px;
    box-shadow: 0 0 30px #Fff;
    aspect-ratio: 16/9;
}
.project_section .area_00 .box02 .img-box img:nth-child(1){
    transform: rotate(-3deg);
}
.project_section .area_00 .box02 .img-box img:nth-child(2) {
    transform: rotate(3deg);
}

.project_section .area_detail {
    position: relative;
    z-index: 1;
}
.project_section .area_detail .box{}
.project_section .area_detail .box01 {
    width: 35%;
    margin-right: auto;
}
.project_section .area_detail .box01 .img_box{}
.project_section .area_detail .box01 .img_box img {
    aspect-ratio: 1;
    border-radius: 15px;
}
.project_section .area_detail .box02 {
    width: 60%;
}
.project_section .area_detail .box02 .ttl_box {
    display: flex;
    align-items: center;
}
/* 見出し：01 …… 破線 …… タイトル */
.project_section .area_detail .box02 .ttl_box{
  display: flex;
  align-items: baseline; 
  gap: clamp(8px, 1vw, 14px);
}

.project_section .area_detail .box02 .ttl_box .number{
  color: var(--c-blue, #0B5CCB);
  font-weight: 800;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: clamp(8px, 1vw, 12px);
  font-size: var(--fs-num-lg);
}

.project_section .area_detail .box02 .ttl_box .number::after{
  content: "";
  display: inline-block;
  width: clamp(18px, 4vw, 44px);
  border-top: 2px dotted color-mix(in oklab, var(--c-blue, #0B5CCB) 55%, white 45%);
  opacity: .9;
  transform: translateY(-0.1em);
}
.project_section .area_detail .box02 .ttl_box .ttl {
    font-weight: 700;
    text-shadow: none;
    font-size: clamp(1.125rem, 1.002rem + 0.41vw, 1.375rem);
}
.project_section .area_detail .box02 .ttl_box .ttl{}
.project_section .area_detail .box02 .contents_box {
    margin-top: 50px;
}
.project_section .area_detail .box02 .contents_box .list {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 35px;
}
.project_section .area_detail .box02 .contents_box .list .img_box {
    width: 20%;
    margin: 0 auto;
}
.project_section .area_detail .box02 .contents_box .list .img_box img {
    width: 70px;
    aspect-ratio: 1;
    object-fit: contain;
}
.project_section .area_detail .box02 .contents_box .list .txt{}
.project_section .area_detail .box02 .contents_box .list .txt {
    width: 80%;
    color: var(--gray);
    font-weight: 400;
    line-height: 1.8;
}
.project_section .area_01 {
    padding-top: 120px;
}
.project_section .area_01 .box01 {

}
.project_section .area_01 .box02 {}

.project_section .area_02 {
    padding-top: 120px;
}
.project_section .area_02 .box01 {
    order: 2;
    margin-right: inherit;
    margin-left: auto;
}
.project_section .area_02 .box02 {
    order: 1;
}

.project_section .area_03 {
    padding-top: 120px;
}
.project_section .area_03 .box01 {}
.project_section .area_03 .box02 {}

.project_page .bottom_section {
    padding-bottom: 0;
}
.project_page .bottom_section .container {}
/* hidden 未定義なら */
[hidden]{ display:none !important; }

/* 切替アニメ（フェード＋下からスライド） */
.project_section.panel{
  transition: opacity .35s ease, transform .35s ease;
}
.project_section.panel.anim-enter{
  opacity: 0;
  transform: translateY(12px);
}
.project_section.panel.anim-enter.anim-active{
  opacity: 1;
  transform: translateY(0);
}
/* 共通：filter のアニメーションを許可 */
.link_area .js-panel-link .card {
    transition: filter 0.3s ease;
}

/* 非表示側（暗くする） */
.link_area .js-panel-link[aria-selected="false"] .card {
    filter: brightness(0.3);
}

/* 表示側（明るい） */
.link_area .js-panel-link[aria-selected="true"] .card {
    filter: brightness(1);
}


/* モーション控えめに配慮 */
@media (prefers-reduced-motion: reduce){
  .project_section.panel{ transition: none !important; }
}

/* hover アニメーション（共通） */
.link_area .js-panel-link:hover .card {
    filter: brightness(0.55);
}

/* 選択中は hover で少し明るく（主張しすぎない程度） */
.link_area .js-panel-link[aria-selected="true"]:hover .card {
    filter: brightness(1.1);
}

/* ========== page-services.php ========== */
.services_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.services_top {
    margin-top: -80px;
}
.services_top .area:nth-child(1) {
    position: relative;
    height: 70%;
}
.services_top .area:nth-child(1) .ttl_box {
    position: absolute;
    top: 40%;
    left: 5%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.services_top .area:nth-child(1) .title-en01 {}
.services_top .area:nth-child(1) .title-ja {}
.services_top .area:nth-child(1) .title-en02 {}
.services_top .area:nth-child(1) .img_box {
    height: 100%;
    justify-content: space-between;
    display: flex;
    gap: 10px;
}
.services_top .area:nth-child(1) .img_box img {
}
.services_top .area:nth-child(1) .img_box .top_01 {
    width: 39%;
    object-fit: cover;
    height: 100%;
}
.services_top .area:nth-child(1) .img_box .top_02 {
    width: 60%;
    object-fit: cover;
    height: 100%;
}
.services_page .link_area {
    height: 30%;
}
.services_page .link_area .txt_box {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 90%;
    margin: 0 auto;
}
.services_page .link_area .txt_box .ttl {}
.services_page .link_area .txt_box .ex {}
.services_top .circle_block {
    position: absolute;
    top: 0px;
    right: -25%;
    z-index: -1;
}
.services_top .circle_block .circle-name{}
.services_top .circle_block .circle-name .block{}
.services_top .circle_block .circle-name .circleText{}
.services_top .circle_block .circle-name .circleText .circle{}
.services_top .circle_block .circle-name .circleText .circleText__text {
    font-size: 22px;
    letter-spacing: 1px;
}
.services_top .circle_block .circle-name .block {
    width: 865px;
    height: 865px;
    margin: auto;
    opacity: .4;
}
.services_top .circle_block .circle-name.circleText__text {
    fill: var(--purple);
    font-size: 20px;
    letter-spacing: 0.05em;
}
.services_section {
    padding-bottom: 120px;
}
.services_section .area {
  justify-content: space-between;
  align-items: flex-start;
    flex-wrap: nowrap;
    align-items: stretch;
}
.services_section .box01 {
    width: 25%;
    min-width: 220px;
    align-self: stretch;
}
.services_section .services_list {
    position: sticky;
    top: 70px;
    width: 80%;
    margin: 0 auto;
}
.services_section .services_list li {
    font-weight: 600;
    padding-top: 18px;
}
.services_section .services_list li a {
    width: 100%;
    display: block;
}
.services_section .services_list li:nth-child(1) {
    border-bottom: 1px solid var(--red);
}
.services_section .services_list li:nth-child(2){
  border-bottom: 1px solid var(--yellow);
}
.services_section .services_list li:nth-child(3){
  border-bottom: 1px solid var(--purple);
}
.services_section .services_list li:nth-child(4){
  border-bottom: 1px solid var(--orange);
}
.services_section .services_list li:nth-child(5){
  border-bottom: 1px solid var(--green);
}
.services_section .services_list li:nth-child(6){
  border-bottom: 1px solid var(--brown);
}
.services_section .services_list li:nth-child(7){
  border-bottom: 1px solid var(--brown);
}
.services_section .box02 {
    width: 73%;
}
.services_section .contents {
    position: relative;
    height: 850px;
    border-radius: 50px 0 0 0;
}
.services_section .contents .back_txt{}
.services_section .contents .back_txt.ttl {
    font-size: 120px;
    text-shadow: none;
    opacity: .1;
    position: absolute;
    top: 5%;
    left: 5%;
    line-height: 1;
    font-weight: 900;
    z-index: 0;
}
.services_section .contents .back_txt.number {
    font-size: 150px;
    text-shadow: none;
    opacity: .1;
    position: absolute;
    top: 30%;
    right: 5%;
    line-height: 1;
}
.services_section .contents .card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    color: #fff;
    width: 90%;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.services_section .contents .card .ttl {
    text-shadow: none;
    margin-bottom: 20px;
    width: 60%;
}
.services_section .contents .card .lead {
    margin-bottom: 8px;
    width: 60%;
}
.services_section .contents .card .ex {
    margin-bottom: 20px;
    width: 60%;
}
.services_section .contents .card .img_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 16px;
}
.services_section .contents .card .img_box img {
    width: 32%;
    border-radius: 10px;
}

/* 475px 以下でスライドショー表示に切り替え */
@media (max-width: 475px) {

  .services_section .contents .card .img_box {
    position: relative;
    display: block; 
    width: 100%;
    max-width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    gap: 0;
  }

.services_section .contents .card .img_box img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
    opacity: 0;
    animation: serviceSlide 30s infinite ease-in-out;
  }

  /* 6枚あるので、アニメーションの開始タイミングをずらす */
  .services_section .contents .card .img_box img:nth-child(1) { animation-delay: 0s; }
  .services_section .contents .card .img_box img:nth-child(2) { animation-delay: 5s; }
  .services_section .contents .card .img_box img:nth-child(3) { animation-delay: 10s; }
  .services_section .contents .card .img_box img:nth-child(4) { animation-delay: 15s; }
  .services_section .contents .card .img_box img:nth-child(5) { animation-delay: 20s; }
  .services_section .contents .card .img_box img:nth-child(6) { animation-delay: 25s; }

  @keyframes serviceSlide {
    0%    { opacity: 0; }
    10%   { opacity: 1; }
    90%   { opacity: 1; }
    100%  { opacity: 0; }
  }
}

.services_section .contents .buttons {
    display: inline;
    position: absolute;
    bottom: 13%;
    right: 3%;
}
.services_section .contents .buttons [class^=btn-] {
    width: 285px;
    background-color: #000;
}
.services_section .contents:not(:first-child){
  margin-top: -40px;
}
.services_section .contents.office {
  background-color: var(--gray);
}
.services_section .contents.pachinko {
  background-color: var(--red);
}
.services_section .contents.rental {
  background-color: var(--orange);
}
.services_section .contents.hotel {
  background-color: var(--purple);
}
.services_section .contents.food {
  background-color: var(--green);
}
.services_section .contents.services_area {
  background-color: var(--yellow);
}
.services_section .contents.game {
    background-color: var(--brown);
    border-radius: 50px 0 0 50px;
}
.services_section .btn-0:before {
    background-color: #fff;
}
.services_section .btn-0.btn-0:hover {
    color: #000;
}


/* ========== page-recruit.php ========== */
.recruit_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.circle_block01 {
    position: fixed;
    top: -26%;
    right: 0%;
    z-index: -1;
}
.circle_block01 .circle-name{}
.circle_block01 .block{
    width: 400px;
    height: 400px;
    margin: auto;
    opacity: .4;
}
.recruit_page .circle_block01 .circleText {
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--orange);
}
.recruit_page .circle_block01 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.circle_block02 {
    position: fixed;
    top: 80%;
    left: 0%;
    z-index: -1;
}
.circle_block02 .circle-name{}
.circle_block02 .block{
    width: 400px;
    height: 400px;
    margin: auto;
    opacity: .4;
}
.recruit_page .circle_block02 .circleText{
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--orange);
}
.recruit_page .circle_block02 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.recruit_section {
    position: relative;
    padding-top: 120px;
    padding-bottom: 120px;
}
.recruit_section .area {
    justify-content: space-between;
}
.recruit_section .area .box {}
.recruit_section .area .box01 {
  width: 25%;
}
.recruit_section .area .box01 .ttl_box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 80%;
    margin: 0 auto;
}
.recruit_section .area .box01 .title-en01 {}
.recruit_section .area .box01 .title-en02 {}
.recruit_section .area .box01 .title-ja {
    border: 1px solid #000;
    padding: 0 8px;
    font-weight: 400;
}
.recruit_section .area .box01 .recruit_list {
    width: 80%;
    margin: 0 auto;
    padding-top: 30px;
    position: sticky;
    top: 70px;
}
.recruit_section .area .box01 .recruit_list  li {
    font-weight: 600;
    padding-top: 18px;
    border-bottom: 1px solid #000;
}
.recruit_section .area .box01 .recruit_list li a {
      width: 100%;
    display: block;
}
.recruit_section .area .box02 {
    width: 73%;
    margin-top: 70px;
}
.recruit_section .sheet {}
.recruit_section .sheet .ttl {
    text-shadow: none;
    position: relative;
    padding-left: 20px;
    font-weight: 600;
}
.recruit_section .sheet .ttl::before {
    content: "●";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    font-size: 10px;
    color: #000;
    line-height: 1;
}
.recruit_section .sheet table {
    border-collapse: separate;
    border-spacing: 0;
    border-radius: 30px 0 0 30px;
    overflow: hidden;
    width: 100%;
    margin-top: 20px;
    box-shadow: 0 0 30px #b3b3b3;
}
.recruit_section .sheet tbody{}
.recruit_section .sheet tbody tr{}
.recruit_section .sheet tbody tr th {
    background-color: #ed6f01e0;
    text-align: left;
    width: 30%;
    border: 1px solid var(--orange);
    color: #fff;
    padding-left: 5%;
    font-size: clamp(18px, calc((100vw - var(--vw-min)) * 0.00465 + 18px), 22px);
    line-height: 1.6;
    letter-spacing: 1px;
}
.recruit_section .sheet tbody tr td {
    width: 70%;
    border: 1px solid var(--orange);
    padding: 20px 20px;
    font-weight: 400;
    background-color: rgb(255 255 255 / 90%);
    white-space: normal;
    font-weight: 600;
}
.recruit_section .sheet tbody tr td p {
    font-weight: 600;
    white-space: normal;
    margin-top: 5px;
}
.recruit_section .sheet tbody tr td .badge_area {}
.recruit_section .sheet tbody tr td .badge {
    color: var(--orange);
    border: 1px solid var(--orange);
    border-radius: 5px;
    padding: 0 5px;
    background-color: #fff;
    box-shadow: 0px 0px 4px #d5d5d5;
    font-weight: 500;
    margin-right: 8px;
}
.recruit_section .sheet tbody tr td .badge.tag02 {
    margin-top: 12px;
    display: inline-block;
}
.recruit_section .sheet tbody tr td p.span{}
.recruit_section .sheet tbody tr td ul{}
.recruit_section .sheet tbody tr td li {
    font-weight: 600;
}
.recruit_section #sheet02 {
    padding-top: 60px;
}
.recruit_section .biz-columns {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 24px;
    margin-top: 6px;
}
.recruit_section .biz-columns .mr-1 {
  padding-left: 16px;
}
.recruit_section .buttons {
    display: flex;
    justify-content: center;
    margin-top: 35px;
}
.recruit_section .buttons [class^=btn-] {
    height: 65px;
    width: 375px;
    background-color: #000;
    display: grid;
    place-items: center;
    height: 50px;
    transform: none;
    line-height: 50px;
    font-size: 17px;
    font-weight: 500;
    letter-spacing: 2px;
    border-radius: 8px;
}

.entry_section {
    position: relative;
    padding-bottom: 120px;
}
.entry_section .area {
    justify-content: space-between;
}
.entry_section .area .box {}
.recentry_sectionruit_section .area .box01 {
  width: 25%;
}
.entry_section .area .box01 .ttl_box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 80%;
    margin: 0 auto;
}
.entry_section .area .box01 .title-en01 {}
.entry_section .area .box01 .title-en02 {}
.entry_section .area .box01 .title-ja {
    border: 1px solid #000;
    padding: 0 8px;
}


/* ========== page-faq.php ========== */
.faq_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.faq_page .circle_block01 .circleText {
    font-size: 19px;
    letter-spacing: 1px;
    fill: var(--sky);
}
.faq_page .circle_block01 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.faq_page .circle_block02 .circle-name{}
.faq_page .circle_block02 .circleText{
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--sky);
}
.faq_page .circle_block02 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.faq_section {
    position: relative;
    padding-top: 120px;
}
.faq_section .area {
    justify-content: space-between;
}
.faq_section .area .box {}
.faq_section .area .box01 {
    width: 25%;
}
.faq_section .area .box01 .ttl_box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 80%;
    margin: 0 auto;
}
.faq_section .area .box01 .title-en01 {}
.faq_section .area .box01 .title-en02 {}
.faq_section .area .box01 .title-ja {
    border: 1px solid #000;
    padding: 0 8px;
}
.faq_section .area .box01 .recruit_list {
      width: 80%;
    margin: 0 auto;
    padding-top: 30px;
}
.faq_section .area .box01 .recruit_list  li {
    font-weight: 600;
    padding-top: 18px;
    border-bottom: 1px solid #000;
}
.faq_section .area .box01 .recruit_list li a {
      width: 100%;
    display: block;
}
.faq_section .area .box02 {
    width: 73%;
    margin-top: 70px;
}
.faq_section .box02 .card-area {
    width: 80%;
    margin: 0px auto;
    padding: 60px 0;
}
.faq_section .box02 .card-area .card {
    margin-bottom: 10px;
}
.faq_section .question-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    background-color: #000;
    color: #fff;
    padding: 1% 5%;
    border-radius: 8px;
}
.faq_section .card.open .question-wrap {
    border-radius: 8px 8px 0 0;
}

.faq_section .question {
    font-weight: bold;
    flex: 1;
    margin: 0;
    display: flex;
    align-items: center;
}
.faq_section .arrow {
  transition: transform 0.4s ease;
  margin-left: 10px;
}
.faq_section .card {
    border-radius: 8px;
    border: 1px solid #000;
}
.faq_section .card span {
    padding-right: 20px;
}
.faq_section .card.open .arrow {
  transform: rotate(180deg);
}
.faq_section .answer {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s ease, opacity 0.4s ease;
  margin: 0;
  padding: 0 5%;
}
.faq_section .card.open .answer {
    max-height: 500px;
    opacity: 1;
    padding: 1% 5%;
    border-radius: 0 0 8px 8px;
    display: flex;
    align-items: center;
    background-color: #fff;
}
.faq_section .card.open .answer span {
  color: var(--sky);
}
.faq_section .box02 .back {
    background-color: var(--sky);
    border-radius: 30px 0 0 30px;
    box-shadow: 0 0 30px #878787;
}
.section02.faq_section {
    padding-bottom: 120px;
}
.section02.faq_section .area {}
.section02.faq_section .box01 {
    width:73%;
}
.section02.faq_section .box01 .back {
    background-color: var(--sky);
    border-radius: 0px 30px 30px 0px;
    box-shadow: 0 0 30px #878787;
}
.section02.faq_section .box01 .card-area {
    width: 80%;
    margin: 0px auto;
    padding: 60px 0;
}
.section02.faq_section .box01 .card-area .card {
    margin-bottom: 10px;
}

/* ========== page-company.php ========== */
.company_page .circle_block01 .circleText {
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--gray);
}
.company_page .circle_block01 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.company_page .circle_block02 .circleText{
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--gray);
}
.company_page .circle_block02 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.company_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.company_section {
    margin-bottom: 120px;
    padding-top: 120px;
}
.company_section .area {
  justify-content: space-between;
}
.company_section .box01 {
    width: 25%;
}
.company_section .company_list {
    width: 80%;
    margin: 0 auto;
    padding-top: 10px;
    position: sticky;
    top: 50px;
}
.company_section .company_list li {
    font-weight: 600;
    padding-top: 18px;
}
.company_section .company_list li a {
    width: 100%;
    display: block;
}
.company_section .ttl_box {
    width: 97.5%;
    margin-left: auto;
}
.company_section .ttl_box .title-en01 {}
.company_section .ttl_box .title-ja {}

.company_section .company_list li:nth-child(1){
  border-bottom: 1px solid var(--red);
}
.company_section .company_list li:nth-child(2){
  border-bottom: 1px solid var(--yellow);
}
.company_section .company_list li:nth-child(3){
  border-bottom: 1px solid var(--purple);
}
.company_section .company_list li:nth-child(4){
  border-bottom: 1px solid var(--orange);
}
.company_section .company_list li:nth-child(5){
  border-bottom: 1px solid var(--green);
}
.company_section .company_list li:nth-child(6){
  border-bottom: 1px solid var(--brown);
}
.company_section .company_list li:nth-child(7) {
    border-bottom: 1px solid var(--gray);
    margin-top: 50px;
}
.company_section .box02 {
    width: 73%;
}
.company_section .contents {
    position: relative;
    height: 400px;
    border-radius: 35px 0 0 0;
}
.company_section .contents .detail {
    display: flex;
    align-items: flex-start;
    width: 95%;
    margin: 0 auto;
    gap: 20px;
}
.company_section .contents.office .img_box {
    top: 20px;
}
.company_section .contents.office, .company_section .contents.pachinko, .company_section .contents.rental, .company_section .contents.hotel, .company_section .contents.game {
    position: relative;
    height: fit-content;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 35px;
    padding-bottom: 80px;
}
.company_section .contents.game {
    padding-bottom: 50px;
}
.company_section .contents.office .img_box, 
.company_section .contents.pachinko .img_box, 
.company_section .contents.hotel .img_box {
    width: 45%;
}
.company_section .contents.rental .img_box, .company_section .contents.game .img_box,
.company_section .contents.food .img_box {
}
.company_section .contents .img_box img {
    border-radius: 12px;
    aspect-ratio: 6/3;
}
.company_section .contents.office .card, .company_section .contents.pachinko .card, .company_section .contents.rental .card, .company_section .contents.hotel .card, .company_section .contents.game .card,
.company_section .contents.food .card {
    width: 50%;
}
.company_section .contents.food, .company_section .contents.services_area {
    position: relative;
    height: fit-content;
    display: flex;
    flex-direction: column;
    padding-top: 35px;
    padding-bottom: 80px;
}
.company_section .contents.food .img_area,
.company_section .contents.services_area .img_area{
  justify-content: space-between;
}


.company_section .contents.food .img_area img,
.company_section .contents.services_area .img_area img {}

.company_section .contents.food .detail, .company_section .contents.services_area 
.detail {
    flex-direction: row;
    align-items: start;
}
.company_section .contents.services_area .img_area img {}

.company_section .contents.food .img_box, 
.company_section .contents.services_area .img_box {
}

.company_section .contents.services_area .card {
    width: 48%;
}
.company_section .contents.food .card {
    width: 95%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}
.company_section .contents.food .card .shop-area-card:nth-child(1) {
}
.company_section .contents.food .card .shop-area-card:nth-child(2) {
}
.company_section .contents.food .card .shop-area-card__list {
    column-gap: 0em;
}
.company_section .contents .card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    color: #fff;
    width: 90%;
    margin: 0 auto;
}
.company_section .contents .ttl.fs-lg {
    text-shadow: none;
    margin-bottom: 20px;
    color: #fff;
    text-align: left;
    border-bottom: 1px solid #fff;
    width: 95%;
    margin: 0 auto 20px;
}
/* add */
/* カード全体 */
.shop-area-card {
  display: inline-block;
  padding: 1em 1.2em;
}

.shop-area-card__head {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.75em;
    margin-bottom: 16px;
}

.shop-area-card__label {
    font-weight: 700;
    padding: 3px 8px 2px;
    font-size: 15px;
    border-radius: 2px;
    background-color: #fff;
}

.shop-area-card__count {
    white-space: nowrap;
    font-weight: 500;
}
.shop-area-card__body {
  margin-top: 0.4em;
}
.shop-area-card__list {
    list-style: none;
    padding: 0;
    margin: 0;
    column-count: 2;
    column-gap: 2em;
}
.shop-area-card__list li {
    position: relative;
    padding-left: 1em;
    break-inside: avoid;
    padding-bottom: 1px;
    font-weight: 500;
    font-size: 15px;
}
.shop-area-card__list li::before {
    content: "-";
    position: absolute;
    left: 0;
    top: 0;
}
.company_section .contents.game .shop-area-card__list {
    column-count: 1;
}
.shop-area-card .company_table {
    border-collapse: separate;
    border-spacing: 0 10px;
}
.shop-area-card .company_table tbody{}
.shop-area-card .company_table tr{}
.shop-area-card .company_table tr th {
    width: 28%;
}
.shop-area-card .company_table tr th, .shop-area-card .company_table tr td {
    font-weight: 500;
    vertical-align: baseline;
}
.shop-area-card .company_table tr td {
    line-height: 1.4;
    font-weight: 500;
}

.company_section .contents.pachinko .shop-area-card__label {
  color: var(--red);
}
.company_section .contents.rental .shop-area-card__label {
  color: var(--orange);
}
.company_section .contents.hotel .shop-area-card__label {
  color: var(--purple);
}
.company_section .contents.food .shop-area-card__label {
  color: var(--green);
}
.company_section .contents.services_area .shop-area-card__label {
  color: var(--yellow);
}
.company_section .contents.game .shop-area-card__label {
  color: var(--brown);
}
.company_section .contents.game .card02 {
    width: 95%;
    margin: 0 auto;
}
.shop-area-card .game_table02 {}
.shop-area-card .game_table02 tr th {
    width: 8%;
}
.shop-area-card .game_table02 tr td {
    width: 12%;
}

@media (max-width: 600px) {
  .shop-area-card__list {
    column-count: 1;
  }
}

.company_section .contents .img_box {
  position: relative;
}
.company_section .contents .img_box .name {
    position: absolute;
    bottom: 8px;
    left: 0;
    color: #000;
    background-color: #fff;
    padding: 1px 10px;
    font-size: clamp(1.125rem, 1.002rem + 0.41vw, 1.375rem);
}
.company_section .contents .img_area {
  display: flex;
}
.company_section .contents:not(:first-child) {
    margin-top: -30px;
}
.company_section .contents.office {
    background-color: var(--gray);
    margin-bottom: 100px;
    border-radius: 35px 0 0 35px;
    padding-top: 50px;
    position: relative;
    top: 3%;
}
.company_section .contents.pachinko {
  background-color: var(--red);
}
.company_section .contents.rental {
  background-color: var(--orange);
}
.company_section .contents.hotel {
  background-color: var(--purple);
}
.company_section .contents.hotel .shop-area-card__list {
    column-count: 1;
}
.company_section .contents.food {
  background-color: var(--green);
}
.company_section .contents.services_area {
  background-color: var(--yellow);
}
.company_section .contents.game {
    background-color: var(--brown);
    border-radius: 35px 0 0 35px;
}

/* ========== page-number.php ========== */
.number_top .title-ja {
    top: 0px;
}
.number_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.number_top {
    margin-top: -80px;
    height: 500px;
}
.number_top .area:nth-child(1) {
    position: relative;
    height: 100%;
}
.number_top .area:nth-child(1) .ttl_box {
    position: absolute;
    top: 40%;
    left: 5%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.number_top .area:nth-child(1) .title-en01 {}
.number_top .area:nth-child(1) .title-ja {}
.number_top .area:nth-child(1) .title-en02 {}
.number_top .area:nth-child(1) .img_box {
    height: 100%;
    justify-content: space-between;
}
.number_top .area:nth-child(1) .img_box img {
    box-shadow: 0px 0px 30px #959595;
}
.number_top .area:nth-child(1) .img_box .top_01 {
    width: 38%;
    object-fit: cover;
    height: 100%;
}
.number_top .area:nth-child(1) .img_box .top_02 {
    width: 60%;
    object-fit: cover;
    height: 100%;
}
/* 下部 */
:root {
  --fs-xxs: clamp(10px, 0.86vw, 12px);   /* コピーライト */
  --fs-xs: clamp(12px, 1vw, 14px);       /* 注記・補足 */
  --fs-sm: clamp(15px, 1.3vw, 18.17px);  /* ナビ・小見出し */
  --fs-sm2: clamp(15px, 1.35vw, 18.89px);/* ページ小見出し */
  --fs-body: clamp(16px, 1.43vw, 20px);  /* 本文段落 */

  /* Content labels / Timeline */
  --fs-unit: clamp(18px, 1.57vw, 22.03px); /* 単位・記号 */
  --fs-timeline-item: clamp(19px, 1.64vw, 23px); /* 年表項目 */
  --fs-year: clamp(20px, 1.71vw, 24px);         /* 年表の西暦 */
  --fs-intro-callout: clamp(22px, 1.97vw, 27.63px); /* 導入見出し */
  --fs-anniv-line: clamp(22px, 2vw, 28px);         /* 周年テキスト */

  /* Numbers & Emphasis */
  --fs-num-unit: clamp(26px, 2.45vw, 34.33px); /* 数値横の単位 */
  --fs-num-md: clamp(28px, 2.7vw, 37.88px);    /* 中～大数値 */
  --fs-num-lg: clamp(30px, 2.85vw, 40px);      /* 大数値 */
  --fs-num-xl: clamp(38px, 3.68vw, 51.49px);   /* さらに大 */
  --fs-num-dec: clamp(41px, 4vw, 56.09px);     /* 特大小数 */

  /* Section / Hero headings */
  --fs-section-en: clamp(40px, 3.82vw, 53.53px); /* 英字見出し */
  --fs-hero: clamp(42px, 4vw, 55.65px);          /* 英字ヒーロータイトル */

  /* Extra-large */
  --fs-kanji-xxl: clamp(55px, 5vw, 70.01px); /* 特大和文 */
  --fs-massive: clamp(80px, 7.5vw, 105.02px);/* 超特大数値 */
}

.number_section {
    padding: 120px 0;
}
.number_section .red_line {
  position: relative;
}
.number_section .red_line::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(to right, #e04634 0%, rgba(224,70,52,0) 100%);
    border-radius: 2px;
}
.number_section .area04 .red_line::after, .number_section .area06 .red_line::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(to right, 
        rgba(224,70,52,0) 0%,
        #e04634 20%,
        #e04634 80%,
        rgba(224,70,52,0) 100%
    );
    mask-image: radial-gradient(ellipse at center, rgba(0,0,0,1) 70%, rgba(0,0,0,0) 100%);
    mask-repeat: no-repeat;
    mask-size: 100% 100%;
    border-radius: 3px;
}

.number_section .number {
    font-weight: 900;
}
.number_section .box {
    border-radius: 15px;
    box-shadow: 0 0 30px #e3e3e3;
}
.number_section .box01 {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 3rem;
    gap: 25px;
    margin-bottom: 25px;
}
.number_section .box01 .img_box {
    width: 40%;
    margin: 0 auto;
}
.number_section .box01 .img_box img {
    width: 80%;
    display: flex;
    justify-content: center;
    margin: 0 auto;
}
.number_section .box01 .txt_box {
    width: 69%;
}
.number_section .box01 .txt_box .ttl {
    font-size: var(--fs-hero);
}
.number_section .box01 .date-box {
    font-family: sans-serif;
    font-weight: bold;
    line-height: 1.2;
    display: flex;
    align-items: center;
}
.number_section .box01 .date-box .jp {
    font-size: var(--fs-kanji-xxl);
}
.number_section .box01 .date-box .jp .number {
    font-size: var(--fs-massive);
    vertical-align: -5px;
}
.number_section .box01 .date-box .mini_box {
    vertical-align: -5px;
}
.number_section .box01 .date-box .en {
    vertical-align: super;
    margin-left: 4px;
    font-size: var(--fs-body);
}
.number_section .box01 .date-box .en .number {
    font-size: var(--fs-anniv-line);
}
.number_section .box01 .date-box .month {
    display: block;
    margin-top: 12px;
    font-size: var(--fs-num-unit);
    font-weight: 800;
    line-height: 1;
}
.number_section .box01 .date-box .month .number {
    font-size: var(--fs-num-dec);
    line-height: 0;
}
.number_section .area02 {
    padding: 3rem;
    box-shadow: 0 0 30px #e3e3e3;
    border-radius: 15px;
    margin-bottom: 25px;
}
.number_section .area02 .parent {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    grid-template-rows: repeat(5, 1fr);
    grid-column-gap: 0px;
    grid-row-gap: 0px;
}
.number_section .area02 .parent .div1 {
    grid-area: 1 / 1 / 3 / 5;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 40px;
}
.number_section .area02 .parent .div2 {
    grid-area: 1 / 5 / 3 / 9;
    display: flex;
    width: 100%;
    flex-direction: column;
    justify-content: center;
}
.number_section .area02 .parent .div3 {
    grid-area: 3 / 1 / 4 / 9;
    padding-top: 20px;
    padding-bottom: 15px;
}
.number_section .area02 .parent .div4 { grid-area: 4 / 1 / 5 / 5; }
.number_section .area02 .parent .div5 { grid-area: 5 / 1 / 6 / 5; }
.number_section .area02 .parent .div6 { grid-area: 4 / 5 / 5 / 9; }
.number_section .area02 .parent .div7 { grid-area: 5 / 5 / 6 / 9; }

.number_section .area02 .parent .div1 .img_box {}
.number_section .area02 .parent .div1 .img_box img {
    width: 125px;
    height: auto;
}
.number_section .area02 .parent .div1 .txt_box,
.number_section .area02 .parent .div2 .txt_box
{}
.number_section .area02 .parent .div1 .txt_box .sub, .number_section .area02 .parent .div2 .txt_box .sub {
    font-size: var(--fs-anniv-line);
    letter-spacing: 2px;
    font-weight: 600;
}
.number_section .area02 .parent .div1 .txt_box .price, .number_section .area02 .parent .div2 .txt_box .price {
    font-size: var(--fs-num-lg);
}
.number_section .area02 .parent .div1 .txt_box .price .number, .number_section .area02 .parent .div2 .txt_box .price .number {
    font-size: var(--fs-hero);
    vertical-align: -2px;
}
.number_section .area02 .parent .div3 .ex {
    font-size: var(--fs-intro-callout);
}
.number_section .area02 .parent .div4 .card, .number_section .area02 .parent .div5 .card, .number_section .area02 .parent .div6 .card, .number_section .area02 .parent .div7 .card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: dotted 1px #000000;
    width: 90%;
    margin: 0 auto;
}

.number_section .area02 .parent .div4 .card .name, .number_section .area02 .parent .div5 .card .name, .number_section .area02 .parent .div6 .card .name, .number_section .area02 .parent .div7 .card .name {
    font-size: var(--fs-body);
}

.number_section .area02 .parent .div4 .card .price, .number_section .area02 .parent .div5 .card .price, .number_section .area02 .parent .div6 .card .price, .number_section .area02 .parent .div7 .card .price {
    font-size: var(--fs-intro-callout);
}
.number_section .area02 .parent .div4 .card .price .number, .number_section .area02 .parent .div5 .card .price .number, .number_section .area02 .parent .div6 .card .price .number, .number_section .area02 .parent .div7 .card .price .number {
    font-size: var(--fs-num-lg);
    vertical-align: -2px;
}
.number_section .area03 {
    display: flex;
    justify-content: space-between;
    gap: 25px;
    margin-bottom: 25px;
}
.number_section .area03 .box {
    width: 50%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 25px;
    padding: 3rem;
}
.number_section .area03 .box .img_box {
    width: 30%;
    margin: 0 auto;
}
.number_section .area03 .box:nth-child(1) .img_box img {
    width: 140px;
}
.number_section .area03 .box:nth-child(2) .img_box img {
    width: 120px;
    margin: 0 auto;
}
.number_section .area03 .box .group {
    width: 60%;
}
.number_section .area03 .box .group .ttl {
    font-size: var(--fs-anniv-line);
}
.number_section .area03 .box .group .ex {
    font-size: var(--fs-num-lg);
}
.number_section .area03 .box .group .ex .number {
    font-size: var(--fs-num-dec);
    vertical-align: -3px;
}
.number_section .area04 {
    display: flex;
    width: 100%;
    justify-content: space-between;
    margin-bottom: 25px;
}
.number_section .area04 .box:nth-child(1) {
    width: 55%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 2rem;
    margin-right: 25px;
}
.number_section .area04 .box:nth-child(1) .name {
    font-size: var(--fs-num-unit);
    width: 90%;
    text-align: center;
    margin: 0 auto;
}
.number_section .area04 .box:nth-child(1) .img_box {
    width: 70%;
    margin: 3rem auto 0;
}
.number_section .area04 .box:nth-child(1) .img_box img {
    width: 100%;
    margin: 0 auto;
}
.number_section .area04 .box:nth-child(2) {
    width: 45%;
    box-shadow: none;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.number_section .area04 .box:nth-child(2) div {
    box-shadow: 0 0 30px #e3e3e3;
    padding: 10px 0;
    border-radius: 15px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.number_section .area04 .box:nth-child(2) div:nth-child(1) {
}
.number_section .area04 .box:nth-child(2) div:nth-child(1) img {
    width: 130px;
    margin-bottom: 15px;
    padding-right: 15px;
}
.number_section .area04 .box:nth-child(2) div:nth-child(2)  img {
    width: 95px;
    margin-bottom: 15px;
}
.number_section .area04 .box:nth-child(2) div .name {
    font-size: var(--fs-anniv-line);
    width: 80%;
    text-align: center;
    line-height: .8;
    padding-bottom: 10px;
}
.number_section .area04 .box:nth-child(2) div .name span{}
.number_section .area04 .box:nth-child(2) div .ttl {
    font-size: var(--fs-intro-callout);
}
.number_section .area04 .box:nth-child(2) div .ttl .number {
    font-size: var(--fs-hero);
    line-height: 1.2;
    vertical-align: -2px;
}
.number_section .area05 .box:nth-child(1) .img_box img {
    width: 135px;
}
.number_section .area05 .box:nth-child(2) .img_box img {
    width: 135px;
}
.number_section .area06 {
    display: flex;
    box-shadow: 0 0 30px #e3e3e3;
    padding: 3rem;
    border-radius: 15px;
}
.number_section .area06 .box {
    border-radius: 0;
    box-shadow: none;
    width: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.number_section .area06 .box .ttl {
    text-align: center;
    width: 80%;
    margin: 0 auto;
    font-size: var(--fs-num-lg);
}
.number_section .area06 .list {}
.number_section .area06 .list ul {
    margin-top: 35px;
}
.number_section .area06 .list ul li{}
.number_section .area06 .list ul li .card {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 20px;
    margin-bottom: 15px;
}
.number_section .area06 .list ul li .card img {
    width: 50px;
}
.number_section .area06 .list ul li .card .sub {
    font-size: var(--fs-year);
}
.number_section .area06 .list ul li:nth-child(1) .card .sub {
    color: var(--red);
}
.number_section .area06 .list ul li:nth-child(2) .card .sub 
{
    color: var(--yellow);
}
.number_section .area06 .list ul li:nth-child(3) .card .sub {
    color: var(--purple);
}
.number_section .area06 .list ul li:nth-child(4) .card .sub {
    color: var(--orange);
}
.number_section .area06 .list ul li:nth-child(5) .card .sub {
    color: var(--green);
}
.number_section .area06 .list ul li:nth-child(6) .card .sub {
    color: var(--brown);
}
.number_section .area06 .list ul li:nth-child(7) .card .sub {
    color: var(--gray);
}
.number_section .area06 .img_box {
    width: 80%;
    margin: 3rem auto 0;
}
.number_section .area06 .img_box img {
    width: 100%;
}
/* history */
/* =============== HISTORY =============== */
.history { padding: clamp(24px, 3vw, 48px) 0; }
.history__inner { width: min(1100px, 92%); margin: 0 auto; }
.history__label {
    display: inline-block;
    padding: 0 10px;
    border: 2px solid var(--red);
    font-weight: 700;
}
.history__title {
    font-size: clamp(28px, 4vw, 56px);
    font-weight: 900;
    letter-spacing: .04em;
    margin: .25rem 0 1.5rem;
    color: var(--red);
}

.history__list {
  position: relative;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* 行 */
.history__item {
  position: relative;
  display: grid;
  grid-template-columns: 5.5rem 1fr;
  gap: 1rem;
  align-items: start;
  padding: 1.2rem 0 2.4rem;
}
.history__item::after {
    content: "";
    position: absolute;
    left: 104px;
    bottom: 0;
    width: 5px;
    height: 25px;
    background-image: linear-gradient(#e24a34 5px, transparent 5px);
    background-size: 5px 10px;
    background-repeat: repeat-y;
}
.history__item:last-of-type::after {
}

.history__list::after {
    content: "";
    position: absolute;
    left: 104px;
    bottom: -125px;
    width: 5px;
    height: 120px;
    background-image: linear-gradient(#e24a34 6px, transparent 6px);
    background-size: 5px 12px;
    background-repeat: repeat-y;
}
.history__list.is-open::after {
    bottom: -125px;
}
.history__year {
    font-weight: 900;
    font-size: clamp(18px, 2.2vw, 26px);
    text-align: left;
}
.history__body {
    font-size: clamp(16px, 1.8vw, 22px);
    font-weight: 700;
    letter-spacing: .02em;
    position: relative;
    padding-left: 1.25rem;
    padding-top: 2px;
}
.history__body::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0px;
    width: 5px;
    height: 35px;
    background: var(--red);
}

/* 折りたたみ領域 */
.history__more { display: none; }

/* トグルボタン */
.history__togglewrap, .history__closewrap {
    text-align: center;
    margin-top: 1.25rem;
    position: relative;
}
.history__toggle {
    appearance: none;
    border: none;
    cursor: pointer;
    font-weight: 900;
    font-size: clamp(16px, 1.8vw, 20px);
    padding: .9rem 1.4rem;
    border-radius: 6px;
    transition: transform .2s ease, opacity .2s ease;
}
.history__toggle {
    background: var(--red);
    color: #fff;
    position: absolute;
    left: 130px;
    top: -30px;
    font-size: var(--fs-intro-callout);
    font-weight: 600;
    letter-spacing: 3px;
}
.history__close {
    display: inline-flex;
    align-items: center;
    gap: .6em;
    padding: 5px 20px;
    border: 2px solid var(--history-accent, var(--red));
    background: #fff;
    color: var(--history-accent, var(--red));
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
    transition: transform .2s ease, opacity .2s ease;
    position: absolute;
    right: 0;
    bottom: 30px;
}
.history__close .history__closeLabel {
    font-size: 25px;
    font-weight: 900;
    font-family: 'Montserrat';
}
.history__closeIcon {
    width: 20px;
    height: 20px;
    fill: var(--history-accent, #e24a34);
    display: block;
    transform: translateY(-1px);
}

.history__close:hover { transform: translateY(-1px); opacity: .9; }
.history__close:focus-visible { outline: 2px solid var(--history-accent, #e24a34); outline-offset: 2px; }

.history__toggle:hover, .history__close:hover { transform: translateY(-1px); opacity:.9; }

.number_message {
    padding-top: 5rem;
}
.number_message .area {
    position: relative;
    width: 95%;
    margin: 0 auto;
}
.number_message .img_box {
    width: 100%;
}
.number_message .img_box img {
    filter: brightness(0.7);
    opacity: .9;
}
.number_message .txt_area {
    color: #fff;
    position: absolute;
    inset: 50% auto auto 50%;
    width: 100%;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    height: 35%;
}
.number_message .txt_area .ex {
    text-align: center;
}
.number_message .txt_area .main {
    text-align: center;
    font-size: var(--fs-num-unit);
}
.number_message .txt_area .main .back {
    background-color: var(--red);
    font-size: var(--fs-num-lg);
    padding: 0 8px;
    margin: 0 10px;
}
/* ========== archive-news.php ========== */
.news_page .circle_block01 .circleText {
    font-size: 21px;
    letter-spacing: 1px;
    fill: var(--brown);
}
.news_page .circle_block01 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.news_page .circle_block02 .circleText{
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--brown);
}
.news_page .circle_block02 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.company_page {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
}
.news_section {
    margin-bottom: 120px;
    padding-top: 120px;
}
.company_secnews_sectiontion .area {
  justify-content: space-between;
}
.news_section .ttl_box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 95%;
    margin: 0 auto;
}
.news_section .ttl_box .title-ja {
    border: 1px solid #000;
    padding: 0 8px;
}
.news_section .box01 {
    width: 25%;
}
.news_section .box02 {
    width: 75%;
    background-color: var(--brown);
    padding: 3rem 0rem 3rem 3rem;
    border-radius: 30px 0 0 30px;
    margin-top: -4rem;
}
.news_section .news_list {
    width: 80%;
    margin: 0 auto;
    padding-top: 10px;
    position: sticky;
    top: 50px;
}
.news_section .news_list li {
    font-weight: 600;
    padding-top: 18px;
    border-bottom: 1px solid #000;
}
.news_section .news_list li a {
    width: 100%;
    display: block;
}
.news_section .news_list a[aria-current="page"]{
  opacity: .45;
  pointer-events: none;
  font-weight: 600;
}
.achieve__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: clamp(18px, 2.5vw, 28px);
    margin-top: 1rem;
    padding-right: 10px;
}
@media (max-width: 1024px){
  .achieve__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 600px){
  .achieve__grid { grid-template-columns: 1fr; }
}

.achieve__card {
  position: relative;
  border-radius: 16px;
}
.achieve__link {
  display:block; text-decoration:none; color:inherit;
}
.achieve__thumb {
    position: relative;
    border-radius: 0px 12px 12px 12px;
    padding: 5px;
    background: #fff;
    box-shadow: 0 0 0 2px #fff inset, 0 0 0 1px rgba(0,0,0,.08);
}
.achieve__thumb img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 0 12px 12px 12px;
}
.achieve__badge {
    position: absolute;
    left: 0;
    top: -33px;
    background: #fff;
    color: #8c5a2f;
    padding: .35rem .55rem;
    border-radius: 5px 5px 0 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
}
.achieve__badgeText {
    --tilt: -5deg;
    display: inline-block;
    transform: rotate(var(--tilt));
    transform-origin: center;
    white-space: nowrap;
      
  font-weight: 900;

}
.achieve__title {
  margin: .8rem .2rem .4rem;
  font-weight:900; line-height:1.4;
  font-size: clamp(16px, 1.8vw, 20px);
  color:#fff;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.achieve__excerpt {
    margin: 0 .2rem 0;
    font-size: clamp(13px, 1.4vw, 15px);
    line-height: 1.7;
    color: rgba(255,255,255,.85);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
    padding-bottom: 15px;
}
@supports (line-clamp: 3) or (-webkit-line-clamp: 3){
  .achieve__excerpt{ line-clamp: 3; }
}
.achieve__empty { color:#fff; padding:1rem 0; }

/* ページネーション */
.achieve__pagination {
  display:flex; justify-content:center; gap:.4rem;
  margin-top: clamp(18px, 3vw, 28px);
}
.achieve__pagination .page-numbers {
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:8px;
  background:#fff; color:#333; text-decoration:none; font-weight:700;
  border:1px solid #ddd;
}
.achieve__pagination .current {
  background:#4b3; color:#fff; border-color:#4b3;
}

/* insta */
.insta_section {
    padding-bottom: 100px;
}
.insta_section .area{}
.insta_section .area .box01 {
    width: 25%;
}
.insta_section .area .box02 {
    width: 75%;
    margin: 0 auto;
}
.insta_section .area .box02 .ttl {
    text-shadow: none;
    font-weight: 900;
    letter-spacing: 1px;
    text-align: center;
    margin-bottom: 40px;
}
.insta_section .area .box02 .feed_area {
    width: 80%;
    margin: 0 auto;
}
.instagram-gallery-item__media-mask {
    background-color: #8b623aa3 !important;
}
/* ========== single.php ========== */
.single-article__label {
    display: inline-block;
    color: var(--brown);
    background-color: #fff;
    padding: 3px 8px 1px;
}
.single-article__top .ttl_box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 95%;
    flex-direction: row;
    margin: inherit;
}
.single-article__top .ttl_box .single-article__title{
    width: 69%;
    color: #fff;
}
.single-article__top .ttl_box .single-article__meta{
    width: 30%;
    color: #fff;
}
.single-article__content {
    background-color: #fff;
    border-radius: 15px 0 0 15px;
    padding: 2rem;
    font-weight: 400;
}
.single-article__content p {
    font-weight: 400;
}
.single-article__pn {
    justify-content: center;
    gap: 20px;
    margin: 25px auto;
    color: #fff;
    width: 90%;
}
.single-article__pn a{}
.single-article__thumb img {
    aspect-ratio: 16/9;
}
.single-article__thumb {
    position: relative;
    border-radius: 12px 0px 0px 12px;
    padding: 5px;
    background: #fff;
    box-shadow: 0 0 0 2px #fff inset, 0 0 0 1px rgba(0,0,0,.08);
}
/* ========== page-contact.php ========== */
.contact_section {
    padding-bottom: 120px;
}
.contact_page .circle_block01 .circleText {
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--pink);
}
.contact_page .circle_block01 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.contact_page .circle_block02 .circleText{
    font-size: 22px;
    letter-spacing: 1px;
    fill: var(--pink);
}
.contact_page .circle_block02 .circleText__circle{
    font-size: 20px;
    letter-spacing: 0.05em;
}
.contact_top {
    height: 500px;
    text-decoration: underline;
}
.contact_top .area {}
.contact_top .ttl_box {
    position: absolute;
    top: 40%;
    left: 5%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.contact_top .title-en01 {
}
.contact_top .title-en02{}
.contact_top .title-ja{}
/* フォーム全体 */
.contact_section .form_area {
    background-color: var(--pink);
    padding: 3rem;
    border-radius: 30px;
    color: #fff;
}
.contact_section .form_area .contact_form01{
    color: #000;
}
.nf-field-label .nf-label-span, .nf-field-label label {
    color: #fff;
}
.ninja-forms-req-symbol { 
  display: none !important;
}
.nf-form-cont .nf-field-label:has(.ninja-forms-req-symbol) label::after {
    content: "必須";
    display: inline-block;
    margin-left: .5em;
    line-height: 1.6;
    background-color: #fff;
    color: #000;
    padding: 2px 5px 2px;
    font-size: clamp(0.813rem, 0.768rem + 0.17vw, 0.938rem);
    vertical-align: middle;
    font-weight: 400;
}

.nf-form-fields-required {
    display: none;
}
.field-wrap {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 20px;
}
.contact form label {
    display: block;
    color: var(--color01);
    width: auto;
    display: flex;
    justify-content: space-between;
    margin-top: 0;
    margin-bottom: 0;
    font-weight: 400;
}
.label-above .nf-field-element, .label-below .nf-field-element {
    width: 65% !important;
}
.label-above .nf-field-label {
    margin-bottom: 0px;
    width: 30%;
}
.field-wrap .pikaday__container, .field-wrap .pikaday__display, .field-wrap>div input, .field-wrap select, .field-wrap textarea {
    padding: 0.6em;
    border: 1px solid #00000038;
    font-size: 1em;
    box-sizing: border-box;
    background: #ffffff;
    color: #000;
}
.label-right .field-wrap {
    justify-content: center;
}
.label-right .field-wrap .nf-field-label:has(.ninja-forms-req-symbol) label::after {
  display: none;
}
.recaptcha_message {}
.recaptcha_message p {
    text-align: center;
}
.recaptcha_message p a {
    text-decoration: underline;
}
.field-wrap .pikaday__container, .field-wrap .pikaday__display, .field-wrap>div input, .field-wrap select, .field-wrap textarea {
    color: #000;
    border-radius: 8px;
    border: 2px solid #000;

}
.field-wrap button,
.field-wrap input[type=button],
.field-wrap input[type=submit] {
    position: relative;
    overflow: hidden; 
    z-index: 0;
    width: 200px !important;
    background-color: #000;
    color: #fff;
    border: none;
    cursor: pointer;
    transition: color 0.3s ease; 
    transition: 0.3s ease;
}

.field-wrap input[type=submit]::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-color: #fff;
    z-index: -1;
    transition: left 0.3s ease;
    transition: 0.3s ease;
}
.field-wrap input[type=submit]:hover::before {
    left: 0;
}
.field-wrap input[type=submit]:hover {
    color: #000;
    background-color: #fff;
}
/* entry */
.thanks_message_recruit {}
.thanks_message_contact {}

.entry_section .form_area {
    background-color: #ed6f01e0;
    padding: 3rem;
    border-radius: 30px;
    color: #fff;
    width: 73%;
}
.entry_section .form_area .contact_form01{
    color: #000;
}
.entry_section .form_area .label-above .nf-field-element, .entry_section .form_area .label-below .nf-field-element {
    width: 70% !important;
}
.entry_section .nf-field-element:last-child {}

.entry_section .field-wrap {
    padding-bottom: 0;
}
.entry_section .field-wrap .pikaday__container, 
.entry_section .field-wrap .pikaday__display, 
.entry_section .field-wrap>div input, 
.entry_section .field-wrap select, 
.entry_section .field-wrap textarea {
    border: 1px solid #000;
}
.entry_section .field-wrap > div input[type=checkbox], .entry_section .field-wrap button, .entry_section .field-wrap input[type=button], .entry_section .field-wrap input[type=submit] {
    margin-left: 14%;
}
.entry_section .nf-field-label .nf-label-span, .entry_section .nf-field-label label {
    font-weight: 700;
    margin: 0;
    padding: 0;
    font-size: clamp(18px, calc((100vw - var(--vw-min)) * 0.00465 + 18px), 22px);
    line-height: 1.6;
    letter-spacing: 1px;
}
/* privacylink */
.policy_link {}
.policy_link p {
    font-weight: 400;
    font-size: 14px;
}
.policy_link a {
    font-size: 14px;
    text-decoration: underline;
}
/* ========== RESPONSIVE ========== */
/* 1920px～ */
@media screen and (min-width: 1921px) {}
/* 1471px～1920px */
@media screen and (min-width: 1471px) and (max-width: 1920px) {}
/* 1024px～1470px */
@media screen and (max-width: 1469px){
.concept_top .color_belt {
    height: clamp(60rem, 32.735rem + 42.6vw, 71.875rem);
}
.concept_page .section02 .container {
    padding-top: clamp(1.875rem, -22.52rem + 38.12vw, 12.5rem);
}
.concept_top {
    height: clamp(48.125rem, 35.21rem + 20.18vw, 53.75rem);
}
.concept_page .section03 .container {
    padding-top: clamp(5.625rem, 1.32rem + 6.73vw, 7.5rem);
}
.concept_page .section04 .container {
    padding-top: clamp(6.25rem, 0.51rem + 8.97vw, 8.75rem);
}
.concept_page .section05 {
    margin-top: clamp(5.625rem, 1.32rem + 6.73vw, 7.5rem);
}
.concept_page .section04 .img_box img {
    width: 90%;
}
.services_top .circle_block .circle-name .block {
    width: clamp(41.875rem, 13.893rem + 43.72vw, 54.063rem);
    height: clamp(41.875rem, 13.893rem + 43.72vw, 54.063rem);
}
.services_top .circle_block .circle-name .circleText .circleText__text {
    font-size: clamp(1.063rem, 0.345rem + 1.12vw, 1.375rem);
    letter-spacing: 1px;
}
.services_section .contents .card .ex {
    width: 80%;
    text-align: justify;
}
.services_section .contents .card .lead {
    width: 85%;
}
.services_section .contents {
    height: clamp(39.688rem, 8.835rem + 48.21vw, 53.125rem);
}
.services_section .contents .card .img_box {
    gap: 5px;
}
.services_section {
    padding-bottom: clamp(4.375rem, -2.8rem + 11.21vw, 7.5rem);
}
.type_list.section {
    padding-top: clamp(0.625rem, -15.16rem + 24.66vw, 7.5rem);
    padding-bottom: clamp(5.625rem, 1.32rem + 6.73vw, 7.5rem);
}
.employee_single .section03 {
    padding-top: clamp(2.5rem, -8.98rem + 17.94vw, 7.5rem);
}
.section03.main_draft .area {
    padding-top: clamp(2.5rem, -8.98rem + 17.94vw, 7.5rem);
}
.bottom_section {
    padding-top: clamp(8.438rem, 6.285rem + 3.36vw, 9.375rem);
}
.bottom_section .slide-wrapper {
    height: clamp(34.688rem, 16.033rem + 29.15vw, 42.813rem);
}
.bottom_section .swiper {
    height: 100%;
}
.bottom_section .nav-buttons {
    bottom: -8%;
}
.project_section .area_01 {
    padding-top: clamp(3.125rem, -6.92rem + 15.7vw, 7.5rem);
}
.project_section .area_02 {
    padding-top: clamp(3.125rem, -6.92rem + 15.7vw, 7.5rem);
}
.project_section .area_03 {
    padding-top: clamp(3.125rem, -6.92rem + 15.7vw, 7.5rem);
}
.project_page .bottom_section {
    padding-top: clamp(3.125rem, -6.92rem + 15.7vw, 7.5rem);
}
.project_top .circle_block .circle-name .block {
    width: clamp(41.875rem, 13.893rem + 43.72vw, 54.063rem);
    height: clamp(41.875rem, 13.893rem + 43.72vw, 54.063rem);
}
.project_top .circle_block .circle-name .circleText .circleText__text {
    font-size: clamp(1.063rem, 0.345rem + 1.12vw, 1.375rem);
}
.faq_section {
    padding-top: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
}
.section02.faq_section {
    padding-bottom: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
}
.entry_section {
    padding-bottom: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
}
.recruit_section {
    padding-top: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
    padding-bottom: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
}
.company_section {
    margin-bottom: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
    padding-top: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
}
.news_section {
    margin-bottom: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
    padding-top: clamp(5.313rem, 0.29rem + 7.85vw, 7.5rem);
}
.shop-area-card__list li {
    font-size: 13px;
}
}
/* ~1280px */
@media screen and (max-width: 1280px) {}
/* 768px~1023px タブレット縦*/
@media screen and (max-width: 1024px) {
    .child_top {
    height: clamp(36.563rem, 1.875rem + 72.27vw, 48.125rem);
}
    .concept_top {
    height: clamp(36.563rem, 1.875rem + 72.27vw, 48.125rem);
}
.concept_top .parent {
    height: auto;
}
.concept_top .color_belt {
    height: clamp(45.625rem, 2.5rem + 89.84vw, 60rem);
}
.concept_page .section02 .img_box img {
    aspect-ratio: 4/6;
}
.concept_page .section03 .area .box01 .img_box {
    gap: 15px;
}
.concept_page .section03 .img_box img:nth-child(1) {
    margin-bottom: 15px;
}
.concept_page .section04 .img_box img {
    aspect-ratio: 4/6;
}
.concept_page .section05 {
    height: clamp(16.25rem, -10rem + 54.69vw, 25rem);
}
.services_section .area {
flex-direction: column;
}
.services_section .box01 {
    position: sticky;
    top: var(--sticky-top, 0px);
    z-index: 5;
    width: 100%;
    background: hsla(0, 0%, 100%, 0.9);
    padding: 8px 0;
}
.services_section .box01 .services_list {
    position: static;
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 0 12px 6px;
    border-left: none;
    -webkit-overflow-scrolling: touch;
    flex-wrap: wrap;
    justify-content: center;
}
.services_list a {
    white-space: nowrap;
    border-left: none;
    border-bottom: 2px solid transparent;
    padding: 8px 10px 0;
    text-align: center;
}
.services_list a.is-active {
    border-bottom-color: var(--theme, #0000002b);
    background: transparent;
}
.services_section .services_list li {
    width: 23%;
}
.services_section .box02 {
    width: 100%;
}

.number_message .txt_area {
    inset: 25% auto auto 0%;
}
.number_message .txt_area .ex {
    font-size: clamp(1.063rem, 0.5rem + 1.17vw, 1.25rem);
}
.type_list .area {
    grid-template-columns: 1fr 1fr;
}
  .type_list .modal__dialog{
    width: 94vw;
    max-height: 88vh;
  }
.type_list .modal-items {
    grid-template-columns: 1fr 1fr;
}
.type_list .modal-contents.item {
    display: flex;
    justify-content: center;
}
.type_list .modal-contents .box {
    width: clamp(21.875rem, 7.813rem + 29.3vw, 26.563rem);
    height: clamp(27.5rem, 20.938rem + 13.67vw, 29.688rem);
}
.employee_single .single_top .back_color {
    height: clamp(13.75rem, 1.563rem + 25.39vw, 17.813rem);
    top: 20%;
}
.employee_single .single_top .ex_box {
    top: clamp(12.188rem, 25.39vw, 16.25rem);
    width: 90%;
}
.employee_single .single_top {
    padding-bottom: clamp(5.938rem, 1.25rem + 9.77vw, 7.5rem);
    height: clamp(36.563rem, 1.875rem + 72.27vw, 48.125rem);
}
.employee_single .single_top .area {
    position: relative;
    height: 600px;
}
.employee_single .single_top .img_box {
    bottom: 8%;
    width: 60%;
}
.employee_single .section02 .box01 {
    height: 715px;
}
.employee_single .section02 .box01 .img_box .person-shapes {
    left: 0%;
}
.employee_single .section02 .box01 .img_box .person-img {
    width: 78%;
}
.employee_single .section02 .area {
    height: 100%;
}
.employee_single .section02 .box02 {
    width: 60%;
}
.employee_single .section02 .box01 .tag_box {
    bottom: -35%;
}
.employee_single .section02 .box01 .ex_box.tate {
    top: 20%;
    left: 17%;
}
.section03.main_draft .area:nth-child(even) .box01 {
    order: 1;
}
.employee_single .section03 .img_box img {
    aspect-ratio: 16/9;
}
.bottom_section .swiper-slide .slide-img {
    width: 65%;
}
.bottom_section .swiper-slide .text-topleft {
    right: 20%;
}
.bottom_section .swiper-slide .slide-number {
    left: 23%;
}
.bottom_section .swiper-slide.swiper-slide-active .text-bottomleft {
    left: 18%;
}
.bottom_section .swiper-slide .text-center {
    left: 40%;
}
.project_top {
    height: auto;
}
.project_top .area:nth-child(1) {
    height: clamp(36.563rem, 1.875rem + 72.27vw, 48.125rem);
}
.project_page .link_area .txt_box {
    width: 35%;
}
.project_page .link_area .link_box a .img_box img {
    aspect-ratio: 4/6;
}
.project_section .area_00 {
    padding: clamp(4.063rem, -6.25rem + 21.48vw, 7.5rem) 0 0;
    flex-direction: column;
}
.project_section .area_00 .box01 {
    width: 100%;
}
.project_section .area_00 .box01 .index_box {
    padding-top: 30px;
    display: flex;
    justify-content: space-between;
}
.project_section .area_00 .box02 {
    width: 100%;
    aspect-ratio: 16/9;
    margin-top: 20px;
}
.project_page .link_area .link_box a .img_box img {
    aspect-ratio: 4/6;
}
.news_section .box02 {
    margin-top: 0rem;
}
.entry_section .field-wrap > div input[type=checkbox], .entry_section .field-wrap button, .entry_section .field-wrap input[type=button], .entry_section .field-wrap input[type=submit] {
    margin-left: 0%;
}
.recruit_section .biz-columns {
    grid-template-columns: 150px 1fr;
}
.recruit_section .biz-columns .mr-1 {
    padding-left: 0px;
}
}
/* スマホ（01） */
@media screen and (min-width: 375px) and (max-width: 476px) {
  /* child_to */
  .child_top {
    height: 510px;
}
.child_top .title-en01,
.child_top .title-en02 {
    text-shadow: 0 0 5px #fff;
}
.child_top .area:nth-child(1) .img_box {
    flex-direction: column;
    width: 100%;
}
.child_top .area:nth-child(1) .img_box .top_01 {
    width: 100%;
    object-fit: cover;
    height: auto;
}
.child_top .area:nth-child(1) .img_box .top_01 {
    height: 55%;
}
.child_top .area:nth-child(1) .img_box .top_02 {
    width: 100%;
    height: 45%;
}
.child_top .area:nth-child(1) .img_box {
    flex-direction: column;
    width: 100%;
    height: 510px;
}
.child_top .area:nth-child(1) .img_box .top_01 {
    height: 55%;
}
.child_top .area:nth-child(1) .img_box .top_02 {
    width: 100%;
    height: 45%;
}
.child_top .area:nth-child(1) .img_box .top_01 {
    width: 100%;
    object-fit: cover;
    height: 54%;
}
.child_top .area:nth-child(1) .img_box {
    gap: 5px;
}
.child_top .parent {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(6, 1fr);
    grid-column-gap: 10px;
    grid-row-gap: 10px;
}
.child_top .parent > * {
    min-width: 0;
  }
.child_top .div1 {
    grid-area: 3 / 1 / 5 / 2;
    z-index: 1;
}
.child_top .div2 { grid-area: 1 / 1 / 3 / 2; }
.child_top .div3 { grid-area: 5 / 1 / 7 / 3; }
.child_top .div4 { grid-area: 1 / 2 / 5 / 3; }

  .child_top .parent img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
    display: block;
  }
.services_top .area:nth-child(1) .ttl_box {
    top: 61%;
}
.concept_top .color_belt {
    height: 640px;
}
.concept_top {
    height: 495px;
}
.concept_top .fs-xl {
}
.concept_page .section02 .area {
    flex-direction: column;
}
.concept_page .section .ex {
    line-height: 2.5;
    text-underline-offset: 4px;
    letter-spacing: 2px;
}
.concept_page .section .area .middle .copy {
    letter-spacing: 3px;
}
.concept_page .section .area .middle {
    letter-spacing: 3px;
}
.concept_page .section02 .img_box {
    width: 90%;
    aspect-ratio: 16/9;
}
.concept_page .section02 .img_box img {
    aspect-ratio: 16/9;
}
.concept_page .section02 .img_box img:nth-child(1) {
    transform: rotate(2deg);
    left: 0%;
}
.concept_page .section02 .ex02 {
    margin-top: 25px;
}
.concept_page .section .area {
    flex-direction: column;
}
.concept_page .section03 .container {
    padding-top: 55px;
}
.concept_page .section03 .area {
    gap: 40px;
}
.concept_page .section04 .container {
    padding-top: 55px;
}
.concept_page .section04 .img_box {
    width: 90%;
    aspect-ratio: 16/9;
}
.concept_page .section04 .img_box img {
    aspect-ratio: 16/9;
    width: 100%;
}
.concept_page .section04 .img_box img:nth-child(1) {
    transform: rotate(-4deg);
    left: 0%;
    top: 0px;
}
.concept_page .section04 .img_box img:nth-child(2) {
    transform: rotate(1deg);
    left: 0%;
    top: 0px;
}
.concept_page .section04 .ex02 {
    margin-top: 25px;
}
.concept_page .section05 .copy {
    font-size: 13px;
}
.concept_page .section05 {
    height: 160px;
    position: relative;
    margin-top: 55px;
}
.concept_page .section05 .area {
    z-index: 1;
}
.concept_page .section05::before {
  content: "";
  position: absolute;
  top: 0;  bottom: 0;
  left: 0;  right: 0;
  background: black;
  opacity:0.4;
  z-index: 0;
}

.services_section .box01 {
    padding: 30px 0 8px;
}
.services_list a {
    padding: 0px 10px 0;
}
.services_section .box01 .services_list {
    width: 100%;
    position: relative;
    top: 0;
    gap: 0;
}
.services_section .services_list li {
    width: 48%;
    padding-top: 8px;
    margin-right: 5px;
}
.services_top .circle_block .circle-name .block {
    width: 300px;
    height: 300px;
}
.services_top .circle_block {
    top: 6%;
    right: -30%;
}
.services_section .contents {
    top: 15px;
}
.services_section .contents.pachinko {
    height: 500px;
}
.services_section .contents.services_area {
    height: 525px;
}
.services_section .contents.hotel {
    height: 555px;
}
.services_section .contents.rental {
    height: 527px;
}
.services_section .contents.food {
    height: 527px;
}
.services_section .contents.game {
    height: 609px;
}
.services_section .contents .buttons [class^=btn-] {
    width: 185px;
}
.services_section .contents .buttons {
    bottom: 85px;
}
.services_section .contents .back_txt.ttl {
    font-size: 45px;
}
.services_section .contents .back_txt.number {
    font-size: 60px;
    top: 30%;
    right: 5%;
}
.services_section .contents:not(:first-child) {
    margin-top: -50px;
}
.services_section .contents .card .ex {
    width: 100%;
}
.services_section .contents .card {
    height: 95%;
    padding-top: 12%;
    justify-content: flex-start;
}
.services_section .contents .card .ttl {
    width: 100%;
}
/* 余白と影を適度に縮小 */
.number_top .area:nth-child(1) .ttl_box {
    top: 42%;
}
.number_section {
    padding: 38px 0;
}
  .number_section .box {
    border-radius: 12px;
    box-shadow: 0 0 18px #ececec;
  }
  .number_section .red_line::after {
    height: 1.5px;
  }

  /* --- area01（創業） --- */
  .number_section .box01 {
    flex-direction: column;
    align-items: stretch;
    padding: 1.5rem;
    gap: 16px;
    margin-bottom: 16px;
  }
  .number_section .box01 .img_box {
    width: 60%;
  }
  .number_section .box01 .img_box img {
    width: 100%;
  }
  .number_section .box01 .txt_box {
    width: 100%;
  }
  .number_section .box01 .txt_box .ttl {
    /* clampで十分だが、タイトル行間だけ詰める */
    line-height: 1.15;
  }
  .number_section .box01 .date-box {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .number_section .box01 .date-box .jp {
    line-height: 1;
  }
  .number_section .box01 .date-box .jp .number {
    vertical-align: baseline;
  }
  .number_section .box01 .date-box .mini_box {
    display: flex;
    align-items: baseline;
    gap: 8px;
  }
  .number_section .box01 .date-box .en {
    margin-left: 0;
  }
  .number_section .box01 .date-box .month {
    margin-top: 0;
    line-height: 1;
  }

  /* --- area02（資本金グリッド）--- */
  .number_section .area02 {
    padding: 1.5rem;
    border-radius: 12px;
    margin-bottom: 16px;
  }
  .number_section .area02 .parent {
    display: grid;
    grid-template-columns: 1fr;         /* 1カラムに */
    grid-template-rows: auto;
    grid-row-gap: 10px;
    grid-column-gap: 0;
  }
  /* 既存のgrid-area指定を無効化して順番に縦積み */
  .number_section .area02 .parent > div {
    grid-area: auto !important;
  }
  .number_section .area02 .parent .div1 {
      gap: 16px;
      flex-direction: column;
      align-items: center;
  }
  .number_section .area02 .parent .div1 .txt_box, .number_section .area02 .parent .div2 .txt_box {
    width: 100%;
  }
  .number_section .area02 .parent .div1 .img_box img {
    width: 88px;
    height: auto;
  }
  .number_section .area02 .parent .div2 {
    gap: 8px;
  }

  .number_section .area02 .parent .div3 {
    padding: 12px 0 8px;
  }

  .number_section .area02 .parent .div4 .card,
  .number_section .area02 .parent .div5 .card,
  .number_section .area02 .parent .div6 .card,
  .number_section .area02 .parent .div7 .card {
    width: 100%;
    padding: 10px 0;
    gap: 8px;
  }
  .number_section .area02 .parent .div4 .card .name,
  .number_section .area02 .parent .div5 .card .name,
  .number_section .area02 .parent .div6 .card .name,
  .number_section .area02 .parent .div7 .card .name {
    /* 行の折返しで窮屈にならないように */
    line-height: 1.2;
  }

  /* --- area03（従業員数／売上）--- */
  .number_section .area03 {
    flex-direction: column;
    gap: 16px;
    margin-bottom: 16px;
  }
  .number_section .area03 .box {
    width: 100%;
    padding: 1.5rem;
    gap: 16px;
  }
  .number_section .area03 .box .img_box {
    width: 28%;
  }
  .number_section .area03 .box:nth-child(1) .img_box img {
    width: 100px;
  }
  .number_section .area03 .box:nth-child(2) .img_box img {
    width: 90px;
    margin: 0 auto;
  }
  .number_section .area03 .box .group {
    width: 68%;
  }
  .number_section .area03 .box .group .ttl {
    line-height: 1.2;
  }
  .number_section .area03 .box .group .ex .number {
    vertical-align: baseline;
  }

  /* --- area04（男女比／残業・育休）--- */
  .number_section .area04 {
    flex-direction: column;
    gap: 16px;
    margin-bottom: 16px;
  }
  .number_section .area04 .box:nth-child(1) {
    width: 100%;
    margin-right: 0;
    padding: 1.25rem;
  }
  .number_section .area04 .box:nth-child(1) .name {
    width: 100%;
  }
  .number_section .area04 .box:nth-child(1) .img_box {
    width: 90%;
    margin: 1.25rem auto 0;
  }
  .number_section .area04 .box:nth-child(2) {
    width: 100%;
    gap: 12px;
  }
  .number_section .area04 .box:nth-child(2) div {
    padding: 14px 8px;
    border-radius: 12px;
  }
  .number_section .area04 .box:nth-child(2) div:nth-child(1) img {
    width: 100px;
    margin-bottom: 10px;
    padding-right: 0;
  }
  .number_section .area04 .box:nth-child(2) div:nth-child(2) img {
    width: 80px;
    margin-bottom: 10px;
  }
  .number_section .area04 .box:nth-child(2) div .name {
    width: 92%;
    line-height: 1.05;
    padding-bottom: 6px;
  }
  .number_section .area04 .box:nth-child(2) div .ttl .number {
    vertical-align: baseline;
  }

  /* --- area05（年間休日／有給取得）--- */
  .number_section .area05 .box {
    padding: 1.5rem;
  }
  .number_section .area05 .box .img_box img {
    width: 110px;
  }

  /* --- area06（職種数／アイコンリスト＋円グラフ等）--- */
  .number_section .area06 {
    flex-direction: column;
    padding: 1.5rem;
    border-radius: 12px;
    gap: 18px;
  }
  .number_section .area06 .box {
    width: 100%;
  }
  .number_section .area06 .box .ttl {
    width: 100%;
  }
  .number_section .area06 .list ul {
    margin-top: 20px;
  }
  .number_section .area06 .list ul li .card {
    gap: 14px;
    margin-bottom: 12px;
  }
  .number_section .area06 .list ul li .card img {
    width: 40px;
  }
  .number_section .area06 .list ul li .card .sub {
    /* 読みやすい行間へ */
    line-height: 1.15;
    word-break: keep-all;
  }
  .number_section .area06 .img_box {
    width: 100%;
    margin: 1.5rem auto 0;
  }
  .number_section .area06 .img_box img {
    width: 100%;
    height: auto;
  }

  /* 文字のにじみ・はみ出し軽減（強調数値のベースライン補正） */
  .number_section .number {
    font-feature-settings: "palt";
  }
  /* -------------- 共通余白 -------------- */
  .history { padding: 28px 0; }

  /* -------------- 見出し -------------- */
  .history__label {
    padding: 0 8px;
    font-weight: 800;
  }
  .history__title {
    margin: .25rem 0 1rem;
    letter-spacing: .02em;
  }

  /* -------------- タイムライン本体 -------------- */
  /* 年列の幅とギャップを変数化し、疑似要素の位置を連動 */
  .history__list {
    --year-col: 4.2rem; /* 年の列幅（SP） */
    --col-gap: .75rem;  /* 年⇔本文の間隔（SP） */
  }

  .history__item {
    grid-template-columns: var(--year-col) 1fr;
    gap: var(--col-gap);
    padding: 1rem 0 1.75rem;
  }

  .history__year {
    font-size: clamp(17px, 4.4vw, 22px);
  }

  .history__body {
    font-size: clamp(15px, 4vw, 20px);
    padding-left: 1rem;
    padding-top: 0;
  }
  .history__body::before {
    width: 4px;
    height: 28px;
    top: 0;
  }

  /* ドット線の位置を年列幅＋ギャップに合わせて再計算 */
  .history__item::after {
    left: calc(var(--year-col) + var(--col-gap) - 2px);
    width: 4px;
    height: 22px;
    background-image: linear-gradient(#e24a34 5px, transparent 5px);
    background-size: 4px 10px;
  }

  .history__list::after {
    left: calc(var(--year-col) + var(--col-gap) - 2px);
    bottom: -100px;
    width: 4px;
    height: 96px;
    background-image: linear-gradient(#e24a34 6px, transparent 6px);
    background-size: 4px 12px;
  }

  /* 折りたたみ領域（JSでdisplay切替前提） */
  .history__more { display: none; }

  /* -------------- トグル／クローズボタン -------------- */
  /* 位置固定をやめて中央寄せの通常フローに */
  .history__togglewrap,
  .history__closewrap {
    margin-top: .75rem;
  }

  .history__toggle {
    position: static;
    display: inline-block;
    width: auto;
    font-size: clamp(14px, 4vw, 18px);
    padding: .75rem 1.2rem;
    border-radius: 6px;
    letter-spacing: .08em;
  }

  .history__close {
    position: static;
    display: inline-flex;
    padding: .6rem 1rem;
    gap: .5em;
    border-radius: 6px;
  }

  .history__close .history__closeLabel {
    font-size: clamp(16px, 4.6vw, 20px);
  }
  .history__closeIcon {
    width: 16px;
    height: 16px;
  }

  /* -------------- number_message -------------- */
  .number_message { padding-top: 2.5rem; }

  .number_message .area {
    width: 96%;
  }

  .number_message .img_box {
    width: 100%;
  }
  .number_message .img_box img {
    filter: brightness(0.75);
    opacity: .95;
  }

  /* オーバーレイ→縦積みへ（読みやすさ優先） */
  .number_message .txt_area {
    position: static;
    inset: auto;
    translate: none;
    width: 100%;
    margin-top: .9rem;
    color: #111;
    text-shadow: none;
    padding: 0 .25rem;
  }
.number_message .txt_area .ex {
    text-align: left;
    line-height: 1.6;
    font-size: 14px;
}
.number_message .txt_area .main {
    text-align: left;
    margin-top: .5rem;
    font-size: 14px;
    line-height: 1.4;
}
  .number_message .txt_area .main .back {
      display: inline-block;
      padding: 0 .4em;
      margin: 0 .2em;
      border-radius: 4px;
      font-size: clamp(20px, 6vw, 24px);
      line-height: 1.2;
      white-space: nowrap;
      color: #fff;
  }
.project_top {
    height: 100%;
}
.project_top .area:nth-child(1) {
    height: 510px;
}
.project_top .area:nth-child(1) .ttl_box {
    top: 43%;
}
  .project_top .area:nth-child(1) .title-en01,
  .project_top .area:nth-child(1) .title-ja,
  .project_top .area:nth-child(1) .title-en02{
  }

  .project_top .area:nth-child(1) .img_box img{
  }
  .project_top .area:nth-child(1) .img_box .top_01,
  .project_top .area:nth-child(1) .img_box .top_02{
  }

  /* 背景の円テキストはSPでは非表示（パフォーマンス優先） */
  .project_top .circle_block01{ display: none; }

  /* =========================
     上下のリンク帯（link_area）
  ========================== */
.project_page .link_area {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
    padding: 28px 4%;
    height: 100%;
}
  .project_page .link_area .txt_box{
    width: 100%;
  }
  .project_page .link_area .txt_box .ex{
    padding-top: 10px;
  }
.project_page .link_area .link_box {
    width: 100%;
    gap: 8px;
    flex-wrap: wrap;
}
  .project_page .link_area .link_box .card{
    overflow: hidden;
  }
  .project_page .link_area .link_box a{
    flex: 1 1 calc(50% - 6px); /* 2列 */
    max-width: calc(50% - 6px);
  }
.project_page .link_area .link_box a .img_box img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 1;
}
.project_page .link_area .link_box a .txt_box {
    position: absolute;
    bottom: 3px;
    left: 3px;
    gap: 6px;
}
.project_page .link_area .link_box a .img_box img {
    border-radius: 2px;
}

  /* =========================
     パネル共通
  ========================== */
.project_section .container {
    padding: 0;
}
  .project_section .area{
    gap: 16px;
  }

  /* 背景スラッシュはモバイルで控えめに or 非表示 */
  .project_section .slash01,
  .project_section .slash02{
    height: 240px;
    opacity: .4;
  }
  .project_section .slash03,
  .project_section .slash04,
  .project_section .slash05,
  .project_section .slash06{
    display: none;
  }

  /* =========================
     area_00（見出し＋メンバー一覧＋写真2枚）
  ========================== */
  .project_section .area_00{
    padding: 36px 0 0;
    flex-direction: column;
  }
  .project_section .area_00 .box01,
  .project_section .area_00 .box02{
    width: 100%;
  }

  .project_section .area_00 .box01 .ttl_box{
    border-bottom: 1px solid #000;
    padding-bottom: 12px;
  }
.project_section .area_00 .box01 .ttl_box .ttl {
    padding-bottom: 0;
}
  .project_section .area_00 .box01 .index_box {
    padding-top: 20px;
    flex-direction: row;
    justify-content: space-evenly;
}
.project_section .area_00 .box01 .index_box .card {
    gap: 5px;
    margin-bottom: 14px;
}
  .project_section .area_00 .box01 .index_box .card .img_box img{
    width: 68px; height: 68px;
    border-width: 2px;
    transform: skewY(-6deg);
  }

.project_section .area_00 .box02 .img-box img:nth-child(1) {
    transform: rotate(-3deg) !important;
}
.project_section .area_00 .box02 .img-box img:nth-child(2) {
    transform: rotate(3deg) !important;
}
.project_section .area_00 .box02 .img-box {
    left: 0px;
}

  /* =========================
     area_detail（area_01～03 共通）
  ========================== */
  .project_section .area_detail{
    padding-top: 48px; /* 各エリアの余白を圧縮 */
    flex-direction: column;
  }
  .project_section .area_detail .box01,
  .project_section .area_detail .box02{
    width: 100%;
  }
.project_section .area_detail .box01 .img_box img {
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
    border-radius: 12px;
    aspect-ratio: 6/4;
    object-fit: cover;
}

  /* 見出し行：番号＋破線＋タイトル */
.project_section .area_detail .box02 .ttl_box {
    gap: 10px;
    align-items: center;
}
  .project_section .area_detail .box02 .ttl_box .number{
    font-size: var(--fs-num-unit);
  }
.project_section .area_detail .box02 .ttl_box .number::after {
    width: 10px;
    top: 4px;
    position: relative;
}
.project_section .area_detail .box02 .ttl_box .ttl {
    font-size: 16px;
}

  .project_section .area_detail .box02 .contents_box{
    margin-top: 22px;
  }

  /* リストの縦積み＋画像サイズ調整 */
  .project_section .area_detail .box02 .contents_box .list {
      flex-direction: row;
      align-items: flex-start;
      gap: 10px;
      margin-bottom: 20px;
      flex-wrap: nowrap;
  }
.project_section .area_detail .box02 .contents_box .list .img_box {
    width: auto;
    min-width: auto;
}
.project_section .area_detail .box02 .contents_box .list .img_box img {
    width: 50px;
    aspect-ratio: 1;
}
.project_section .area_detail .box02 .contents_box .list .txt {
    width: 80%;
    line-height: 1.7;
    margin-top: -10px;
    text-align: justify;
}

  /* area_02 の左右入替指定は解除（縦積みのため） */
  .project_section .area_02 .box01{
    order: 0;
    margin-left: 0; margin-right: 0;
  }
  .project_section .area_02 .box02{ order: 0; }

.project_section .area_01, .project_section .area_02, .project_section .area_03 {
    padding-top: 25px;
    flex-direction: column-reverse;
}

  /* =========================
     下部リンク帯（再掲 UI）
  ========================== */
  .project_page .bottom_section{
    padding-bottom: 0;
  }
  .project_page .bottom_section .link_area {
    padding: 60px 3%;
    width: 100%;
  }



  /* =========================
     汎用：アニメーション
  ========================== */
  .project_section.panel{
    transition: opacity .3s ease, transform .3s ease;
  }
  .project_section.panel.anim-enter{
    opacity: 0; transform: translateY(10px);
  }
  .project_section.panel.anim-enter.anim-active{
    opacity: 1; transform: translateY(0);
  }
  /* 円テキストはSPでは非表示（パフォーマンス＆可読性優先） */
  .news_page .circle_block01,
  .news_page .circle_block02 { display: none; }

  /* セクション余白の最適化 */
  .news_section{
    margin-bottom: 60px;
    padding-top: 48px;
  }

  /* 見出しボックスは中央寄せ＆余白圧縮 */
  .news_section .ttl_box{
    width: 92%;
    margin: 0 auto 12px;
    align-items: center;
    text-align: center;
    gap: .35rem;
  }
  .news_section .ttl_box .title-ja{
    padding: 0 6px;
  }

  /* 2カラム→縦積み（フィルタ→カード） */
  .news_section .area{
    flex-direction: column;
    gap: 16px;
  }

  /* フィルタメニュー */
  .news_section .box01{
    width: 100%;
  }
  .news_section .news_list{
    width: 100%;
    margin: 0 auto;
    padding-top: 0;
    position: static;     /* sticky解除 */
    top: auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
  }
  .news_section .news_list li{
    padding-top: 0;
    border-bottom: none;
    text-align: center;
  }
  .news_section .news_list li a{
    display: inline-block;
    width: 100%;
    padding: 10px 6px;
    border: 1px solid #000;
    border-radius: 8px;
    background: #fff;
    font-weight: 700;
  }
  .news_section .news_list a[aria-current="page"]{
    opacity: 1;
    background: var(--brown);
    color: #fff;
    border-color: var(--brown);
  }

  /* 一覧側コンテナ */
  .news_section .box02{
    width: 100%;
    padding: 20px 14px;
    border-radius: 16px;
    margin-top: 0;
  }
  .news_section .box02 .area{ padding: 0; }

  /* 3col → 1col（SPは幅に合わせて伸縮） */
  .achieve__grid{
    grid-template-columns: 1fr !important;
    gap: 14px;
    margin-top: .5rem;
    padding-right: 0;
  }

  /* カード */
  .achieve__card{ border-radius: 12px; }
  .achieve__thumb{
    border-radius: 0 10px 10px 10px;
    padding: 4px;
    box-shadow: 0 0 0 2px #fff inset, 0 0 0 1px rgba(0,0,0,.06);
  }
  .achieve__thumb img{
    border-radius: 0 10px 10px 10px;
  }

  /* バッジ位置とサイズ微調整 */
  .achieve__badge{
    top: -26px;
    padding: .3rem .5rem;
    border-radius: 5px 5px 0 0;
  }
  .achieve__badgeText{
    font-size: clamp(12px, 3.8vw, 14px);
  }

  /* タイトル／抜粋の行間・サイズ最適化 */
  .achieve__title{
    margin: .6rem .1rem .35rem;
    font-size: clamp(16px, 4.6vw, 18px);
    line-height: 1.4;
  }
  .achieve__excerpt{
    margin: 0 .1rem 0;
    font-size: clamp(13px, 3.8vw, 14px);
    line-height: 1.7;
    -webkit-line-clamp: 3;
  }

  /* 空表示 */
  .achieve__empty{
    padding: .75rem 0;
    text-align: center;
  }

  /* ページネーション */
  .achieve__pagination{
    gap: .3rem;
    margin-top: 16px;
  }
  .achieve__pagination .page-numbers{
    width: 36px; height: 36px;
    border-radius: 8px;
    font-size: 14px;
  }
    /* 円形テキストはSPでは非表示（描画負荷軽減） */
  .news_page .circle_block01,
  .news_page .circle_block02 { display: none; }

  /* セクション余白の最適化 */
.news_section {
    padding-top: 20px;
    margin-bottom: 60px;
}

  /* タイトルブロックは中央寄せ＆余白圧縮 */
  .news_section .ttl_box{
    width: 92%;
    margin: 0 auto 12px;
    align-items: center;
    text-align: center;
    gap: .35rem;
  }
  .news_section .ttl_box .title-ja{
    padding: 0 6px;
  }

  /* 2カラム → 縦積み（左ナビ→本文） */
  .news_section .area {
      flex-direction: column;
      gap: 16px;
      padding: 0 5px;
  }

  /* 左ナビ（sticky解除＋ボタン化） */
  .news_section .box01{ width: 100%; }
.news_section .news_list {
    width: 100%;
    margin: 0 auto;
    position: static;
    top: auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    padding-top: 0;
}
  .news_section .news_list li{
    padding-top: 0;
    border-bottom: none;
    text-align: center;
  }
  .news_section .news_list li a{
    display: inline-block;
    width: 100%;
    padding: 10px 6px;
    border: 1px solid #000;
    border-radius: 8px;
    background: #fff;
    font-weight: 700;
    text-decoration: none;
  }

  /* 右側（記事コンテナ） */
.news_section .box02 {
    width: 100%;
    padding: 40px 0px 40px 14px;
    border-radius: 16px;
    margin-top: 0;
}

  /* ラベル + タイトル + 日付 */
  .single-article__label{
    padding: 3px 8px 1px;
    font-size: clamp(12px, 3.6vw, 14px);
  }
  .single-article__top .ttl_box{
    width: 100%;
    margin: 0;
    padding-top: 6px;
    flex-direction: column;        /* 横並び → 縦積み */
    align-items: flex-start;
    gap: 6px;
  }
  .single-article__top .ttl_box .single-article__title{
    width: 100%;
    line-height: 1.35;
  }
  .single-article__top .ttl_box .single-article__meta{
    width: 100%;
    text-align: left;              /* 右寄せ → 左寄せ */
    font-size: 13px;
    opacity: .9;
  }

  /* アイキャッチ */
  .single-article__thumb{
    margin: 0 0 12px;
    padding: 4px;
    border-radius: 10px 0 0 10px;
    box-shadow: 0 0 0 2px #fff inset, 0 0 0 1px rgba(0,0,0,.06);
  }
  .single-article__thumb img{
    border-radius: 10px 0 0 10px;
    aspect-ratio: 16/9;
    width: 100%; height: auto;
    display: block;
  }

  /* 本文 */
  .single-article__content{
    padding: 1rem;
    border-radius: 12px 0 0 12px;
    line-height: 1.8;
  }
  .single-article__content p{ line-height: 1.8; }

  /* 前後ナビ（中央リンク含む） */
  .single-article__pn{
    width: 100%;
    margin: 18px auto 0;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .single-article__pn a{
    font-size: 14px;
  }
  /* ========= 背景の円は非表示（描画負荷軽減） ========= */
  .recruit_page .circle_block01,
  .recruit_page .circle_block02 { display: none; }

  /* ========= セクション余白 ========= */
.recruit_section {
    padding-top: 20px;
    padding-bottom: 64px;
    padding-right: 5px;
    padding-left: 5px;
}
  .entry_section{
    padding-bottom: 64px;
  }

  /* ========= 2カラム → 縦積み ========= */
  .recruit_section .area,
  .entry_section .area{
    flex-direction: column;
    gap: 16px;
  }

  /* ========= 左コラム（見出し＋アンカー） ========= */
  .recruit_section .area .box01,
  .entry_section .area .box01{
    width: 100%;
  }
  .recruit_section .area .box01 .ttl_box,
  .entry_section .area .box01 .ttl_box{
    width: 92%;
    margin: 0 auto;
    align-items: center;
    text-align: center;
    gap: .35rem;
  }
  .recruit_section .area .box01 .title-ja,
  .entry_section .area .box01 .title-ja{
    padding: 0 6px;
  }

  /* アンカーリスト：sticky解除＆ボタン化 */
  .recruit_section .area .box01 .recruit_list{
    width: 100%;
    margin: 12px auto 0;
    padding-top: 0;
    position: static;
    top: auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .recruit_section .area .box01 .recruit_list li{
    padding-top: 0;
    border-bottom: none;
    text-align: center;
  }
.recruit_section .area .box01 .recruit_list li a {
    display: inline-block;
    width: 100%;
    padding: 10px 6px;
    border: 1px solid #000;
    border-radius: 8px;
    background: #fff;
    font-weight: 700;
    text-decoration: none;
    text-align: center;
}

  /* ========= 右コラム（本文） ========= */
  .recruit_section .area .box02{
    width: 100%;
    margin-top: 8px;
  }

  /* ========= シート見出し ========= */
  .recruit_section .sheet .ttl{
    padding-left: 16px;
  }
  .recruit_section .sheet .ttl::before{
    left: 0;
    font-size: 9px;
  }

  /* ========= 採用テーブル：横→縦に（行ごとカード化） ========= */
  .recruit_section .sheet table{
    width: 100%;
    margin-top: 14px;
    border-radius: 14px;
    box-shadow: 0 0 18px #d7d7d7;
    border-spacing: 0;
  }
  .recruit_section .sheet tbody tr{
    display: block;                /* 行をカード化 */
    border: 1px solid var(--orange);
    border-radius: 10px;
    overflow: hidden;
    margin: 10px 10px 14px;        /* テーブル内余白 */
    background: #fff;
  }
  .recruit_section .sheet tbody tr th,
  .recruit_section .sheet tbody tr td{
    display: block;
    width: 100%;
    border: none;                   /* 行カード内の枠は消す */
  }

  /* ラベル行（th） */
  .recruit_section .sheet tbody tr th{
    border-bottom: 1px solid var(--orange);
    padding: 12px 14px;
    font-size: clamp(16px, 4.6vw, 18px);
    letter-spacing: .5px;
    line-height: 1.5;
    border-radius: 10px 10px 0 0;
  }

  /* 値行（td） */
  .recruit_section .sheet tbody tr td{
    padding: 12px 14px 14px;
    background: rgb(255 255 255 / 96%);
  }
  .recruit_section .sheet tbody tr td p{
    padding-bottom: 6px;
  }

  /* 2カラムの箇条書きを1カラムへ（columns指定の解除） */
  .recruit_section .sheet tbody tr td > div[style*="columns"]{
    columns: 1 !important;
    gap: 0 !important;
    margin-top: 6px;
  }

  /* バッジ類の折返し最適化 */
  .recruit_section .sheet .badge_area{
    display: flex; flex-wrap: wrap; gap: 6px;
  }
  .recruit_section .sheet .badge{
    padding: 2px 6px;
    border-radius: 6px;
  }

  /* セクション間の余白調整 */
  .recruit_section #sheet02{ padding-top: 36px; }
  #sheet03{ padding-top: 36px; }

  /* ========= ボタン ========= */
  .recruit_section .buttons{
    margin-top: 20px;
    padding: 0 10px;
  }
  .recruit_section .buttons [class^=btn-]{
    width: 100%;
    max-width: 420px;
    height: 48px;
    line-height: 48px;
    font-size: 16px;
    letter-spacing: 1.2px;
  }

  /* ========= エントリー（フォーム側） ========= */
.entry_section .area .box02 {
    width: 100%;
    border-radius: 15px;
}
  .entry_section .form_area {
    padding: 16px 10px;
}
  .entry_section .contact_form01{
  }
  .entry_section .recaptcha_message{
    padding: 8px 4px 0;
    text-align: center;
  }
  .label-above .nf-field-label {
    width: 100%;
  }
  .entry_section .form_area .label-above .nf-field-element, .entry_section .form_area .label-below .nf-field-element {
      width: 100% !important;
      display: flex;
      justify-content: center;
  }
  .recaptcha_message p {
    text-align: left;
    font-weight: 400;
    line-height: 1;
  }
  /* 背景の円はSPでは非表示（描画負荷軽減） */
  .faq_page .circle_block01,
  .faq_page .circle_block02 { display: none; }

  /* セクション余白の最適化 */
  .faq_page {
    padding: 0 5px;
  }
.faq_section {
    padding-top: 20px;
}
  .section02.faq_section { padding-bottom: 64px; }

  /* 2カラム → 縦積み */
  .faq_section .area { flex-direction: column; gap: 16px; }
  .faq_section .area .box01,
  .faq_section .area .box02,
  .section02.faq_section .box01 { width: 100%; margin-top: 0; }

  /* 見出しの中央寄せ */
  .faq_section .area .box01 .ttl_box {
    width: 92%;
    margin: 0 auto;
    align-items: center;
    text-align: center;
    gap: .35rem;
  }
  .faq_section .area .box01 .title-ja { padding: 0 6px; }

  /* 青（空色）バック面の容器 */
  .faq_section .box02 .back,
  .section02.faq_section .box01 .back {
    border-radius: 16px;
    box-shadow: 0 0 18px #bdbdbd;
  }

  /* カード域の幅と余白 */
.faq_section .box02 .card-area, .section02.faq_section .box01 .card-area {
    width: 95%;
    margin: 0 auto;
    padding: 18px 0;
}

  /* カード全体 */
  .faq_section .card { border-radius: 10px; }
  .faq_section .card-area .card { margin-bottom: 12px; }

  /* 質問行：タップしやすく */
  .faq_section .question-wrap {
    padding: 12px 14px;
    border-radius: 10px;
  }
  .faq_section .card.open .question-wrap { border-radius: 10px 10px 0 0; }

  .faq_section .question { line-height: 1.4; }
  .faq_section .question .en.fs-lg { margin-right: 6px; }

  /* 矢印サイズ（inline SVG をCSSで上書き） */
  .faq_section .question-wrap svg { width: 18px; height: 18px; }

  /* 回答：開閉アニメと読みやすさ */
  .faq_section .answer {
    padding: 0 14px;
    line-height: 1.75;
  }
  .faq_section .card.open .answer {
    max-height: 1200px;          /* 文章量に余裕を持たせる */
    padding: 12px 14px 14px;
  }

  /* セクション02（下段）も同じ見た目に統一 */
  .section02.faq_section .box01 { width: 100%; }
  /* 背景の円はSPでは非表示（描画負荷軽減） */
  .company_page .circle_block01,
  .company_page .circle_block02 { display: none; }

  /* セクション余白／見出し */
.company_section {
    padding-top: 20px;
    margin-bottom: 64px;
}
  .company_section .ttl_box{
    width: 92%;
    margin: 0 auto 12px;
    text-align: center;
  }

  /* 2カラム → 縦積み */
  .company_section .area{
    flex-direction: column;
    gap: 16px;
  }
  .company_section .box01,
  .company_section .box02{
    width: 100%;
    margin-top: 0;
  }

  /* 左メニュー：sticky解除＋ボタン化 */
.company_section .company_list {
    width: 98%;
    margin: 0 auto;
    padding-top: 0;
    position: static;
    top: auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.company_section .company_list li:nth-child(1) {
    margin-bottom: 0;
}
  .company_section .company_list li{
    padding-top: 0;
    border-bottom: none !important;  /* 色付きボーダーはSPで非表示 */
  }
  .company_section .company_list li a{
    display: inline-block;
    width: 100%;
    padding: 10px 6px;
    border: 1px solid #000;
    border-radius: 8px;
    background: #fff;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
  }

  /* コンテンツ共通：高さ自動化＆角丸縮小 */
  .company_section .contents{
    height: auto;
    border-radius: 16px;
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .company_section .contents:not(:first-child) {
    margin-top: 0px;
}

  /* オフィスだけ特別だった角丸と余白をSP統一 */
  .company_section .contents.office{
    border-radius: 16px;
    margin-bottom: 24px;
    padding-top: 20px;
    flex-direction: column;
    align-items: stretch;
  }

  /* レイアウト：左右→縦並び */
.company_section .contents .detail {
    width: 94%;
    margin: 0 auto;
    flex-direction: column;
    align-items: stretch;
    gap: 0px;
}
.company_section .contents.food .detail, 
.company_section .contents.services_area .detail,
.company_section .contents.rental .detail,
.company_section .contents.game .detail {
      flex-direction: row;
      flex-wrap: nowrap;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      gap: 12px;
  }
 /* services_area 内のカード幅を固定して、縮まないようにする */
.company_section .contents.food .detail .card, 
.company_section .contents.services_area .detail .card,
.company_section .contents.rental .detail .card,
.company_section .contents.game .detail .card {
      flex: 0 0 80%;
      max-width: 80%;
      scroll-snap-align: start;
       width: 100%;
  }
.company_section .contents.food .detail .img_box, 
.company_section .contents.services_area .detail .img_box,
.company_section .contents.rental .detail .img_box,
.company_section .contents.game .detail .img_box {
      width: 100%;
  }
.company_section .contents.food .detail, 
.company_section .contents.services_area .detail,
.company_section .contents.rental .detail,
.company_section .contents.game .detail {
    scroll-snap-type: x mandatory;
}

  /* 画像ボックス：全幅化 */
  .company_section .contents.office .img_box,
  .company_section .contents.pachinko .img_box,
  .company_section .contents.hotel .img_box{
    width: 100%;
    transform: none;
  }
  .company_section .contents .img_area{
    display: block;
  }
  .company_section .contents.game {
    background-color: var(--brown);
    border-radius: 12px 0 0 12px;
  }
  .company_section .contents .company_table tr {
    display: flex;
    flex-direction: column;
}

  /* 画像の角丸は少しだけ、小さめの影がある場合も想定 */
.company_section .contents .img_box img {
    width: 95%;
    height: 100%;
    aspect-ratio: 16/9;
    border-radius: 12px;
    display: block;
    margin: 0 auto;
}
  .company_section .contents .img_box .name{
    bottom: 6px;
    padding: 2px 8px;
    font-size: clamp(12px, 3.6vw, 14px);
  }
.shop-area-card {
    display: inline-block;
    padding: 1em 10px;
}
.shop-area-card__label {
    font-size: 14px;
}
  /* 2枚のやつ */
  .company_section .contents.food , 
.company_section .contents.services_area {

}
.company_section .contents.food .detail, 
.company_section .contents.services_area .detail,
.company_section .contents.rental .detail,
.company_section .contents.game .detail {
    overflow-x: scroll;
}
.company_section .contents.food .detail .card, 
.company_section .contents.services_area .detail .card {}
.company_section .contents.food .img_box, .company_section .contents.services_area .img_box {
    width: 100%;
    height: 185px;
}
.company_section .contents.office .img_box {
    left: 0%;
    top: 5px;
}
  /* カード（テーブル側）を全幅にして読みやすく */
  .company_section .contents.office .card, .company_section .contents.pachinko .card, .company_section .contents.rental  .card, .company_section .contents.hotel   .card, .company_section .contents.game    .card {
    width: 100%;
    margin-top: 12px;
}
  .company_section .contents .ttl.fs-lg{
    width: 94%;
    margin: 0 auto 10px;
    text-align: left;
    border-bottom: 1px solid rgba(255,255,255,.85);
  }

  /* 会社テーブルの読みやすさ（内側余白＆角丸風） */
  .company_section .contents .company_table{
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
  }
  .company_section .contents .company_table th,
  .company_section .contents .company_table td{
    vertical-align: top;
  }
.company_section .contents .company_table th {
    padding: 8px 0px;
    font-weight: 800;
    vertical-align: top;
}
.company_section .contents .company_table td {
    padding: 0px 0px 8px;
}
  .company_section .contents .company_table tr:last-child th,
  .company_section .contents .company_table tr:last-child td{
    border-bottom: none;
  }

  /* タイトル行の上下間隔 */
  .company_section .contents .ttl{ margin-bottom: 8px; }

  /* 色ごとセクションのボトム余白を少し統一 */
  .company_section .contents.pachinko,
  .company_section .contents.rental,
  .company_section .contents.hotel,
  .company_section .contents.food,
  .company_section .contents.services_area,
  .company_section .contents.game{
    padding-bottom: 20px;
  }
  /* 余白・横幅 */
.type_list.section {
    padding-top: 38px;
    padding-bottom: 72px;
}
  .type_list .container{
    width: 92%;
    margin: 0 auto;
  }
.company_section .contents.pachinko,
  .company_section .contents.rental,
  .company_section .contents.hotel,
  .company_section .contents.food,
  .company_section .contents.services_area,
  .company_section .contents.game{
    border-radius: 0;
  }
  .company_section .contents.pachinko{
    border-radius: 10px 10px 0 0px;
  }
  .company_section .contents.office{
    border-radius: 0 0 10px 10px;
  }
  /* 斜め帯はSPで非表示（負荷＆視認性対策） */
  .employee-archive .slash01,
  .employee-archive .slash02{ display:none; }
.employee-archive .title-en02 {
    text-shadow: none;
    padding: 0 4px;
}
  /* カード一覧：1カラムにしてタップしやすく */
  .type_list .area{
    display:grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .type_list .card{
    width: 100%;
    min-height: 132px;
    height: auto;
    padding: 18px 14px;
    border-radius: 12px;
    box-shadow: 0 6px 16px rgba(0,0,0,.1);
  }
  .type_list .card-inner{ gap: 6px; }
  .type_list .card-icon img{ width: 56px; }

  /* 背景ラベル（英字＆番号）は小さめ＆控えめに */
  .type_list .card-bglabel__en{
    left: 12px; top: 10px;
    font-size: 18px; opacity:.28;
    letter-spacing:.04em;
  }
  .type_list .card-bglabel__num{
    left: 12px; top: 34px;
    font-size: 46px; opacity:.18; line-height:1;
  }

  /* モーダル：全体 */
  html.is-modal-open{ overflow:hidden; }
  .type_list .modal{
    padding: 14px;            /* 端末端と被らないよう余白 */
  }
  .type_list .modal__overlay{ background: rgba(0,0,0,.75); }

  /* ダイアログ：幅いっぱい＋余白 */
  .type_list .modal__dialog{
    width: 100%;
    max-width: none;
    margin: 0 auto;
  }

  /* 閉じるボタン：右上固定・指で押しやすく */
  .type_list .modal__close{
    left: auto;
    right: 10px;
    top: 10px;
    display: inline-grid;
    padding: 8px;
  }
  .type_list .modal__close .icon-close{
    width: 40px; height: 40px;
  }

  /* アイテム：1カラムで縦スクロール */
  .type_list .modal-items{
    grid-template-columns: 1fr;
    gap: 14px;
    max-height: calc(100dvh - 90px);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  .type_list .modal__body.is-single .modal-items{
    max-width: 100%;
    margin-inline: 0;
  }

  /* 各アイテムのボックス */
.type_list .modal-contents .box {
    width: 100%;
    height: 375px;
}
  .type_list .modal-contents .img_box img{
    width: 100%; height: auto; display:block;
    border-radius: 12px;
  }

  /* テキストバッジ類（年・ハッシュタグ） */
  .type_list .modal-contents .ttl{
    font-size: 12px;
    padding: 4px 6px;
  }
  .type_list .modal-contents .hashtag{
    font-size: 11px;
    padding: 2px 5px;
  }

  /* 左下テキスト群の位置・余白 */
.type_list .modal-contents .text-bottomleft {
    left: 10px;
    bottom: 9px;
}

  /* 円形テキスト：小さめ＆右下へ */
  .type_list .modal-contents .text-topleft{
    right: 8px; bottom: 8px;
  }
  .type_list .modal-contents .circleText{ width: 72px; }
  .type_list .modal-contents .circleText__text{ font-size: 14px; }

  /* メッセージ配置：被りを避けて下部左寄せに */
  .type_list .modal-contents .message{
    position: absolute;
    max-width: 75%;
  }
  .type_list .modal-contents .message .txt{
    font-size: 13px;
    line-height: 1.6;
  }
.type_list .modal-contents .message {
    top: 39%;
    left: 18%;
}

  /* テンプレート格納用のdivはそのままでOK（JSがclone） */

  /* 背景画像カードの読み込み最適化（SPは中央寄せでOK） */
  .type_list .card.is-office,
  .type_list .card.is-pachinko,
  .type_list .card.is-rental,
  .type_list .card.is-hotel,
  .type_list .card.is-food,
  .type_list .card.is-services-area,
  .type_list .card.is-game,
  .type_list .card.is-banpaku{
    background-position:center;
    background-size:cover;
  }

  /* ---------- ヒーロー（single_top） ---------- */
.employee_single .single_top {
    padding-bottom: 56px;
    height: 475px;
}
  .employee_single .single_top .container{ width: 92%; margin: 0 auto; }
.employee_single .single_top .area {
    height: auto;
    min-height: 0;
    padding-top: 30px;
}
.employee_single .single_top .back_color {
    top: 22%;
    left: -5px;
    border-radius: 10px;
}
.employee_single .single_top .ttl_box {
    position: static;
    align-items: flex-start;
    gap: 4px;
    margin-bottom: 14px;
    margin-left: 10px;
}
  .employee_single .single_top .ttl_box .ttl02{
    padding: 0 6px;
  }
.employee_single .single_top .ex_box {
    position: static;
    margin-bottom: 14px;
    margin-left: 10px;
}
  .employee_single .single_top .ex_box .ex{ width: 100%; }

.employee_single .single_top .img_box {
    position: relative;
    right: -5px;
    bottom: auto;
    width: 100%;
    margin-top: 10px;
}
.employee_single .single_top .img_box img {
    border-radius: 10px;
    box-shadow: 2px 2px 4px #cfcfcf;
}
.employee_single .single_top .number_box {
    position: absolute;
    top: 41px;
    right: 10px;
}
  .employee_single .single_top .number_box .number{
    -webkit-text-stroke: 4px black; text-stroke: 4px black;
    font-size: clamp(46px, 6.5vw, 64px);
    letter-spacing: 0;
  }
  .employee_single .hashtags li {
    margin-bottom: 2px;
}

  /* ---------- セクション02（プロフィール帯） ---------- */
  .employee_single .section02 .area{
    height: auto;
    flex-direction: column;
    gap: 18px;
    padding: 20px 0 10px;
  }
  .employee_single .section02 .box01, .employee_single .section02 .box02 {
      width: 100%;
      height: auto;
  }

  /* 左カラム（縦コピー／年・ハッシュタグ／人物画像） */
  .employee_single .section02 .box01 .ex_box.tate{
    position: relative;
    margin: 0 0 10px;
  }
  .employee_single .section02 .box01 .ex_box.tate {
    top: 30px;
    left: 15%;
}
  .employee_single .section02 .message{
    font-size: clamp(16px, 4.2vw, 20px);
    letter-spacing: .12em;
    line-height: 1.6;
  }
.employee_single .section02 .box01 .tag_box {
    position: static;
    margin-top: 110px;
}
  .employee_single .section02 .box01 .tag_box .ttl{
    padding: 4px 8px;
    font-size: 14px;
  }
.employee_single .hashtags {
    padding-top: 6px;
    display: grid;
    gap: 1px;
}
  .employee_single .hashtags li span{
    padding: 2px 8px; font-size: 12px;
  }
  .employee_single .section02 .box01 .img_box {
    top: 0;
    left: auto;
    margin-top: 10px;
  }
.employee_single .section02 .box01 .img_box .person-img {
    width: 68%;
    left: auto;
    top: auto;
    margin-left: auto;
    display: block;
}
.employee_single .section02 .box01 .img_box .person-shapes {
    left: 5%;
    top: 3%;
    width: 90%;
    z-index: -1;
}

  /* 右カラム（経歴タイムライン） */
  .employee_single .section02 .box02{
    padding: 10px 0 20px;
    width: 100%;
  }
  .employee_single .section02 .box02 .ttl_box{ gap: 2px; }
  .employee_single .section02 .history_box{ padding: 4px 0; }
  .employee_single .section02 .history-list{ margin-top: 16px; }
.employee_single .section02 .history-list li {
    gap: 10px;
    padding: 8px 0 8px;
    height: auto;
}
.employee_single .section02 .history-list li::after {
    left: 93px;
    top: 43px;
}
.employee_single .section02 .history-list .year {
    width: 84px;
    font-size: 14px;
    letter-spacing: 1px;
    justify-content: end;
}
  .employee_single .section02 .history-list .text{
    padding-left: 10px; line-height: 1.7; font-size: 14px;
  }
  .employee_single .section02 .history-list .text::before{ width: 3px; top: .2em; bottom: .2em; }

  /* ---------- セクション03（本文＋画像ブロック） ---------- */
.section03.main_draft .area {
    gap: 18px;
    padding-top: 25px;
    align-items: stretch;
}
.employee_single .section03 {
    padding-top: 10px;
}
  .employee_single .section03 .area .box{ width: 100%; }
  .section03.main_draft .area:nth-child(even) .box01{ order: 1; }
  .section03.main_draft .area:nth-child(even) .box02{ order: 2; }
  .employee_single .section03 .area .box01 .txt_box{ padding-top: 14px; line-height: 1.9; }
.employee_single .section03 .img_box img {
    border-radius: 10px;
    aspect-ratio: 16/9;
    box-shadow: 2px 2px 4px #cfcfcf;
}
  .employee_single .section03 .area .box01 .txt_box p {
    line-height: 1.8;
}
  .section03.main_draft .area::before{
    top: -40%; height: 160%;
    background: linear-gradient(
      var(--angle, 120deg),
      transparent 0 48%,
      rgb(var(--bar, 178 69 214) / .06) 48% 62%,
      transparent 62% 100%
    );
  }

  /* ---------- OTHER PEOPLE スライダー ---------- */
.bottom_section {
    padding-top: 72px;
    padding-bottom: 20px;
}
.bottom_section .slide-wrapper {
    height: auto;
    min-height: 530px;
    border-radius: 40px;
    padding: 10px 0 50px;
    flex-direction: column;
}
  .bottom_section .slide-wrapper .slide_ttl {
      top: 8%;
  }
.bottom_section .swiper {
    height: 500px;
    max-height: 500px;
}
  .bottom_section .swiper-slide{
    padding: 12px; border-radius: 12px;
    transform: scale(.94);
  }
.bottom_section .swiper-slide.swiper-slide-active {
    transform: scale(1.02);
    margin-top: 50px;
    height: 450px;
}
  .bottom_section .swiper-slide .slide-img {
    width: 100%;
  }

  /* 中央/サイドのクロスフェードは維持 */
  .bottom_section .swiper-slide .slide-img{ border-radius: 10px; }
  .bottom_section .swiper-slide .slide-number {
      top: 18%;
      left: 5%;
      font-size: 40px;
  }

  /* 円形テキスト＆年/ハッシュタグ配置の見直し */
.bottom_section .swiper-slide .text-topleft {
    right: 5%;
    top: 20%;
}
  .bottom_section .block{ width: 100px; height: 100px; }
  .bottom_section .circleText__text{ font-size: 14px; }

.bottom_section .swiper-slide.swiper-slide-active .text-bottomleft {
    left: 6%;
    bottom: 5%;
}
  .bottom_section .swiper-slide .text-bottomleft .ttl{
    font-size: 11px; padding: 2px 6px;
  }
  .bottom_section .swiper-slide .text-bottomleft ul li span{
    font-size: 11px; padding: 2px 4px; margin-bottom: 2px;
  }

  /* 縦書きメッセージは中央やや下に */
.bottom_section .swiper-slide .text-center {
    top: 63%;
    left: 36%;
    transform: translate(-50%, -50%);
    height: 230px;
    width: auto;
}
.bottom_section .swiper-slide .text-center p {
    font-size: 14px;
}

  /* ナビボタン（下中央にまとめる） */
.bottom_section .nav-buttons {
    position: absolute;
    bottom: 0%;
    left: 41%;
    transform: translateX(-50%);
    gap: 16px;
}
  .bottom_section .swiper-button-prev,
  .bottom_section .swiper-button-next{
    width: 72px; height: 72px;
    padding: 8px; border-radius: 50%;
  }
  .bottom_section .swiper-button-prev img,
  .bottom_section .swiper-button-next img{ width: 24px; }
  .bottom_section .swiper-button-prev span,
  .bottom_section .swiper-button-next span{ font-size: 12px; }
/* contact */
.contact_page .circle_block01 {
    display: none;
}
.contact_page .circle_block02 {
    display: none;
}
.contact_top .ttl_box {
    top: 10%;
}
.contact_top {
    height: 175px;
}
.child_top .title-en01, .child_top .title-en02 {
    text-shadow: none;
}
.contact_section .form_area {
    padding: 25px 10px;
    border-radius: 16px;
}
.label-above .nf-field-element, .label-below .nf-field-element {
    width: 100% !important;
}
}
