@charset "UTF-8";
/*!
Theme Name: Cocoon Child
Template:   cocoon-master
Version:    0.0.7
*/
/* レイアウト */
.pc, .pc2 {
  display: none !important;
}

body::after {
  display: none;
}

#container {
  overflow: hidden;
}

.page .wrap {
  width: 100%;
}

.main {
  border: none;
  border-radius: 0;
}

.page .content {
  margin: 0;
}

.page .main {
  padding: 0;
}

.entry-content {
  margin-top: 0;
}

.page .entry-content {
  margin-bottom: 0;
}

.article-header .date-tags {
  display: none;
}

.hr {
  background-color: #fff;
  background-image: linear-gradient(45deg, black 25%, black 25%, transparent 25%, transparent 75%, black 75%, black 75%), linear-gradient(-135deg, black 25%, black 25%, transparent 25%, transparent 75%, black 75%, black 75%);
  background-size: 15px 15px;
  background-position: 0 0, 7.5px 7.5px;
  width: 100%;
  height: 30px;
}

section,
#lead .illust,
#lead .float .inner,
.step_box,
#info .inner,
.before_ft {
  max-width: 1200px;
  margin: 50px auto;
  padding: 0 20px;
}

/* 共通 */
.fade {
  opacity: 0;
  transition: all 1s ease;
}

.fade.show {
  opacity: 1;
  transform: none;
}

.fade.fade_in {
  transition: all 2s ease;
}

.fade.fade_in_slow {
  transition: all 4s ease;
}

.fade.fade_descriprion {
  transition: all 2.5s ease;
  transition-delay: 1.5s;
}

.fade_in_up {
  transform: translate(0, 60px);
}

.fade_rotate {
  transition: all 1.5s ease;
  transform: rotateX(180deg);
}

.fade_rotate2 {
  transition: all 0.3s;
  transform: rotateX(-180deg);
}

.fade_lr {
  transform: translate(-100px, 0);
}

.fade_rl {
  transform: translate(100px, 0);
}

.animation {
  animation: animScale 3s infinite ease-out;
  transform-origin: 50% 50%;
  animation-play-state: running;
}

@keyframes animScale {
  0% {
    transform: scale(0.8, 0.8);
  }
  5% {
    transform: scale(1.15, 1.15);
  }
  10% {
    transform: scale(1, 1);
  }
  15% {
    transform: scale(1.1, 1.1);
  }
  20% {
    transform: scale(1, 1);
  }
  100% {
    transform: scale(1, 1);
  }
}
.delay {
  transition-delay: 0.5s;
}

.for-sp {
  display: none;
}

.for-minisp {
  display: none;
}

.for-pc {
  display: block;
}

.il-block {
  display: inline-block;
}

/* JS */
.js__acc--item {
  display: none;
}

/* 平面回転 */
.fade_rotateL {
  transform: rotate(180deg);
}

.scroll_scaleUp {
  transition: all 0.3s ease;
  transform: scale(0.5);
}

img.vw {
  width: 100vw;
}

.red {
  color: #9a0004;
}

/* 見出し */
.page .article h1 {
  display: none;
}

.article h1 {
  position: relative;
  padding-top: 2.2em;
  text-align: center;
}

.article h2,
.article h3,
.article h4 {
  background: none;
  border: none;
}

.home .article h2 {
  color: black;
  font-size: 1.4rem;
  text-align: center;
}

/* ヘッダー */
#header-container {
  position: fixed;
  top: 0;
  background: transparent;
  width: 100%;
  transition: 0.3s;
  z-index: 1000;
}

#header-container.hide {
  top: -55px;
}

#header, .header-container-in.hlt-top-menu .logo-header img {
  padding-left: 5px;
  display: block;
}

.header-container-in.hlt-top-menu .logo-header img {
  height: 28px;
}

#header {
  margin: 8px 0;
}
#header .header-in {
  min-height: unset !important;
}

.header-container-in.hlt-top-menu .logo-header .site-name-text {
  margin-left: 24px;
  position: relative;
}

.header-container-in.hlt-top-menu .logo-header .site-name-text::after {
  content: "株式会社ファクシア";
  display: block;
  line-height: 1;
  font-size: 0.612em;
  font-weight: 700;
  margin-top: 0.25em;
}

.logo-text {
  padding: 0;
}

/* フッター */
#footer.footer {
  margin-top: 0;
  padding-top: unset;
}

#footer-in {
  max-width: 1200px;
}
#footer-in .footer-bottom {
  margin-top: unset;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#footer-in .footer-bottom::after {
  display: none;
}

.footer-bottom-logo {
  position: unset;
}

.footer-bottom-logo .logo-image {
  max-width: initial;
}

.footer-bottom-logo .site-name-text {
  padding-bottom: 0;
}

.footer-bottom-logo .logo-image img {
  height: 24px;
  display: block;
  margin: 0 auto;
}

/* ----------
トップページ
---------- */
/* main visual */
#main_visual, #step {
  position: relative;
  max-width: initial;
  padding: 0;
}

#main_visual {
  margin-top: 0;
}

#main_visual img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

#main_visual::after {
  position: absolute;
  bottom: 20px;
  left: 50%;
  content: url("/wp-content/uploads/arrow.png");
  opacity: 0.7;
  transform: translate(-50%);
}

#main_visual .main_txt {
  position: absolute;
  top: 50%;
  left: 50%;
  background: -webkit-linear-gradient(0deg, #51eaef 0, #fccf21 35%, #fccf21 45%, #FF0080 80%, #9a0004 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: 100%;
  max-width: 400px;
  padding: 0 30px;
  box-sizing: border-box;
  font-size: 3rem;
  font-weight: bold;
  text-align: center;
  text-shadow: 0 2px 1px rgba(0, 0, 0, 0.2);
  line-height: 1.3;
  transform: translate(-50%, -50%);
}

#main_visual .main_txt .site_link {
  font-size: 1rem;
  -webkit-background-clip: none;
  -webkit-text-fill-color: currentcolor;
  text-shadow: none;
}

#main_visual .site_link a.link_btn {
  color: #9a0004;
}

#main_visual .site_link a.link_btn:hover {
  color: #fff;
}

/* lead */
#lead {
  position: relative;
  padding: 0;
}

h2.lead {
  background: url("/wp-content/uploads/curve.png");
  background-position: center bottom;
  background-size: contain;
  background-repeat: no-repeat;
  margin: 0 auto 30px;
  height: 100px;
}

#lead .illust {
  margin: 0 auto;
  padding: 0 20px;
}

#lead img {
  display: inline-block;
  vertical-align: bottom;
}

#lead .img.boud {
  position: relative;
}

.serif {
  position: absolute;
  top: 0;
  left: 0;
}

#lead .float {
  background: #fff1ed;
  padding: 15px 0 50px;
}

#lead .float .txt {
  font-size: 1.4rem;
  font-weight: 900;
  line-height: 1.7;
}

#lead .float .txt p {
  margin-top: 0;
  padding-bottom: 3px;
}

#lead .float .txt .p1 {
  border-bottom: dotted 0.3rem #b7b7b7;
}

#lead .float .txt .p2 {
  font-size: 1.6rem;
}

#lead .float .txt .cicle {
  background: #fff;
  padding: 0.15rem 0.4rem 0.07rem;
  border-radius: 50%;
  color: #9a0004;
  font-size: 1.7rem;
}

.to_next {
  position: absolute;
  left: 50%;
  bottom: -75px;
  transform: translateX(-50%);
}

/* step */
#step {
  counter-reset: step 0;
}

#step h2.step {
  margin-top: 1em;
}

h2.step .four_step {
  display: inline-block;
  margin: 0 8px;
  color: black;
  font-size: 1.5em;
  font-family: Arial Black;
  transform: rotate(18deg);
}

.step_box {
  margin: 0 auto 5em;
}

.step_item {
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  margin-bottom: 25px;
  padding: 10px 15px;
  border: dotted 0.2rem #b7b7b7;
  box-sizing: border-box;
}

.step_item .img {
  width: 38%;
}

.step_item .img img {
  margin: auto;
  border-radius: 10px;
}

.step_item .img, .step_item .txt {
  display: flex;
  flex-flow: column wrap;
  justify-content: flex-start;
  align-items: flex-start;
}

.step_item .txt {
  width: 60%;
  padding: 10px;
  padding-right: 0;
  box-sizing: border-box;
}

.step_item h3 {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 10px 10px 10px 3rem;
  padding-right: 0;
  box-sizing: border-box;
  font-size: 1rem;
  line-height: 1.2;
}

.step_item h3::before {
  counter-increment: step 1;
  content: counter(step) " ";
  position: absolute;
  top: 50%;
  margin-left: -3rem;
  color: black;
  font-family: Arial Black;
  font-size: 3rem;
  transform: translateY(-50%);
}

.step_item .txt .s {
  margin: 0;
  margin-top: 0.5em;
  font-size: 0.8rem;
}

/* reason */
#reason {
  position: relative;
  max-width: initial;
  margin: 0;
  padding: 0;
}

.hands .hand_l, .hands .hand_r {
  display: none;
}

#reason .inner {
  max-width: 960px;
  margin: 0 auto;
  padding: 50px 20px;
}

#reason h2 {
  margin: 0;
  padding: 0;
}

#reason .desc {
  margin: 0;
  font-size: 0.875rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.4;
}

#reason h2 span {
  display: inline-block;
  background: #fccf21;
  margin: 0 8px;
  padding: 0 10px;
  color: #fff;
  transform: skewX(-15deg);
}

.reason {
  position: relative;
  margin: 110px auto 40px;
  padding: 20px 25px;
  border: solid 2px black;
}

.reason::after {
  position: absolute;
  top: -1.2rem;
  left: 50px;
  background: #fff;
  padding: 0 10px;
  color: black;
  font-size: 1.3rem;
  font-weight: bold;
}

.reason.r1::after {
  content: "選ばれる理由①";
}

.reason.r2::after {
  content: "選ばれる理由②";
}

.reason.r3::after {
  content: "選ばれる理由③";
}

.reason .txt {
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}

.reason .comment {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -100px;
  right: 0;
  background: url("/wp-content/uploads/comment-sp.png");
  background-size: contain;
  width: 150px;
  height: 150px;
  margin: 0;
  color: #fff;
  font-weight: bold;
  text-shadow: 1px 1px 1px #000, -1px 1px 1px #000, 1px -1px 1px #000, -1px -1px 1px #000, 1px 1px 1px #000, -1px 1px 1px #000, 1px -1px 1px #000, -1px -1px 1px #000;
  text-align: center;
  transform: rotate(20deg);
}

#reason .inner .site_link {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2em;
}

/* information */
#info {
  max-width: initial;
  padding: 80px 0;
  position: relative;
  background-color: #ffe200;
  margin-bottom: 0;
}

#info .inner {
  background: rgba(255, 255, 255, 0.9);
  padding: 30px 20px;
  box-shadow: 0 0 25px rgba(0, 0, 0, 0.4);
  position: relative;
  z-index: 10;
}

h2.info {
  margin: 10px 0 0;
  color: #9a0004;
  text-shadow: 0 2px 1px rgba(0, 0, 0, 0.2);
}

#info .inner .txt {
  max-width: 800px;
  margin: 0 auto;
  color: #000;
  font-size: 1.12rem;
  font-weight: 500;
}

#info .info_box.entrance {
  color: #000;
  font-size: 1.12rem;
  font-weight: 500;
}

.article #info .inner h3 {
  margin: 0;
  font-size: 1.2rem;
  padding-left: 0;
}

.article #info .inner h3 .fa {
  margin-right: 4px;
}

#info .info_box.entrance .add {
  font-size: 1rem;
  line-height: 1.4;
}

#info .inner .txt p {
  line-height: 2;
}

#info .info_box img {
  padding-top: 18px;
}

#info input[type=text],
#info input[type=email],
#info input[type=tel],
#info textarea {
  padding: 8px 12px 7px;
  border: solid 1px #ccc;
  font-size: 0.8rem;
}

#info input[type=submit] {
  background: black;
  width: auto;
  padding: 9px 20px 8px;
  border: solid 1px black;
  color: #fff;
  text-indent: 10px;
  text-align: center;
  letter-spacing: 10px;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  transition: all 0.4s;
}

#info input[type=submit]:hover {
  opacity: 0.7;
}

#info .info_box.prof img {
  padding: 0 30%;
}

/* google Reviews */
.info_box_review {
  width: 100%;
  height: 295px;
  margin-bottom: 30px;
  padding: 30px;
  box-sizing: border-box;
  background: #fff;
  overflow-y: scroll;
}

/* topic */
#topic h2 {
  margin-bottom: 0;
  font-size: 1.8rem;
  text-align: left;
}

/* 新着記事カルーセル */
#topic-slider {
  max-width: 1200px;
  margin: 0 auto;
}

#topic-slider::before, #topic-slider::after {
  display: table;
  content: "";
}

#topic-slider::after {
  clear: both;
}

