@charset "utf-8";

/*--------------------------------------
  # page-title
--------------------------------------*/
#pagetitle {
  position: relative;
  overflow: hidden;
}

#pagetitle .pagetitle-wrapper {
  position: absolute;
  z-index: 1;
  bottom: 0;
  left: 0;
  margin-right: 20px;
  padding: 15px 25px 0 15px;
  font-size: min(10vw, 5.4rem);
  background: #FFF;
  line-height: 1.2;
  transition: 0.8s 0.3s transform, 0.8s 0.3s opacity;
}

#pagetitle:not(.scrollin) .pagetitle-wrapper {
  transform: translateX(-100px);
  opacity: 0;
}

#pagetitle .pagetitle-wrapper .en {
  margin-bottom: 0.2em;
  color: var(--main-color);
  font-family: "Outfit", sans-serif;
  font-size: 44.44%;
  font-weight: 500;
}

#pagetitle .pagetitle-wrapper .jp {
  margin: 0 0 -0.04em -0.04em;
  font-weight: 800;
}

#pagetitle .pagetitle-img {
  overflow: hidden;
}

#pagetitle .pagetitle-img img {
  display: block;
  width: 100%;
  height: 160px;
  object-fit: cover;
  transition: 0.8s 0.1s;
}

#pagetitle:not(.scrollin) .pagetitle-img img {
  filter: blur(50px);
  opacity: 0;
}

#pagetitle .pagetitle-img img[src*="features"] {
  object-position: 50% 10%;
}

#pagetitle .pagetitle-img img[src*="service"] {
  object-position: 50% 85%;
}

#pagetitle .pagetitle-img img[src*="labor"] {
  object-position: 50% 25%;
}

#pagetitle .pagetitle-img img[src*="payroll"] {
  object-position: 50% 16%;
}

#pagetitle .pagetitle-img img[src*="rules"] {
  object-position: 50% 15%;
}

#pagetitle .pagetitle-img img[src*="consulting"] {
  object-position: 50% 62%;
}

#pagetitle .pagetitle-img img[src*="workstyle"] {
  object-position: 50% 75%;
}

#pagetitle .pagetitle-img img[src*="audit"] {
  object-position: 50% 88%;
}

#pagetitle .pagetitle-img img[src*="recruit"] {
  object-position: 50% 5%;
}

#pagetitle .pagetitle-img img[src*="news"] {
  object-position: 50% 15%;
}

#pagetitle .pagetitle-img img[src*="contact"] {
  object-position: 50% 15%;
}

@media (min-width: 950px) {
  #pagetitle {
    padding: 110px 40px 0;
    /* padding-top: 110px; */
  }

  #pagetitle .pagetitle-wrapper {
    left: 40px;
    padding: 30px 65px 0 0;
  }

  #pagetitle .pagetitle-wrapper .en {}

  #pagetitle .pagetitle-img {}

  #pagetitle .pagetitle-img img {
    height: 390px;
  }
}

/*--------------------------------------
  # breadcrumbs
--------------------------------------*/
#breadcrumbs {
  padding: 20px 15px;
  font-size: 1.2rem;
  line-height: 1.2;
  overflow: hidden;
  overflow-x: auto;
}

#breadcrumbs ol {
  display: flex;
}

#breadcrumbs li {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

#breadcrumbs li:first-child:before {
  content: "\f015";
  margin: 0 0.3em -0.09em 1px;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  opacity: 0.6;
}

#breadcrumbs li:not(:first-child):before {
  content: '>';
  margin: 0 5px;
  opacity: 0.6;
}

#breadcrumbs li a {}

@media (min-width: 950px) {
  #breadcrumbs {
    margin: 20px 40px 40px;
    padding: 20px 0;
    font-size: 1.3rem;
  }

  #breadcrumbs li:not(:first-child):before {
    margin: 0 7px;
  }
}

/*--------------------------------------
  # main
--------------------------------------*/

#main {}

#main .contact {
  margin-top: 30px;
}

#main .local-nav+.contact {
  margin-top: 0;
}

@media (min-width: 950px) {
  #main {
    padding-bottom: 50px;
  }

  #main .contact {
    margin-top: 60px;
  }
}

/*--------------------------------------
  # layout
--------------------------------------*/

.column-layout {
  overflow: hidden;
}

.column-layout .column-layout-main {}

.column-layout .column-layout-sub {
  padding: 25px 25px 0;
}

/* column-layout-sub-item */

