body, h1, h2, h3, h4, h5, h6, p, address,
ul, ol, li, dl, dt, dd,
table, caption, th, td, img, form {
	margin: 0;
	padding: 0;
	border: none;
	font-style: normal;
	font-weight: 400;
	font-size: 1.4rem;
	list-style-type: none;
	font-family: YakuHanJP, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
	letter-spacing: 0.1em;
	line-height: 1;
	font-variant-ligatures:none;
}

.oswald-<uniquifier> {
  font-family: "Oswald", sans-serif;
}

figure{
    margin: 0;
    padding: 0;
}

textarea {
	font-size: 100%;
}

*:focus {
outline: none;
}

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

hr{
}

html{
	min-height: 620px;
	height: 100%;
	overflow-y: scroll;
	font-size: 62.5%;

	font-feature-settings: "palt" 1;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	text-justify: inter-ideograph;
    scroll-behavior: smooth;
}

iframe[name="google_conversion_frame"]{
	position: absolute;
	top: 0;
}

input, button, textarea, select {
}

body {
    height: 100%;
    background: #F2F2F2;
    color: #000;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a{
	text-decoration: none;
	color: #000;
}

a:hover{
	text-decoration: none;
	color: #444;
}

a:hover img{
}
 
a img {
}

input[type="submit"] {
  -webkit-appearance: none;
  border-radius: 0;
}

.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.youtube iframe{
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

.link_button a{
    background-color: #000;
    color: #fff;
    text-align: center;
    line-height: 1; 
    padding: 4px 16px;
    border:solid 1px #000;
    border-radius: 12px;
    transition: all ease .5s;
    font-weight: 600;
}

.link_button a:hover{
    background-color: #fff;
    color: #000;
}


/* 共通ヘッダー */
.header {
    width: 100%;
    position: fixed;
    top: 0;
    transition: color 0.2s ease;
    z-index: 500;
}

.scroll_body .header{
    background-color: #fff;
}

.header-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 40px;
    max-width: 1400px;
    margin: 0 auto;
}

.header-logo {
    width: 240px;
    position: relative;
    z-index: 1000;
}

.header-navigation {

}

.openbtn1 {
}
.openbtn1 span {
}

#g-nav {
    display: flex;
    align-items: center;
    gap: 48px;
    justify-content: flex-end;
}

.main-nav {
}

.main-nav-list {
    display: flex;
    gap: 56px;
}

.main-nav-item {
    font-weight: 700;
}

.main-nav-item a {
    transition: color 0.2s ease;
}

.main-nav-item a:hover {
    color: #E35449;
}

.contact-button {
}
.contact-button__circle {
}
.contact-button__arrow {
}

.contact-button__arrow--new {
}

.header .contact-button {
    background-color: #E35449;
    font-size: 1.2rem;
    gap: 20px;
}

.header .contact-button__circle {
    width: 24px;
    height: 24px;
}

/* メインセクション */
.main-section {
    padding-top: 150px;
    overflow: hidden;
    background-color: #fff;
}

.main-section__content {
    position: relative;
    z-index: 10;
    margin: 0 0 90px;
}

.main-visual-catchphrase {
    width: 1012px;
    margin: 0 auto;
    display: flex;
    gap: 40px;
    flex-direction: column;
    z-index: 100;
    position: relative;
}

.catchphrase-item-tsutawari,
.catchphrase-item-tsunagari,
.catchphrase-item-hirogatte {
    display: flex;
    align-items: center;
    gap: 48px;
    justify-content: space-between;
}

.catchphrase-item-tsunagari .catchphrase-image {
    order: 2;
}

.main-visual-slide {
}

.flowing-gallery {
}

.flowing-gallery__track {
}

.main-visual-video {
    width: 311px;
    height: 111px;
    border-radius: 10px;
    overflow: hidden;
}

.main-visual-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.catchphrase-image img {
}

.catchphrase-item-tsutawari .catchphrase-image{
    width: 398px;
}

.catchphrase-item-tsunagari .catchphrase-image{
    width: 403px;
}

.catchphrase-item-hirogatte .catchphrase-image{
    width: 651px;
}

.main-visual-slide {
    overflow: hidden;
    width: 563px;
}

.flowing-gallery {
    width: 100%;
    border-radius: 12px;
    overflow: hidden;
}

.flowing-gallery__track {
    display: flex;
    width: calc(100% * 2);
    animation: slide 20s linear infinite;
}

.catchphrase-item-tsunagari .flowing-gallery__track {
    animation: slide-left-to-right 20s linear infinite;
}

.flowing-gallery__slide {
    flex: 0 0 20%;
    height: 111px;
    background-color: ghostwhite;
    background-position: center;
    background-size: cover;
}

@keyframes slide {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@keyframes slide-left-to-right {
    0% {
        transform: translateX(-50%);
    }
    100% {
        transform: translateX(0);
    }
}

/* メイン画像 フェード */
.fade-gallery {
    position: relative;
    width: 589px;
    height: 111px;
    border-radius: 12px;
    overflow: hidden;
}

.fade-gallery__slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center;
    background-size: cover;
    opacity: 0;
    transition: opacity 1.5s ease; /* 1.5秒かけてフェード */
    z-index: 1;
}

.fade-gallery__slide.is-active {
    opacity: 1;
    z-index: 2; 
}

/* メイン画像 スライド */
.main-section__scroll-container {
    width: 100%;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
}

.main-section__scroll-text {
    white-space: nowrap;
    display: flex;
    gap: 56px;
    animation: contact-section__scroll 24s linear infinite;
    will-change: transform;
}

.main-section__scroll-text li {
}

.main-section__scroll-text img {
    height: 54px;
    vertical-align: middle;
    width: auto;
    max-width: unset;
}

@keyframes contact-section__scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.main-section__footer {
    padding: 0 40px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    max-width: 1400px;
    margin: 0 auto;
}

.company-info {
}

.company-info__text {
    font-size: 1.2rem;
    line-height: 1.8;
    color: #939393;
    font-weight: 700;
}

.news-section {
    border-left: solid 2px #E35449;
    padding-left: 24px;
    border-right: solid 2px #E35449;
    padding-right: 80px;
}

.news-section__header {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    margin-bottom: 12px;
    gap: 10px;
}

.news-section__header h2 {
    font-size: 1.6rem;
    font-weight: 500;
    font-family: "Oswald", sans-serif;
    letter-spacing: 0.01em;
}

.news-section__date {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.news-section__content h3 {
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.6;
}

.news-section__content a {
    transition: color 0.3s ease;
}

.news-section__content a:hover {
}


/* トップページのアバウトセクションのスタイル */
.top-about-section {
    padding-top: 160px;
    background-color: #fff;
}

.about-bubble-container {
    position: relative;
    display: inline-block;
    width: 548px;
    height: 593px;
    opacity: 0;
    transform: scale(0.8) translateY(20px) rotate(-20deg);
    will-change: transform, opacity;
    margin: 0 auto 80px;
    display: flex;
}

.about-bubble-container.active {
  animation: aboutBubbleBounce 0.8s ease forwards;
}

@keyframes aboutBubbleBounce {
  0% {
    opacity: 0;
    transform: scale(0.8) translateY(20px) rotate(-20deg); /* 左回転 */
  }
  60% {
    opacity: 1;
    transform: scale(1.2) translateY(0) rotate(5deg); /* 右にオーバーシュート */
  }
  80% {
    transform: scale(0.95) translateY(0) rotate(-3deg); /* 左にやや揺り戻し */
  }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0) rotate(0deg); /* 最終位置 */
  }
}

.about-bubble-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  object-fit: contain; /* SVGの縦横比を保持 */
}

.about-bubble-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    text-align: left;
    box-sizing: border-box;
    width: 370px;
    margin: 0 auto;
}

.about-bubble-content h2 {
    font-size: 3.6rem;
    color: #ffffff;
    margin-bottom: 40px;
    font-weight: 700;
    line-height: 1.4;
}

.about-bubble-content p {
    color: #ffffff;
    line-height: 1.8;
    font-weight: 700;
}

.about-bubble-content a {
  color: #ffffff; /* リンク色を白に */
  text-decoration: none;
}

.about-bubble-content a:hover {
  color: #e0e0e0; /* ホバー時に薄いグレー */
  text-decoration: underline;
}

.about-bubble-container__button {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 56px;
}