#topic-slider .slick-slider {
  margin-top: 0;
  padding-left: 0;
}

#topic-slider .slick-thumbnail {
  position: relative;
  max-height: 180px; /* サムネイルの高さ */
  overflow: hidden;
}

#topic-slider .slick-slide a {
  display: block;
  color: #000; /* 記事タイトル */
  padding: 0.5em 0.5em 0;
}

#topic-slider .slick-slide a:hover {
  opacity: 0.7;
}

#topic-slider .slick-slide img { /* サムネイル画像表示サイズ */
  width: 100%;
  max-width: 100%;
  height: 150px;
  border: 0;
  vertical-align: middle;
  -o-object-fit: cover;
     object-fit: cover;
}

#topic-slider .slick-cat { /* カテゴリータグ */
  position: absolute;
  top: 0;
  right: -1px;
  background: #fccf21;
  min-width: 8em;
  padding: 0.1em 0.5em;
  color: #fff;
  font-size: 0.8em;
  font-weight: bold;
  text-align: center;
  opacity: 0.8;
}

#topic-slider .slick-title {
  margin: 0.3em 0;
  padding: 5px 0;
  font-size: 1em;
  font-weight: 500;
  text-align: center;
  transition: 1s ease-in-out;
}

#topic-slider .slick-prev {
  left: -55px;
}

#topic-slider .slick-next {
  right: -55px;
}

#topic-slider .slick-prev, #topic-slider .slick-next {
  width: 50px;
  height: 50px;
  margin-top: -20px;
}

#topic-slider .slick-prev::before {
  content: "\f104";
}

#topic-slider .slick-next::before {
  content: "\f105";
}

#topic-slider .slick-prev::before,
#topic-slider .slick-next::before {
  color: #777;
  font-family: "fontAwesome";
  font-size: 20px;
  font-weight: 200;
}

/* フッター直前ウィジェット */
.widget-page-content-bottom {
  margin-bottom: 0;
  padding: 0 15px;
  border-top: solid 1px #eee;
}

.before_ft p {
  text-align: center;
}

.btn_mail {
  text-align: center;
}

.btn_mail a {
  display: inline-block;
  background: #fccf21;
  width: 180px;
  height: 40px;
  border: solid 2px #fccf21;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  line-height: 36px;
  transition: 0.5s;
}

.btn_mail a:hover {
  background: #fff;
  border: dashed 2px #fccf21;
  color: #fccf21;
}

.entry-categories-tags {
  display: none;
}

/* ----------
 * 制作実績
 * ---------- */
.article h1.port, .portTitle {
  display: block;
  position: relative;
  font-size: 2.6rem;
  margin-bottom: 0.5em;
  padding-top: 30px;
  padding-bottom: 0.6em;
  font-weight: bold;
  text-align: center;
  line-height: 1.25;
}

.article h1.port span, .portTitle span {
  position: absolute;
  bottom: 0;
  left: 50%;
  font-size: 0.9rem;
  content: "";
  transform: translateX(-50%);
}

#Portfolio {
  max-width: initial;
  margin: 50px auto;
  padding: 0 20px;
}

#Portfolio ul {
  list-style: none;
  margin: 30px 0 0;
  padding-left: 0;
  display: flex;
  flex-wrap: wrap;
}

#Portfolio ul.product li {
  position: relative;
  width: 50%;
  min-height: 300px;
  margin: 0;
  border: solid 1px #efefef;
  box-sizing: border-box;
  overflow: hidden;
  z-index: 0;
}

#Portfolio ul.product li::after, #portDetail::after, #portData::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  content: "";
  transition: 1s;
  animation: curtainOpen 0.7s ease-in-out 1s 1;
  animation-fill-mode: forwards;
  z-index: -1;
}

#Portfolio ul.product li.service::after,
#portDetail.service::after {
  background: linear-gradient(332deg, rgb(255, 218, 184) 0%, rgb(255, 180, 181) 36%, rgb(255, 225, 225) 66%, rgb(255, 255, 255) 100%);
}

#Portfolio ul.product li.corp::after,
#portDetail.corp::after {
  background: linear-gradient(325deg, rgb(235, 246, 255) 0%, rgb(180, 254, 255) 36%, rgb(225, 252, 255) 66%, rgb(255, 255, 255) 100%);
}

#Portfolio ul.product li.ec::after,
#portDetail.ec::after {
  background: linear-gradient(325deg, rgb(236, 255, 208) 0%, rgb(228, 255, 208) 36%, rgb(213, 255, 227) 66%, rgb(255, 255, 255) 100%);
}

#Portfolio ul.product li.others::after,
#portDetail.others::after {
  background: linear-gradient(325deg, rgb(255, 229, 211) 0%, rgb(255, 225, 114) 36%, rgb(255, 252, 219) 66%, rgb(255, 255, 255) 100%);
}

@keyframes curtainOpen {
  0% {
    width: 0;
  }
  100% {
    width: 1000%;
  }
}
#Portfolio li p {
  margin: 0;
  font-size: 1.2rem;
  font-weight: bold;
}

#Portfolio li p.poType {
  font-size: 0.88rem;
  font-weight: normal;
}

#Portfolio ul li a {
  display: block;
  color: #333;
  text-decoration: none;
}

#Portfolio .su-tabs {
  background: none;
  text-align: center;
}

#Portfolio .su-tabs-pane {
  padding: 0;
}

#Portfolio ul.product li figure, #portDetail figure {
  position: absolute;
  background: #fff;
  overflow: hidden;
  z-index: 1;
}

#Portfolio ul.product li figure.pc_monitor {
  top: 18.3%;
  left: 13.1%;
  width: 55.1%;
  height: 34.9%;
}

#Portfolio ul.product li figure.sp_monitor {
  top: 41%;
  right: 11.3%;
  width: 15%;
  height: 26.2%;
}

#Portfolio ul.product li figure.ph {
  top: 13%;
  right: 5.5%;
  width: 89%;
  height: 59%;
}

#Portfolio ul.product li figure img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.5s;
}

#Portfolio ul.product li a:hover figure img, #Portfolio ul.product li:hover figure.ph img {
  opacity: 0.7;
  transform: scale(1.1);
}

#Portfolio .txt {
  position: absolute;
  bottom: 10%;
  left: 50%;
  width: 100%;
  height: 4em;
  transform: translateX(-50%);
}

#Portfolio .su-tabs-nav span {
  color: #555;
  font-size: 1em;
  transition: 0.3s;
}

#Portfolio .su-tabs-nav span.su-tabs-current {
  color: #9a0004;
}

#Portfolio .su-tabs-nav span:hover {
  background: none;
}

/* 制作実績個別 */
#portDetail {
  position: relative;
  margin-top: 30px;
  margin-bottom: 240px;
  z-index: 1;
  padding: 0;
}

#portDetail .img_bg img {
  width: 100vw;
}

#portDetail figure.pc_monitor {
  top: 17.3%;
  left: 13.1%;
  width: 55.1%;
  height: 44%;
}

#portDetail figure.sp_monitor {
  top: 45.1%;
  right: 11.2%;
  width: 15.09%;
  height: 32.7%;
}

#portDetail .txt {
  position: absolute;
  top: 250px;
  top: 90%;
  background: #fff;
  width: 90%;
  padding: 30px 10px;
  box-sizing: border-box;
  text-align: center;
  box-shadow: 0px 0px 50px 0px rgba(0, 0, 0, 0.1);
  left: 50%;
  transform: translateX(-50%);
}

#portDetail .txt h2.poName {
  padding: 0;
}

.site_link, #main_visual .main_txt .site_link {
  height: 50px;
}

.link_btn, #main_visual .main_txt .link_btn {
  display: inline-block;
  position: relative;
  width: 200px;
  height: 58px;
  text-align: center;
  text-decoration: none;
  line-height: 58px;
  perspective: 300px;
  outline: none;
}

.link_btn::before,
.link_btn::after,
#main_visual .main_txt .link_btn::before,
#main_visual .main_txt .link_btn::after {
  display: block;
  position: absolute;
  content: "";
  z-index: -1;
}

.link_btn,
.link_btn::before,
.link_btn::after,
#main_visual .main_txt .link_btn,
#main_visual .main_txt .link_btn::before,
#main_visual .main_txt .link_btn::after {
  box-sizing: border-box;
  transition: all 0.3s;
}

.link_btn span, #main_visual .main_txt .link_btn span {
  display: block;
  position: absolute;
  width: 200px;
  border: 2px solid black;
  box-sizing: border-box;
  text-align: center;
  font-weight: 500;
  line-height: 56px;
  transition: all 0.3s;
  pointer-events: none;
}

.link_btn span:first-child,
#main_visual .main_txt .link_btn span:first-child {
  background: black;
  color: #fff;
  transform: rotateX(90deg);
  transform-origin: 50% 50% -30px;
}

.link_btn span:last-child,
#main_visual .main_txt .link_btn span:last-child {
  background: #fff;
  color: black;
  transform: rotateX(0deg);
  transform-origin: 50% 50% -30px;
}

.link_btn:hover span:first-child,
#main_visual .main_txt .link_btn:hover span:first-child {
  transform: rotateX(0deg);
}

.link_btn:hover span:last-child,
#main_visual .main_txt .link_btn:hover span:last-child {
  background: black;
  transform: rotateX(-90deg);
}

#portData {
  position: relative;
  max-width: initial;
  margin: -250px auto 0;
  padding: 180px 0 0;
  z-index: 0;
}

#portData.service::after {
  background: linear-gradient(-10deg, rgb(255, 218, 184) 0%, rgb(255, 180, 181) 36%, rgb(255, 225, 225) 66%, rgb(255, 255, 255) 100%);
}

#portData.corp::after {
  background: linear-gradient(-10deg, rgb(235, 246, 255) 0%, rgb(180, 254, 255) 36%, rgb(225, 252, 255) 66%, rgb(255, 255, 255) 100%);
}

#portData.ec::after {
  background: linear-gradient(-10deg, rgb(236, 255, 208) 0%, rgb(228, 255, 208) 36%, rgb(213, 255, 227) 66%, rgb(255, 255, 255) 100%);
}

#portData.others::after {
  background: linear-gradient(-10deg, rgb(255, 229, 211) 0%, rgb(255, 225, 114) 36%, rgb(255, 252, 219) 66%, rgb(255, 255, 255) 100%);
}

#portData .inner {
  background: #fff;
  padding: 40px 35px 20px;
  box-shadow: 1px 1px 2px 0 rgba(0, 0, 0, 0.08);
}

#portData dl {
  display: flex;
  justify-content: space-between;
  flex-flow: row wrap;
  width: 100%;
}

#portData dl dt, #portData dl dd {
  padding: 10px 0;
  border-bottom: 1px solid #f7f7f7;
  font-weight: 500;
}

#portData dl dt {
  width: 32%;
}

#portData dl dd {
  width: 66%;
  margin-left: 0;
}