.column-layout-sub-item {
  margin-bottom: 20px;
}

.column-layout-sub-item .column-layout-sub-item-ttl {
  padding: 6px 10px;
  color: #FFF;
  font-weight: 600;
  background: var(--accent-color);
}

.column-layout-sub-item .column-layout-sub-item-body {
  clear: both;
  padding: 10px 15px;
  background: var(--bg-color);
  overflow: hidden;
}

.column-layout-sub-item .column-layout-sub-item-body ul {}

.column-layout-sub-item .column-layout-sub-item-body ul li {
  margin: 8px 0;
}

.column-layout-sub-item .column-layout-sub-item-body ul li a {
  position: relative;
  display: inline-block;
  padding-left: 18px;
  vertical-align: top;
  font-size: 1.6rem;
  line-height: 1.6;
}

.column-layout-sub-item .column-layout-sub-item-body ul li a:before {
  content: '';
  position: absolute;
  top: 0.8em;
  left: 6px;
  width: 0;
  height: 0;
  margin-top: -3px;
  border: 3px solid transparent;
  border-left: 5px solid;
}

.column-layout-sub-item .column-layout-sub-item-body ul li a:hover {}

@media (min-width: 950px) {
  .column-layout {
    display: flex;
    align-items: flex-start;
    max-width: 1380px;
    margin: 0 auto;
    overflow: visible;
  }

  .column-layout .column-layout-main {
    flex: 1;
  }

  .column-layout .column-layout-sub {
    position: sticky;
    top: 60px;
    width: min(30%, 340px);
    padding: 50px 40px;
  }

  /* column-layout-sub-item */
  .column-layout-sub-item {}

  .column-layout-sub-item .column-layout-sub-item-ttl {}

  .column-layout-sub-item .column-layout-sub-item-body {}

  .column-layout-sub-item .column-layout-sub-item-body ul {}

  .column-layout-sub-item .column-layout-sub-item-body ul li {}

  .column-layout-sub-item .column-layout-sub-item-body ul li a {}

  .column-layout-sub-item .column-layout-sub-item-body ul li a:before {}

  .column-layout-sub-item .column-layout-sub-item-body ul li a:hover {}
}

/*--------------------------------------
  # node
--------------------------------------*/

.node {
  padding: 25px 0;
  transition: 0.8s 0.1s;
}

.node:not(.scrollin) {
  transform: translateY(150px);
  opacity: 0;
}

.node:first-child {}

.node .node-wrapper {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 20px;
}

.node .node-wrapper>*:last-child {
  margin-bottom: 0;
}

/* title */
.node h2 {
  position: relative;
  margin-bottom: 20px;
  padding-bottom: 8px;
  /* color: #5d5d5d; */
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.2;
  opacity: 0.7;
}

.node h2:first-child {
  margin-top: 0;
}

.node h2:after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: #CCC;
}

.node h2.green {
  color: #4a8913;
}