.about-bubble-container__button a{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.about-bubble-container__button p {
    margin-right: 20px;
}

.common-arrow_white {
    width: 40px;
    height: 40px;
    background: #FFF;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23E35449" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 24px;
    background-position: center;
    background-repeat: no-repeat;
    transition: background-color 0.3s, color 0.3s;
}

.about-bubble-container__button:hover .common-arrow_white {
    background: #E35449;
    background-size: 24px;
    background-position: center;
    background-repeat: no-repeat;
    border:solid 1px #fff;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    box-sizing: border-box;
}

.top-about-text-marquee {
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 24px;
}

.top-about-text-marquee, 
.top-about-illustration-marquee{
   pointer-events: none; 
}

.top-about-text-content {
    display: inline-flex;
    animation: topAboutTextScrollRight 120s linear infinite;
}

.top-about-text-group {
    display: inline-flex;
}

.top-about-text-group span {
    font-size: 1.2rem;
    margin-right: 40px;
    font-weight: bold;
}

/* イラスト部分（下の段） */
.top-about-illustration-marquee {
    overflow: hidden;
    white-space: nowrap;
}

.top-about-illustration-content {
    display: inline-flex;
    animation: topAboutIllustrationScrollLeft 30s linear infinite;
    width: calc(100% * 2); /* 12件分の幅 */
}

.top-about-illustration-group {
    display: inline-flex;
    margin: 0 12px;
    width: calc(100% / 12); /* 12等分 */
}

.top-about-illustration-link {
}

/* 左スクロールアニメーション（12件の半分） */
@keyframes topAboutIllustrationScrollLeft {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

/* スクロールアニメーション（上の段） */
@keyframes topAboutTextScrollRight {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

/* トップページ 強み */
.strengths-section {
    background-color: #282828;
    padding: 160px 0;
}

.card-group {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 0 32px;
    box-sizing: border-box;
    max-width: 1400px;
    margin: 0 auto;
}

.stats-card {
    width: 22%;
    padding: 0 48px;
    position: relative;
    color: #fff;
    border-right: 1px solid #fff;
}

.stats-card:last-child {
    border-right: none; /* 最後のカードには区切り線を表示しない */
}

.stats-card-header {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
}

.stats-card-number {
    background-color: #ff4d4d;
    color: #282828;
    border-radius: 50%;
    width: 35px;
    height: 35px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    font-family: "Oswald", sans-serif;
    letter-spacing: 0.01em;
}

.stats-card-title {
    font-weight: 700;
}

.stats-card-value {
    margin-bottom: 32px;
    display: flex;
    align-items: flex-end;
}

.stats-card-number-value {
    font-size: 7.6rem;
    font-weight: bold;
    font-family: "Oswald", sans-serif;
    letter-spacing: 0.01em;
}

.stats-card-unit {
    font-size: 2.4rem;
    font-weight: 700;
    margin-left: 8px;
    width: 64px;
}

.stats-card-description p {
    line-height: 2;
    font-weight: bold;
}

.footer-note {
    font-size: 1rem;
    margin-top: 32px;
    text-align: right;
}

/* 主要取引先セクションのスタイル */
.partners-section {
    color: #fff;
    display: flex;
    align-items: center;
    padding-left: 80px;
    overflow: hidden;
    max-width: 1400px;
    margin: 80px auto 0;
    box-sizing: border-box;
    width: 100%;
    display: flex;
}

.partners-text {
    width: 30%;
}
.partners-title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 16px;
    text-align: left;
}
.partners-subtitle {
    font-size: 1.2rem;
    text-align: left;
}
.partners-marquee {
    width: 70%;
    overflow: hidden;
    white-space: nowrap;
}
.partners-marquee-content {
    display: inline-flex;
    animation: partnersScroll 80s linear infinite;
}
.partners-banner-group {
    display: inline-flex;
}

.partners-banner-group div {
    width: 140px;
    margin-right: 24px;
}

/* 無限スクロールアニメーション */
@keyframes partnersScroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

/* トップページ課題解決 */

.solution-section {
  padding: 160px 80px;
  
}

.solution-section__wrapper {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 80px;
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
}

.solution-section__left {
    flex: 1;
    position: sticky;
    top: 160px;
    height: 100%;
}

.solution-section__title {
  font-size: 3.2rem;
  font-weight: bold;
  margin-bottom: 24px;
}

.solution-section__subtitle {
  line-height: 1.8;
  font-weight: 700;
  font-size: 1.6rem;
}
.solution-section__right {
  flex: 1;
}

.solution-section__grid {
    background-color: #E35449;
    border-radius: 16px;
    padding: 32px;
    margin-bottom: 32px;
}

.solution-section__card {
    position: relative;
}

.solution-section__card-number {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 2.4rem;
  font-weight: bold;
  color: #fff;
  font-family: "Oswald", sans-serif;
}

.solution-section__card-title {
  font-size: 2.4rem;
  font-weight: bold;
  color: #fff;
  margin-bottom: 64px;
}

.solution-section__card-text {
    color: #fff;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.8;
    width: 240px;
}

.solution-section__card-action {
  position: absolute;
  top: 100px;
  right: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.solution-section__card-example {
  font-size: 1.6rem;
  font-weight: 700;
  color: #fff;
}
.solution-section__card-plus {
  width: 32px;
  height: 32px;
  background: #fff;
  border-radius: 50%;
  position: relative;
}
.solution-section__card-plus::before {
  content: '+';
  position: absolute;
  top: 46%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 2.4rem;
  color: #d9534f;
}
.solution-section__card-plus.is-open::before {
  content: '-';
  top: 40%;
}

.solution-section__drawer {
    max-height: 0;
    overflow: hidden;
    padding: 0 20px;
    background-color: #fff;
    border-radius: 8px;
    color: #333;
    font-size: 1.2rem;
    line-height: 1.8;
    transition: max-height 0.3s ease, padding 0.3s ease;
}

.solution-section__drawer.is-open {
    padding: 40px 20px;
    margin-top: 20px;
}

.solution-section__drawer-title {
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 20px;
    line-height: 1.6;
}

.solution-section__drawer-text {
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1.8;
}

.solution-section__drawer-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-top: 24px;
}

.solution-section__drawer-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.solution-section__drawer-item-image {
    width: 100%;
    height: 0;
    padding-top: 56%;
    background-color: #e0e0e0;
    border-radius: 8px;
    margin-bottom: 8px;
    background-position: center;
    background-size: cover;
}

.solution-section__drawer-item-title {
    font-size: 1rem;
    font-weight: bold;
}

.solution-section__drawer-item-text {
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.4;
}


/* トップページありがとうの数 */
.thanks-section {
  background-color: #fff;
  border-top: solid 2px;
}

.thanks-section__header {
  text-align: center;
  margin-bottom: 40px;
}

.thanks-section__title {
  font-size: 36px;
  font-weight: bold;
  color: #333;
  margin-bottom: 10px;
}
.thanks-section__subtitle {
  font-size: 16px;
  color: #666;
}
.thanks-section__carousel {
  overflow: hidden;
  width: 100%;
}

.thanks-section__carousel-track {
display: flex;
animation: scroll 160s linear infinite;
}

.thanks-section__card {
    padding: 20px 16px;
    display: flex;
    gap: 16px;
    flex: 0 0 auto;
    align-items: flex-end;
    transition: background-color 0.3s ease, color 0.3s ease;
    position: relative;
}

.thanks-section__card::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 1px;
    height: 48%;
    background-color: #777;
}

.thanks-section__card:hover {
  background-color: #E35449;
  color: #fff;
}

.thanks-section__card:hover .thanks-section__card-date,
.thanks-section__card:hover .thanks-section__card-text-number {
  color: #ffffff;
}

.thanks-section__card .thanks-section__card-text:last-child {
  margin-bottom: 0;
}

.thanks-section__card-date {
    font-size: 1.6rem;
    font-weight: bold;
    color: #E35449;
    letter-spacing: 0.01em;
    transition: color 0.3s ease;
}

.thanks-section__card-text {
  font-size: 1.6rem;
  font-weight: 700;
}

.thanks-section__card-text-number {
font-size: 2.4rem;
color: #E35449;
transition: color 0.3s ease;
}

@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc(-100%)); /* トラックの全幅分移動 */
  }
}


/* トップページ主な仕事部分 */
.works-section {
    background-color: #282828;
    padding: 160px 80px;
    overflow: hidden;
}

.works-section__title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
    margin: 0 auto 40px;
    max-width: 1400px;
}

.works-section__title h2 {
    font-weight: 700;
    color: #fff;
    font-size: 3.2rem;
}

.works-section__title .common-link__button {
    color: #fff;
    border: solid 1px #fff;
}

.works-section__title .common-link__button:hover {
    background-color: #E35449;
    color: #fff;
    border: 1px solid #E35449;
}

.works-section__side-scroll {
    max-width: 1400px;
    margin: 0 auto;
}

.works-section__side-scroll--container {
  width: 100%;
}

.works-section__side-scroll--list-wrapper {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 44%;
}

.works-section__side-scroll--list {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    gap: 0 28px;
}

.works-section__side-scroll--item {
    width: calc((100vw - 28px) / 2);
    min-width: 300px;
    border-radius: 10px;
    position: relative;
    max-width: 800px;
}

.works-section__side-scroll--item-content-wrapper {
  display: flex;
  flex-direction: column;
}

.works-section__side-scroll--item-image-wrapper {
    overflow: hidden;
    border-radius: 10px;
    margin-bottom: 24px;
}

.works-section__side-scroll--item-image {
    width: 100%;
    height: 0;
    padding-top: 57.14%;
    background-color: #e0e0e0;
    border-radius: 16px;
    background-size: cover;
    background-position: center;
    transition: transform 0.4s ease-out;
}

.works-section__side-scroll--item:hover .works-section__side-scroll--item-image {
    transform: scale(1.1);
}

.works-section__side-scroll--item-content {
    position: relative;
}

.works-section__side-scroll--item-title {
    font-size: 1.8rem;
    font-weight: bold;
    color: #fff;
    margin-bottom: 16px;
}

.works-section__side-scroll--item-text {
    font-size: 1.2rem;
    color: #fff;
}

.works-section__side-scroll--item-text a{
    color: #fff;
}

.works-section__card-arrow {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 40px;
    height: 40px;
    background: #E35449;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 20px;
    background-position: center;
    background-repeat: no-repeat;
}

.works-section__side-scroll--bottom-content {
  height: 1000px;
  margin-top: 40px;
  padding: 40px;
  background: #282828;
  border-radius: 10px;
  text-align: center;
}

.works-section__side-scroll--bottom-content p {
  color: #fff;
}

.industry-list {
    background-color: #404040;
    padding: 56px 48px;
    border-radius: 16px;
    text-align: center;
    margin: 0 auto;
    box-sizing: border-box;
    max-width: 1200px;
}

.industry-list h3 {
    color: #fff;
    font-size: 1.8rem;
    margin-bottom: 32px;
    font-weight: 700;
}

.industry-grid {
    display: flex;
    gap: 16px 2%;
    flex-wrap: wrap;
}

.industry-item {
    display: block;
    background-color: transparent;
    border: 1px solid #ffffff;
    color: #ffffff;
    padding: 16px;
    font-size: 1.2rem;
    border-radius: 6px;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.3s;
    font-weight: 700;
    width: 12.5%;
    white-space: nowrap;
    box-sizing: border-box;
}

.industry-item:hover {
    background-color: #fff;
    color: #404040;
}


/* トップページサービス部分 */
.services-section {
    background-color: #F2F2F2;
    padding: 160px 80px 0;
}

.services-section__title{
	text-align: center;
	margin-bottom: 64px;
}

.services-section__title h2 {
    font-size: 3.2rem;
    font-weight: 700;
}

.services-section__gridlist {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: relative;
    z-index: 200;
    max-width: 1400px;
    margin: 0 auto;
}

.services-section__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: auto;
    gap: 20px;
    margin: 0 auto;
}

.services-section__card {
    background: #fff;
    border-radius: 16px;
    padding: 24px;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    box-sizing: border-box;
}

.services-section__card--video {
  padding: 0;
  background: none;
  box-shadow: none;
  overflow: hidden;
}

.services-section__card--tall {
  grid-row: span 2;
}
.services-section__card--extra-tall {
  grid-row: span 3;
}
.services-section__card--large {
  grid-column: span 2;
  grid-row: span 2;
}
.services-section__card--medium {
  grid-column: span 2;
}
.services-section__card-content {
  display: flex;
  flex-direction: column;
}

.services-section__card-image {
    width: 100%;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.services-section__card--bgimg01 {
    background-image: url(../images/home/top_service_bgimg_top.jpg);
    background-position: center;
    background-size: cover;
}

.services-section__card--bgimg02 {
    background-image: url(../images/home/top_service_bgimg_bottom.jpg);
    background-position: center;
    background-size: cover;
}

.services-section__card-video {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  object-fit: cover;
}

.services-section__card-title {
    font-weight: 700;
    margin-bottom: 12px;
    line-height: 1.4;
}

.services-section__card-text {
    font-size: 1.2rem;
    color: #7A7676;
    line-height: 1.6;
}

.services-section__card-arrow {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
    background: #E35449;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
}

.services-section__card--medium .services-section__card-content,
.services-section__card--large .services-section__card-content {
    display: flex;
    flex-direction: row;
    gap: 20px;
    justify-content: space-between;
    align-items: flex-end;
}

.services-section__card-content--detail {
    width: 48%;
}

.services-section__card--medium .services-section__card-image-container,
.services-section__card--large .services-section__card-image-container {
    overflow: hidden;
    width: 48%;
}

.services-section__card-image-container {
  overflow: hidden;
  border-radius: 8px;
}

.services-section__card-image {
  transition: transform 0.3s ease;
}

.services-section__card:hover .services-section__card-image {
  transform: scale(1.1);
}

.services-section__card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.services-section__card-link-event{
    display: flex;
    align-items: flex-end;
}

/* WEBサイト制作 */
.services-section__card-image--web {
    margin-bottom: 24px;
}
.services-section__card-image--system {
}
.services-section__card-image--drone {
    margin-bottom: 24px;
}
.services-section__card-image--video {
}
.services-section__card-image--illustration {
}
.services-section__card-image--graphic {
}
.services-section__card-image--digitize {
}
.services-section__card-image--cad3d {
}
.services-section__card-image--redesign {
}
.services-section__card-image--cg3d {
}
.services-section__card-image--design {
    margin-bottom: 24px;
}
.services-section__card-image--macro {
}
.services-section__card-image--print {
    margin-bottom: 24px;
}
.services-section__card-image--event {
}
.services-section__card-image--translation {
}

.services-section__card-image {
  transition: transform 0.3s ease;
}

.services-section__card-image-container {
  overflow: hidden;
  border-radius: 8px;
}

.services-section__card-content--web .services-section__card-image-container,
.services-section__card-content--drone .services-section__card-image-container,
.services-section__card[style*="grid-row: span 3"] .services-section__card-image-container {
    margin-bottom: 24px;
}

.services-section__card-image-container svg {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    transition: transform 0.3s ease;
}

.services-section__card:hover .services-section__card-image-container svg {
  transform: scale(1.1);
}

.services-section__card-svg-image {
    display: block;
    width: 100%;
    height: auto;
    transition: transform 0.3s ease;
}

.services-section__card:hover .services-section__card-svg-image {
  transform: scale(1.1);
}

.services-section__card:hover .services-section__card-image {
  transform: none;
}

.services-section__card--tall .services-section__card-content--web, .services-section__card--tall .services-section__card-content--drone, .services-section__card--extra-tall .services-section__card-content--web {
    margin-top: 16px;
}

.services-section__card--medium .services-section__card-image-container,
.services-section__card--large .services-section__card-image-container {
    width: 48%;
    overflow: hidden;
}

.services-section__card-link-event {
    display: block; 
}

.services-section__contact {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 80px 0;
    margin: 0 auto;
    position: relative;
    max-width: 1200px;
}

.services-section__contact--left {
    flex: 1;
    margin-left: 120px;
    position: relative;
    z-index: 100;
}

.services-section__contact--title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 42px;
    line-height: 2;
}

.services-section__contact--subtitle {
    margin-bottom: 40px;
    font-weight: 700;
    line-height: 2;
}