@media screen and (max-width: 768px) {
  #lead .float .txt .p1.il-block {
    display: inline;
  }
  #info .inner .txt,
  #info .info_box.entrance .add {
    font-size: 0.875rem;
  }
  #info .info_box.entrance .add {
    white-space: nowrap;
  }
  .article #info .inner h3 {
    margin-top: 18px;
  }
}
@media screen and (max-width: 480px) {
  .reason::after {
    left: -10px;
  }
  .reason .txt {
    font-size: 1.2rem;
  }
  #reason .inner .site_link {
    display: inline-block;
    margin: 0 auto;
    flex-direction: column;
  }
  #reason .link_btn {
    margin-top: 1em;
  }
  #reason .link_btn:first-child {
    margin-top: unset;
  }
}
@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
  .pc {
    display: block !important;
  }
  /* 見出し */
  .home .article h2 {
    font-size: 1.8rem;
  }
  /* ----------
  トップページ
  ---------- */
  #main_visual img {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
  /* lead */
  h2.lead {
    max-width: 720px;
    height: 120px;
  }
  .illust, .float .inner {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
  }
  .illust .img {
    width: 50%;
  }
  .float .img {
    order: 0;
    width: 35%;
  }
  #lead .float {
    padding-bottom: 15px;
  }
  #lead .float .txt {
    order: 1;
    width: 60%;
    font-size: 1.6rem;
  }
  #lead .float .txt .p2 {
    font-size: 1.8rem;
  }
  /* step */
  .step_box {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
  }
  .step_item {
    position: relative;
    width: 49%;
  }
  .step_item::after {
    position: absolute;
    z-index: 1;
  }
  .item1 {
    order: 0;
  }
  .item2 {
    order: 1;
  }
  .item4 {
    order: 2;
    margin-bottom: 0;
  }
  .item3 {
    order: 3;
    margin-bottom: 0;
  }
  .item1::after {
    top: 50%;
    right: -45px;
    content: url("/wp-content/uploads/arrow1.png");
    transform: translateY(-50%);
  }
  .item2::after {
    bottom: -50px;
    left: 50%;
    content: url("/wp-content/uploads/arrow2.png");
    transform: translateX(-50%);
  }
  .item3::after {
    top: 50%;
    left: -45px;
    content: url("/wp-content/uploads/arrow3.png");
    transform: translateY(-50%);
  }
  .item4::after {
    top: -45px;
    left: 50%;
    content: url("/wp-content/uploads/arrow4.png");
    transform: translateX(-50%);
  }
  .step_item .txt .s {
    margin-bottom: 1rem;
    font-size: 0.88rem;
  }
  /* reason */
  .reason {
    margin: 60px 0 60px 150px;
  }
  .reason .comment {
    top: 0;
    left: -150px;
    background: url("/wp-content/uploads/comment.png");
    transform: rotate(-10deg);
  }
  /* information */
  #info .inner {
    padding: 65px;
  }
  .info_fl {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    max-width: 800px;
    margin: 0 auto;
    /* padding-top: 50px; */
  }
  .info_box {
    /* width: 46%; */
  }
  .info_box.entrance {
    width: 46%;
  }
  /* google Reviews */
  .info_box_review {
    height: 240px;
  }
  /* 新着記事スライダー */
  #topic-slider {
    padding: 0 30px;
  }
  #topic-slider .slick-thumbnail {
    max-height: 200px; /* サムネイルの高さ */
  }
  #topic-slider .slick-slide img { /* サムネイル画像表示サイズ */
    height: 180px;
  }
  /* フッター直前ウィジェット */
  .before_ft {
    display: flex;
    justify-content: flex-end;
    margin: 0 auto;
  }
  .before_ft p {
    width: 20%;
    height: 40px;
    line-height: 40px;
  }
  /* ----------
   * 制作実績
   * ---------- */
  #Portfolio ul.product {
    display: flex;
    flex-flow: row wrap;
  }
  #Portfolio ul.product li {
    width: 50%;
  }
  /* 制作実績個別 */
  #portDetail {
    width: 70%;
    margin: 60px 0 0 30%;
    padding: 0;
    box-shadow: 0 0 50px 0 rgba(0, 0, 0, 0.1);
  }
  #portDetail figure.pc_monitor {
    top: 17.3%;
    left: 13.1%;
    width: 55.1%;
    height: 44%;
  }
  #portDetail figure.sp_monitor {
    top: 45.7%;
    right: 11.2%;
    width: 15%;
    height: 33.2%;
  }
  #portDetail .txt {
    top: 120px;
    left: -38%;
    width: 45%;
    transform: unset;
  }
  #portData {
    margin-top: -100px;
    padding: 80px 50px 50px;
  }
  #portData .data {
    display: flex;
  }
}
@media screen and (min-width: 1024px) {
  .pc2 {
    display: block !important;
  }
  .sp2 {
    display: none !important;
  }
  /* 見出し */
  .home .article h2 {
    font-size: 2.4rem;
  }
  /* lead */
  h2.lead {
    max-width: 900px;
    height: 150px;
  }
  #lead .float .txt {
    font-size: 1.9rem;
  }
  #lead .float .txt .p2 {
    font-size: 2.2rem;
  }
  #lead .float .txt .cicle {
    padding: 0.33rem 0.7rem 0.11rem;
    font-size: 3.8rem;
  }
  /* step */
  .step_item h3 {
    padding: 30px 10px 10px 3rem;
    font-size: 1.2rem;
  }
  .step_item h3::before {
    top: calc(50% + 10px);
  }
  .step_item .txt .s {
    margin-top: 2.5rem;
    margin-left: 3.6em;
  }
  /* reason */
  #reason {
    position: relative;
  }
  .hands .hand_l, .hands .hand_r {
    display: block;
    position: absolute;
    top: 0;
    width: 350px;
    height: 300px;
  }
  .hands .hand_l {
    left: 0;
  }
  .hands .hand_r {
    right: 0;
  }
  #reason .desc {
    padding-top: 3rem;
    line-height: 1.8;
  }
  #reason h2 {
    padding-bottom: 50px;
  }
  /* 新着記事カルーセル */
  #topic-slider .slick-slide img { /* サムネイル画像表示サイズ */
    height: 200px;
  }
  /* ----------
   * 制作実績
   * ---------- */
  #Portfolio ul.product li {
    width: 33.3333%;
  }
  #portDetail .txt {
    top: 200px;
    padding: 50px 0;
  }
  #portData .inner {
    padding: 60px 50px 50px;
  }
}
@media screen and (min-width: 1200px) {
  /* ----------
  トップページ
  ---------- */
  #portDetail .txt {
    padding: 100px 0;
  }
  #Portfolio ul.product li {
    width: 33.3333%;
    width: 25%;
  }
}
/* 2020.05.26追加 */
.snsHeader {
  display: flex;
  margin-bottom: 1em;
  border-bottom: solid 1px #777;
}

#info .info_box.prof .snsHeader img {
  margin-right: 0.5em;
  padding: 0;
}

#info .info_box.prof .snsHeader .ttl {
  display: inline-block;
  margin-right: 0.8em;
  font-weight: bold;
}

#info .info_box.prof .snsHeader .sns__link a {
  color: #9a0004;
  font-size: 88%;
  text-decoration: none;
}

#sb_instagram.sbi_col_3 {
  margin-bottom: 30px;
}

#sb_instagram.sbi_col_3 #sbi_images .sbi_item.sbi_type_carousel {
  float: none;
  width: 33.33% !important;
}

#sb_instagram .sbi_photo_wrap {
  color: transparent;
}

#sb_instagram.sbi_col_3 #sbi_load .sbi_load_btn {
  border-radius: 0;
  transition: all 0.4s;
}

#info .blogcard {
  display: none;
}

/* 2020.06.1追加 */
/* ----------
 * 選ばれる3つの理由
 * ---------- */
.reasons .entry-content p,
.concept .entry-content p,
.advantage p,
.check__list__yl li,
.check__list__bk li {
  font-size: 1.1em;
  font-weight: 500;
  line-height: 2;
}

.reasons .inner {
  max-width: 1200px;
  margin: 0 auto;
}

.font__l {
  display: inline-block;
  margin: 0.3em 0;
  font-size: larger;
  font-weight: bold;
  line-height: 1.9;
}

.underline__yl {
  background: linear-gradient(transparent 72%, #fccf21 0%);
}

.article .cta {
  margin: 50px 0;
}

.article .cta a {
  display: block;
}

#reasonsList {
  max-width: initial;
  padding: 0;
}

#main__visual {
  margin: 50px auto 0;
}

#main__visual h1 {
  display: block;
  padding: 0;
}

#main__visual img {
  width: 100vw;
}

#reasonsList .reasons__list {
  list-style: none;
  padding-left: 0;
}

#reasonsList .reasons__list > li {
  position: relative;
  margin: 0 0 40px 0;
  padding: 0 20px;
  z-index: 0;
}

#reasonsList .reasons__list > li::before,
#reasonsList .reasons__list > li::after {
  position: absolute;
  width: 80%;
  height: 500px;
  content: "";
}

#reasonsList .reasons__list > li::before {
  top: 60px;
  right: 0;
  background: #f4f4f4;
  z-index: -1;
}

#reasonsList .reasons__list > li::after {
  top: 210px;
  left: 0;
  background: url("/wp-content/uploads/bg-check.png") center/cover no-repeat;
  z-index: -2;
}

.reasons .list__ttl__red {
  position: relative;
  padding: 15px 15px 0 82px;
  color: black;
  font-size: 1.4em;
  font-weight: bold;
}

#reasonsList .list__ttl__red::after {
  position: absolute;
  top: 9px;
  left: 0;
  width: 70px;
  height: 70px;
  content: "";
}

#reasonsList .item03 .list__ttl__red::before {
  width: 120px;
  height: 100px;
  background: url(/wp-content/uploads/illust-reason3.png) center top/contain no-repeat;
}

#reasonsList .list__ttl__red::after {
  filter: grayscale(1);
}

#reasonsList .item01 .list__ttl__red::after {
  background: url(/wp-content/uploads/num1.png) center top/contain no-repeat;
}

#reasonsList .item02 .list__ttl__red::after {
  background: url(/wp-content/uploads/num2.png) center top/contain no-repeat;
}

#reasonsList .item03 .list__ttl__red::after {
  background: url(/wp-content/uploads/num3.png) center top/contain no-repeat;
}

#reasonsList .reasons__list li .img,
#conceptContent .inner .img {
  width: 90%;
  margin: 2em auto;
}

.reasons__list .item02 .inner .check__list__bk,
.reasons__list .item02 .inner .check__list__yl,
#advantageInfo .check__list__yl,
#advantageFeature .check__list__yl {
  list-style: none;
  padding-left: 0;
}

.check__list__bk li {
  position: relative;
  padding-left: 1.5em;
}

.check__list__bk li::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  height: 19px;
  background: url(/wp-content/uploads/icon-check-bk.png) center top/contain no-repeat;
  content: "";
}

.check__list__yl li {
  position: relative;
  padding-left: 1.5em;
}

.check__list__yl li::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  height: 19px;
  background: url(/wp-content/uploads/icon-check-yl.png) center top/contain no-repeat;
  content: "";
}

/* ----------
 * 大切にしていること
 * ---------- */
#main__visual.il h1.page__ttl__red {
  display: block;
  padding: 0;
  text-align: center;
}

#main__visual.il p {
  color: #9a0004;
  margin: 0 auto;
  font-family: "MS UI Gothic", "Yu Gothic UI", YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
  font-weight: bold;
}

#main__visual.il .top_page_ttl {
  font-size: 3rem;
}

#main__visual.il .top_page_ttl_sub {
  font-size: 1.2rem;
}

#main__visual.il h1 img {
  width: 80%;
  max-width: 432px;
  margin: 0 auto;
}

.entry-content #main__visual.li .img {
  margin: 3em auto 2em;
}

#conceptContent .icon__list {
  list-style: none;
  margin: 40px 0;
  padding: 0 20px;
}

#conceptContent .icon__list li {
  width: 100%;
  margin-bottom: 30px;
  padding: 1.5em;
  font-size: 90%;
  border: solid #9a0004 5px;
  box-sizing: border-box;
}

.icon__list li .img {
  text-align: center;
}

#conceptContent .icon__list li:last-child {
  margin-bottom: 0;
}

#conceptContent .icon__list li h3 {
  margin: 1em auto 0;
  padding: 0;
  color: #9a0004;
  text-align: center;
}

#conceptContent .concept__txt {
  margin-bottom: 30px;
}

#conceptContent .concept__txt p {
  text-align: center;
}

#conceptSummary .concept__area {
  position: relative;
  margin: 0 5px 51px 0;
  padding: 25px;
  z-index: 0;
}

#conceptSummary .concept__area::before,
#conceptSummary .concept__area::after {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
}

#conceptSummary .concept__area::before {
  top: 20px;
  left: 20px;
  background: url(/wp-content/uploads/bg-concept.png) center top/cover no-repeat;
  z-index: -2;
}

#conceptSummary .concept__area::after {
  top: 0;
  left: 0;
  background: #f4f4f4;
  z-index: -1;
}

#conceptSummary .concept__area .font__red {
  color: #9a0004;
  font-weight: bold;
}

/* ----------
 * これからホームページを作ろうとお考えの方へ
 * ---------- */
.img.advantage {
  margin: 30px auto;
}

#advantageInfo {
  margin: 0;
}

#advantageInfo .imgbox__ad {
  display: flex;
  align-items: flex-end;
}

#advantageInfo .imgbox__ad__l,
#advantageInfo .imgbox__ad__r {
  padding: 0 10px;
}

#advantageInfo .check__list__box {
  margin-top: -100px;
  padding: 20px;
  background: url(/wp-content/uploads/bg-check-advantage.png) center top/cover no-repeat;
}

#advantageInfo .check__list__yl {
  margin: 0;
  padding: 100px 10px 10px;
  background: #fff;
}

#advantageInfo .img {
  margin: 30px 0;
}

#advantageInfo p {
  text-align: center;
}

#advantageFeature .advantage__content {
  margin-bottom: 30px;
  padding: 1.5em;
  border: solid black 6px;
  box-sizing: border-box;
}

#advantageFeature .advantage__content .img {
  margin-top: 1.2em;
  text-align: center;
}

#advantageFeature .advantage__content p,
#advantageFeature .txt {
  text-align: center;
}

#advantageFeature .advantage__content .left {
  text-align: left;
}

/* ----------
 * banner
 * ---------- */
.f__banner {
  display: none;
  position: fixed;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  list-style: none;
  z-index: 999;
  padding-left: unset;
}

.f__banner li a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 128px;
  height: 18vh;
  margin-bottom: 10px;
  border-radius: 5px 0 0 5px;
  background: #fff100;
  color: #000;
  font-size: 0.8em;
  font-size: 1.7vh;
  font-weight: bold;
  text-decoration: none;
  text-orientation: upright;
  writing-mode: vertical-rl;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.4);
  transition: all 0.5s;
}

.f__banner li a:hover {
  opacity: 0.7;
}

.f__banner .works a,
.ft__banner .works a {
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  background: black;
  letter-spacing: 0.4em;
}