.node h2.green:after {
  background: #9cc974;
  background: linear-gradient(90deg, #9cc974 1%, #b5e38c 20%, #9cc974 80%, #b5e18d 100%);
}

.node h3 {
  margin: 1.6em 0 0.6em;
  font-size: 120%;
  padding: 8px 10px 8px;
  color: #FFF;
  background: #b0905c;
  line-height: 1.2;
}

.node h3:first-child {
  margin-top: 0;
}

.node h4 {
  margin: 1em 0;
  padding-bottom: 0.25em;
  font-size: 110%;
  border-bottom: 1px solid #CCC;
  line-height: 1.6;
}

.node h5 {}

@media (min-width: 950px) {
  .node {
    padding: 50px 0;
  }

  .node .node-wrapper {
    padding: 0 40px;
  }

  /* title */
  .node h2 {
    margin-bottom: 30px;
    padding-bottom: 15px;
    font-size: 3.6rem;
  }

  .node h2:after {}

  .node h3 {
    font-size: 150%;
  }

  .node h4 {
    font-size: 128%;
  }

  .node h5 {}
}

/*--------------------------------------
  # contents-nav
--------------------------------------*/

.contents-nav {}

.contents-nav ol {
  display: flex;
  flex-wrap: wrap;
  margin: -5px;
}

.contents-nav ol li {
  width: 50%;
  padding: 5px;
}

.contents-nav ol li a {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 7px 25px 7px 10px;
  color: #FFF;
  font-size: 94%;
  font-weight: 700;
  background: linear-gradient(90deg, var(--black-color) 50%, var(--accent-color) 50%);
  background-size: 210%;
  background-position: 99%;
  border-radius: 5px;
  text-decoration: none;
  line-height: 1.3;
}

.contents-nav ol li a.current {
  filter: grayscale(1) opacity(0.5);
  pointer-events: none;
}

.contents-nav ol li a:before {
  content: '';
  position: absolute;
  top: 50%;
  right: 5px;
  width: 7px;
  height: 7px;
  border-top: 2px solid;
  border-right: 2px solid;
  opacity: 0.8;
  transform: translate(-50%, -50%) rotate(45deg);
}

.contents-nav ol li a:hover {}

@media (min-width: 950px) {
  .contents-nav {}

  .contents-nav ol {
    margin: -10px;
  }

  .contents-nav ol li {
    width: 33.33%;
    padding: 10px;
  }

  .contents-nav ol li a {
    padding: 20px 30px 20px 15px;
    font-size: 100%;
    /* background: linear-gradient(90deg, var(--black-color) 50%, var(--accent-color) 50%); */
    /* background-size: 210%; */
    /* background-position: 99%; */
    transition: 0.2s;
  }

  .contents-nav ol li a:hover {
    background-position: 1%;
  }

  .contents-nav ol li a:before {
    right: 8px;
    width: 9px;
    height: 9px;
    transition: 0.2s;
  }

  .contents-nav ol li a:hover:before {
    right: 18px;
  }

  .contents-nav ol li a:hover {}
}

/*--------------------------------------
  # NEWS
--------------------------------------*/

.news-item-wrapper {}

.news-item-wrapper .news-item {
  margin-bottom: 40px;
}

.news-item-wrapper .news-item>a {
  text-decoration: none;
}

.news-item-wrapper .news-item .news-item-img {
  position: relative;
  height: 0;
  margin-bottom: 15px;
  padding-top: 60%;
  overflow: hidden;
}

.news-item-wrapper .news-item .news-item-img:after {
  content: '';
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid rgb(102 102 102 / 20%);
}

.news-item-wrapper .news-item .news-item-img .new {
  position: absolute;
  z-index: 3;
  top: 0;
  left: 0;
  display: block;
  width: 6em;
  padding: 15px 0 4px;
  color: #FFF;
  font-size: 1.1rem;
  font-weight: 500;
  background: #ff6052;
  text-align: center;
  line-height: 1.2;
  transform-origin: 50% 0;
  transform: translateX(-50%) rotate(-45deg);
}

.news-item-wrapper .news-item .news-item-img img {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-item-wrapper .news-item .news-item-date-cat {
  display: flex;
  align-items: baseline;
  margin-bottom: 0.5em;
  color: #999;
  font-size: 88%;
  line-height: 1.2;
}

.news-item-wrapper .news-item .news-item-date-cat a {
  display: block;
  margin-left: 10px;
  padding: 3px 8px;
  color: #FFF;
  font-size: 88%;
  border-radius: 3px;
  text-decoration: none;
}

.news-item-wrapper .news-item .news-item-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  margin-bottom: 5px;
  font-weight: bold;
}

.news-item-wrapper .news-item .news-item-body {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 4;
  font-size: 90%;
}

.news-header {
  clear: both;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 20px;
}

.news-header .title {
  width: 100%;
  font-size: 1.8rem;
  margin-bottom: 8px;
  padding-bottom: 10px;
  border-bottom: 1px solid #CCC;
  line-height: 1.5;
}

.news-header .date-cat {
  display: flex;
  align-items: baseline;
  margin-bottom: 8px;
  color: #999;
  font-size: 88%;
  line-height: 1.2;
}

.news-header .date-cat a {
  display: block;
  padding: 3px 8px;
  color: #FFF;
  font-size: 88%;
  border-radius: 3px;
  text-decoration: none;
}

.news-header #seo-share {
  margin: 0 0 8px auto;
}