.services-section .services-section__contact--right {
    width: 420px;
    margin-right: 120px;
    bottom: 0;
    position: absolute;
    right: 0;
    z-index: 100;
}

.services-section__contact--right svg {
    width: 100%;
    height: 100%;
}

.services-section__contact--image {
}

.services-section__contact--circle {
    left: 0;
    width: 520px;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    z-index: 0;
}

.services-section__contact--circle img {
    animation: rotate 240s linear infinite;
}

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

.contactpage-section__form-input input, .contactpage-section__form-textarea textarea {
    font-size: 1.6rem;
}

.contactpage-section__form-input input::placeholder,
.contactpage-section__form-textarea textarea::placeholder {
  color: #D7D7D7;
}

/* トップページブログ部分 */
.blog-section {
    display: flex;
    padding: 160px 80px;
    gap: 160px;
    justify-content: space-between;
    margin: 0 auto;
    position: relative;
    background-color: #fff;
    overflow: hidden;
    max-width: 1400px;
}

.blog-section__left {
    flex: 1;
    max-width: 300px;
}

.blog-section__title {
    font-size: 3.2rem;
    font-weight: bold;
    margin-bottom: 32px;
}

.blog-section__subtitle {
    margin-bottom: 32px;
    line-height: 1.8;
}

.common-link__button {
    display: inline-flex;
    align-items: center;
    gap: 40px;
    padding: 6px 12px 6px 24px;
    font-size: 1.2rem;
    background: none;
    border: 1px solid #000;
    border-radius: 32px;
    cursor: pointer;
    transition: background-color 0.3s, color 0.3s;
    font-weight: 600;
    position: relative;
}

.common-link__button a{
	position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;	
}

.common-link__button:hover {
	background-color: #E35449;
	color: #fff;
	border: 1px solid #E35449;
}

.common-link__button::after {
    content: '';
    display: inline-block;
    width: 32px;
    height: 32px;
    background: #E35449;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
}

.common-link__button:hover::after {
	width: 32px;
	height: 32px;
	background: #fff;
	background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23E35449" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
	background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
}