.ft__banner {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  margin: 0;
  flex-flow: row wrap;
  list-style: none;
  width: 100%;
  padding-left: 0;
  z-index: 999;
}

.ft__banner li {
  width: 33.33%;
}

.ft__banner .works {
  width: 50%;
}

.ft__banner li a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 43px;
  border: solid 1px #333;
  box-sizing: border-box;
  background: #fff100;
  color: #333;
  font-size: 0.9em;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  line-height: 1.3;
}

.go-to-top {
  bottom: 96px;
}

#footer.footer {
  margin-bottom: 86px;
}

@media screen and (min-width: 768px) {
  /* ----------
      * banner
      * ---------- */
  .f__banner {
    display: block;
  }
  .ft__banner {
    display: none;
  }
  #footer.footer {
    margin-bottom: 0;
  }
  .go-to-top {
    bottom: 10px;
    right: 70px;
  }
}
@media screen and (min-width: 1024px) {
  /* ----------
      * 選ばれる3つの理由
      * ---------- */
  .reasons .entry-content p,
  .concept .entry-content p,
  .advantage .entry-content p {
    font-size: 1.4em;
    line-height: 2.2;
  }
  .entry-content .cta {
    margin: 200px auto 100px;
  }
  #reasonsList .reasons__list > li::before {
    top: 150px;
  }
  #reasonsList .reasons__list > li::before,
  #reasonsList .reasons__list > li::after {
    right: 9%;
    width: 65%;
    height: 800px;
  }
  #reasonsList .reasons__list > li::after {
    top: 315px;
  }
  #reasonsList .reasons__list li .img {
    width: 70%;
    margin: 2.2em auto;
  }
  #reasonsList .list__ttl__red {
    padding: 3% 9% 0 18%;
    font-size: 2.7em;
  }
  #reasonsList .list__ttl__red::after {
    top: 0;
    left: 0;
    width: 170px;
    height: 170px;
    content: "";
  }
  .font__l {
    margin-top: 0;
    line-height: 3;
  }
  #reasonsList .item02 .inner {
    margin: 0 0 0 auto;
  }
  #reasonsList .item03 .list__ttl__red::before {
    width: 124px;
    height: 300px;
  }
  #reasonsList .reasons__list .item02::before {
    right: 0;
  }
  #reasonsList .reasons__list .item02::after {
    left: 5%;
  }
  .check__list__bk li,
  .check__list__yl li {
    padding-left: 2em;
    font-size: 1.4em;
    font-weight: 500;
    line-height: 2.2;
  }
  .check__list__yl li::after,
  .check__list__bk li::after {
    top: 43%;
    width: 1.4em;
    height: 1.6em;
    transform: translateY(-50%);
  }
  /* ----------
  * 大切にしていること
  * ---------- */
  #conceptContent {
    text-align: center;
  }
  #main__visual.il .img {
    width: 479px;
    margin: 90px auto 0;
  }
  #main__visual.il .img img {
    width: 100%;
  }
  #conceptContent .icon__list {
    display: flex;
    justify-content: space-around;
  }
  #conceptContent .icon__list p {
    line-height: 1.9;
  }
  #conceptContent .icon__list .img {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 200px;
  }
  #conceptContent .icon__list h3 {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 54px;
  }
  #conceptContent .icon__list li {
    width: 33.3333%;
    margin: 0 30px 0 0;
    font-size: 86%;
    text-align: left;
  }
  #conceptContent .icon__list li:last-child {
    margin-right: 0;
  }
  #conceptContent .icon__list li h2 {
    font-size: 22px;
  }
  #conceptContent .concept__txt {
    margin: 70px 0;
  }
  #conceptSummary .concept__area {
    padding: 60px;
    margin-bottom: 80px;
  }
  #conceptSummary .concept__area::before {
    top: 40px;
    left: 40px;
  }
  .entry-content .cta {
    text-align: center;
  }
  /* ----------
      * これからホームページを作ろうとお考えの方へ
      * ---------- */
  .advantage #main__visual.il h1 img {
    max-width: initial;
    margin: 0 auto;
  }
  .advantage #main__visual.il .img {
    width: 750px;
    margin-bottom: 30px;
  }
  #advantageInfo {
    margin: 0 auto;
  }
  #advantageInfo .imgbox__ad {
    justify-content: space-between;
  }
  #advantageInfo .imgbox__ad__r {
    margin-right: 3em;
  }
  #advantageInfo .imgbox__ad__r img {
    margin: 0 auto;
  }
  #advantageInfo .check__list__box {
    margin-top: -200px;
    padding: 40px;
  }
  #advantageInfo .check__list__yl {
    padding: 200px 40px 40px;
  }
  #advantageInfo .check__list__yl li {
    font-size: 1.9em;
    font-weight: bold;
  }
  #advantageInfo .img {
    margin: 50px 0;
    text-align: center;
  }
  #advantageFeature .advantage__content .img {
    text-align: center;
  }
  #advantageFeature .check__list__yl {
    max-width: 537px;
    margin: 0 auto;
  }
  #advantageFeature p.left {
    max-width: 537px;
    margin: 1.5em auto;
  }
  #advantageFeature .advantage__content {
    border: solid black 12px;
  }
}
.shota {
  width: 50%;
}

.top_news_text {
  margin: 0px auto 20px;
  padding: 40px 5%;
  width: 100%;
  text-align: center;
  font-size: 18px;
  background-color: #fff100;
  box-shadow: 0px 5px 5px #999;
}

#Portfolio ul li a .su-animate img[src="/wp-content/uploads/portfolio-bg.png"] {
  display: block;
  width: 100%;
  height: 100%;
}

/* 2021.12.13追加 
----------
* 料金一覧
---------- */
.price #main__visual.il h1 img {
  width: 40%;
  max-width: 200px;
  margin: 0 auto;
}

#main__visual.il .price {
  width: 250px;
  max-width: 50%;
  margin: 55px auto 0;
}

/*
#price-table-area ul.plan-list {
	display: flex;
	justify-content: space-between;
	list-style: none;
	padding-left: 0;
}
#price-table-area .plan-list > li{
	width: 29%;
	border: #9A0004 solid 1px;
}
.plan01 .plan-name-box {
	background-color: #E0DC16;
}
.plan02 .plan-name-box {
	background-color: #E00007;
}
.plan03 .plan-name-box {
	background-color: #9A0004;
}
.plan-name-box p {
	margin: 0;
	text-align: center;
	color: #fff;
	padding: 10px 0;
	font-size: 18px;
	font-weight: bold;
}
*/
@media screen and (min-width: 1024px) {
  #main__visual.il .price {
    width: 250px;
    max-width: 50%;
    margin: 55px auto 0;
  }
}
/* 2022.01.01追加 */
.br-sp {
  display: none;
}

.price-main {
  background: #fff;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.price-main .inner {
  max-width: 1200px;
  margin: 0 auto;
}

.price-main ul {
  list-style: none;
}

/*料金理念*/
.price-philosophy-area {
  padding-top: 70px;
  position: relative;
}

#price-philosophy-box {
  min-height: 340px;
  padding-bottom: 60px;
  position: relative;
}

.price-philosophy-subttl {
  margin: 0;
  position: relative;
}

.STSub {
  font-size: 0.88rem;
  letter-spacing: 0.15em;
  position: relative;
  display: block;
  margin-left: 30px;
}

.STSub::before {
  content: "";
  position: absolute;
  top: 10px;
  left: -20px;
  width: 10px;
  height: 4px;
  display: block;
}

.BCPrice::before {
  background: #fff100;
}

#price-philosophy-ttl {
  font-size: 2.1rem;
  text-align: center;
  line-height: 1.5;
  letter-spacing: 0.085em;
  margin: 0;
  padding-top: 20px;
  font-size: 2.7em;
  color: black;
}

.price-philosophy-flex {
  display: flex;
  justify-content: space-between;
  margin: 50px 0 0;
}

#priceCInfo {
  width: 60%;
}

.PCatcInfo {
  font-size: 1rem;
  line-height: 1.8;
  letter-spacing: 0.085em;
}

.cost-cut-img {
  width: 30%;
  -o-object-fit: contain;
     object-fit: contain;
}

/*料金ページナビゲーション*/
.pageNav {
  margin: 0px;
  padding-top: 10px;
  position: relative;
}

.PNBeige {
  background: #eceae7;
  border-top: 1px solid #d7d5d2;
  border-bottom: 1px solid #d7d5d2;
}

.PNList {
  display: flex;
  justify-content: space-between;
  flex-flow: row wrap;
  height: 40px;
  padding: 0;
}

.PNList li {
  text-align: center;
  border-left: 2px solid #fff;
  display: block;
  width: calc(33.33% - 2px);
}

.PNList li:first-of-type {
  border: none;
}

.PNList a {
  color: #555;
  letter-spacing: 0.08em;
  height: calc(100% - 5px);
  position: relative;
  text-decoration: none;
  display: block;
  cursor: pointer;
  overflow: hidden;
}

.PNList a::before {
  content: "";
  position: absolute;
  bottom: 9px;
  left: 50%;
  width: 0;
  height: 0;
  margin-left: -4px;
  border-style: solid;
  border-width: 6px 4px 0 4px;
  border-color: #aea299 transparent transparent transparent;
}

.PNList a:hover {
  background: #ffe900;
  /*
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 0;
  height: 100%;
  display: block;
  -webkit-transition: all .5s cubic-bezier(.075, .82, .165, 1) .1s;*/
  transition: all 0.5s;
}

.PNList a:hover::before {
  bottom: 3px;
  transition: all 0.5s;
}

/*サービス範囲*/
#PPriceContents {
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.7);
}

.secWrapp {
  padding: 70px 0 60px;
}

.secWrapp, .secWrappLined {
  padding: 70px 0 60px;
  position: relative;
  overflow: hidden;
}

.BGBeige {
  background: #f4f4f4;
}

.PSTJP {
  color: black;
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  margin-top: 22px;
  display: block;
}

#PPriceCopy {
  width: 48em;
  margin: 40px auto 0;
}

.HCopyCenter {
  text-align: center;
  margin-top: 45px;
  font-size: 1rem;
  line-height: 2;
  letter-spacing: 0.085em;
}

.copyIBlock {
  text-align: left;
  display: inline-block;
}

#priceItem {
  width: 880px;
  margin: 60px auto 0;
}

.flexC {
  display: flex;
  justify-content: space-between;
  flex-flow: row wrap;
}

#priceItemImage {
  width: 397px;
}

.rota340 {
  animation: rota340 1.25s cubic-bezier(0.075, 0.82, 0.165, 1);
}

@keyframes rota340 {
  0% {
    transform: rotate(-180deg);
    opacity: 0;
  }
  100% {
    transform: rotate(0deg);
    opacity: 1;
  }
}
#priceItemList {
  width: 400px;
  margin: 25px 0 0;
  padding: 0;
}

#priceItemList > li {
  color: #705e54;
  font-size: 1rem;
  letter-spacing: 0.15em;
  margin: 5px 0 0;
  font-weight: bold;
}

/*総費用目安*/
.secWrappLined {
  padding: 70px 0 60px;
  border-top: 1px solid #ddd;
}

#totalCost {
  padding-bottom: 40px;
  position: relative;
}

#totalCostContainer {
  padding: 45px 0 0;
  overflow: hidden;
}

.bg-example {
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  width: 344px;
  height: 147px;
}

.rightIn01 {
  animation: rightIn 0.6s ease-in-out;
}

.lazyloaded {
  opacity: 1;
  transition: all 0.5s;
}

#totalCImfo {
  width: 50em;
  margin: 0 0 0 50px;
}

.CTLeft16 {
  font-size: 1rem;
  line-height: 2;
  letter-spacing: 0.075em;
}

#TCostList {
  max-width: 1200px;
  margin: 60px auto 0;
}

/*各ケース例*/
.TCLItem {
  width: 48%;
  margin-bottom: 40px;
  position: relative;
  display: flex;
  flex-direction: column;
  border: #e6e6e6 4px solid;
}

/*各ケースタイトル*/
.TCIName {
  margin: 0;
  position: relative;
  padding-top: 0;
  display: flex;
  align-items: center;
  padding: 5px;
  background: #e6e6e6;
}

.TCIName-box {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.TCCase {
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  line-height: 1;
  margin: 0;
}

.TCCNum {
  font-size: 2.875rem;
  font-style: normal;
  line-height: 1;
  margin: 0;
}

.TCCCatch {
  font-size: 1.375rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  padding-left: 10px;
}

.plan-content-box {
  padding: 5px 25px;
}

.TCIinfo {
  color: #6e5e54;
  font-size: 0.9375rem;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.06em;
  margin: 30px 0 0;
}

.TCSpecification {
  margin: 30px 0 0;
}

.TCSpecification > dt {
  color: #888;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  margin: 0 0 18px;
  font-weight: bold;
}

.TCSpecDetail {
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 8px 0 0;
  padding: 0 0 0 20px;
  position: relative;
}

.TCSpecDetail:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  height: 19px;
  background: url(images/icon-check.png) center top/contain no-repeat;
}

