@charset "UTF-8";
/*
    Template: swell
    Theme Name: a-cel
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* リンク文字を太字にする */
a:hover{
	font-weight: bold;
}

/* お問い合わせリンクデザイン */
.c-gnav>.menu-item.menu-item-59 a span {
  background-color: #61DDFF;
  padding: 10px 20px;
  border-radius: 20px;
  font-weight: bold;
}

/* JP/ENリンク */
.c-gnav>.menu-item.menu-item-67 a span {
  background-color: #659df3;
  padding: 8px 12px 8px 10px;
	width: 2em;
	margin-right: 4px;
  &::after {
    content: "";
    position: absolute;
    width: 108px;
    height: 30px;
    top: 0px;
    left: 12px;
    background: linear-gradient(120deg, #659df3 0%, #659df3 30%, transparent 0%, transparent 100%);
    z-index: -1;
  }
}
.c-gnav>.menu-item.menu-item-68 a span {
  background-color: #d9d9d9;
  padding: 8px 10px 8px 0px;
	width: 2em;
	margin-left: 4px;
  &::before {
    content: "";
    position: absolute;
    width: 38px;
    height: 30px;
    top: 0px;
    left: -18px;
    background: linear-gradient(120deg, transparent 0%, transparent 30%, #d9d9d9 30%, #d9d9d9 100%);
    z-index: -1;
  }
}

/* メインメニューのサブ階層を横並びにする */
.c-gnav>.menu-item{
	position: static;
}
.c-gnav>.menu-item>.sub-menu {
	position:absolute;
  width: 100vw;
	margin-left: -50vw;
  top: 100%;
  -webkit-transform: none;
  transform: none;
  padding-left: calc(100% / 4);
}
@media (min-width: 1400px) {
  .c-gnav>.menu-item>.sub-menu {
    padding-left: calc((100% - 960px) / 2);
  }
}
.c-gnav .sub-menu li {
    display: inline-block;
    float: left;
    line-height: 2.6em;
}
/* タイトルの文字色 */
.l-topTitleArea__body {
	color: #333;
}

/* 受託サービス サービスメニュー */
.service-menu .swell-block-column {
  padding: 0;
}
.service-menu  .wp-block-image {
	margin: auto;
	padding: 0;
	position: relative;
	z-index: 0;
}
.service-menu  .wp-block-image a {
	display: block;
  height: 210px;
  min-height: 180px;
  max-height: 17vw;
	position: relative;
	width: 100%;
  background-color: #ffc432;
  padding-top: 2em;
  border-radius: 10px;
}
.service-menu  a[href="###"] {
	pointer-events: none;
}
.service-menu  .wp-block-image a:hover img {
	opacity: .85;
	transform: translateY(-4px);
}
.service-menu  .wp-block-image img {
	display: block;
	margin: 0 auto;
	padding: 0 0 1.7em;
	transition: opacity .25s, transform .25s;
	width: auto;
	width: 40%;
}
.service-menu  .wp-block-image figcaption {
	bottom: -1px;
	left: 0;
	pointer-events: none;
	position: absolute;
	text-align: center;
	width: 100%;
	white-space: nowrap;
  font-weight: bold;
  font-size: 1em;
  color: #000;
  padding-bottom: 1em;
}
.p-postList__cat {
  padding: 4px 8px;
  border-radius: 2px;
  color: #fff;
}
.page-index.swell-block-linkList .swell-block-linkList__item {
  width: auto;
  background-color: #90ee91;
  padding: 8px 12px;
  border-radius: 8px;
}

/* コンタクトフォームデザイン */
.wpcf7 input:not([type=checkbox]):not([type=radio]):not([type=submit]), .wpcf7 select, .wpcf7 textarea {
  border-radius: 0;
  background-color: transparent;
  border: none;
  width: 100%;
}
.wpcf7 input:not([type=checkbox]):not([type=radio]):not([type=submit]):focus-visible, .wpcf7 select:focus-visible, .wpcf7 textarea:focus-visible {
  outline: none;
}
.wpcf7 input:not([type=checkbox]):not([type=radio]):not([type=submit]), .wpcf7 select {
  border-bottom: 1.5px solid #333;
}
.wpcf7 textarea {
  border: 1.5px solid #333;
}
.wpcf7-turnstile.cf-turnstile,
.wpcf7 form p {
  width: 90%;
  max-width: 500px;
  margin: 30px auto;
}
.wpcf7 label {
  width: 100%;
}
.wpcf7 .wpcf7-submit {
  border-radius: 0;
  padding: 0.3rem 2rem;
  background-color: #04384c;
  color: #fff;
  border: none;
  min-width: 200px;
  display: block;
  margin: 3em auto;
}
.wpcf7 label .required{
  background-color: #F44336;
  color: #fff;
  font-size: 0.7em;
  display: inline-block;
  padding: 4px 8px;
  line-height: 1em;
  border-radius: 4px;
  margin-left: 0.4em;
  vertical-align: 3px;
}

@media (min-width: 600px) {
    .p-mainVisual__slideTitle {
        font-size: 40px;
    }
}