.blog-section__right {
    flex: 2;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.blog-section__card {
    display: flex;
    gap: 36px;
    align-items: flex-start;
    position: relative;
}

.blog-section__card-image {
    width: 48%;
    padding-top: 30%;
    background-color: #e0e0e0;
    border-radius: 10px;
    background-size: cover;
    background-position: center;
}

.blog-section__card-content {
    flex: 1;
    padding-bottom: 32px;
}

.blog-section__card-date {
    font-size: 1.2rem;
    color: #B8B8B8;
    font-weight: 600;
}

.blog-section__card-date .date {
    font-family: "Oswald", sans-serif;
    margin-right: 16px;
}

.blog-section__card-title {
    font-size: 2.1rem;
    font-weight: 700;
    margin-bottom: 20px;
    margin-top: 16px;
    line-height: 1.4;
}

.blog-section__card-text {
    font-size: 1.2rem;
    line-height: 1.8;
}

.blog-section__card-arrow {
    width: 32px;
    height: 32px;
    background: #E35449;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
    align-self: center;
    position: absolute;
    right: 0;
    bottom: 0;
}


/* footer上Contact */
.contact-section {
    position: relative;
    background-color: #E35449;
    color: white;
    display: flex;
    padding: 160px 80px 200px;
    overflow: hidden;
}

.contact-section__content {
    display: flex;
    gap: 80px;
    z-index: 1;
    justify-content: space-between;
    width: 88%;
    margin: 0 auto;
    max-width: 1200px;
}

.contact-section__text-block {
}

.contact-section__text-block h2 {
    font-size: 3.2rem;
    font-weight: 600;
}

.contact-section__text-block p {
    margin-top: 28px;
    font-size: 1.6rem;
}

.contact-button {
    display: flex;
    align-items: center;
    gap: 80px;
    padding: 12px 12px 12px 24px;
    font-size: 1.6rem;
    background: none;
    border: 1px solid #fff;
    color: #fff;
    border-radius: 40px;
    cursor: pointer;
    position: relative;
    font-weight: 600;
}

.contact-button__circle {
    display: inline-block;
    width: 40px;
    height: 40px;
    background: white;
    border-radius: 50%;
    position: relative;
    overflow: hidden;
}

.contact-button__arrow {
  position: absolute;
  width: 20px;
  height: 20px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23d9534f" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
  background-size: 20px;
  background-repeat: no-repeat;
  background-position: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.3s ease;
}

.contact-button:hover .contact-button__arrow {
  transform: translate(50%, -150%); /* 斜め右上に直線移動 */
}

.contact-button__arrow--new {
  position: absolute;
  width: 20px;
  height: 20px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23d9534f" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
  background-size: 20px;
  background-repeat: no-repeat;
  background-position: center;
  top: 50%;
  left: 50%;
  transform: translate(-150%, 50%); /* 斜め左下からスタート */
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.contact-button:hover .contact-button__arrow--new {
  transform: translate(-50%, -50%); /* 中央へ直線移動 */
  opacity: 1;
}

.contact-section__scroll-container {
    position: absolute;
    bottom: -6px;
    width: 100%;
}

.contact-section__scroll-text {
    opacity: 0.2;
    white-space: nowrap;
    display: flex;
    gap: 160px;
    animation: contact-section__scroll 12s linear infinite;
}

.contact-section__scroll-text li {
}

.contact-section__scroll-text img {
    height: 160px;
    vertical-align: middle;
    width: auto;
    max-width: unset;
}

@keyframes contact-section__scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* footer */

.footer {
    padding: 110px 40px 56px;
    background: #282828;
    color: #fff;
}

.footer-top {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: space-between;
    max-width: 1400px;
    margin: 0 auto;
}

.footer-left {
  flex: 1 1 300px;
}

.footer-logo {
    margin-bottom: 32px;
}

.footer-logo img {
    margin-bottom: 40px;
    width: 395px;
    height: auto;
}

.footer-logo h2 {
    font-size: 1.8rem;
    font-weight: 600;
}

.footer-address {
    font-size: 1.6rem;
    line-height: 1.8;
}

.map-btn {
    margin-top: 40px;
    padding: 12px 48px;
    background: transparent;
    border: 1px solid #fff;
    color: #fff;
    border-radius: 24px;
    cursor: pointer;
    font-size: 1.2rem;
    font-weight: 600;
    display: inline-block;
    position: relative;
    transition: color 0.2s ease;
}

.map-btn:hover{
    background-color: #ffff;
    color: #000;
}

.map-btn a {
    color: #fff;
    width: 100%;
    position: absolute;
    height: 100%;
    top: 0;
    left: 0;
}

.footer-sitemap {
    display: flex;
    gap: 40px;
    flex-wrap: nowrap;
}

.footer-sitemap ul {
    min-width: 140px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.footer-sitemap li {
    font-size: 1.2rem;
}

.footer-sitemap li strong{
    font-size: 1.4rem;
}

.footer-sitemap a {
  color: #fff;
}

.footer-sitemap a:hover {
  text-decoration: underline;
}

.footer-links {
    margin-top: 110px;
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: flex-start;
    max-width: 1400px;
    margin: 110px auto 0;
}

.footer-links a {
  color: #fff;
  text-decoration: none;
  position: relative;
}

.footer-links a::after {
  content: '';
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-left: 0.4em;
  vertical-align: middle;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a1 1 0 0 1-1 1H6a1 1 0 0 1-1-1V7a1 1 0 0 1 1-1h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

.arrow-up {
    width: 10px;
    height: 10px;
    border-left: 1px solid #fff;
    border-bottom: 1px solid #fff;
    transform: rotate(135deg);
    margin-bottom: -3px;
}

.footer-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.footer-line .line.left {
  flex-grow: 1;
  height: 1px;
  background-color: #fff;
}

.footer-line .line.right {
  width: 60px; /* 調整用 */
  height: 1px;
  background-color: #fff;
}

.back-to-top {
  width: 40px;
  height: 40px;
  border: 1px solid #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  margin: 0 20px;
}

.footer-bottom {
    padding: 24px 0 24px;
    color: #fff;
    max-width: 1400px;
    margin: 0 auto;
}

.footer-bottom-content {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 auto;
    gap: 40px;
}

.footer-policy-links {
  display: flex;
  gap: 40px;
}

.footer-policy-links a {
    color: #fff;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 600;
}

.footer-copy {
    font-weight: 600;
    white-space: nowrap;
    font-size: 1rem;
    font-family: "Oswald", sans-serif;
}


/* 下層ページ 共通style */

.otherpage-container {
    padding-top: 120px;
    margin: 120px auto 0;
}

.otherpage-container__headline {
    margin: 0 auto 80px;
    padding: 0 80px;
    max-width: 1400px;
}

.otherpage-subheading {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 12px;
}

.otherpage-container__headline h2 {
  font-size: 3.2rem;
  font-weight: 700;
}

.link__all {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
}

.otherpage-breadcrumb {
  padding: 16px 40px;
  background-color: #fff;
}

.otherpage-breadcrumb ul {
    display: flex;
    max-width: 1400px;
    justify-content: flex-end;
    margin: 0 auto;
}

.otherpage-breadcrumb li {
  font-size: 1.2rem;
  font-weight: 700;
}

.breadcrumb-separator {
  margin: 0 12px;
}

.common-arrow_black {
    width: 30px;
    height: 30px;
    background: #000;
    border-radius: 50%;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-130)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-position: center;
    background-repeat: no-repeat;
    transition: background-color 0.3s, color 0.3s;
    background-size: 20px;
}

.otherpage-anchor-nav {
  min-width: 240px;
  position: sticky;
  top: 140px;
  height: 100%;
}

.otherpage-anchor-nav__list {
  padding: 0;
}

.otherpage-anchor-nav__item {
  margin-bottom: 32px;
  font-weight: 700;
  position: relative;
  padding-left: 20px;
}

.otherpage-anchor-nav__item a.is-current::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #E35449;
  border-radius: 50%;
}

.otherpage-anchor-nav__item--back {
    margin-top: 160px;
    display: flex;
    align-items: center;
    position: relative;
}

.otherpage-anchor-nav__item a {
}

.otherpage-anchor-nav__item--back a{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.otherpage-anchor-nav__item--back p {
    font-weight: 700;
    margin-right: 16px;
    letter-spacing: 0.05em;
}

.otherpage-anchor-nav__item a:hover,
.otherpage-anchor-nav__item--back a:hover {
}


/* 実績一覧 */
.work-section {
    display: flex;
    flex-direction: column;
    gap: 64px;
    padding: 0 80px;
    max-width: 1200px;
    margin: 0 auto;
}

.work-section__categories {
    background-color: #fff;
    padding: 32px;
    box-sizing: border-box;
    border-radius: 10px;
}

.work-section__industry-filter {
    display: flex;
    margin-bottom: 32px;
}

.work-section__industry-filter-title {
  font-weight: 700;
  min-width: 140px;
}

.work-section__industry-filter-list {
    list-style: none;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 12px 16px;
}

.work-section__industry-filter-item {
    font-size: 1.2rem;
    background-color: #000;
    color: #fff;
    border-radius: 4px;
}

.work-section__industry-filter-item a {
    transition: color 0.3s;
    color: #ffff;
    padding: 8px 12px;
    display: block;
}

.work-section__industry-filter-item a:hover {
}

.work-section__category-filter {
    display: flex;
}

.work-section__category-filter-title {
    font-weight: 700;
    min-width: 140px;
}

.work-section__category-filter-list {
    list-style: none;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 8px;
}

.work-section__category-filter-item {
    font-size: 1.2rem;
    color: #fff;
    border-radius: 30px;
    border: solid #000 1px;
}

.is-active.work-section__category-filter-item {
    background-color: #E35449;
    border: solid #E35449;
}

.is-active.work-section__category-filter-item a {
    color: #fff;
}

.work-section__category-filter-item a {
    transition: color 0.3s;
    padding: 8px 12px;
    display: block;
}

.work-section__category-filter-item a:hover {
}

.work-section__items {
    display: flex;
    gap: 40px 3%;
    flex-wrap: wrap;
}

.work-section__item {
    overflow: hidden;
    width: 31.3%;
}

.work-section__thumbnail-wrapper {
    overflow: hidden;
    margin-bottom: 16px;
    border-radius: 10px;
}

.work-section__thumbnail {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding-top: 56%;
    background-color: ghostwhite;
    position: relative;
    transition: transform 0.3s;
}

.work-section__item:hover .work-section__thumbnail {
    transform: scale(1.05);
}

.work-detail__client {
    font-weight: 700;
}

.work-section__title-block {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.work-section__title {
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 16px;
    margin-top: 8px;
}

.work-section__title a {
    transition: color 0.3s;
}

.work-section__title a:hover {
    color: #007bff;
}

.work-section__industry {
    background-color: #000;
    color: #fff;
    font-size: 1rem;
    padding: 8px 12px;
    border-radius: 10px;
    font-weight: 700;
}

.work-section__meta {
}

.work-section__meta-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.work-section__meta-categories li {
    font-size: 1rem;
    border: solid 1px;
    border-radius: 30px;
    font-weight: 700;
    padding: 4px 10px;
}

.work-section__meta-categories a {
    transition: color 0.3s;
}

.work-section__meta-categories a:hover {
}


/* 事業一覧 */
.service-list__wrapper {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 80px;
    display: flex;
    flex-wrap: wrap;
    gap: 20px 2%;
    position: relative;
    z-index: 100;
}

.service-list__item {
    display: flex;
    gap: 4%;
    width: 49%;
    background-color: #ffff;
    border-radius: 10px;
    box-sizing: border-box;
    padding: 24px;
    position: relative;
}

.service-list__thumbnail {
    width: 36%;
    overflow: hidden;
}

.service-list__thumbnail img {
    width: 100%;
    height: auto;
    transition: transform 0.3s;
}

.service-list__item:hover .service-list__thumbnail img {
    transform: scale(1.05);
}

.service-list__content {
    width: 60%;
}

.service-list__title {
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 16px;
}

.service-list__catchcopy {
    color: #939393;
    line-height: 1.6;
}

.service-list__item .services-section__card-arrow {
    top: unset;
    bottom: 24px;
    right: 24px;
}

.service-archive__contact--right {
    flex: 1;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 560px;
    margin-right: 120px;
}

.service-archive__contact--right svg {
    width: 100%;
    height: 100%;
}

.related-links {
    background-color: #fff;
    padding: 120px 0;
    position: relative;
    z-index: 100;
}

.otherpage-container__headline h3{
    font-size: 2.6rem;
    font-weight: 700;
}

.related-links__list {
    margin: 0 auto 80px;
    padding: 0 80px;
    max-width: 1400px;
    display: flex;
    flex-wrap: wrap;
    gap: 88px 3%;
}

.related-links__item {
    width: 31.3%;
    position: relative;
}

.related-links__thumbnail {
    overflow: hidden;
    border: solid 1px #000;
    box-sizing: border-box;
    border-radius: 10px;
    margin-bottom: 32px;
}

.related-links__thumbnail img {
    width: 100%;
    height: auto;
    transition: transform 0.3s;
}

.related-links__item h4{
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 24px;
}

.related-links__item:hover .related-links__thumbnail img {
    transform: scale(1.05);
}

.related-links__description {
}

.related-links__description p{
    line-height: 1.8;
}


/* 事業詳細 */
.service-section__wrapper {
    display: flex;
    gap: 40px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 80px;
    position: relative;
}

.service-section {
    margin-bottom: 160px;
}

.service-section__content {
  width: 100%;
}

.service-section__block {
  margin-bottom: 56px;
  background-color: #fff;
  border-radius: 10px;
  box-sizing: border-box;
  padding: 48px;
  display: flex;
  gap: 48px;
}

.service-section__thumbnail {
  min-width: 280px;
}

.service-section__thumbnail img {
  width: 100%;
  height: auto;
}

.service-section__block-inner {
}

.service-section__body {
}

.service-section__body h4 {
  font-size: 1.8rem;
  margin-bottom: 24px;
  font-weight: 700;
  line-height: 1.6;
}

.service-section__body p {
  line-height: 1.8;
  margin-bottom: 16px;
}

.service_use {
  margin-top: 40px;
  padding-top: 40px;
  border-top: solid 1px #B9B9B9;
}

.service_use h3 {
  font-size: 2.1rem;
  margin-bottom: 32px;
  font-weight: 700;
}

.service_use h4 {
    font-size: 1.6rem;
    line-height: 1.4;
    font-weight: 700;
    margin-bottom: 12px;
}

.service_use p {
  margin-bottom: 8px;
  line-height: 1.8;
}

.service_use strong {
  line-height: 1.4;
}

.service-section__block-title {
  min-width: 280px;
  margin-bottom: 15px;
}

.service-section__block-title h3 {
  font-size: 2.1rem;
  font-weight: 700;
}

.service_strength {
}

.service_strength p {
    margin-bottom: 8px;
    line-height: 1.8;
}

.service_strength h4 {
    font-size: 1.6rem;
    line-height: 1.4;
    font-weight: 700;
    margin-bottom: 12px;
}

.service_strength strong {
  line-height: 1;
}

.service-section__faq {
  margin-bottom: 56px;
  background-color: #fff;
  border-radius: 10px;
  box-sizing: border-box;
  padding: 48px;
  display: flex;
  gap: 48px;
}

.service-section__faq-title {
  min-width: 280px;
  margin-bottom: 32px;
}

.service-section__faq-title h3 {
  font-size: 2.1rem;
  font-weight: 700;
}

.service-section__faq-inner {
  display: flex;
  flex-direction: column;
  gap: 44px;
}

.service_faq_01,
.service_faq_02,
.service_faq_03,
.service_faq_04,
.service_faq_05 {
}

.service_faq_01_q,
.service_faq_02_q,
.service_faq_03_q,
.service_faq_04_q,
.service_faq_05_q {
  font-weight: bold;
  position: relative;
  padding-left: 36px;
  font-size: 1.6rem;
  margin-bottom: 20px;
  line-height: 1.6;
}

.service_faq_01_q::before,
.service_faq_02_q::before,
.service_faq_03_q::before,
.service_faq_04_q::before,
.service_faq_05_q::before {
  content: "Q";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 30px;
  background-image: url('../images/common/balloon_black.svg');
  background-size: cover;
  background-repeat: no-repeat;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  line-height: 26px;
}

.service_faq_01_a,
.service_faq_02_a,
.service_faq_03_a,
.service_faq_04_a,
.service_faq_05_a {
  position: relative;
  padding-left: 36px;
  line-height: 1.8;
}

.service_faq_01_a::before,
.service_faq_02_a::before,
.service_faq_03_a::before,
.service_faq_04_a::before,
.service_faq_05_a::before {
  content: "A";
  position: absolute;
  left: 0;
  top: 0;
  width: 28px;
  height: 30px;
  background-image: url('../images/common/balloon_red.svg');
  background-size: cover;
  background-repeat: no-repeat;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  line-height: 28px;
}

.service-section__related-works {
  margin-bottom: 56px;
  background-color: #fff;
  border-radius: 10px;
  box-sizing: border-box;
  padding: 48px;
}

.service-section__related-works-title {
  margin-bottom: 32px;
}

.service-section__related-works-title h3 {
  font-size: 2.1rem;
  font-weight: 700;
}

.service-section__related-works-inner {
}

.service_related_works {
    display: flex;
    flex-wrap: wrap;
    gap: 48px 4%;
}

.service-section__related-work {
    width: 48%;
}

.service-section__work-thumbnail-wrapper {
    overflow: hidden;
    margin-bottom: 16px;
    border-radius: 10px;
}

.service-section__work-thumbnail {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    display: block;
    transition: transform 0.3s;
    padding-top: 64%;
}

.service-section__related-work:hover .service-section__work-thumbnail {
  transform: scale(1.05);
}

.service-section__work-meta {
    display: flex;
    align-items: center;
    margin-bottom: 12px;
    gap: 12px;
}

.service-section__related-client {
    font-weight: 700;
}

.service-section__related-industry {
    background-color: #000;
    color: #fff;
    box-sizing: border-box;
    padding: 8px 12px;
    border-radius: 4px;
    font-size: 1rem;
    font-weight: 700;
}

.service-section__work-title {
  margin-top: 16px;
  font-size: 1.6rem;
  font-weight: 700;
}

.service-section__work-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 6px;
    margin-top: 16px;
}

.service-section__work-categories a {
    border: solid 1px;
    display: block;
    padding: 6px 10px;
    box-sizing: border-box;
    border-radius: 30px;
    font-size: 1rem;
    font-weight: 700;
}

.service-section__work-title:hover {
  text-decoration: underline;
}

.service-section__related-link {
  background-color: #fff;
  border-radius: 10px;
  box-sizing: border-box;
  padding: 48px;
}

.service-section__related-link-title {
  margin-bottom: 32px;
}

.service-section__related-link-title h3 {
  font-size: 2.1rem;
  font-weight: 700;
}

.service-section__related-link-inner {
}

.service_related_link {
    display: flex;
    flex-wrap: wrap;
    gap: 32px 4%;
}

.service-section__related-link-item {
    width: 48%;
}

.service-section__link-thumbnail-wrapper {
    overflow: hidden;
    border: solid 1px;
    box-sizing: border-box;
    border-radius: 10px;
    margin-bottom: 20px;
}

.service-section__link-thumbnail {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    display: block;
    padding-top: 48%;
    transition: transform 0.3s;
}

.service-section__related-link-item:hover .service-section__link-thumbnail {
    transform: scale(1.05);
}

.service-section__link-title {
  font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 16px;
}

.related-links-produce {
    color: #888;
    font-size: 1.2rem;
    letter-spacing: 0.05em;
    margin-left: 16px;
}

.service-section__link-description {
  line-height: 1.8;
}


/* 認定・認証 */

.certificationspage .otherpage-container__headline{
    text-align: center;
    margin-bottom: 100px;
}

.certifications-section {
}

.certifications-section__list {
    max-width: 960px;
    margin: 0 auto 120px;
    padding: 0 160px;
}

.certifications-section__list__item {
    background-color: #fff;
    margin-bottom: 36px;
    border-radius: 10px;
    display: flex;
    box-sizing: border-box;
    padding: 32px 40px;
    gap: 80px;
    justify-content: space-between;
}

.certifications-section__list__item__left {
}

.certifications-section__list__item__title {
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 24px;
    line-height: 1.4;
}

.certifications-section__list__item__description {
    line-height: 1.8;
}

.certifications-section__list__item__right {
    min-width: 150px;
    width: 150px;
}

.certifications-section__list__item__image {
}

/* お知らせ一覧 */
.newspage {
}

.newssingle  .otherpage-container__headline,
.newspage .otherpage-container__headline{
    text-align: center;
}

.newspage-section {
    padding: 0 160px;
    max-width: 1200px;
    margin: 0 auto 160px;
}

.newspage-section__list {
  margin-bottom: 96px;
}

.newspage-section__list__item {
  background-color: #fff;
  border-radius: 10px;
  margin-bottom: 20px;
}

.newspage-section__accordion-header {
  cursor: pointer;
  display: flex;
  align-items: center;
  position: relative;
  padding: 40px 44px;
  width: 100%;
  box-sizing: border-box;
}

.newspage-section__accordion-date {
  font-weight: 700;
  letter-spacing: 0.01em;
  width: 140px;
}

.newspage-section__accordion-title {
  font-weight: 700;
}

.newspage-section__accordion-icon {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-50%, -50%);
}

.newspage-section__accordion-icon::before {
  content: '+';
  background-color: #E35449;
  border-radius: 50%;
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
}

.newspage-section__accordion-header.active .newspage-section__accordion-icon::before {
  content: '-';
  background-color: #E35449;
  border-radius: 50%;
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 26px;
  text-align: center;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
}

.newspage-section__accordion-header.active {
}

.newspage-section__accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease, opacity 0.5s ease;
  opacity: 0;
  margin-left: 184px;
  padding-right: 44px;
}

.newspage-section__accordion-content.active {
    max-height: 100%;
    opacity: 1;
    padding-bottom: 40px;
}

.newspage-section__accordion-content p {
  line-height: 1.8;
  margin-bottom: 20px;
}

.newspage-section__accordion-content p:last-child {
  margin-bottom: 0;
}

.newspage-section__accordion-content a {
    text-decoration: underline;
    white-space: pre-wrap;
}

.wp-pagenavi {
  margin: 0 auto;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.wp-pagenavi .pages {
  margin-right: 20px;
  font-size: 1.2rem;
  font-weight: 700;
}

.wp-pagenavi a {
}

.wp-pagenavi span.current {
  margin: 0 12px 0 0;
  border: none;
  background: #000;
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  line-height: 36px;
  text-align: center;
  box-sizing: border-box;
  justify-content: center;
  display: flex;
  align-items: center;
  transition: .3s;
  font-size: 1.2rem;
  font-weight: 700;
}

.wp-pagenavi a.page {
  margin: 0 12px 0 0;
  border: solid 1px #000;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  line-height: 36px;
  text-align: center;
  box-sizing: border-box;
  justify-content: center;
  display: flex;
  align-items: center;
  transition: .3s;
  font-size: 1.2rem;
  font-weight: 700;
}

.wp-pagenavi a.page:hover {
  background: #000;
  color: #fff;
}

.wp-pagenavi .first {
  margin-right: 10px;
}

.wp-pagenavi .extend {
  margin-right: 10px;
}

.wp-pagenavi .previouspostslink {
    /* display: flex; */
    /* align-items: center; */
    /* justify-content: center; */
    /* width: 50px; */
    /* height: 50px; */
    /* border-radius: 50%; */
    /* font-size: 0; */
    position: absolute;
    left: 0;

    /* border: solid 1px; */
    /* box-sizing: border-box; */
    content: url(../images/common/allow_left.svg);
    transition: transform 0.3s ease;
}

.wp-pagenavi .previouspostslink:hover {
  transform: translateX(-5px);
}

.wp-pagenavi .nextpostslink {
    /* display: flex; */
    /* align-items: center; */
    /* justify-content: center; */
    /* width: 50px; */
    /* height: 50px; */
    /* border-radius: 50%; */
    /* font-size: 0; */
    position: absolute;
    right: 0;

    /* border: solid 1px; */
    /* box-sizing: border-box; */
    content: url(../images/common/allow_right.svg);
    transition: transform 0.3s ease;
}

.wp-pagenavi .nextpostslink:hover {
  transform: translateX(5px);
}

.newssingle .newspage-section__accordion-content {
    max-height: 100%;
    opacity: 1;
    padding-bottom: 40px;
}

/* ハリマブログ一覧 */
.blogpage {
}

.blogpage-section {
    margin: 0 auto 160px;
    max-width: 1400px;
    padding: 0 80px;
    display: flex;
    position: relative;
    gap: 40px;
    align-items: flex-start;
}

.blogpage-section__main {
    width: 100%;
}

.blogpage-section__featured {
  display: flex;
  margin-bottom: 56px;
  gap: 4%;
  justify-content: space-between;
  position: relative;
}

.blogpage-section__featured-link {
  display: block;
}

.blogpage-section__featured-thumbnail-wrapper {
    overflow: hidden;
    width: 48%;
}

.blogpage-section__featured-thumbnail {
    background-size: cover;
    width: 100%;
    height: 0;
    padding-top: 58%;
    background-position: center;
    transition: transform 0.3s ease;
}

.blogpage-section__featured:hover .blogpage-section__featured-thumbnail {
  transform: scale(1.05);
}

.blogpage-section__details {
  width: 48%;
  position: relative;
}

.blogpage-section__featured-meta {
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.blogpage-section__featured-date {
  font-size: 1.2rem;
  color: #8F8F8F;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.blogpage-section__featured-author {
  font-size: 1.2rem;
  color: #8F8F8F;
  font-weight: 700;
}

.blogpage-section__featured-title {
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 12px;
    line-height: 1.4;
}

.blogpage-section__excerpt {
}

.blogpage-section__excerpt p {
  line-height: 1.8;
}

.blogpage-section__list {
    display: flex;
    flex-wrap: wrap;
    gap: 48px 2%;
    margin-bottom: 100px;
}

.blogpage-section__list-item {
  width: 23.5%;
}

.blogpage-section__list-link {
  display: block;
}

.blogpage-section__list-thumbnail-wrapper {
    overflow: hidden;
    margin-bottom: 12px;
}

.blogpage-section__list-thumbnail {
    background-size: cover;
    width: 100%;
    height: 0;
    padding-top: 58%;
    background-position: center;
    transition: transform 0.3s ease;
}

.blogpage-section__list-link:hover .blogpage-section__list-thumbnail {
  transform: scale(1.05);
}

.blogpage-section__list-meta {
    margin-bottom: 5px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.blogpage-section__list-date {
  font-size: 1.2rem;
  color: #8F8F8F;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.blogpage-section__list-author {
  font-size: 1.2rem;
  color: #8F8F8F;
  font-weight: 700;
}

.blogpage-section__list-title {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.6;
}

.blogpage-section__sidebar {
  min-width: 300px;
  box-sizing: border-box;
  padding: 32px;
  background-color: #fff;
  border-radius: 10px;
}

.blogpage-section__sidebar-title {
  border-bottom: solid 1px #CCC;
  padding-bottom: 16px;
  margin-bottom: 24px;
  font-weight: 700;
}

.blogpage-section__archives {
  margin-bottom: 48px;
  position: relative;
}

.blogpage-section__archives::after {
    content: '▼';
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 1rem;
}

.blogpage-section__archives-select {
    appearance: none;
    cursor: pointer;
    padding: 16px 24px 16px 20px;
    width: 100%;
    border-radius: 5px;
    font-weight: 700;
    font-size: 1.2rem;
}

.blogpage-section__categories {
  margin-bottom: 64px;
}

.blogpage-section__categories-list {
}

.blogpage-section__categories-items {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.blogpage-section__categories-items a {
  background-color: #000;
  color: #fff;
  font-size: 1.2rem;
  padding: 8px 12px;
  border-radius: 4px;
  font-weight: 700;
  display: block;
  box-sizing: border-box;
}

.blogpage-section__popular {
}

.blogpage-section__popular-list {
}

.blogpage-section__popular-link {
  display: block;
}

.blogpage-section__popular-thumbnail-wrapper {
  overflow: hidden;
}

.blogpage-section__popular-thumbnail {
  background-size: cover;
  width: 100%;
  height: 0;
  padding-top: 58%;
  background-position: center;
  transition: transform 0.3s ease;
}

.blogpage-section__popular-link:hover .blogpage-section__popular-thumbnail {
  transform: scale(1.05);
}

.blogpage-section__popular-item {
  margin-bottom: 40px;
}

.blogpage-section__popular-item:last-child {
  margin-bottom: 0;
}

.blogpage-section__popular-meta {
  margin: 12px 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.blogpage-section__popular-date {
  font-size: 1.2rem;
  color: #8F8F8F;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.blogpage-section__popular-author {
  font-size: 1.2rem;
  color: #8F8F8F;
  font-weight: 700;
}

.blogpage-section__popular-title {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.6;
}

/* ハリマブログ詳細 */
.blogsinglepage {
}

.blogpage-section {
}

.blogpage-section__main {
    min-width: 0;
}

.blogpage-section__article {
    background-color: #fff;
    padding: 56px 48px;
    box-sizing: border-box;
    margin-bottom: 72px;
    border-radius: 10px;
}

.blogpage-section__article-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    border-bottom: solid 1px;
    padding-bottom: 24px;
    margin-bottom: 40px;
}

.blogpage-section__article-header-left {
}

.blogpage-section__article-header-right {
}

.blogpage-section__article-date {
    font-size: 1.2rem;
    font-weight: 700;
    color: #8F8F8F;
    letter-spacing: 0.01em;
}

.blogpage-section__article-header .blogpage-section__article-date {
  margin-bottom: 8px;
}

.blogpage-section__article-title {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.6;
}

.blogpage-section__article-author {
    font-size: 1.2rem;
    font-weight: 700;
    color: #8F8F8F;
    white-space: nowrap;
}

.blogpage-section__article-content {
}

.blogpage-section__article-thumbnail {
    margin-bottom: 24px;
}

.blogpage-section__article-body {
}

.blogpage-section__article-body h1,
.blogpage-section__article-body h2,
.blogpage-section__article-body h3,
.blogpage-section__article-body h4,
.blogpage-section__article-body h5 {
    font-weight: 700;
    line-height: 1.6;
}

.blogpage-section__article-body h1 {
    font-size: 2.8rem;
    margin: 4rem 0 2rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid #333;
}

.blogpage-section__article-body h2 {
    font-size: 2.2rem;
    margin: 3.5rem 0 1.8rem;
    padding-left: 1rem;
    border-left: 5px solid #e35449;
}

.blogpage-section__article-body h3 {
    font-size: 1.8rem;
    margin: 3rem 0 1.5rem;
}

.blogpage-section__article-body h4 {
    font-size: 1.6rem;
    margin: 2.5rem 0 1.2rem;
}

.blogpage-section__article-body h5 {
    font-size: 1.4rem;
    margin: 2rem 0 1rem;
}

.blogpage-section__article-body ul,
.blogpage-section__article-body ol {
    margin: 0 0 1.5rem 0;
    padding-left: 0;
    list-style-type: none;
}

.blogpage-section__article-body li {
    margin-bottom: 0.8rem;
    line-height: 1.8;
    position: relative;
    padding-left: 28px;
}

.blogpage-section__article-body ul li::before {
    content: '';
    position: absolute;
    left: 0.5em;
    top: 0.6em;
    width: 0.6em;
    height: 0.6em;
    background-color: #e35449;
    border-radius: 50%;
}

.blogpage-section__article-body ol {
    counter-reset: list-counter;
}

.blogpage-section__article-body ol li {
    counter-increment: list-counter;
}

.blogpage-section__article-body ol li::before {
    content: counter(list-counter);
    position: absolute;
    left: 0;
    top: 0.2em;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.6em;
    height: 1.6em;
    background-color: #e35449;
    border-radius: 50%;
    font-size: 1em;
    font-weight: 700;
    color: #fff;
    font-family: "Oswald", sans-serif;
}

.blogpage-section__article-body ul ul,
.blogpage-section__article-body ol ol,
.blogpage-section__article-body ul ol,
.blogpage-section__article-body ol ul {
    margin-top: 0.8rem;
    margin-bottom: 0.8rem;
    padding-left: 1.5em;
}

.blogpage-section__article-body ul ul li::before {
    background-color: #ccc;
}

.blogpage-section__article-body ol ol li::before {
    background-color: #e0e0e0;
    color: #555;
}

.blogpage-section__article-body p {
    margin-bottom: 24px;
    line-height: 1.8;
}

.blogpage-section__article-body p:last-child{
}

.blogpage-section__article-body a{
  text-decoration: underline;
}

.blogpage-section__article-body img{
  margin-bottom: 24px;
}

.blogpage-section__author-info {
    border: solid;
    border-radius: 10px;
    padding: 32px 28px;
    display: flex;
    align-items: flex-end;
    position: relative;
    gap: 40px;
    margin-top: 64px;
    justify-content: space-between;
}

.blogpage-section__author-info-label {
    font-weight: 700;
    margin-bottom: 36px;
}

.blogpage-section__author-info-details {
}

.blogpage-section__author-info-department {
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 8px;
}

.blogpage-section__author-info-role {
    font-size: 1.2rem;
}

.blogpage-section__article-body pre {
  display: block;
  background-color: #2d2d2d;
  color: #f8f8f2;
  padding: 24px;
  border: 1px solid #444;
  border-radius: 6px;
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, Courier, monospace;
  font-size: 1em;
  line-height: 1.6;
  overflow-x: auto;
  white-space: pre;

  max-width: 100%;          /* 親要素の幅を超えないようにする */
  overflow-x: auto;          /* はみ出た場合に横スクロールバーを表示 */
  white-space: pre;          /* 自動で折り返さない（コードの整形を維持）*/
  box-sizing: border-box;    /* paddingとborderを幅の計算に含める */
}

.blogpage-section__article-body pre code {
  background-color: transparent;
  padding: 0;
  border: none;
  font-size: inherit;
}

/* --- 共通の基本設定 --- */
.blogpage-section__article-body blockquote {
  margin: 2em 0;
  padding: 0;
  border: none;
  line-height: 1.8;
}

.blogpage-section__article-body blockquote:not(:has(pre)) {
    background-color: #ffffff;
    border: 1px solid #f0f0f0;
    padding: 1.5em 2em;
    border-radius: 6px;
}

.blogpage-section__article-body blockquote:not(:has(pre)) p {
  margin: 0;
}

.blogpage-section__article-body blockquote:has(pre) {
    position: relative;
    border: 1px solid #ddd;
    border-radius: 6px;
}

.blogpage-section__article-body blockquote:has(pre) p {
  margin-bottom: 1em;
}
.blogpage-section__article-body blockquote:has(pre) p:last-of-type {
  margin-bottom: 1.5em;
}

.blogpage-section__article-body blockquote:has(pre) pre {
    margin: 0;
    border: none;
    background-color: #fff;
    color: #000;
    white-space: break-spaces;
}

.blogpage-section__article-body blockquote:has(pre)[data-cite-title] {
  margin-top: 2.5em;
  padding-top: 3.5em;
}

.blogpage-section__article-body blockquote:has(pre)[data-cite-title]::before {
  content: attr(data-cite-title);
  position: absolute;
  top: 0;
  left: -1px;
  right: -1px;
  padding: 0.7em 1em;
  background-color: #e9e9e9;
  color: #333;
  font-weight: bold;
  font-size: 1.2rem;
  border-bottom: 1px solid #ddd;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  box-sizing: border-box;
}

.blogpage-section__author-info-profile {
    margin-top: 32px;
    position: relative;
    padding-left: 32px;
}

.blogpage-section__author-info-profile::before {
    content: "";
    position: absolute;
    display: inline-block;
    background-image: url(../images/common/icon_balloon.svg);
    height: 19px;
    width: 20px;
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.blogpage-section__author-info-profile p {
    line-height: 1.8;
}

.blogpage-section__author-info-name {
    font-weight: 500;
    margin-top: 12px;
}

.blogpage-section__author-info .common-link__button {
    min-width: 260px;
}

.blogpage-section__nav {
    margin-bottom: 56px;
    position: relative;
}

.blogpage-section__nav-prev {
  border-right: solid;
    padding-right: 100px;
}

.blogpage-section__nav-prev a {
    display: inline-flex;
    align-items: center;
    font-weight: 700;
}

.blogpage-section__nav-prev a::before {
  content: url('../images/common/allow_left.svg');
  margin-right: 16px;
  transition: transform 0.3s ease;
}

.blogpage-section__nav-prev a:hover::before {
  transform: translateX(-5px);
}

.blogpage-section__nav-list {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    gap: 12px;
}

.blogpage-section__nav-list p{
    font-weight: 700;
}

.blogpage-section__nav-list a:hover .blogpage-section__nav-list p{
  color: #444;
}

.blogpage-section__nav-next {
    border-left: solid;
    padding-left: 100px;
}

.blogpage-section__nav-next a {
  display: inline-flex;
  align-items: center;
  font-weight: 700;
}

.blogpage-section__nav-next a::after {
  content: url('../images/common/allow_right.svg');
  margin-left: 16px;
  transition: transform 0.3s ease;
}

.blogpage-section__nav-next a:hover::after {
  transform: translateX(5px);
}

.blogpage-section__author-posts {
    background-color: #fff;
    padding: 56px 48px;
    box-sizing: border-box;
}

.blogpage-section__author-posts-title {
    margin-bottom: 32px;
}

.blogpage-section__author-posts-title h3{
  font-size: 1.8rem;
  font-weight: 700;
}

.blogpage-section__author-posts-list {
  margin-bottom: 0;
}

.blogpage-section__author-posts-item {
}

.blogpage-section__author-posts-thumbnail-wrapper {
}

.blogpage-section__author-posts-thumbnail {
}

.blogpage-section__author-posts-meta {
    display: flex;
    gap: 8px;
}

.blogpage-section__nav-wrapper {
    display: flex;
    justify-content: space-between;
}

/* お問い合わせページ */
.contactpage {
}

.contactpage-section {
  padding: 0 80px;
  margin: 0 auto;
  max-width: 1400px;
}

.contactpage-section-inner {
    background-color: #fff;
    display: flex;
    box-sizing: border-box;
    padding: 48px;
    gap: 48px;
    position: relative;
    border-radius: 10px;
    margin-bottom: 160px;
}

.contactpage-section__info {
  position: sticky;
  top: 120px;
  height: 100%;
}

.contactpage-section__info-title {
    font-size: 2.1rem;
    font-weight: 700;
    line-height: 1.6;
    margin-bottom: 20px;
}

.contactpage-section__info-description {
  line-height: 1.6;
  font-weight: 500;
  margin-bottom: 24px;
}

.contactpage-section__info-phone {
  border: solid;
  box-sizing: border-box;
  padding: 32px;
  border-radius: 10px;
}

.contactpage-section__info-phone-title {
  font-size: 2.1rem;
  margin-bottom: 16px;
  font-weight: 700;
}

.contactpage-section__info-phone-text {
    font-weight: 500;
    margin-bottom: 24px;
    line-height: 1.6;
}

.contactpage-section__info-phone-number {
    font-weight: 500;
    margin-bottom: 20px;
    font-size: 4rem;
    color: #E35449;
    font-family: "Oswald", sans-serif;
    letter-spacing: 0.05em;
}

.contactpage-section__info-contact-hours {
  font-size: 1.6rem;
}

.contactpage-section__form {
  background-color: #F7F7F7;
  padding: 40px 56px;
  box-sizing: border-box;
  border-radius: 10px;
}

.contactpage-section__form-field {
  margin-bottom: 40px;
}

.contactpage-section__form-label {
  font-weight: 700;
  margin-bottom: 16px;
}

.contactpage-section__form-required {
  background-color: #F01100;
  color: #fff;
  font-size: 1rem;
  border-radius: 4px;
  padding: 2px 8px;
  margin-left: 12px;
}

.contactpage-section__form-zipcode {
  display: flex;
  gap: 16px;
}

.contactpage-section__form-zipcode button {
  border-radius: 6px;
  background: #636363;
  color: #fff;
  border: none;
  font-size: 1.2rem;
  font-weight: 700;
  padding: 8px 16px;
}

.contactpage-section__form-input {
}

.contactpage-section__form-input input, .contactpage-section__form-textarea textarea {
  border-radius: 4px;
  border: 1px solid #D7D7D7;
  background: #fff;
  padding: 8px;
  box-sizing: border-box;
  width: 100%;
}

.contactpage-section__form-textarea textarea {
  height: 250px;
}

.contactpage-section__form-textarea {
}

.contactpage-section__form-consent {
}

.contactpage-section__form-consent-group {
}

.contactpage-section__form-consent-text {
}

.contactpage-section__form-privacy-link {
  text-align: center;
  margin-bottom: 32px;
  margin-top: 20px;
}

.contactpage-section__form-privacy-link a {
  color: #D43626;
  text-decoration: underline;
  font-weight: 700;
}

.contactpage-section__form-error {
  display: none;
}

.contactpage-section__form-error.active {
  display: block !important;
  color: red !important;
  font-size: 1rem !important;
}

.contactpage .contact-button {
    margin: 0 auto;
    background-color: #E35449;
}

.contactpage .contact-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.contactpage .contact-button__arrow {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23000000" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
}

.contactpage .contact-button__arrow--new {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23000000" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
}


/* 個人情報保護方針 */
.privacypolicy .otherpage-container__headline h2 {
  text-align: center;
}

.privacypolicy__sections {
    max-width: 960px;
    margin: 0 auto 80px;
    padding: 0 160px;
}

.privacypolicy__overview {
  margin-bottom: 56px;
}

.privacypolicy__date {
    margin-bottom: 16px;
    text-align: right;
    font-size: 1.2rem;
}

.privacypolicy__intro-text {
  line-height: 1.8;
  text-align: justify;
}

.privacypolicy__section {
  margin-bottom: 48px;
}

.privacypolicy__section-title {
  font-size: 2.1rem;
  font-weight: bold;
  margin-bottom: 16px;
}
.privacypolicy__section-text {
  line-height: 1.8;
}

.privacypolicy__subsection {
    margin-top: 24px;
    margin-bottom: 24px;
}

.privacypolicy__subsection-title {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 12px;
}
.privacypolicy__subsection-text {
  line-height: 1.8;
}

.privacypolicy__list-wrapper {
    margin-top: 16px;
    margin-bottom: 16px;
}

.privacypolicy__list {
  list-style-type: disc;
  margin: 0;
  padding: 0;
}

.privacypolicy__list-item {
    margin-bottom: 12px;
    line-height: 1.6;
    font-weight: 500;
}

.privacypolicy__footer {
  margin-top: 56px;
  text-align: right;
}
.privacypolicy__footer-text {
  margin-bottom: 16px;
  line-height: 1.8;
}

.privacypolicy__disclaimer {
  max-width: 1200px;
  margin: 0 auto 160px;
  padding: 0 160px;
}
.privacypolicy__disclaimer-header {
  margin-bottom: 48px;
}
.privacypolicy__disclaimer-title {
  font-size: 2.1rem;
  font-weight: 700;
}

.privacypolicy__disclaimer-item {
    margin-bottom: 48px;
}

.privacypolicy__disclaimer-item-title {
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 12px;
    line-height: 1.6;
}

.privacypolicy__disclaimer-item-text {
  line-height: 1.8;
}

.privacypolicy__contact-wrapper {
  margin-top: 12px;
  margin-bottom: 12px;
  box-sizing: border-box;
  padding: 16px 24px;
  border: solid 1px #B8B8B8;
  width: fit-content;
}

.privacypolicy__contact-wrapper h5 {
    font-weight: 700;
    margin-bottom: 12px;
    line-height: 1.6;
}

.privacypolicy__contact-text {
  line-height: 1.8;
}

.privacypolicy__subsection-text span{
  font-weight: 500;
}

.privacypolicy__subsection-text a {
    text-decoration: underline;
    color: #E35449;
    display: block;
    white-space: pre-wrap;
    word-wrap: break-word;
}

.privacypolicy__subsection-title {
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom: 12px;
}


/* ISMS認証登録/情報セキュリティ基本方針 */
.securitypolicy {
}

.securitypolicy .otherpage-container__headline h2 {
  text-align: center;
  margin-bottom: 40px;
}

.securitypolicy__registration {
    max-width: 960px;
    margin: 0 auto 160px;
    padding: 0 160px;
}

.securitypolicy__registration-heading h3 {
    font-size: 2.1rem;
    font-weight: 700;
    margin-bottom: 24px;
}

.securitypolicy__registration-text p {
    margin-bottom: 40px;
    text-align: justify;
    line-height: 1.8;
}

.securitypolicy__registration-table-wrapper {
    overflow-x: auto;
    margin-bottom: 48px;
}

.securitypolicy__registration-table {
  width: 100%;
  border-collapse: collapse;
}

.securitypolicy__registration-table th, .securitypolicy__registration-table td {
    border: 1px solid #ccc;
    padding: 16px 16px;
    text-align: left;
    line-height: 1.6;
}

.securitypolicy__registration-table th {
    background-color: #eaeaea;
    font-weight: 700;
}

.securitypolicy__basics {
    max-width: 880px;
    margin: 0 auto 160px;
    padding: 0 160px;
}

.securitypolicy__basics-heading h3 {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 32px;
}

.securitypolicy__basics-dates {
    text-align: right;
    margin-bottom: 16px;
}

.securitypolicy__basics-dates p {
    line-height: 1.6;
    font-size: 1.2rem;
}

.securitypolicy__basics-vision {
  margin-bottom: 32px;
}

.securitypolicy__basics-vision-title {
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 16px;
}

.securitypolicy__basics-vision-text {
    line-height: 1.8;
}

.securitypolicy__basics-policy {
  margin-bottom: 32px;
}
.securitypolicy__basics-policy-title {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 12px;
}
.securitypolicy__basics-policy-list {
  list-style-type: decimal;
  counter-reset: number;
}

.securitypolicy__basics-policy-item {
    position: relative;
    padding-left: 32px;
    line-height: 1.6;
    margin-bottom: 16px;
}

.securitypolicy__basics-policy-item::before {
    margin-bottom: 12px;
    line-height: 1.6;
    counter-increment: number;
  content: '（' counter(number) '）';
  position: absolute;
  left: 0;
}

.securitypolicy__basics-signature p {
    text-align: right;
    line-height: 1.8;
    margin-top: 48px;
}


/* わたしたちについてページ */
.aboutpage.otherpage-container {
  padding-top: 0;
  margin: 0;
}

.aboutpage .otherpage-container__headline {
  max-width: unset;
  position: absolute;
  width: 100%;
  box-sizing: border-box;
  z-index: 100;
}

.aboutpage .otherpage-container__headline h2 {
  text-align: center;
  margin-top: 160px;
  font-size: 2.8rem;
}

/* マップセクション */
.map-section {
  position: relative;
  width: 100%;
  height: calc(400vh + 800px);
  margin-bottom: 160px;
}

.map-sticky {
    position: sticky;
    top: 0;
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

#japan-map {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  transform-origin: top left;
  transform: translate(0, 0) scale(1);
}

#map-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 56px;
  height: 56px;
  transform: translate(-50%, -50%) scale(0);
  transform-origin: center center;
  pointer-events: none;
}

#map-icon img {
  width: 100%;
  height: 100%;
  display: block;
}

@keyframes popIn {
  0% {
    transform: translate(-50%, -50%) scale(0);
  }
  60% {
    transform: translate(-50%, -50%) scale(1.4);
  }
  100% {
    transform: translate(-50%, -50%) scale(1);
  }
}

@keyframes popOut {
  0% {
    transform: translate(-50%, -50%) scale(1);
  }
  100% {
    transform: translate(-50%, -50%) scale(0);
  }
}

/* 企業ビジョン */
.aboutpage__vision {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 80px;
  position: absolute;
  bottom: 60px;
}

.aboutpage__vision-content {
  width: 560px;
}

.aboutpage__vision-heading {
  font-size: 2.4rem;
  margin-bottom: 24px;
  font-weight: 700;
}

.aboutpage__vision-text {
  line-height: 2;
  font-size: 1.8rem;
  text-align: justify;
}

/* ご挨拶 */
.aboutpage__greeting {
  padding: 0 80px;
  max-width: 1400px;
  margin: 0 auto 160px;
}

.aboutpage__greeting-inner {
    display: flex;
    gap: 88px;
    justify-content: space-between;
    gap: 40px;
}

.aboutpage__greeting-image-wrapper {
  width: 48%;
}

.aboutpage__greeting-image-wrapper img {
  background-color: #fff;
}

.aboutpage__greeting-content {
  width: 48%;
}

.aboutpage__greeting-heading {
  font-size: 2.4rem;
  margin-bottom: 16px;
  font-weight: 700;
}

.aboutpage__greeting-text {
  line-height: 2;
  margin-bottom: 32px;
  font-weight: 500;
  text-align: justify;
}

.aboutpage__greeting-footer {
  text-align: right;
}

.aboutpage__greeting-company {
  font-weight: 700;
  margin-bottom: 12px;
  font-size: 1.2rem;
}

.aboutpage__greeting-ceo {
  font-weight: 700;
  font-size: 1.8rem;
}

/* 経営理念とキャッチコピー */
.aboutpage__philosophy-catch {
  display: flex;
  gap: 40px;
  padding: 0 80px;
  justify-content: space-between;
  max-width: 1400px;
  margin: 0 auto 160px;
}

.aboutpage__philosophy,
.aboutpage__catch {
  background-color: #fff;
  box-sizing: border-box;
  border-radius: 10px;
  padding: 32px;
  width: 48%;
}

.aboutpage__philosophy-heading,
.aboutpage__catch-heading {
  font-size: 2rem;
  margin-bottom: 40px;
  font-weight: 700;
  padding-bottom: 24px;
  border-bottom: solid 1px #B1B1B1;
}

.aboutpage__philosophy-item {
  margin-bottom: 56px;
}

.aboutpage__philosophy-item:last-child {
  margin-bottom: 0;
}

.aboutpage__philosophy-item-title {
  font-size: 1.8rem;
  margin-bottom: 16px;
  font-weight: 700;
}

.aboutpage__philosophy-item-text {
  line-height: 1.6;
  font-size: 16px;
}

.aboutpage__catch-content {}

.aboutpage__catch-slogan {
  font-size: 2.1rem;
  margin-bottom: 40px;
  line-height: 1.8;
  font-weight: 700;
  display: flex;
  justify-content: center;
}

.aboutpage__catch-text {
  line-height: 2;
}

/* 会社概要 */
.aboutpage__overview {
  background-color: #fff;
}

.aboutpage__overview-inner {
  padding: 160px 80px;
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 320px;
}

.aboutpage__overview-heading-wrapper {
  min-width: 120px;
}

.aboutpage__overview-heading {
  font-size: 2.4rem;
  font-weight: 700;
}

.aboutpage__overview-details {}

.aboutpage__overview-list {
  border-top: 1px solid #B8B8B8;
  padding-top: 32px;
}

.aboutpage__overview-term {
  font-weight: bold;
  clear: left;
  float: left;
  width: 120px;
  line-height: 1.8;
}

.aboutpage__overview-definition {
  border-bottom: 1px solid #B8B8B8;
  padding-bottom: 32px;
  margin-bottom: 32px;
  padding-left: 120px;
  line-height: 1.8;
  text-align: justify;
}

.aboutpage__overview-definition p{
    line-height: 1.8;
    margin-bottom: 16px;
}

.aboutpage__overview-definition p:last-child{
    margin-bottom: 0;
}

.aboutpage__overview-definition ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.aboutpage__overview-definition ul li {
  font-weight: 500;
  line-height: 1.6;
}

/* ==== 沿革タイムライン全体 ==== */
.aboutpage__history {
  padding: 120px 0 0;
}

.aboutpage__history-heading-wrapper {
  padding: 0 80px;
  max-width: 1400px;
  margin: 0 auto;
}

.aboutpage__history-heading {
  font-size: 2.4rem;
  font-weight: 700;
}

.aboutpage__timeline-section {
  position: relative;
  width: 100%;
  height: 0;
}

.aboutpage__timeline-outer {
  position: sticky;
  top: calc(100px + 48px);
  left: 0;
  width: 100%;
  height: calc(100vh - (100px + 48px));
  background: transparent;
  overflow: hidden;
}

.aboutpage__timeline-scroll-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
}

.aboutpage__timeline-track {
  position: absolute;
  top: 70px;
  left: 80px;
  height: 2px;
  background: #000;
  z-index: 1;
}

.aboutpage__timeline-scroll {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 80px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  transform: translateX(0);
  padding: 56px 0 0 80px;
}

.aboutpage__timeline-item {
  position: relative;
  min-width: 430px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: transparent;
}

.aboutpage__timeline-item::before {
  content: "";
  position: absolute;
  top: 0px;
  left: 12px;
  transform: translateX(-50%);
  width: 30px;
  height: 30px;
  background: #000;
  border-radius: 50%;
  z-index: 3;
}

.aboutpage__timeline-meta {
  margin-bottom: 64px;
  margin-top: 56px;
}

.aboutpage__timeline-date {
  margin-bottom: 20px;
}

.aboutpage__timeline-date p {
  font-weight: 700;
}

.aboutpage__timeline-date span {
  font-size: 2.4rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  font-family: 'Oswald', 'Arial', sans-serif;
}

.aboutpage__timeline-desc p {
  font-size: 1.2rem;
  line-height: 1.4;
}

.aboutpage__timeline-imgwrap {
    position: relative;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 420px;
    gap: 20px;
}

.aboutpage__timeline-img-year {
    position: absolute;
    top: -20px;
    left: -20px;
    font-size: 4.8rem;
    font-weight: 700;
    color: #ffffff00;
    opacity: .82;
    -webkit-text-stroke: 1px #000;
    text-stroke: 1px #000;
    z-index: 2;
    font-family: 'Oswald', 'Arial', sans-serif;
    line-height: 1;
    pointer-events: none;
}

.aboutpage__timeline-imgwrap img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/2.5;
    object-fit: cover;
    border-radius: 10px;
}

.aboutpage__timeline-imgwrap img.history_2023_02 {
    width: 40%;
    aspect-ratio: 3 / 4.7;
}

.aboutpage__timeline-imgwrap img.history_2023_logo {
    aspect-ratio: unset;
    object-fit: unset;
}

.aboutpage__timeline-scroll::-webkit-scrollbar {
  display: none;
}

.aboutpage__timeline-scroll {
  -ms-overflow-style: none;
  scrollbar-width: none;
}


/* 404ページ */
.errorpage {
}

.errorpage.otherpage-container {
    padding-top: 160px;
}

.errorpage__content {
    justify-content: flex-start;
    background-image: url(../images/404/404_background.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    height: 0;
    padding-top: 40%;
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
}

.errorpage__body {
    display: flex;
    flex-direction: column;
    gap: 32px;
    position: absolute;
    top: 12%;
    left: 50%;
    transform: translate(-50%, -50%);
    align-items: center;
    width: 40%;
}

.errorpage__logo {
    width: 64%;
}

.errorpage__message {
    font-size: 1.6rem;
    line-height: 1.8;
    text-align: center;
    font-weight: 700;
}

.errorpage__button.common-link__button::after {
    background: #282828;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
}

.errorpage__button.common-link__button:hover::after {
    background: #fff;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23d9534f" stroke-width="2" transform="rotate(-45)"><path d="M5 12h14M12 5l7 7-7 7"/></svg>');
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
}

/* 実績紹介 */
.workspage.otherpage-container {
    margin-bottom: 120px;
}

.work-section {
    display: flex;
    flex-direction: column;
    gap: 64px;
    padding: 0 80px;
    max-width: 1400px;
    margin: 0 auto;
}

.work-section__categories {
  background-color: #fff;
  padding: 32px;
  box-sizing: border-box;
  border-radius: 10px;
}

.work-section__industry-filter {
    display: flex;
    margin-bottom: 32px;
    align-items: flex-start;
}

.work-section__industry-filter-title {
  font-weight: 700;
  min-width: 140px;
}

.work-section__industry-filter-list {
  list-style: none;
  padding: 0;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 12px 16px;
}

.work-section__industry-filter-item {
  font-size: 1.2rem;
  background-color: #000;
  color: #fff;
  border-radius: 4px;
  transition: background-color 0.3s;
}

.work-section__industry-filter-item.is-active {
    background-color: #E35449;
}

.work-section__industry-filter-item:hover {
    background-color: #E35449;
    color: #fff;
}

.work-section__industry-filter-item a {
  transition: color 0.3s;
  color: #ffff;
  padding: 8px 12px;
  display: block;
}

.work-section__industry-filter-item a:hover {
}

.work-section__category-filter {
  display: flex;
}

.work-section__category-filter-title {
  font-weight: 700;
  min-width: 140px;
}

.work-section__category-filter-list {
  list-style: none;
  padding: 0;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 8px;
}

.work-section__category-filter-item {
  font-size: 1.2rem;
  color: #fff;
  border-radius: 30px;
  border: solid #000 1px;
  transition: background-color 0.3s;
}

.work-section__category-filter-item a {
  transition: color 0.3s;
  padding: 8px 12px;
  display: block;
  transition: background-color 0.3s;
}

.work-section__category-filter-item a:hover {
    color: #fff;
}

.work-section__category-filter-item:hover {
    background-color: #E35449;
    color: #fff;
    border:solid #E35449 1px;
}

.work-section__items {
  display: flex;
  gap: 40px 3%;
  flex-wrap: wrap;
}

.work-section__item {
  overflow: hidden;
  width: 31.3%;
}

.work-section__thumbnail-wrapper {
  overflow: hidden;
  margin-bottom: 16px;
  border-radius: 10px;
}

.work-section__thumbnail {
  width: 100%;
  height: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding-top: 56%;
  background-color: ghostwhite;
  position: relative;
  transition: transform 0.3s;
}

.work-section__item:hover .work-section__thumbnail {
  transform: scale(1.05);
}

.work-detail__client {
  font-weight: 700;
}

.work-section__title-block {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.work-section__title {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 16px;
  margin-top: 8px;
}

.work-section__title a {
  transition: color 0.3s;
}

.work-section__title a:hover {
  color: #E35449;
}

.work-section__industry {
    background-color: #000;
    color: #fff;
    font-size: 1rem;
    padding: 8px 12px;
    border-radius: 6px;
    font-weight: 700;
}

.work-section__meta {
}

.work-section__meta-categories {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.work-section__meta-categories li {
  font-size: 1rem;
  border: solid 1px;
  border-radius: 30px;
  font-weight: 700;
  padding: 4px 10px;
}

.work-section__meta-categories a {
  transition: color 0.3s;
}

.work-section__meta-categories a:hover {
}

.work-section__industry-filter-title, .work-section__category-filter-title {
background-color: transparent;
border: none;
text-align: left;
}

/* 実績詳細 */
.work-detail {
    padding: 0 80px;
    margin: 0 auto 120px;
    max-width: 1400px;
}

.work-detail__main {
}

.work-detail__header {
    margin-bottom: 48px;
}

.work-detail__title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 20px;
    line-height: 1.4;
}

.work-detail__meta-group {
    display: flex;
    align-items: center;
    gap: 12px;
}

.work-detail__client {}
.work-detail__industry {
    background-color: #000;
    color: #fff;
    padding: 6px 10px;
    font-size: 1rem;
    font-weight: 700;
    border-radius: 4px;
}

.work-detail__categories {
    margin-top: 24px;
}

.work-detail__category-list {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.work-detail__category-item a {
    border: solid 1px;
    padding: 4px 12px;
    box-sizing: border-box;
    font-size: 1.2rem;
    font-weight: 700;
    border-radius: 30px;
}

.work-detail__thumbnail {
    overflow: hidden;
    border-radius: 10px;
    margin-bottom: 72px;
}

.work-detail__thumbnail img{
    width: 100%;
}

.work-detail__content-wrapper {
    display: flex;
    position: relative;
    gap: 80px;
}

.work-detail__nav {
}

.work-detail__nav-group {}

.worksingle .work-detail__nav-group:first-child {
}

.worksingle .otherpage-anchor-nav {
    min-width: 180px;
}

.worksingle .otherpage-anchor-nav__item--back {
    margin-top: 40px;
}

.work-detail__article {
}
.work-detail__body {
    background-color: #fff;
    padding: 48px;
    border-radius: 10px;
    margin-bottom: 64px;
    box-sizing: border-box;
}

.work-detail__body-heading {
    font-size: 3.2rem;
    font-weight: 700;
    margin-bottom: 48px;
}

.work-detail__body p{
    line-height: 2;
    text-align: justify;
    margin-bottom: 16px;
}

.work-detail__body p:last-child{
  margin-bottom: 0;
}

.work-detail__solving {
    background-color: #fff;
    padding: 48px;
    box-sizing: border-box;
    border-radius: 10px;
}
.work-detail__section-title {
    font-size: 2rem;
    margin-bottom: 24px;
    font-weight: 700;
}
.work-detail__solving-detail {}
.work-detail__solving-detail h3{
  font-size: 1.6rem;
  margin-bottom: 16px;
  font-weight: 700;
}

.work-detail__solving-detail p{
  margin-bottom: 16px;
  line-height: 2;
}

.work-detail__solving-detail p:last-child{
  margin-bottom: 0;
}

.work-detail__solving-detail img{
  margin:16px 0;
}

.work-detail-section {
    margin-top: 80px;
    background-color: #fff;
    padding: 48px;
    border-radius: 10px;
    box-sizing: border-box;
}

.work-detail-section h4 {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 48px;
}

.work-detail-section h3 {
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 20px;
}

.work-detail-section p{
  margin-bottom: 16px;
  line-height: 2;
}

.work-detail__logo-detail p{
}

.work-detail__web-detail a{
    text-decoration: underline;
}

.work-detail__logo-detail p img{
    width: 100%;
}

.work-detail__related {}
.work-detail__related-list {}
.work-detail__related-item {}
.work-detail__related-thumbnail {}
.work-detail__related-title {}

.work-detail__date {
    text-align: right;
    font-size: 1.2rem;
    font-weight: 700;
}

.worksingle .service-section__related-works {
    margin-top: 80px;
}

.gallery-slider {
    width: 100%;
    margin: 40px auto 0;
    position: relative;
    overflow: hidden;
}

.worksingle .swiper-slide {
    text-align: center;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    /* position: relative; */
    width: 100% !important;
    flex-direction: column;
    padding-bottom: 20px;
}

.worksingle .swiper-slide img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 10px;
}

.worksingle .swiper-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    box-sizing: border-box;
    /* padding: 10px 20px; */
    /* background-color: rgba(0, 0, 0, 0.7); */
    /* color: #fff; */
    text-align: left;
}

.worksingle .swiper-button-next, .swiper-button-prev {
    color: #adadad !important;
    background-color: #ffff;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50%;
}

.worksingle .swiper-button-next::after,.worksingle .swiper-button-prev::after {
    font-size: 2rem;
    font-weight: 700;
}

.worksingle .swiper-pagination-bullet {
    background: #ffffff !important;
    opacity: 0.7 !important;
    width: 12px !important;
    height: 12px !important;
    margin: 0 8px !important;
}

.worksingle .swiper-pagination-bullet-active {
    background: #E35449 !important;
}

.worksingle .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: var(--swiper-pagination-bottom,10%) !important;
}

.work-side__nav-category {
    position: relative;
    margin-top: 64px;
}

.work-side__nav-category:before {
    content: '';
    position: absolute;
    left: 20px;
    top: -32px;
    display: inline-block;
    width: 120px;
    height: 2px;
    background-color: #000;
}

.wp-video {
    width: 100% !important;
}

.mejs-container {
    width: 100% !important;
}


/* サンキューページ */
.thankyoupage .otherpage-container__headline{
    text-align: center;
}

.thankyoupage-section {
    max-width: 880px;
    margin: 0 auto 120px;
    padding: 64px 80px;
    background-color: #f9f9f9;
    border-radius: 10px;
    text-align: center;
    box-sizing: border-box;
    width: 88%;
}

.thankyoupage-section__title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 40px;
}

.thankyoupage-section__text {
    line-height: 1.8;
    margin-bottom: 24px;
}

.thankyoupage-section__note {
    font-size: 1.4rem;
    color: #E35449;
    font-weight: 500;
    line-height: 1.6;
}

.thankyoupage-section__button-wrapper {
    margin-top: 40px;
}

.newspage-section__accordion-content pre {
    white-space: break-spaces;
    line-height: 1.8;
    word-wrap: break-word;
    font-family: YakuHanJP, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
}
















/* 800px 以上 */
@media (min-width: 800px) {

a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
}

.sp_view{
    display: none;
}

}