.TCIPrice {
  background-position: left;
  margin: auto 25px 0;
}

.TCTotal {
  color: #6e5e54;
  font-size: 1.125rem;
  letter-spacing: 0.12em;
}

.TCTPrice {
  font-size: 1.25rem;
  letter-spacing: 0.1em;
  margin-left: 8px;
}

.TCTAmount {
  font-size: 2.25rem;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-left: 3px;
}

/*1ケース目*/
.leftIn01 {
  animation: leftIn 0.6s ease-in-out;
}

#TCI01 .TCCase, #TCI01 .TCCNum {
  color: #00DE12;
}

#TCI01 .TCCCatch {
  color: #00DE12;
}

#TCI01 span.TCTPrice {
  color: #00DE12;
}

/*2ケース目*/
#TCI02 .TCCase, #TCI02 .TCCNum {
  color: #00D8F5;
}

#TCI02 .TCCCatch {
  color: #00D8F5;
}

#TCI02 span.TCTPrice {
  color: #00D8F5;
}

/*3ケース目*/
.leftIn02, .NNCurrent:before {
  animation: leftIn 0.8s ease-in-out;
}

.TCLItem:nth-of-type(3):before {
  left: 0;
}

.rightIn02 {
  animation: rightIn 0.8s ease-in-out;
}

#TCI03 .TCCase, #TCI03 .TCCNum {
  color: #FF4800;
}

#TCI03 .TCCCatch {
  color: #FF4800;
}

#TCI03 span.TCTPrice {
  color: #FF4800;
}

/*4ケース目*/
.leftIn02, .NNCurrent:before {
  animation: leftIn 0.8s ease-in-out;
}

.TCLItem:nth-of-type(3):before {
  left: 0;
}

.rightIn02 {
  animation: rightIn 0.8s ease-in-out;
}

#TCI04 .TCCase, #TCI04 .TCCNum {
  color: #1200DE;
}

#TCI04 .TCCCatch {
  color: #1200DE;
}

#TCI04 span.TCTPrice {
  color: #1200DE;
}

/*価格帯の分布*/
#priceDistribution {
  max-width: 1200px;
  margin: 20px auto 0;
  padding-top: 60px;
  border-top: 1px solid #ddd;
}

/*円グラフ*/
#PDGraph {
  width: 400px;
  height: 400px;
  padding: 0 0 0 60px;
  position: relative;
}

.PDGraph-pie {
  position: absolute;
  top: 0px;
}

.PDGraph-letter {
  position: absolute;
  top: 2px;
  left: 77px;
  z-index: 1;
}

/*
.PDCircle {
	display: inline-block;
	transform: rotate(-90deg);
	-webkit-border-radius: 50%;
	border-radius: 50%;
}
.PDCircle .PDType {
	fill: transparent;
	stroke-width: 400;
}
.PDTypeA6 {
	-webkit-animation: circleA6 1s forwards;
	animation: circleA6 1s forwards;
}
.PDCircle .PDType6 {
	stroke: #005565;
}
.PDTypeA5 {
	-webkit-animation: circleA5 1s forwards;
	animation: circleA5 1s forwards;
}
.PDCircle .PDType5 {
	stroke: #007289;
}
.PDTypeA4 {
	-webkit-animation: circleA4 1s forwards;
	animation: circleA4 1s forwards;
}
.PDCircle .PDType4 {
	stroke: #0088a7;
}
.PDTypeA3 {
	-webkit-animation: circleA3 1s forwards;
	animation: circleA3 1s forwards;
}
.PDCircle .PDType3 {
	stroke: #00a2c5;
}
.PDTypeA2 {
	-webkit-animation: circleA2 1s forwards;
	animation: circleA2 1s forwards;
}
.PDCircle .PDType2 {
	stroke: #27b2d2;
}
.PDTypeA1 {
	-webkit-animation: circleA1 1s forwards;
	animation: circleA1 1s forwards;
}
.PDCircle .PDType1 {
	stroke: #4ec2dd;
}
#PDGraphInfo {
	font-size: 1rem;
	letter-spacing: .1em;
	margin: 0;
	padding: 0;
}
.PDDt {
	position: absolute;
	margin: 0;
}
.PDDD {
	position: absolute;
	color: #fff;
	margin: 0;
}
.PDDNum {
	font-size: 1.25rem;
	letter-spacing: .08em;
	margin-right: 2px;
}
.fadeUp02 {
	-webkit-animation: fadeUp .9s ease-in-out;
	animation: fadeUp .9s ease-in-out;
}
#PDT01 {
	top: -2px;
	left: 275px;
}
#PDT01:before, #PDT05:before, #PDT06:before {
	content: "";
	position: absolute;
	background: #bbb;
	width: 2px;
	height: 15px;
	display: block;
}
#PDT01:before {
	bottom: -22px;
	left: 40%;
	transform: rotate(18deg);
}
#PDD01 {
	top: 81px;
	left: 282px;
}
#PDT02, #PDT03, #PDT04 {
	color: #fff;
}
#PDT02 {
	top: 177px;
	left: 328px;
}
#PDD02 {
	top: 202px;
	left: 356px;
}
#PDT03 {
	top: 316px;
	left: 204px;
}
#PDD03 {
	top: 341px;
	left: 230px;
}
#PDT04 {
	top: 190px;
	left: 95px;
}
#PDD04 {
	top: 215px;
	left: 122px;
}
#PDT05 {
	top: 30px;
	left: 40px;
}
#PDT05:before {
	bottom: -18px;
	right: 0;
	transform: rotate(-40deg);
}
#PDD05 {
	top: 95px;
	left: 166px;
}
#PDT06 {
	top: -5px;
	left: 145px;
}
#PDT06:before {
	bottom: -22px;
	left: 78%;
	transform: rotate(-10deg);
}
#PDD06 {
	top: 74px;
	left: 223px;
}
*/
/*分布説明*/
#PDistributInfo {
  width: 50%;
}

#PDIST {
  display: block;
  color: black;
  font-size: 1.875rem;
  letter-spacing: 0.1em;
  margin: 0;
}

#spPDIST {
  display: none;
}

#PDICopy {
  margin: 40px 0 0;
}

#TCostBT {
  width: 400px;
  margin: 40px 0 0;
}

.linkBT01 {
  font-size: 1.125rem;
  text-align: center;
  letter-spacing: 0.1em;
  margin: 0 auto;
  position: relative;
}

.linkBT01 a {
  color: #333;
  text-decoration: none;
  padding: 20px 0 22px;
  display: inline-block;
  cursor: pointer;
  display: block;
  position: relative;
  overflow: visible;
  z-index: 1;
  transition: all 0.5s cubic-bezier(0.075, 0.82, 0.165, 1) 0.1s;
}

/*
.linkBT01 a:hover {
	color: #000;
	background: #ffe900;
	transition: .5s;
}*/
.linkBT01 a::before {
  background: #fff;
  border: 1px solid #bbb;
  z-index: -2;
}

.linkBT01 a::before, .linkBT01 a::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  display: block;
  transition: all 0.5s cubic-bezier(0.075, 0.82, 0.165, 1) 0.1s;
}

.linkBT01 a:after {
  transform: scaleX(0);
  transform-origin: left top;
  background: #777;
  border: 1px solid #777;
  z-index: -1;
}

.linkSign01 {
  position: absolute;
  top: 50%;
  background: #444;
  width: 50px;
  height: 1px;
  transition: inherit;
  pointer-events: none;
  right: -25px;
}

.linkSign01::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  transition: inherit;
  border-top: 2px solid transparent;
  border-right: 5px solid transparent;
  border-left: 3px solid #555;
  border-bottom: 4px solid #555;
}

/*サービス料金一覧*/
.BGGrayF7 {
  background: #f4f4f4;
}

#variousServicePrice:before {
  animation: rightLongIn 1.2s cubic-bezier(0.075, 0.82, 0.165, 1);
  transform-origin: right top;
  background-image: url(../common_im/line-w.png);
  height: 82px;
  opacity: 1;
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  opacity: 0.8;
  background: url(../common_im/line02.png) repeat 0 0/6px 6px;
  width: 50%;
  height: 140px;
  display: block;
}

#variousPInfo {
  color: #555;
  letter-spacing: 0.1em;
  margin: 40px 0 0 140px;
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.7);
}

.texCaut {
  color: #dd2e00;
}

/*料金表*/
.priceList {
  margin: 20px auto 0;
  max-width: 1200px;
}

.priceCatST {
  color: black;
  font-size: 1.625rem;
  letter-spacing: 0.1em;
  margin: 50px 0 0;
  padding-top: 40px;
  border-top: 2px solid #e9e9e9;
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.7);
}

.priceCatST .PCatSTEN {
  color: #666;
  font-size: 0.875rem;
  font-style: normal;
  margin-top: 12px;
  display: block;
}

.PCCaut {
  font-size: 0.9375rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  margin: 20px 0 0;
}

.texCaut {
  color: #dd2e00;
}

.priceTable {
  width: 100%;
  margin-top: 35px;
  border: none;
  border-collapse: collapse;
}

.priceTable th, .priceTable td {
  font-size: 0.9375rem;
  line-height: 1.6;
  letter-spacing: 0.06em;
  padding: 2%;
  border: 1px solid #ddd;
}

.priceTable th {
  color: #555;
  background: #fff;
  text-align: left;
  width: 28%;
  vertical-align: top;
}

.priceTable td {
  background: #fcfcfa;
  min-width: 150px;
}

.PTSM {
  font-size: 0.875rem;
  font-weight: normal;
  margin-top: 8px;
  display: block;
}

.SPCaution {
  color: #d22e00;
  margin-top: 12px;
  display: block;
}

/*管理・保守・運用*/
.planBox {
  width: 100%;
  height: 100%;
  background-color: #e6e6e6;
  padding: 20px;
  margin-top: 20px;
}

.planBox.neew {
  display: flex;
  justify-content: space-between;
}

.plan_box03 {
  width: 100%;
}

.plan_box03 div p.planBoxHeading {
  width: 100%;
  background-color: black;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 14px;
  padding: 15px;
  margin: 0;
}

.planTextBox {
  font-size: 18px;
  text-align: center;
  padding: 15px 5px;
  line-height: 1;
  background-color: #fff;
  margin: 0 auto;
  border: 0.5px #e0e0e0 solid;
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 0;
}

span.plan_largeLetter {
  font-size: 36px;
  padding: 2px;
  line-height: 1;
  font-weight: bold;
}

.service-contents {
  color: #888;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  margin: 18px 0 0;
  font-weight: bold;
}

.management_textbox02 {
  font-size: 14px;
  display: flex;
  justify-content: center;
}

.management_textbox02 div {
  width: 100%;
}

.planCheckMark {
  padding-left: 20px;
  margin: 0;
}

.planCheckMark > li {
  padding-left: 1em;
  text-indent: -1em;
}

.planCheckMark > li:before {
  content: "";
  display: inline-block;
  width: 13px;
  height: 13px;
  background: url(images/icon-check.png) center top/contain no-repeat;
  margin-right: 10px;
  vertical-align: baseline;
}

.managementNote {
  width: 100%;
  margin: 0 auto;
  padding-top: 20px;
}

.managementNote p {
  margin: 0;
}

p.managementNote_1st {
  font-size: 14px;
  margin-bottom: 10px;
}

/*お気軽にお問い合わせください*/
#botContactInfo {
  background: #f4f4f4;
  padding: 70px 0;
}

#botContactInfo #variousPrice {
  margin-bottom: 0;
  margin-top: 0;
}

.STSub.STSBlue:before, .STSPro:before, .BCBlue:before {
  background: #30a2d2;
}

.STSub:before, .TSEN:before, .BISEn:before, #BotCIList .BIST:before {
  content: "";
  position: absolute;
  top: 9px;
  left: -20px;
  width: 10px;
  height: 4px;
  display: block;
}

#BotCIList {
  margin-top: 30px;
}

.TBItem, #TBTel, #BCITel, .BCItem {
  color: #333;
  text-decoration: none;
  width: calc(33.315% - 101px);
  margin: 0;
  padding: 40px 45px 40px 55px;
  border-right: 1px solid #ddd;
  display: block;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

#BCITel, .BCItem {
  width: 33.3%;
  padding: 40px 40px 40px 45px;
}

.BIST {
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  margin: 0;
  position: relative;
}

.BIST {
  transition: all 0.2s ease 0.2s;
}

.STSub.STSBlue:before, .STSPro:before, .BCBlue:before {
  background: #30a2d2;
}

#BotCIList .BIST:before {
  top: 12px;
}

/*電話*/
#BCITel {
  background: #fff;
  padding-bottom: 0;
}

#BCITel:hover {
  color: #e53900;
}

#TBTelNum {
  font-size: 16px;
  margin-bottom: 0;
}

#TBTelNum, #TBTelNum a, #TBTelNum a:before {
  transition: all 0.15s ease-in-out 0.1s;
}