@media (min-width: 950px) {
  .news-item-wrapper {}

  .news-item-wrapper .news-item {
    display: grid;
    grid-template-columns: 35% 40px auto;
    padding-bottom: 40px;
    border-bottom: 1px dotted #CCC;
  }

  .news-item-wrapper .news-item>a {
    grid-column: 3 / 4;
  }

  .news-item-wrapper .news-item>a:first-child {
    grid-column: 1 / 2;
    grid-row: 1 / 4;
  }

  .news-item-wrapper .news-item .news-item-img {
    margin-bottom: 0;
  }

  .news-item-wrapper .news-item .new {}

  .news-item-wrapper .news-item .news-item-img img {}

  .news-item-wrapper .news-item .news-item-date-cat {
    grid-column: 3 / 4;
  }

  .news-item-wrapper .news-item .news-item-title {
    margin-bottom: 10px;
  }

  .news-item-wrapper .news-item .news-item-body {}

  .news-header {
    margin-bottom: 40px;
  }

  .news-header .title {
    font-size: 2.2rem;
  }

  .news-header .date-cat {
    margin-bottom: 0;
  }

  .news-header .date-cat a {}

  .news-header .date-cat a:hover {}

  .news-header #seo-share {
    margin: 0 0 0 auto;
  }
}

/* pager */

.pager {
  margin: 0;
  line-height: 1.2;
}

.pager ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.pager li {
  margin: 4px;
}

.pager span,
.pager a {
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 1.5em;
  padding: 4px;
  text-align: center;
}

.pager .current {
  color: #999;
}

.pager .prev,
.pager .next {
  width: 2em;
  height: 2em;
  color: #FFF;
  background: var(--main-color);
  text-decoration: none;
}

/* post-nav */

.post-nav {
  clear: both;
  margin: 40px -25px 20px;
  border-top: 1px solid #CCC;
  line-height: 1.2;
}

.post-nav .prev,
.post-nav .next {
  border-bottom: 1px solid #CCC;
}

.post-nav a {
  position: relative;
  display: block;
  padding: 15px 0;
  font-size: 94%;
}

.post-nav a:before {
  content: '';
  position: absolute;
  top: 50%;
  width: 8px;
  height: 8px;
  transform: translateY(-50%) rotate(-45deg);
  opacity: 0.6;
}

.post-nav .prev a {
  padding-left: 25px;
}

.post-nav .prev a:before {
  left: 8px;
  border-top: 1px solid;
  border-left: 1px solid;
}

.post-nav .next a {
  padding-right: 25px;
  text-align: right;
}

.post-nav .next a:before {
  right: 8px;
  border-right: 1px solid;
  border-bottom: 1px solid;
}

@media (min-width: 950px) {

  .post-nav {
    display: flex;
    margin: 40px 0 20px;
  }

  .post-nav .prev,
  .post-nav .next {
    flex: 1;
  }

  .post-nav .next {
    border-left: 1px dotted rgba(0, 0, 0, 0.2);
  }

  .post-nav a {
    padding: 15px;
  }

  .post-nav a:before {}

  .post-nav .prev a {}

  .post-nav .prev a:before {}

  .post-nav .next a {}

  .post-nav .next a:before {}

}


/*--------------------------------------
  # company
--------------------------------------*/


/*--------------------------------------
  # features
--------------------------------------*/

.features-layout {}

.features-layout .features-layout-inner {}

.features-layout .features-layout-img {
  margin: 50px 0;
}

.features-layout .features-layout-img img {
  display: block;
  width: 100%;
  object-fit: cover;
}

.features-list {}

.features-list .features-item {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px dotted #999;
}

.features-list .features-item .features-item-title {}

.features-list .features-item .features-item-icon {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.764em;
  height: 1.764em;
  margin: 0 auto 20px;
  color: #FFF;
  font-size: min(7.5vw, 3.4rem);
  font-weight: 400;
  font-family: "Outfit", sans-serif;
  background: var(--main-color);
  border-radius: 100%;
}

.features-list .features-item .features-name {
  margin-bottom: 15px;
  padding-bottom: 0;
  font-size: min(5.6vw, 2.6rem);
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  opacity: 1;
}

.features-list .features-item .features-name:after {
  display: none;
}

.features-list .features-item .features-name.smaller {
  line-height: 1.2;
}

.features-list .features-item .features-item-inner {}

.features-list .features-item .features-item-inner>*:last-child {
  margin-bottom: 0;
}