/* 1060px 以上 */
@media (min-width: 1060px) {

.openbtn1 {
    display: none;
}

.main-nav-item_contact{
    display: none;
}

}

















@media screen and (max-width: 1060px) and (min-width: 800px) {

.main-visual-catchphrase {
    width: 800px;
}

.blog-section__card-text {
    display: none;
}

.blog-section__subtitle br{
    display: none;
}

.blog-section__card-date{
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.contact-section__content {
    align-items: center;
}

.contact-section__text-block {
    width: 320px;
}

.solution-section__drawer-grid {
    display: flex;
    flex-direction: column;
}

.card-group {
    display: flex;
    flex-wrap: wrap;
    gap: 48px 4%;
}

.stats-card {
    width: 48%;
    box-sizing: border-box;
}

.stats-card:nth-child(2) {
  border-right: none;
}

.partners-subtitle {
    line-height: 1.6;
}

.partners-text {
    padding-right: 40px;
}

.industry-item {
    white-space: unset;
    width: auto;
}

.services-section {
    padding: 160px 40px 0;
}

.works-section__side-scroll--list-wrapper {
    padding-top: 48%;
}

.footer-sitemap {
    gap: 32px;
}

.partners-section {
    padding-left: 56px;
}

.solution-section {
    padding: 160px 40px;
}

.works-section {
    padding: 160px 40px;
}

.blog-section {
    padding: 160px 40px;
}

.company-info {
    max-width: 400px;
}

.company-info br{
    display: none;
}

.services-section .services-section__contact--right {
    height: 420px;
}



}














/* 1540px 以下 */
@media screen and (max-width:1540px) {

.blogpage-section__list {
    gap: 40px 3%;
}

.blogpage-section__list-item {
    width: 31.3%;
}





}





/* 1260px 以下 */
@media screen and (max-width:1260px) {

.blogpage-section__list-item {
    width: 48.5%;
}

.stats-card {
    padding: 0 24px;
}

.partners-section {
    padding-left: 60px;
}

.services-section .services-section__contact--right {
    margin-right: 0;
}







}




/* 1200px 以下 */
@media screen and (max-width:1200px) {

.works-section__side-scroll--list-wrapper {
    padding-top: 48%;
}

.service-section__thumbnail {
    min-width: 200px;
}

.service-section__block-title {
    min-width: 200px;
}

.service-section__faq-title {
    min-width: 200px;
}

.newspage-section {
    padding: 0 80px;
}

.certifications-section__list {
    padding: 0 80px;
}

.privacypolicy__disclaimer,
.privacypolicy__sections {
    padding: 0 80px;
}

.securitypolicy__registration,
.securitypolicy__basics {
    padding: 0 80px;
}

.blog-section {
    gap: 80px;
}

.errorpage__message {
    font-size: 1.4rem;
}

.blogpage-section__author-info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.services-section__card-image--web,
.services-section__card-image--drone {
    margin-top: 24%;
}









}





/* 1060px 以下 */
@media screen and (max-width:1060px) {
.openbtn1 {
    width: 50px;
    height: 50px;
    cursor: pointer;
    z-index: 1000;
    position: absolute;
    right: 4%;
    top: 18px;
}

.openbtn1 span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    height: 4px;
    background-color: #424D5B;
    right: 7px;
    width: 72%;
}

.scroll_body .openbtn1 span{
}

.openbtn1 span:nth-of-type(1) {
    top: 12px;
}

.openbtn1 span:nth-of-type(2) {
    top: 24px;
    display: none;
}

.openbtn1 span:nth-of-type(3) {
    top: 26px;
}

.openbtn1.active span:nth-of-type(1) {
    top: 16px;
    transform: translateY(6px) rotate(-32deg);
}

.openbtn1.active span:nth-of-type(2) {
    display: none;
}

.openbtn1.active span:nth-of-type(3) {
    top: 28px;
    transform: translateY(-6px) rotate(32deg);
}

.openbtn1.active span {
    background-color: #424D5B;
}

.openbtn1 p{
    font-weight: 700;
    color: #424D5B;
    position: absolute;
    top: 36px;
    left: 6px;
    font-size: 1.2rem;
}

#g-nav {
    position: fixed;
    z-index: -1;
    opacity: 0;
    top: 0;
    transition: all 0.3s;
    right: 0;
    box-sizing: border-box;
    bottom: 0; 
    left: unset;
    pointer-events: none;
    background-color: #fff;
    overflow-y: scroll;
    box-shadow: -20px 0 40px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 120px 0 40px;
    width: 100%;
    max-width: 400px;
}