#TBTelNum a {
  color: #00a2c7;
  text-decoration: none;
  padding-left: 1.5em;
  position: relative;
  display: flex;
  align-items: center;
}

#TBTelNum a:before {
  content: "";
  position: absolute;
  left: 0;
  display: block;
  background: url(images/blue-icon-tel.png) center top/contain no-repeat;
  width: 1em;
  height: 1em;
}

.BICopy,
.advantage .BICopy {
  font-size: 0.875rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  margin: 18px 0 0;
}

#BCITel .BICopy {
  margin-top: 6px;
}

.TBIcon {
  position: absolute;
  bottom: 30px;
  right: 30px;
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
}

.TBIcon {
  margin-bottom: -5px;
}

.TBIcon-tel {
  background: url(images/gray-icon-tel.png);
  background-size: contain;
  background-repeat: no-repeat;
}

.TBIcon-mail {
  background: url(images/gray-icon-mail.png);
  background-size: contain;
  background-repeat: no-repeat;
}

.TBIcon-flow {
  background: url(images/gray-icon-flow.png);
  background-size: contain;
  background-repeat: no-repeat;
}

#TBTel .TBIcon, #BCITel .TBIcon {
  background-position: 0 0;
  width: 36px;
  height: 36px;
}

#BCITel .BICopy {
  margin-top: 0;
}

/*Webホームで*/
.TBItem:before, .TBItem:after, .BCItem:before, .BCItem:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  display: block;
}

.TBItem:before, .BCItem:before {
  z-index: -2;
}

.BCItem:before {
  background: #fff;
  width: 100%;
}

.STSContact:before, .BCForm:before {
  background: #c59;
}

.TLSign, .PLSign, .TSSign, .TBMore, .RLBISign, .QASign {
  background: #444;
  vertical-align: 5px;
  display: inline-block;
  position: relative;
  width: 36px;
  height: 1px;
  margin: -15px 0 0 20px;
  transition: inherit;
  pointer-events: none;
}

.TBMore {
  margin-left: 15px;
  vertical-align: 3px;
}

.TBMore:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  transition: inherit;
  border-top: 2px solid transparent;
  border-right: 5px solid transparent;
  border-left: 3px solid #555;
  border-bottom: 4px solid #555;
}

#TBForm .TBIcon, #BCForm .TBIcon {
  background-position: 0 0;
  width: 40px;
  height: 30px;
  bottom: 33px;
}

.TBItem:before, .TBItem:after, .BCItem:before, .BCItem:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  display: block;
}

.TBItem:after, .BCItem:after {
  background: #ae6e82;
  width: 0;
  z-index: -1;
}

.BCItem:after {
  transition: all 0.5s cubic-bezier(0.075, 0.82, 0.165, 1) 0.1s;
}

/*サービスの流れ*/
.STSFollow:before, .BCFollow:before {
  background: #30993e;
}

.leftIn02, .NNCurrent:before {
  animation: leftIn 0.8s ease-in-out;
}

#TBFlow .TBIcon {
  background-position: 0 0;
  width: 40px;
  height: 24px;
  bottom: 33px;
}

/*jQueryスライドインクラス----------------*/
/*下から*/
.slidein-top {
  transform: translateY(50px);
  opacity: 0;
  visibility: hidden;
  transition: transform 1s, opacity 1s, visibility 1s;
}

.slidein-top.js_active-top {
  transform: translateY(0px);
  opacity: 1;
  visibility: visible;
}

/*左へ*/
.slidein-left {
  transform: translateX(50px);
  opacity: 0;
  visibility: hidden;
  transition: transform 1s, opacity 1s, visibility 1s;
}

.slidein-left.js_active-left {
  transform: translateX(0px);
  opacity: 1;
  visibility: visible;
}

/*右へ*/
.slidein-right {
  transform: translateX(-50px);
  opacity: 0;
  visibility: hidden;
  transition: transform 1s, opacity 1s, visibility 1s;
}

.slidein-right.js_active-right {
  transform: translateX(0px);
  opacity: 1;
  visibility: visible;
}

/*回転*/
.slidein-rotate {
  transform: rotate(-180deg);
  opacity: 0;
  visibility: hidden;
  transition: transform 1s, opacity 1s, visibility 1s;
}

.slidein-rotate.js_active-rotate {
  transform: rotate(0deg);
  opacity: 1;
  visibility: visible;
}

/*時間差*/
.transition-delay-1s {
  transition-delay: 1s;
}

.transition-delay-2s {
  transition-delay: 2s;
}

@media screen and (max-width: 1023px) {
  .price-main .inner {
    margin: 0 auto;
  }
  .price-philosophy-area {
    padding-top: 40px;
    position: relative;
  }
  .price-philosophy-subttl {
    padding-left: 45px;
    margin: 0;
    padding: 0 20px 0 30px;
    position: relative;
  }
  .STSub {
    font-size: 0.8125rem;
    letter-spacing: 0.15em;
    position: relative;
    display: block;
    margin-left: 20px;
  }
  #price-philosophy-ttl {
    font-size: 1.875rem;
    padding-top: 5px;
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0.085em;
    margin: 25px 0 0;
  }
  .price-philosophy-flex {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 50px 0 0;
  }
  .PCatcInfo, .HCopyCenter {
    font-size: 0.9375rem;
    line-height: 2;
    letter-spacing: 0.075em;
    margin: 25px 0 0;
    padding: 0 20px;
  }
  #priceCInfo {
    width: 90%;
  }
  .cost-cut-img {
    width: 70%;
    max-width: 300px;
    -o-object-fit: contain;
       object-fit: contain;
  }
  #botContactInfo {
    padding: 50px 0;
  }
  /*料金ページナビゲーション*/
  .PNBeige {
    background: #eceae7;
  }
  .pageNav {
    margin: 0 10px 10px;
    padding: 5px;
    position: relative;
  }
  .PNList {
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: space-between;
    flex-flow: row wrap;
    height: auto;
  }
  #pricePN li {
    width: calc(33.3% - 3px);
  }
  .PNList li:first-of-type {
    margin: 0;
  }
  #pricePN li:nth-of-type(2) {
    margin: 0;
  }
  #pricePN li:nth-of-type(3) {
    margin: 0;
  }
  .PNList a {
    color: #555;
    background: #fff;
    font-size: 0.875rem;
    letter-spacing: 0.08em;
    padding: 10px 0 15px;
    position: relative;
    z-index: 1;
    transition: all 0.15s ease-in-out 0.1s;
    text-decoration: none;
    display: block;
    cursor: pointer;
    overflow: hidden;
    height: auto;
  }
  .PNList a::before {
    content: "";
    position: absolute;
    bottom: 5px;
    left: 50%;
    width: 0;
    height: 0;
    margin-left: -4px;
    border-style: solid;
    border-width: 6px 4px 0 4px;
    border-color: #aea299 transparent transparent transparent;
    transition: all 0.15s ease-in-out 0.1s;
  }
  /*サービス範囲*/
  .secWrapp {
    padding: 50px 0 40px;
  }
  .secST, .secJST {
    margin: 0;
    position: relative;
  }
  .PSTJP {
    color: black;
    line-height: 1.6;
    letter-spacing: 0.08em;
    margin-top: 15px;
    display: block;
  }
  #PPriceCopy {
    width: auto;
  }
  .HCopyCenter {
    padding-left: 5%;
    padding-right: 5%;
    text-align: center;
    font-size: 0.9375rem;
    line-height: 2;
    letter-spacing: 0.075em;
    margin: 25px 0 0;
    padding: 0 20px;
  }
  .copyIBlock {
    text-align: left;
    display: inline-block;
  }
  #priceItem {
    width: auto;
    margin-top: 30px;
  }
  .flexC {
    display: flex;
    justify-content: space-between;
    flex-flow: row wrap;
  }
  #priceItemImage {
    width: 80%;
    max-width: 400px;
    margin: 0 auto;
    max-width: 360px;
  }
  #priceItemList {
    width: auto;
    margin: 20px auto 0;
    padding: 0 20px;
    margin-top: 10px;
    padding: 0 0 0 30px;
  }
  #priceItemList > li {
    color: #705e54;
    font-size: 0.9375rem;
    line-height: 1.25;
    letter-spacing: 0.15em;
    margin: 12px 0 0;
  }
  /*総費用目安*/
  .secWrappLined {
    padding: 50px 0 40px;
    border-top: 1px solid #ddd;
  }
  #totalCost {
    position: relative;
    padding-bottom: 0;
  }
  #totalCostContainer, #variousPInfo, .priceList {
    padding: 0 0;
  }
  #totalCostContainer {
    margin: 0;
    padding: 0 0;
    overflow: hidden;
  }
  .bg-example {
    top: -20px;
    right: 70px;
    width: 240px;
    height: 118px;
    padding: 0;
  }
  #totalCImfo {
    margin: 20px 0 0;
    width: calc(100% - 280px);
    min-height: 120px;
  }
  .CTLeft16 {
    font-size: 0.9375rem;
    line-height: 2;
    letter-spacing: 0.075em;
  }
  #TCostList {
    margin: 0 auto;
    width: 75%;
  }
  /*各ケース例*/
  .TCLItem {
    margin-top: 30px;
    position: relative;
    width: 100%;
  }
  /*各ケースタイトル*/
  .TCIName {
    margin: 0;
    position: relative;
    padding: 5px;
  }
  .TCCase {
    letter-spacing: 0.1em;
    font-size: 1.125rem;
  }
  .TCCNum {
    top: 15px;
    font-size: 2.8125rem;
  }
  .TCCCatch {
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-size: 1.375rem;
  }
  .TCIinfo {
    color: #6e5e54;
    font-size: 0.9375rem;
    font-weight: bold;
    line-height: 1.8;
    letter-spacing: 0.06em;
    margin: 20px 0 0;
  }
  .TCSpecification {
    margin: 30px 0 0;
  }
  .TCSpecification > dt {
    color: #888;
    font-size: 1rem;
    letter-spacing: 0.1em;
    margin: 0 0 16px;
  }
  .TCSpecDetail {
    font-size: 0.875rem;
    padding: 0 0 0 18px;
  }
  .TCIPrice {
    background-position: left;
    min-height: 30px;
    margin: 20px 0 0 5px;
  }
  .TCTotal {
    color: #6e5e54;
    font-size: 1rem;
    letter-spacing: 0.08em;
  }
  .TCTPrice {
    font-size: 0.875rem;
    letter-spacing: 0.1em;
    margin-left: 6px;
  }
  .TCTAmount {
    font-size: 1.875rem;
    font-style: normal;
    letter-spacing: 0.025em;
    margin-left: 2px;
  }
  /*1ケース目*/
  .TCLItem:nth-of-type(1), .TCLItem:nth-of-type(3) {
    padding-right: 0;
  }
  .leftIn01 {
    animation: leftIn 0.6s ease-in-out;
  }
  #TCI01 .TCCNum {
    letter-spacing: 0;
  }
  /*2ケース目*/
  .TCLItem:nth-of-type(2), .TCLItem:nth-of-type(4) {
    padding-left: 0;
  }
  .rightIn01 {
    animation: rightIn 0.6s ease-in-out;
  }
  /*3ケース目*/
  .TCLItem:nth-of-type(3), .TCLItem:nth-of-type(4) {
    margin-top: 0px;
  }
  .leftIn02, .NNCurrent:before {
    animation: leftIn 0.8s ease-in-out;
  }
  .TCLItem:nth-of-type(3):before, .TCLItem:nth-of-type(4):before {
    content: "";
    position: absolute;
    top: -40px;
    background: #ddd;
    height: 0px;
  }
  /*4ケース目*/
  .TCLItem:nth-of-type(3), .TCLItem:nth-of-type(4) {
    margin-top: 0px;
  }
  .leftIn02, .NNCurrent:before {
    animation: leftIn 0.8s ease-in-out;
  }
  .TCLItem:nth-of-type(3):before, .TCLItem:nth-of-type(4):before {
    content: "";
    position: absolute;
    top: -40px;
    background: #ddd;
    height: 0px;
  }
  /*価格帯の分布*/
  #priceDistribution {
    margin: 40px auto 0;
    padding-top: 40px;
    border-top: 1px solid #ddd;
    display: block;
  }
  #spPDIST {
    display: block;
    color: black;
    letter-spacing: 0.1em;
    margin: 0;
    font-size: 1.625rem;
    text-align: center;
  }
  /*円グラフ*/
  #PDGraph {
    width: 300px;
    height: 300px;
    margin: 70px auto 0;
    padding: 0;
    position: relative;
  }
  .PDGraph-pie {
    position: relative;
    top: 0;
  }
  .PDGraph-letter {
    position: absolute;
    top: 3px;
    left: 40px;
    z-index: 1;
  }
  /*
  .spPDCircle {
     display: inline-block;
     transform: rotate(-90deg);
     -webkit-border-radius: 50%;
     border-radius: 50%;
  }
  .spPDCircle .PDType {
     fill: transparent;
     stroke-width: 300;
  }
  .PDTypeA6 {
     animation: circleA6 1s forwards;
  }
  .spPDCircle .PDType6 {
     stroke: #005565;
  }
  .PDTypeA5 {
     animation: circleA5 1s forwards;
  }
  .spPDCircle .PDType5 {
     stroke: #007289;
  }
  .PDTypeA4 {
     animation: circleA4 1s forwards;
  }
  .spPDCircle .PDType4 {
     stroke: #0088a7;
  }
  .PDTypeA3 {
     animation: circleA3 1s forwards;
  }
  .spPDCircle .PDType3 {
     stroke: #00a2c5;
  }
  .PDTypeA2 {
     animation: circleA2 1s forwards;
  }
  .spPDCircle .PDType2 {
     stroke: #27b2d2;
  }
  .PDTypeA1 {
     animation: circleA1 1s forwards;
  }
  .spPDCircle .PDType1 {
     stroke: #4ec2dd;
  }
  #PDGraphInfo {
     font-size: 0.9375rem;
     letter-spacing: .1em;
     margin: 0;
     padding: 0;
  }
  .PDDt {
     position: absolute;
     margin: 0;
     white-space: nowrap;
  }
  .PDDD {
     position: absolute;
     color: #fff;
     margin: 0;
  }
  .PDDNum {
     font-size: 1.25rem;
     letter-spacing: .08em;
     margin-right: 2px;
  }
  .fadeUp02 {
     -webkit-animation: fadeUp .9s ease-in-out;
     animation: fadeUp .9s ease-in-out;
  }
  #PDT01 {
     top: -25px;
     left: 195px;
  }
  #PDT01:before {
     bottom: -16px;
     left: -5px;
     transform: rotate(20deg);
  }
  #PDT01:before, #PDT05:before, #PDT06:before {
     content: "";
     position: absolute;
     background: #bbb;
     width: 2px;
     height: 15px;
     display: block;
  }
  #PDD01 {
     top: 28px;
     left: 164px;
  }
  #PDT02, #PDT03, #PDT04 {
     color: #fff;
  }
  #PDT02 {
     top: 112px;
     left: 188px;
  }
  #PDD02 {
     top: 135px;
     left: 212px;
  }
  #PDT03 {
     top: 208px;
     left: 95px
  }
  #PDD03 {
     top: 230px;
     left: 120px;
  }
  #PDT04 {
     top: 115px;
     left: 15px;
  }
  #PDD04 {
     top: 135px;
     left: 42px;
  }
  #PDT05 {
     top: -11px;
     left: 0;
  }
  #PDD05 {
     top: 45px;
     left: 75px;
  }
  #PDT06 {
     top: -40px;
     left: 80px;
  }
  #PDD06 {
     top: 28px;
     left: 119px;
  }
  */
  /*分布説明*/
  #PDistributInfo {
    width: auto;
  }
  #PDIST {
    display: none;
  }
  #PDICopy {
    max-width: 640px;
    margin: 25px auto 0;
  }
  #TCostBT {
    width: 280px;
    margin: 25px auto 0;
  }
  #TCostBT a {
    padding: 17px 0 16px;
  }
  .linkBT01 a:before {
    background: #fff;
    border: 1px solid #bbb;
    z-index: -2;
  }
  .linkBT01 a:before, .linkBT01 a:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - 2px);
    height: calc(100% - 2px);
    display: block;
  }
  .linkBT01 a:after {
    transform: scaleX(0);
    transform-origin: left top;
    background: #777;
    border: 1px solid #777;
    z-index: -1;
    transition: all 0.5s cubic-bezier(0.075, 0.82, 0.165, 1) 0.1s;
  }
  #TCostBT a .linkSign01 {
    right: -18px;
    width: 36px;
  }
  /*サービス料金一覧*/
  #variousPInfo {
    margin: 25px 0 0;
    padding: 0 20px;
  }
  /*料金表*/
  .priceList {
    margin: 20px auto 0;
    padding: 0 20px;
  }
  .priceCatST {
    font-size: 1.1875rem;
    line-height: 1.5;
    letter-spacing: 0.1em;
    margin: 40px 0 0;
    padding-top: 30px;
    border-top: 3px solid #e9e9e9;
  }
  .priceCatST .PCatSTEN {
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    margin-top: 8px;
  }
  .PCCaut {
    line-height: 1.6;
  }
  .priceTable {
    margin-top: 25px;
  }
  .priceTable th, .priceTable td {
    font-size: 0.875rem;
  }
  .priceTable th {
    color: #444;
  }
  .PTSM {
    font-size: 0.8125rem;
  }
  .PValue {
    color: #4e7eae;
    font-weight: bold;
  }
  /*管理・保守・運用*/
}
@media screen and (max-width: 768px) {
  /*料金理念*/
  .br-sp {
    display: block;
  }
  .price-philosophy-subttl {
    padding-left: 0;
  }
  #price-philosophy-ttl {
    font-size: 1.7rem;
    padding-top: 5px;
  }
  #priceCInfo {
    width: 100%;
  }
  /*料金ページナビゲーション*/
  #pricePN li {
    width: 100%;
  }
  #pricePN li:nth-of-type(2) {
    margin-top: 5px;
  }
  #pricePN li:nth-of-type(3) {
    margin-top: 5px;
  }
  /*サービス範囲*/
  #PPriceContents .PSTJP, #totalCost .PSTJP {
    font-size: 1.3125rem;
  }
  #priceItemImage {
    width: 80%;
    max-width: 400px;
    margin: 0 auto;
  }
  #priceItemList {
    width: auto;
    margin: 20px auto 0;
    padding: 0 20px;
  }
  /*総費用目安*/
  .bg-example {
    position: relative;
    top: 0;
    right: 0;
    width: 80vw;
    height: 58vw;
    padding: 0;
    margin: 0 auto;
  }
  #totalCImfo {
    margin: 20px 0 0;
    width: 100%;
  }
  #TCostList {
    margin: 0 auto;
    width: 100%;
  }
  /*各ケース例*/
  /*各ケースタイトル*/
  .TCIName {
    padding: 5px;
  }
  .TCCase {
    font-size: 0.9375rem;
    letter-spacing: 0.1em;
  }
  .TCCNum {
    font-size: 2.25rem;
  }
  .TCCCatch {
    font-size: 1.25rem;
    line-height: 1.4;
    letter-spacing: 0.1em;
  }
  .plan-content-box {
    padding: 5px;
  }
  /*1ケース目*/
  /*2ケース目*/
  /*3ケース目*/
  /*4ケース目*/
  /*価格帯の分布*/
  #spPDIST {
    font-size: 1.5rem;
    text-align: left;
  }
  /*円グラフ*/
  /*分布説明*/
  #TCostBT {
    width: 280px;
    margin: 25px auto 0;
  }
  #TCostBT a {
    padding: 17px 0 16px;
  }
  /*サービス料金一覧*/
  #variousPInfo {
    padding: 0;
  }
  /*料金表*/
  .priceList {
    padding: 0;
  }
  .priceTable tr {
    border-bottom: 1px solid #ddd;
  }
  .priceTable th, .priceTable td {
    width: 100%;
    display: block;
    border: none;
  }
  .priceTable th {
    background: #eee;
    padding: 12px 10px;
    border-top: 1px solid #ddd;
  }
  .priceTable td {
    padding: 8px 10px 0;
  }
  .priceTable tr td:first-of-type {
    padding: 12px 10px 0;
  }
  .priceTable tr td:last-of-type {
    padding-bottom: 12px;
  }
  .PTSM {
    margin-top: 2px;
  }
  /*管理・保守・運用*/
  .management_textbox02 {
    flex-direction: column;
  }
  /*お気軽にお問い合わせください*/
  #BotCIList {
    flex-direction: column;
  }
  #BCITel, .BCItem {
    width: 100%;
    padding: 40px 40px 40px 45px;
    margin-bottom: 1px;
  }
  #TBTelNum a:before {
    top: 6px;
  }
}
/* ----------
 * カスタム投稿タイプ（新）制作実績
 * ---------- */