@media (min-width: 950px) {
  .features-layout {
    display: flex;
    margin-bottom: 80px;
  }

  .features-layout .features-layout-inner {
    position: relative;
    width: 65%;
    margin: 55px 0 0;
    padding: 45px 50px 0 0;
    background: #FFF;
  }

  .features-layout .features-layout-img {
    flex: 1;
    margin: 0 0 0 -100px;
  }

  .features-layout.reverse {
    flex-direction: row-reverse;
  }

  .features-layout.reverse .features-layout-inner {
    position: relative;
    width: 65%;
    margin: 55px 0 0;
    padding: 45px 0 0 50px;
    background: #FFF;
  }

  .features-layout.reverse .features-layout-img {
    margin: 0 -100px 0 0;
  }

  .features-layout .features-layout-img img {
    height: calc(100% - 100px);
  }

  .features-layout .features-layout-img img[src*="img01"] {
  object-position: 93%;
  }

  .features-layout .features-layout-img img[src*="img02"] {
  object-position: 5%;
  }

  .features-list {}

  .features-list .features-item {
    position: relative;
  }

  .features-list .features-item .features-item-title {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
  }

  .features-list .features-item .features-item-icon {
    margin: 0 15px 0 0;
  }

  .features-list .features-item .features-name {
    margin-bottom: 0;
    line-height: 1.2;
    text-align: left;
  }

  .features-list .features-item .features-item-inner {
    margin-left: 15px;
  }
}

/*--------------------------------------
  # service
--------------------------------------*/

.service-list {}

.service-list .service-item {
  margin: 50px 0;
}

.service-list .service-item a.service-slide-inner {
  position: relative;
  display: block;
  padding: 0 20px 30px;
  background: #FFF;
  border: 1px solid #999;
  text-decoration: none;
}

.service-list .service-item a.service-slide-inner:hover {}

.service-list .service-item a.service-slide-inner .service-slide-num {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: baseline;
  font-family: "Outfit", sans-serif;
  font-size: min(8vw, 4.0rem);
  font-weight: 200;
  line-height: 1.2;
  transform: translate(-15%, -30%);
  background: #FFF;
  border-right: 10px solid #FFF;
  border-bottom: 10px solid #FFF;
}

.service-list .service-item a.service-slide-inner .service-slide-num:before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 58%;
  height: 65%;
  border-right: 1px solid;
  transform: rotate(30deg);
}

.service-list .service-item a.service-slide-inner .service-slide-num .num {
  width: 0.5em;
  margin-right: 0.4em;
  text-align: right;
}

.service-list .service-item a.service-slide-inner .service-slide-num .total {
  position: relative;
  font-size: 70%;
  transform: translate(0, 20%);
}

.service-list .service-item a.service-slide-inner .service-slide-img {}

.service-list .service-item a.service-slide-inner .service-slide-img img {
  display: block;
  width: 100%;
}

.service-list .service-item a.service-slide-inner .service-slide-title {
  font-size: 1.7rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}

ul.list-check {
  margin: 30px 0;
  padding: 20px;
  background: var(--bg-color);
}

ul.list-check li {
  position: relative;
  margin-bottom: 15px;
  padding: 0 0 15px 25px;
  color: var(--main-color);
  /* font-size: 108%; */
  font-weight: 700;
  border-bottom: 1px dashed;
  line-height: 1.4;
}

ul.list-check li .small {
  color: var(--black-color);
  font-weight: 500;
}

ul.list-check li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

ul.list-check li::before {
  content: "\f058";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  left: 0;
}

@media (min-width: 950px) {
  .service-list {
    display: flex;
    flex-wrap: wrap;
    margin: 60px -20px;
  }

  .service-list .service-item {
    width: 33.33%;
    margin: 0;
    padding: 30px 20px;
  }

  .service-list .service-item a.service-slide-inner {
    /* padding-bottom: 40px; */
    transition: .2s;
  }

  .service-list .service-item a.service-slide-inner:hover {
    filter: brightness(1.1);
    transform: scale(1.08);
  }

  .service-list .service-item a.service-slide-inner .service-slide-num {}

  .service-list .service-item a.service-slide-inner .service-slide-num .num {}

  .service-list .service-item a.service-slide-inner .service-slide-num .total {}

  .service-list .service-item a.service-slide-inner .service-slide-img {
    margin-bottom: 10px;
  }

  .service-list .service-item a.service-slide-inner .service-slide-img img {}

  .service-list .service-item a.service-slide-inner .service-slide-title {
    margin: 0 -20px;
    font-size: min(1.6vw, 2.0rem);
  }

  ul.list-check {
    clear: both;
    display: flex;
    flex-wrap: wrap;
    margin: 40px 0;
    padding: 15px;
  }

  ul.list-check li,
  ul.list-check li:last-child {
    width: calc(50% - 30px);
    margin: 0 15px;
    padding: 20px 0 20px 25px;
    border-bottom: 1px dashed;
  }

  ul.list-check li:nth-child(2n):nth-last-child(1),
  ul.list-check li:nth-child(2n+1):nth-last-child(2),
  ul.list-check li:nth-child(2n+1):nth-last-child(1) {
    border-bottom: none;
  }

  ul.list-check li::before {}
}










