#g-nav.panelactive {
    opacity: 1;
    z-index: 999; /* z-indexを少し上げておく */
    pointer-events: unset;
    transform: translateX(0);
}

.main-nav-list {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.main-nav {
    width: 88%;
    margin: 0 auto;
}

.main-nav-item {
    border-bottom: solid 1px #B1B1B1;
    padding-bottom: 32px;
}

.main-nav-item_contact{
    display: block;
}

.header .contact-button{
    display: none;
}

.services-section__contact--right {
    width: 360px;
    height: 280px;
}

.service-section__block {
    display: flex;
    flex-direction: column;
}

.service-section__block {
    display: flex;
    flex-direction: column;
}

.service-section__faq {
    display: flex;
    flex-direction: column;
}

.service_related_works {
    display: flex;
    flex-direction: column;
}

.service-section__related-work {
    width: 100%;
}

.service_related_link {
    display: flex;
    flex-direction: column;
}

.service-section__related-link-item {
    width: 100%;
}

.aboutpage__overview-inner {
    display: flex;
    flex-direction: column;
    gap: 64px;
}

.errorpage__body {
    top: 8%;
}

.workspage .work-section__item {
    overflow: hidden;
    width: 48%;
}

.blogpage-section__excerpt {
    display: none;
}

.blogpage-section__featured-title {
    font-size: 1.6rem;
}






}





/* 960px 以下 */
@media screen and (max-width:960px) {

.blogpage-section {
    flex-direction: column;
}

.blogpage-section__sidebar {
    min-width: unset;
    width: 100%;
}




}




























