.tax-works_category .content,
.tax-works_tag .content {
  margin: 0;
}

.tax-works_category .wrap,
.tax-works_tag .wrap {
  width: 100%;
}

.tax-works_category .main,
.tax-works_tag .main {
  width: 100%;
  padding: 0;
  margin: 0;
}

.tax-works_category .sidebar,
.tax-works_tag .sidebar {
  display: none;
}

.tax-works_category .archive-title,
.tax-works_tag .archive-title {
  display: none;
}

.tax-works_category h1.port,
.tax-works_tag h1,
.portTitle,
#main__visual .portTitle {
  display: block;
  position: relative;
  font-size: 2.6rem;
  margin-bottom: 0.5em;
  padding-top: 30px;
  padding-bottom: 0.6em;
  font-weight: bold;
  text-align: center;
  line-height: 1.25;
}

.tax-works_category h1.port span,
.tax-works_tag h1.posrt span,
.portTitle span {
  position: absolute;
  left: 50%;
  font-size: 0.9rem;
  content: "";
  top: 100%;
  transform: translate(-50%, -1em);
  width: 100%;
}

#Portfolio .md-ajax-links-tab {
  display: flex;
  justify-content: center;
  align-items: center;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box {
  width: 100%;
  max-width: 1080px;
  padding: 45px 35px 40px 35px;
  background-color: #f4f4f4;
  font-size: 16px;
  display: flex;
  justify-content: space-between;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap {
  width: 47.5%;
  font-weight: 700;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-show-box {
  background-color: white;
  padding: 1.25em 1.5em 1.25em 1.5em;
  cursor: pointer;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-show-box .md-ajax-links-show-btn {
  text-align: center;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list {
  display: flex;
  flex-wrap: wrap;
  background-color: white;
  padding: 1em;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item {
  width: 50%;
  display: flex;
  align-items: center;
  padding: 0.5em 1em;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item a {
  margin-left: 1.25em;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item .md-ajax-links-arrow {
  position: relative;
  margin-right: 0.75em;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item .md-ajax-links-arrow::before, #Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item .md-ajax-links-arrow::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item .md-ajax-links-arrow::before {
  width: 1.8em;
  height: 1.8em;
  min-width: 1.8em;
  min-height: 1.8em;
  background-color: #f4f4f4;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}
#Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item .md-ajax-links-arrow::after {
  background-color: transparent;
  width: 0.5em;
  height: 0.5em;
  border: 2px solid black;
  border-left: none;
  border-bottom: none;
  transform: rotateZ(45deg) translate(-85%, 10%);
}
#Portfolio .portfolio__lead {
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  width: 45em;
  max-width: 100%;
  margin: 2.75em auto;
  padding: 1.2em 1em;
  background-color: #f4f4f4;
}
#Portfolio .portfolio__lead .portfolio__lead-big {
  margin: 0 0.25em;
}
#Portfolio .portfolio__lead .portfolio__lead-appeal {
  font-size: 1.125em;
  color: #fff100;
  font-weight: 700;
  padding: 0.125em 0.45em;
  background-color: black;
}

.tax-works_category #Portfolio .txt,
.tax-works_tag #Portfolio .txt {
  text-align: center;
}

.pagination-next {
  margin: 24px 0 0;
  clear: both;
  text-align: center;
  display: inline-flex;
  justify-content: center;
  width: 100%;
}

/*新制作実績個別*/
.single-works .content {
  margin: 0;
}

.single-works .wrap {
  width: 100%;
}

.single-works .main {
  padding: 0;
}

.single-works .entry-content {
  margin-bottom: 0;
}

.single-works .article h1 {
  display: none;
}

@media screen and (max-width: 768px) {
  .md-ajax-links-tab li {
    line-height: 2;
  }
}
/* 2024.04.01追加 */
#fancybox-overview {
  display: none;
}
#fancybox-overview .inner {
  max-width: 1200px;
  margin: 0px auto;
}
#fancybox-overview .fancybox-overview-content {
  width: 100%;
}
#fancybox-overview .fancybox-overview-content h2 {
  font-size: 18px;
  border-left: 6px solid #fff100;
  padding-left: 0.75em;
  line-height: 1.3;
  margin-bottom: 0.75em;
}
#fancybox-overview .fancybox-overview-content table tbody tr th, #fancybox-overview .fancybox-overview-content table tbody tr td {
  padding: 1em 1.5em;
}
#fancybox-overview .fancybox-overview-content table tbody tr td {
  background-color: white;
}

.more .more-btn {
  display: inline-block;
  width: 100%;
  background-color: black;
  height: 3em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  color: white;
  transition: opacity 0.2s ease;
}
.more .more-btn:hover {
  opacity: 0.75;
}