/*--------------------------------------
  # メールフォーム
--------------------------------------*/
.form-wrapper {
  margin-top: 50px;
  margin-bottom: 40px;
}

.form-wrapper .form-inner {}

.form-wrapper .form-item {
  margin: 25px 0;
}

.form-wrapper .form-item p {
  display: contents;
}

.form-wrapper .form-item dt {
  display: flex;
  align-items: center;
  margin-bottom: 8px;
  font-weight: bold;
  line-height: 1.2;
}

.form-wrapper .form-item dd {}

.form-wrapper .form-item .required,
.form-wrapper .form-item .optional {
  margin-left: 8px;
  padding: 2px 4px;
  font-size: 1.0rem;
  font-weight: 400;
}

.form-wrapper .form-item .required {
  color: #FFF;
  background: #F00;
}

.form-wrapper .form-item .optional {
  color: #333;
  background: #E0E0E0;
}

.form-wrapper .form-item .form-item-row+.form-item-row {
  margin-top: 8px;
}

.form-wrapper .form-item input {
  vertical-align: baseline;
  width: 100%;
  padding: 5px;
}

.form-wrapper .form-item .zipcode input {
  width: calc(100% - 1.5em);
  margin-left: 0.5em;
}

.form-wrapper .form-item textarea {
  display: block;
  width: 100%;
  padding: 5px;
}

.form-wrapper .form-item .wpcf7-not-valid-tip {
  margin-top: 4px;
  padding: 5px;
  color: #F00;
  font-size: 1.2rem;
  background: #fff1f1;
  line-height: 1.4;
}

.form-wrapper .form-item-cloudflare {
  text-align: center;
}

.form-wrapper .form-item-cloudflare p {
  display: contents;
}

.form-wrapper .form-item-btn {
  padding-top: 20px;
}

.form-wrapper .form-item-btn>p {
  margin-bottom: 0;
}

.form-wrapper .form-item-btn input {
  appearance: none;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 160px;
  height: 42px;
  margin: 0 auto;
  padding: 0 50px;
  color: #FFF;
  font-size: 1.7rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  background: #1d6ebf;
  border: none;
  outline: none;
  border-radius: 100vw;
  text-decoration: none;
  line-height: 1.2;
  cursor: pointer;
}

.form-wrapper .wpcf7 form .wpcf7-response-output {
  margin: 0;
}

@media (min-width: 950px) {
  .form-wrapper {
    margin-top: 60px;
  }

  .form-wrapper .form-inner {
    max-width: 940px;
    margin: 0 auto;
    padding: 40px;
    border-radius: 10px;
    box-shadow: 3px 5px 15px rgba(0, 0, 0, 0.15);
  }

  .form-wrapper .form-item {
    display: flex;
    align-items: baseline;
    margin: 30px 0;
  }

  .form-wrapper .form-item.first {
    margin-top: 0;
  }

  .form-wrapper .form-item p {}

  .form-wrapper .form-item dt {
    justify-content: space-between;
    width: 30%;
    margin-bottom: 0;
    padding-right: 25px;
  }

  .form-wrapper .form-item dd {
    flex: 1;
  }

  .form-wrapper .form-item .required,
  .form-wrapper .form-item .optional {}

  .form-wrapper .form-item .required {}

  .form-wrapper .form-item .optional {}

  .form-wrapper .form-item .form-item-row+.form-item-row {}

  .form-wrapper .form-item input {
    padding: 8px;
    font-size: 95%;
  }

  .form-wrapper .form-item .zipcode input {
    width: 12em;
  }

  .form-wrapper .form-item textarea {
    padding: 8px;
    font-size: 95%;
  }

  .form-wrapper .form-item .wpcf7-not-valid-tip {}

  .form-wrapper .form-item-btn {}

  .form-wrapper .form-item-btn input {
    min-width: 220px;
    height: 47px;
    padding: 0 60px;
    transition: 0.2s;
  }

  .form-wrapper .form-item-btn input:hover {
    opacity: 0.6;
  }

  .form-wrapper .wpcf7 form .wpcf7-response-output {}
}