@media screen and (max-width: 1024px) {
  #Portfolio .md-ajax-links-tab .md-ajax-links-box {
    flex-direction: column;
  }
  #Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap {
    width: 100%;
  }
  #Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item {
    width: 50%;
  }
  #Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap + .md-ajax-links-wrap {
    margin-top: 30px;
  }
}
@media screen and (max-width: 768px) {
  .for-pc {
    display: none;
  }
  #header-container {
    background-color: rgba(255, 255, 255, 0.7);
  }
  .header-container-in.hlt-top-menu .logo-header .site-name-text {
    margin-left: 0;
  }
  .header-container-in.hlt-top-menu .logo-header img {
    padding-left: 0;
    margin: 0 auto;
  }
}
@media screen and (max-width: 480px) {
  .for-sp {
    display: block;
  }
  #Portfolio .md-ajax-links-tab .md-ajax-links-box {
    flex-direction: column;
    padding: 32px 24px 40px 24px;
  }
  #Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list .md-ajax-links-item {
    width: 100%;
  }
  #Portfolio .md-ajax-links-tab .md-ajax-links-box .md-ajax-links-wrap .md-ajax-links-list + .md-ajax-links-wrap {
    margin-top: 24px;
  }
}
@media screen and (max-width: 375px) {
  .for-minisp {
    display: block;
  }
}
/* 2024.04.17追加 */
#message {
  padding-top: 2em;
}
#message .message-box {
  border: black 5px double;
  padding: 1.75em 0;
  margin: 0 auto;
  font-weight: bold;
}
#message .message-box p + p {
  margin-top: 1em;
}
#message .message-box .text-center {
  text-align: center;
}

#main_visual {
  margin-bottom: 0;
}

#review {
  padding: unset;
  margin: unset;
  max-width: unset;
  width: 100%;
}
#review * {
  margin: unset;
  padding: unset;
}
#review .review-head-box .review-head-ttl-box {
  background-color: white;
  border: 2px solid black;
  margin: 0 auto;
  max-width: 480px;
  width: 80%;
  padding: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: translateY(32px);
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-text-box {
  font-size: 24px;
  font-weight: 800;
  text-align: center;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-text-box span {
  display: inline-block;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box {
  display: flex;
  font-size: 20px;
  font-weight: 800;
  align-items: center;
  margin-top: 0.25em;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star {
  position: absolute;
  font-family: "fontAwesome";
  display: flex;
  align-items: center;
  left: 0;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star i {
  font-style: normal;
  margin-right: 0.1em;
  font-size: 1.25em;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star i:last-child {
  margin-right: unset;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star:first-child {
  position: relative;
  color: gray;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star:first-child i {
  transform: scale(0.9);
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star:last-child {
  color: #fbbc04;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-star-box .review-head-ttl-evaluation-star:last-child i:last-child {
  width: 0.85em;
  overflow: hidden;
}
#review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box .review-head-ttl-evaluation-text-box {
  margin-left: 0.75em;
}
#review .review-inner {
  padding: 64px 0;
  background-color: #ffe200;
}
#review .review-inner .review-box {
  max-width: 1440px;
  width: 80%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  position: relative;
}
#review .review-inner .review-box .review-card-area {
  width: 100%;
  overflow: hidden;
  position: relative;
  filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, 0.3));
}
#review .review-inner .review-box .review-card-area .review-card-box {
  width: 100%;
  display: flex;
  align-items: flex-start;
  font-size: 16px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item {
  padding: 0 1em;
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: 20%;
  scroll-snap-align: start;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-card-inner {
  background-color: white;
  border-radius: 8px;
  padding: 1.5em;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-header-box {
  display: flex;
  align-items: center;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-header-box .review-header-img-box {
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  width: 3em;
  min-width: 3em;
  padding-top: 3em;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-header-box .review-header-img-box .review-header-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-header-box .review-header-info-box {
  line-height: 1.5;
  margin-left: 0.75em;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-header-box .review-header-info-box .review-header-info-name-box {
  font-size: 1em;
  font-weight: 800;
  white-space: nowrap;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-header-box .review-header-info-box .review-header-info-date-box {
  font-size: 12px;
  color: #939393;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-star-box {
  font-family: "fontAwesome";
  color: #fbbc04;
  line-height: 1;
  font-size: 1.125em;
  margin: 0.5em 0 0.25em;
  display: flex;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-star-box i {
  font-style: normal;
  margin-right: 0.125em;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-star-box i:last-child {
  margin-right: unset;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-content-box {
  font-size: 0.9375em;
  text-align: justify;
  font-feature-settings: "palt";
  line-height: 1.75;
  position: relative;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-content-box .review-content-text {
  height: 7em;
  overflow: hidden;
  transition: height 0.2s ease;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-content-box::after {
  content: "...";
  display: none;
  position: absolute;
  width: 1em;
  height: 1.75em;
  background-color: white;
  right: 0;
  bottom: 0;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-content-box.excerpt::after {
  display: block;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-more-btn-box {
  font-size: 14px;
  background-color: white;
  color: #939393;
  padding-top: 1.5em;
  padding-bottom: 0.25em;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  visibility: hidden;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-more-btn-box .review-more-btn {
  cursor: pointer;
  position: absolute;
  left: 0;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-more-btn-box .review-more-btn.more {
  display: inline;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-more-btn-box .review-more-btn.back {
  display: inline;
  display: none;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-more-btn-box .review-more-btn.hidden {
  display: none;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-more-btn-box .review-more-btn:hover {
  color: black;
  text-decoration: underline;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item .review-content-box.excerpt + .review-more-btn-box {
  visibility: visible;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item.open .review-content-box::after {
  display: none;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item.open .review-more-btn-box .review-more-btn.more {
  display: none;
}
#review .review-inner .review-box .review-card-area .review-card-box .review-card-item.open .review-more-btn-box .review-more-btn.back {
  display: inline;
}
#review .review-inner .review-box .review-card-area .review-card-box::-webkit-scrollbar {
  display: none;
}
#review .review-inner .review-box .review-btn-box {
  display: flex;
  position: absolute;
  z-index: 100;
  transition: opacity 0.2s ease, visibility 0.2s ease;
  visibility: visible;
}
#review .review-inner .review-box .review-btn-box .preview-btn {
  font-family: "fontAwesome";
  font-size: 48px;
  line-height: 1;
  cursor: pointer;
  color: white;
  transition: transform 0.2s ease;
}
#review .review-inner .review-box .review-btn-box .preview-btn i {
  font-style: normal;
}
#review .review-inner .review-box .review-btn-box .preview-btn:hover {
  transform: scale(1.2);
}
#review .review-inner .review-box .review-btn-box.preview-prev {
  left: -8px;
  transform: translateX(-100%);
}
#review .review-inner .review-box .review-btn-box.preview-next {
  right: -8px;
  transform: translateX(100%);
}
#review .review-inner .review-box .review-btn-box.is-inactive {
  opacity: 0;
  visibility: hidden;
}

#noticed {
  width: 100%;
  max-width: unset;
  margin: 0;
  padding: 90px 0;
  background-color: black;
}
#noticed .inner {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
}
#noticed .noticed__title {
  font-size: 30px;
  font-weight: 700;
  text-align: center;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
#noticed .noticed__title .noticed__title-text {
  background-color: white;
  margin: 0 0 0.75em;
  padding: 0.25em 0.5em;
  position: relative;
  display: inline-block;
}
#noticed .noticed__title .noticed__title-text::before {
  content: "";
  display: inline-block;
  width: 1.111em;
  height: 0.75em;
  background-color: white;
  position: absolute;
  top: calc(100% - 1px);
  left: 50%;
  transform: translateX(-50%);
  -webkit-clip-path: polygon(100% 0, 0 0, 50% 100%);
          clip-path: polygon(100% 0, 0 0, 50% 100%);
}
#noticed .noticed__lead {
  font-size: 36px;
  font-weight: 700;
  text-align: center;
  color: white;
  margin: 1em auto 1.67em;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
#noticed .noticed__lead .noticed__lead-text {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#noticed .noticed__lead .noticed__lead-big {
  font-size: 1.6667em;
  line-height: 1;
  color: #ffe200;
  vertical-align: middle;
  position: relative;
  margin: 0.15em 0.5em 0.05em;
  display: inline-block;
}
#noticed .noticed__lead .noticed__lead-big::before, #noticed .noticed__lead .noticed__lead-big::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 0.574691667em;
  height: 0.574691667em;
  border: 1px solid #ffe200;
}
#noticed .noticed__lead .noticed__lead-big::before {
  top: -0.15em;
  left: -0.125em;
  border-right: unset;
  border-bottom: unset;
}
#noticed .noticed__lead .noticed__lead-big::after {
  bottom: -0.05em;
  right: -0.125em;
  border-top: unset;
  border-left: unset;
}
#noticed .noticed__letter {
  font-size: 20px;
  text-align: center;
  color: white;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer-bottom-flex {
  display: flex;
  align-items: center;
  gap: 1em;
}

.sns-list {
  list-style: none;
  padding: unset;
  margin: unset;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 8px;
}
.sns-list .sns-list-item {
  width: 24px;
  height: 24px;
}
.sns-list .sns-list-item img {
  display: block;
}

.grecaptcha-badge {
  display: none;
}

.text--bold {
  font-weight: 700;
}

@media screen and (max-width: 1500px) {
  #review .review-inner .review-box .review-card-area .review-card-box .review-card-item {
    flex-basis: 25%;
  }
}
@media screen and (max-width: 1240px) {
  #review .review-inner .review-box .review-card-area .review-card-box .review-card-item {
    flex-basis: 33.3333333333%;
  }
}
@media screen and (max-width: 1023px) {
  #noticed .noticed__title {
    font-size: 22.5px;
  }
  #noticed .noticed__lead {
    font-size: 25.2px;
  }
  #noticed .noticed__letter {
    font-size: 18px;
  }
  .footer-bottom-flex {
    gap: 0.75em;
  }
  #footer-in .footer-bottom {
    flex-direction: column;
  }
  .sns-list {
    margin-top: 0;
  }
  .copyright {
    margin-top: unset;
  }
  #Portfolio .portfolio__lead {
    font-size: 16px;
  }
}
@media screen and (max-width: 900px) {
  #review .review-inner .review-box .review-card-area .review-card-box .review-card-item {
    flex-basis: 50%;
  }
}
@media screen and (max-width: 768px) {
  .tax-works_category h1.port,
  .tax-works_tag h1,
  .portTitle,
  #main__visual .portTitle {
    font-size: 2rem;
  }
  .tax-works_category h1.port span,
  .tax-works_tag h1 span,
  .portTitle span,
  #main__visual .portTitle span {
    font-size: 0.6rem;
  }
  #review .review-inner .review-box .review-card-area .review-card-box .review-card-item {
    width: unset;
    min-width: 100%;
    margin-left: unset;
  }
  #review .review-inner .review-box .review-card-area .review-card-box .review-card-item:last-child {
    margin-right: unset;
  }
  #noticed {
    padding: 64px 0;
  }
  #noticed .noticed__lead .noticed__lead-text {
    justify-content: center;
  }
  #noticed .noticed__lead .noticed__lead-text .noticed__lead-text--center {
    width: 100%;
    margin: 0.4em 0;
  }
  #noticed .noticed__letter {
    text-align: justify;
  }
  #noticed .noticed__letter .sp-none {
    display: none;
  }
  #Portfolio .portfolio__lead {
    font-size: 14px;
  }
}
@media screen and (max-width: 666px) {
  #Portfolio ul.product li {
    min-height: unset;
  }
  #Portfolio ul.product li figure.pc_monitor {
    top: 8vw;
    height: 16.7vw;
    -o-object-fit: contain;
       object-fit: contain;
  }
  #Portfolio ul.product li figure.sp_monitor {
    top: 18.9vw;
    height: 11.9vw;
  }
  #Portfolio ul.product li p.poType {
    display: none;
  }
  #Portfolio .txt {
    bottom: -1vw;
  }
}
@media screen and (max-width: 480px) {
  #message {
    padding-top: 1em;
  }
  #message .message-box {
    padding: 0.5em 0;
  }
  #review .review-head-box .review-head-ttl-box {
    padding: 18px;
  }
  #review .review-head-box .review-head-ttl-box .review-head-ttl-text-box {
    font-weight: 800;
  }
  #review .review-head-box .review-head-ttl-box .review-head-ttl-text-box span:not(:first-child) {
    margin-top: 0.375em;
  }
  #review .review-head-box .review-head-ttl-box .review-head-ttl-evaluation-box {
    flex-direction: column;
    justify-content: center;
    font-size: 18px;
  }
  #noticed .noticed__title {
    font-size: 1.25rem;
  }
  #noticed .noticed__lead {
    font-size: 1.4rem;
  }
  #noticed .noticed__letter {
    font-size: 0.8rem;
  }
  #info .info {
    font-size: 1.175rem;
    padding-left: 0;
    padding-right: 0;
  }
  #Portfolio ul.product li figure.sp_monitor {
    height: 10.8vw;
  }
  #Portfolio ul.product li p {
    font-size: 0.8rem;
  }
  #Portfolio .txt {
    bottom: -1.5vw;
  }
}
@media screen and (max-width: 480px) {
  #info .info {
    font-size: 1rem;
  }
}/*# sourceMappingURL=style.css.map */