@charset "UTF-8";
/*
Theme Name: MY THEME 
Author: Aini-ku
Description: Aini-kuオリジナルテーマ
Version: 1.10(2023.2 最新版)
*/


/* ===========================================
 メモ（memo）
 * ======================================== */
/*background-image: url("images/arrow_icon.png");*/

/* ===========================================
 共通（common）
 * ======================================== */
html {
	scroll-behavior: smooth;
}
html, body { 
	overflow-x: clip; 
}   

body{
	margin:0;
	font-size:18px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight:700;
}
img {
    max-width: 100%;
    height: auto;
}
h2{
	font-size:27px;
	letter-spacing:2px;
}


/* 枠組み（container）
------------------------------------------ */
.wrapper{
	width:100%;
	max-width:100vw;
}
.container{
	width:80%;
	margin:auto;
}

@media screen and (max-width:520px){
	.container{
		width:95%;
		margin:auto;
	}

}
/* レスポンシブ（responsive）
------------------------------------------ */
.pc,.pc_960{
	display:block !important;
}
.sp,.sp_960{
	display:none !important;
}

@media screen and (max-width:960px){
	.pc_960{
		display:none !important;
	}
	.sp_960{
		display:block !important;
	}
}
@media screen and (max-width:520px){
	.sp{
		display:block !important;
	}
	.pc{
		display:none !important;
	}
}


/* FLEX（flex）
------------------------------------------ */
.flex{
	display:flex;
	align-items:center;
	flex-wrap: no-wrap;
}
.flex-between{
	justify-content:space-between;
}
.flex-center{
	justify-content:center;
}
.flex-start{
	justify-content:start;
}
.flex-align-start{
	align-items: start;
}
.flex-item10{
	width:10%;
}
.flex-item20{
	width:20%;
}
.flex-item25{
	width:25%;
}
.flex-item30{
	width:33%;
}
.flex-item45{
	width:45%;
}
.flex-item50{
	width:50%;
}
.flex-item60{
	width:60%;
}
.flex-item70{
	width:70%;
}

@media screen and (max-width:520px){
	.flex{
		flex-wrap:wrap;
	}
	.flex-item10,.flex-item20,.flex-item25,.flex-item30,.flex-item45,.flex-item50,.flex-item60,.flex-item70{
		width: 100%;
	}
	.reverse {
		flex-direction: column-reverse;
	}
}

/* POSITION（position）
------------------------------------------ */
.center{
	text-align: center;
}
.left{
	text-align: left;
}
.right{
	text-align: right;
}

/* WIDTH（width）
------------------------------------------ */
.w-80{
	width: 80%;
}
.w-90{
	width: 90%;
}

/* ===========================================
 アニメーション（anime）
 * ======================================== */
.fadeDown{
	animation-name:fadeDownAnime;
	animation-duration:2s;
	animation-fill-mode:forwards;
	animation-play-state: paused;
	opacity:0;
}
.fadeDown.is-show {
  animation-play-state: running;
}

@keyframes fadeDownAnime{
  from {
    opacity: 0;
	transform: translateY(-70px);
  }

  to {
    opacity: 1;
	transform: translateY(0);
  }
}

.fadeUP{
	animation-name:fadeUPAnime;
	animation-duration:2s;
	animation-fill-mode:forwards;
	animation-play-state: paused;
	opacity:0;
}
.fadeUP.is-show {
  animation-play-state: running;
}
@keyframes fadeUPAnime{
  from {
	  opacity: 0;
	  transform: translateY(20px);
  }

  to {
	  opacity: 1;
	  transform: translateY(0);
  }
}

/*左から右にフェードイン*/
.fadeIn{
	animation-name:fadeInAnime;
	animation-duration:2s;
	animation-fill-mode:forwards;
	opacity:0;
}
@keyframes fadeInAnime {
  0% {
     opacity: 0;
     transform: translateX(-20px);
  }
  100% {
     opacity: 1;
     transform: translateX(0);
  }
}

/*右から左にフェードイン*/
.fadeIn2{
	animation-name:fadeInAnime2;
	animation-duration:2s;
	animation-fill-mode:forwards;
	opacity:0;
}
@keyframes fadeInAnime2 {
  0% {
     opacity: 0;
     transform: translateX(20px);
  }
  100% {
     opacity: 1;
     transform: translateX(0);
  }
}

/*拡大フェードイン*/
.fadeScale{
	animation-name:fadeScaleAnime;
	animation-duration:2s;
	animation-fill-mode:forwards;
	opacity:0;
}
@keyframes fadeScaleAnime {
  0% {
     opacity: 0;
     transform: scale(0.9);
  }
  100% {
     opacity: 1;
     transform:scale(1);
  }
}

/*マーカー（蛍光ペン）アニメーション*/
.point{
  background: linear-gradient(transparent 70%, #FFBC4B 70%);
  display: inline;
  /* 背景の繰り返しを停止 */
  background-repeat: no-repeat;
  /* マーカーの横方向を0にして縮める */
  background-size: 0% 100%;
  /* マーカーが引かれる速度を指定 */
  transition:background-size 1.5s;
}

/* マーカーが引かれる際に付与するクラス */
.point.on {
  /* 横方向を100%にして、マーカーを引く */
  background-size: 100% 100%;
}


/*常に上下に揺れるアニメーション*/
.yurayura {
  animation: yurayuraMove 1.5s ease-in-out;
  animation-iteration-count: 5; 
  animation-fill-mode: forwards;
  opacity: 0; 
}
.yurayura.is-show {
  opacity: 1; 
  animation-play-state: running; 
}

@keyframes yurayuraMove {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(-10px); }
  100% { transform: translateY(0); }
}

/* ===========================================
 ヘッダー（header）
 * ======================================== */
.header{
	width:100%;
	height:9vh;
	max-height:150px;
	background:#fff;
	padding-left:3%;
}

/* 固定表示時の状態 */
.header.is-fixed {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	transform: translateY(0);
	opacity: 1;
}

/* アニメーションで上からスッと現れる */
.header.slide-in {
	transform: translateY(-100%);
	opacity: 0;
	animation: slideDown 0.7s ease forwards;
}

@keyframes slideDown {
	from {
		transform: translateY(-100%);
		opacity: 0;
	}

	to {
		transform: translateY(0);
		opacity: 1;
	}
}

.header .title{
	text-align:center;
	font-size:25px;
}
.header a{
	text-decoration:none;
	color:black;
}
.header .cta{
	position:relative;
	display:block;
	width:200px;
	height:9vh;
	color:black;
	background:#FDE91C;
	padding-top:12px;
	padding-right: 10px; /* > の分の余白 */
	font-size:16px;
	font-weight:bold;
}
.header .cta::after {
	content: ">";
	position: absolute;
	top: 50%;
	right: 8%;
	transform: translateY(-50%); 
	font-weight: 700;
	z-index:1;
}

/*スマホ*/
.sp .header{
	display: flex;
	align-items: center; /* 上下中央寄せ */
	height:9vh;
}
.sp .header .title,.sp .header .title img{
	width:auto;
	height:6vh;
	margin:auto;
}

@media screen and (max-width:960px){
	.header{
		height:7vh;
	}
	.header, .header .cta{
		height:7vh;
	}
}

/*ハンバーガーメニュー
------------------------------------------ */
.hamburger_logo{
	width:50%;
}
.menu-btn {
    position: fixed;
    top: 90px;
    right: 50px;
    display: flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 101;
	border-radius:50%;
}
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
    content: '';
    display: block;
    height: 7px;
    width: 45px;
    background-color:#0071BC;
    position: absolute;
}
.menu-btn span:before {
    bottom: 15px;
}
.menu-btn span:after {
    top: 15px;
}

#menu-btn-check:checked ~ .menu-btn span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#menu-btn-check:checked ~ .menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
	background-color:#FFFFFF;
}
#menu-btn-check:checked ~ .menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
	background-color:#FFFFFF;
}
#menu-btn-check {
    display: none;
}

.menu-content ul {
    padding: 80px 50px 10px 10%;
}
.menu-content ul li {
    list-style: none;
}
.menu-content ul li:not(.menu_category) {
    padding-left:30px;
}
.menu-content ul li a {
    display: block;
    width: 100%;
    font-size: 15px;
    box-sizing: border-box;
    color:#ffffff;
    text-decoration: none;
    padding: 9px 15px 10px 0;
    position: relative;
}
.menu-content ul li {
    list-style: none;
}
.menu-content ul li a {
    display: block;
    width: 100%;
    font-size: 15px;
    box-sizing: border-box;
    color:#ffffff;
    text-decoration: none;
    padding: 9px 15px 10px 0;
    position: relative;
}
.menu-content ul .menu_category{
	color:#FFFFFF;
	text-decoration:none;
}
.menu-content ul .menu_title h3::after{
	content: '';/*何も入れない*/
	display: inline-block;/*忘れずに！*/
	width: 50px;/*画像の幅*/
	height: 40px;/*画像の高さ*/
	background-image: url("images/arrow_icon.png");
	background-size: contain;
	background-repeat:no-repeat;
	vertical-align: middle;
	margin-left:15px;
}

.menu-content {
    width: 30%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 100%;/*leftの値を変更してメニューを画面外へ*/
	z-index: 100;
    background-color: black;
	opacity:0.9;
    transition: all 0.5s;/*アニメーション設定*/
}

#menu-btn-check:checked ~ .menu-content {
    left: 70%;/*メニューを画面内へ*/
}

@media screen and (max-width:520px){
	.menu-btn {
		top: 20px;
		right: 20px;
	}
	/*スマホ時は全面表示する*/
	.hamburger_logo{
		width:100%;
	}
	.menu-content {
		width:100%;
	}
	#menu-btn-check:checked ~ .menu-content {
		left: 0;/*メニューを画面内へ*/
	}
}
/*ハンバーガーメニューここまで*/

/* ===========================================
 ホームページ（front-page.php）
 * ======================================== */
.front h2{
	margin-bottom:25px;
}
.front_image_container{
	position:relative;
}
.front_image{
	width:100%;
	text-align:center;
}
.front_image img{
	pointer-events: none;
}

/*実績*/
.front .achievements{
	background:#F6F6F6;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:10%;
}
.front .achievements h2{
	font-weight:bold;
}
.front .achievements h2 span {
	font-size:1.35em;
	background: linear-gradient(#ffe700 0 0) 0 85% / 0% 0.30em no-repeat;
	transition: background-size 0.8s ease-out;
}
.front .achievements h2.is-show span {
	background-size: 100% 0.30em;
}

.front .achievements .slider{
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	margin-top:50px;
}
.front .achievements .slider img{
	width:90%;
	border-radius:20px;
}
.front .achievements .ribbon {
	position: relative;
	display: inline-block;
	padding: 8px 20px;
	background: #ffe700;
	color: #444;
	font-size:1.3em;
	font-weight: 700;
	border-radius: 10px 10px 0px 0px;
	margin-bottom:15px;
	z-index:1;
}
.front .achievements .ribbon::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -24px;
	border-style: solid;
	border-width: 25px 0 0 25px;
	border-color: #e0e0e0 transparent transparent transparent;
	z-index:-1;
}




/*広告と広報の違い*/
.front .brand_arc {
	background: #FDE91C;;
	padding: 150px 20px 60px;
	text-align: center;
	position: relative;
	overflow: hidden;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}
.front .brand_arc::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	aspect-ratio: 3 / 1;                    
	background: url("images/arc.jpg") no-repeat center top / cover;           
}
.front .brand_arc .brand_arc_lead{
	font-size:1.5em;
	font-weight:bold;
}
.front .brand_arc h2{
	font-size:1.8em;
	font-weight:bold;
	line-height:2em;
}
.front .brand_arc h2 .large{
	font-size:1.6em;
	color:#58B7B7;
	background:linear-gradient(#fff 0 0) left 85% / 0% 0.30em no-repeat;
	transition: background-size .8s ease-out;
}
.front .brand_arc h2 .large.is-show {
	background-size: 100% 0.30em;
}

.front .brand_arc_inner {
	position: relative;
	z-index: 1;
	max-width: 850px;
	margin: 0 auto;
}
.front .brand_arc_center{
	background:#FDE91C;
	position: relative;
	overflow: hidden;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}
.front .brand_arc_center_inner{
	max-width:90%;
	margin: 0 auto;
	padding:0 2%;
}
.front .brand_arc_center_inner .submidashi{
	margin-top:50px;
}
.front .brand_arc_center_inner h2{
	font-size:1.8em;
	font-weight:bold;
	line-height:2em;
}
.front .brand_arc_center_inner h2 .large {
	font-size:1.6em;
	color:#58B7B7;
	background:linear-gradient(#fff 0 0) left 85% / 0% 0.30em no-repeat;
	transition: background-size .8s ease-out;
}
.front .brand_arc_center_inner h2 .large.is-show {
	background-size: 100% 0.30em;
}
.front .brand_arc_center_inner .image_box{
	width:80vw;
	margin:50px auto;
}
.front .brand_arc_center .ad_or_pr_image_image{
	width:80vw;
}
.front .brand_arc_center .brand_arc_comparison{
	background:#fff;
	padding:8% 5%;
	border-radius:10px;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	width: 80vw;
}
.front .brand_arc_center .brand_arc_comparison h3{
	font-size:1.8em;
	font-weight:bold;
	line-height:2.2em;
	margin-bottom:80px;
}
.front .brand_arc_center .brand_arc_comparison h3 .markup{
	background:#EC6C4C;
	color:#fff;
	font-size:1.5em;
	margin:0 7px;
	padding:3px 5px;
	display:inline-block; 
	clip-path: inset(0 100% 0 0);
	transition: clip-path .8s ease-out;
}
.front .brand_arc_center .brand_arc_comparison h3 .markup.is-show{
	clip-path: inset(0 0 0 0);
}
.front .brand_arc_center .arrow{
	width:300px;
	margin:50px auto;
}

.front .brand_arc_center .matome{
	font-size:1.5em;
	font-weight:bold;
	line-height:3.0em;
}
.front .brand_arc_center_inner .matome .white{
	font-size:1.4em;
	background:#fff;
	padding:5px 15px;
}
.front .brand_arc_center_inner .matome .orange{
	font-size:1.8em;
	font-weight:900;
	color:#EC6C4C;
    text-shadow:
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 4px #fff,
        0 0 4px #fff,
        0 0 5px #fff,
        0 0 5px #fff;
}

.front .brand_arc_bottom {
	background: #f6f6f6;
	padding: 170px 20px 60px;
	text-align: center;
	position: relative;
	overflow: hidden;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}
.front .brand_arc_bottom::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height:235px;                
	background: url("images/arc_bottom.jpg") no-repeat center bottom / cover;           
}


/*メリット*/
.front .merit {
	padding:8% 0 5% 0;
	background:#f6f6f6;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}
.front .merit h2{
	font-weight:bold;
	line-height:2.0em;
}
.front .merit h2 .large{
	color:#E86D4C;
	font-size:1.3em;
}
.front .merit h2 .dots{
	background-image: radial-gradient(circle at center, #58B7B7 20%, transparent 20%); 
	background-position: top right;
	background-repeat: repeat-x; 
	background-size: 1.1em 0.3em; 
	padding-top: .4em;
}

.front .merit .merit_text{
	font-weight:bold;
	font-size:1.0em;
	line-height:2.2em;
}
.front .merit .markup{
	display:inline-block;
	background:#FDE91C;
	font-size:1.2em;
	padding:0 20px;
	margin-top:7px;
	line-height:2.4em;
}
.front .merit_image{
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}

/*ポイント*/
.front .point_box{
	background-color:#FEFCE3;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding-bottom:10%;
	overflow-x:hidden;
}
.front .point_box .title_box{
	position: relative;
	background:	#59B5BB;
	padding:2% 5%;
}
.front .point_box .title_box::after {
	content: "";
	position: absolute;
	bottom: -23px; 
	left: 50%;
	transform: translateX(-50%);
	border-width: 50px 50px 0 50px; /* 三角サイズ */
	border-style: solid;
	border-color: #59B5BB transparent transparent transparent; 
}
.front .point_box .title_box .subtitle{
	font-size:1.2em;
	font-weight:bold;
	color:#fff;
}
.front .point_box .title_box h2{
	font-size:2.0em;
	font-weight:bold;
	color:#fff;
}
.front .point_box .title_box h2 .large{
	font-size:1.7em;
	font-weight:900;
	color:#EC6C4C;
    text-shadow:
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 4px #fff,
        0 0 4px #fff,
        0 0 5px #fff,
        0 0 5px #fff;
}

.front .point_box .flex{
	margin-top:8%;
}

.front .point_box .text-box {
	position: relative;
	z-index: 2; 
	padding: 5% 15px 0 3%;
	margin-right: -80px;
	border-radius: 6px;
}
.front .point_box .text-box.right {
	text-align:left;
	padding: 5% 3% 0 15px;
	margin-left: -80px;
	margin-right:0;
}
.front .point_box .text-box .text{
	margin-top:40px;
}

.front .point_box .image-box img {
	display: block;
	height: auto;
	z-index: 1;
}

.front .point_box .text-box .subtitle{
	font-size:1.2em;
	font-weight:bold;
}
.front .point_box .text-box h3{
	font-size:1.7em;
	font-weight:bold;
	color:#FDE91C;
	line-height:2.0em;
}
.front .point_box .text-box h3 .highlight{
	background:#504F4D;
	padding:3px 15px;
	display:inline-block;         
	white-space: nowrap;          
	clip-path: inset(0 100% 0 0); 
	transition: clip-path .8s ease-out;
	margin-bottom:3px;
}

.front .point_box .text-box h3 .highlight.is-show{
	clip-path: inset(0 0 0 0);
}

.front .point_box .point_matome{
	width:80%;
	margin:100px auto 0 auto;
	padding:3%;
	border:solid 2px #D4D4D3;
	background:#fff;
	font-size:1.2em;
	font-weight:bold;
}
.front .point_box .point_matome .underline{
	display:block;
	border-bottom:solid #D4D4D3 1px;
	padding-top:10px;
	padding-bottom:15px;
}
.front .point_box .point_matome .markup{
	display:inline-block;
	background:#FDE91C;
	padding:5px 20px;
}
.front .point_box .point_matome .large{
	color:#EA6C4B;
	font-size:2.2em;
}
.front .point_image{
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}


/*お客様の声*/
.front .voice{
	background:#F6F6F6;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .voice h2{
	font-size:1.9em;
	font-weight: bold;
    line-height: 2.0em;
}
.front .voice h2 .large{
	font-size:1.6em;
	color:#5AB6BC;
	margin-right:5px;
}
.front .voice .subtitle img{
	width:50%;
	max-width:230px
}
.front .voice .fukidashi{
	position:relative;
	background:#FDE91C;
	padding:4%;
	border-radius:20px;
	margin-top:50px;
	font-weight:bold;
}
.front .fukidashi::after {
  content: "";
  position: absolute;
  bottom: -67px; 
  left: 20%;
  transform: translateX(-50%) rotate(15deg);
  border-width: 40px;
  border-style: solid;
  border-color: #FDE91C transparent transparent transparent; 
}

.front .voice .fukidashi .title{
	font-size:1.4em;
	margin-bottom:40px;
	line-height:1.8em;
}
.front .voice .fukidashi .text{
	font-size:0.9em;
	line-height:1.9em;
}
.front .voice .fukidashi .large{
	font-size:1.5em;
	font-weight:900;
    color: #EA6C4B;
    text-shadow:
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 3px #fff,
        0 0 4px #fff,
        0 0 4px #fff,
        0 0 5px #fff,
        0 0 5px #fff;
}
.front .voice .fukidashi .markup{
	background:#fff;
	padding:3px 2px;
}
.front .voice_name {
	gap: 14px;
	font: 16px/1.3 -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
	margin-top:50px;
	padding-left:3%;
}

.front .voice_name img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	background: #bbb; 
}

.front .voice .voice_video {
	position: relative;
	width: 100%;         
	padding-top: 56.25%; /* 16:9 → 9 / 16 = 0.5625 = 56.25% */
	padding-left:5%;
	padding-right:5%;
	margin: 7% auto;
}

.front .voice .voice_video iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/*理由*/
.front .reason{
	background:#FDE91C;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .reason h2{
	font-weight:bold;
	line-height: 2.0em;
}
.front .reason h2 .large {
	font-size:1.6em;
	color:#5AB6BC;
	background-image: repeating-linear-gradient(
		to right,
		#EA6C4B 0 6px,   /* dashの長さ */
		transparent 6px 10px
	);
	background-position: left calc(100% - 0px);
	background-repeat: no-repeat;
	background-size: 0% 4px;
	transition: background-size .6s ease-out;
}

.front .reason h2 .large.is-show {
	background-size: 100% 4px;
}


.front .reason .reason_box{
	background:#fff;
	padding:3%;
	margin-top:50px;
	font-weight:bold;
	line-height:1.9em;
}
.front .reason .reason_box .markup{
	font-size:1.1em;
	color:#EA6C4B;
}
.front .reason .reason_box img{
	width:80%;
}
.front .reason_image{
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}


/*比較*/
.front .comparison{
	background:#F6F6F6;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .comparison h2{
	font-size: 2.5em;
	font-weight: bold;
    line-height: 1.7em;
	color:#5AB6BC;
}
.front .comparison .comparison_text{
	font-weight:bold;
	margin-top:40px;
}
.front .comparison .comparison_image{
	margin-top:60px;
	margin-bottom:50px;
}

.front .comparison h2.medialist{
	color:#514F50;
}
.front .comparison .dots-v_box {
	position: relative;
	height: 85px;
	line-height: 0; 
}
.front .comparison .dots-v {
	position:absolute;
	top:50%; 
	left:50%;
	transform:translate(-50%,-50%); 
	width:6px;                     
	height:58px;                 
	background:
		radial-gradient(circle, #000 3px, transparent 3px)
		50% 0 / 100% 15px repeat-y;   
}


.front .comparison .medialist_box {
	width:85%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end; /* 下寄せ */
	height: auto;           
	padding: 16px 20px;
	background: #fff;
	border: 2px solid #cfcfcf;
	box-shadow: inset 0 0 0 1px #999;
	margin:auto;
}
.front .comparison .medialist_box ul{
	list-style:none;
	margin:0;
	padding:0;
}
.front .comparison .medialist_box li{
	display:flex;
	gap:10px;
	align-items:center;
	margin:.6em 0;
	font-size:1.2em;
	font-weight:bold;
}
.front .comparison .medialist_box .chk{
	width:30px;
	height:30px;
	flex:0 0 30px;
	margin-right:10px;
}
.front .comparison .medialist_box .em{
	font-size:1.5em;
	color:#EA6C4B;
	font-weight:700;
}

.front .comparison .setsumei{
	width:85%;
	margin:50px auto;
	font-weight:bold;
	line-height:2.5em;
}
.front .comparison .setsumei .markup{
    background: #FDE91C;
	margin-top:8px;
	padding:5px 15px;
	font-size:1.2em;
}
	
/*メッセージ*/
.front .message_image{
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}
.front .message{
	background-image:url("images/message_bg.png");
	background-repeat:no-repeat;
	background-size:cover;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .message h2 {
    font-size: 2.5em;
    font-weight: bold;
    line-height: 1.7em;
	color:#514F50;
}
.front .message h3{
    color: #5AB6BC;
	font-size:1.6em;
    font-weight: 700;
	margin-top:50px;
	line-height:1.5em;
}
.front .message h3 .small{
	font-size:0.8em;
	color: #5AB6BC;
	font-weight:bold;
}
.front .message .text{
	font-weight:bold;
	line-height:2.3em;
	margin-top:50px;
}
.front .message .name{
	font-weight:bold;
	line-height:2.0em;
	margin-top:50px;
}
.front .message .vs_text{
	font-size:1.3em;
	font-weight:bold;
	margin:60px auto;
}
.front .message .message_image2{
	margin-bottom:150px;
}
.front .message .message_image2 img{
	width:85%;
}


/*QA*/
.front .qa h2 {
	position:relative;
    font-size: 2.5em;
    font-weight: bold;
    line-height: 1.7em;
	color:#514F50;
	z-index:1;
}
.front .qa h2::after {
	content: "";
	position: absolute;
	top: 50%;
	left:50%;
	transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	width:  250px;       
	height: 150px;
	background: url("images/faq_title_bg.png") no-repeat center/contain;
	opacity: 1;         
	pointer-events: none; 
	z-index:-1;
}
.front .qa{
	background:#F0EEE5;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .qa_bottom{
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
}
/* 全体のQ&Aカード（青背景部分） */
.front .qa .qa_box {
	position: relative;
	background: #63aeb0;             
	border-radius: 16px;
	padding-bottom:50px;
	margin-top:80px;
}
.front .qa .qa_head {
	position: relative;
	margin-bottom: 18px;
}
.front .qa .qa_head h3 {
	padding-top:60px;
	text-align: left;
	font-size: 1.4em;
	font-weight: 700;
	color: #fff;
	line-height:1.5em;
	padding-left: 90px; 
	padding-right:5%;
}

.front .qa .q_badge {
	position: absolute;
	left: 0;
	top: 0;
	width: 80px;
	height: 80px;
	background: #3e7e81;  
	color:#fff;
	border-radius: 16px 0 70px 0;  
	font-size:35px;
	font-weight:bold;
	padding-top:7px;
	padding-left:18px;
}
.front .qa .qa_inner{
	width:90%;
	background:#fff;
	padding:3%;
	margin:40px auto 0 auto;
	border-radius:16px;
}
.front .qa .qa_inner p {
	margin: 0;
	display: flex;
	align-items: flex-start;
	font-weight:bold;
	line-height:2.0em;
	gap: 10px; 
}
.front .qa .a_badge {
	color: #3e7e81;
	font-weight: bold;
	font-size: 25px;
	flex: 0 0 auto;  
	line-height: 1;   
	margin: 0;
}
.front .qa .answer_text {
	flex: 1;
}
.front .qa .answer_text .markup{
	font-size:1.1em;
	color:#EA6C4B;
}

/*明るい未来*/
.front .future{
	background:#FDE91C;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .future h2{
	position:relative;
	background:#fff;
	font-weight:bold;
	padding:2%;
	line-height:2.2em;
}
.front .future h2 .large{
	font-size:1.3em;
	color:#EA6C4B;
}
.front .future h2::after {
    content: "";
    position: absolute;
    bottom: -67px;
    left: 60%;
    transform: translateX(-50%) rotate(15deg);
    border-width: 40px;
    border-style: solid;
    border-color: #FFF transparent transparent transparent;
}
.front .future .text{
	font-weight:bold;
	margin-top:50px;
	margin-bottom:30px;
	font-size:1.3em;
	line-height:1.5em;
}
.front .future .cta_btn {
	display: inline-block;
	padding: 18px 98px 18px 62px;
	background: linear-gradient(to bottom, #8fd3d0 0%, #5ca9a6 100%);
	border-radius: 999px;
	color: #fff;
	font-weight: 700;
	font-size: 20px;
	text-decoration: none;
	text-shadow: 0 2px 2px rgba(0,0,0,0.25);
	box-shadow:
		inset 0 2px 1px rgba(255,255,255,.65),
		0 5px 0 #3f8f8c,
		0 6px 8px rgba(0,0,0,.12);              
	position: relative;
	transition: box-shadow .25s ease, transform .25s ease;
}

.front .future .cta_btn:hover {
	box-shadow:
		inset 0 1px 0 rgba(255,255,255,.5),  
		0 3px 0 #3f8f8c,                      
		0 4px 6px rgba(0,0,0,.12);          
	transform: translateY(2px);   
}

.front .future .cta_btn::after {
	content: "";
	position: absolute;
	right: 18px;
	top: 50%;
	width: 30px;
	height: 30px;
	margin-top: -15px;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 2px 3px rgba(0,0,0,0.2);
	z-index: 1;
}

.front .future .cta_btn::before {
	content: "＞";
	position: absolute;
	right: 25px;
	top: 50%;
	transform: translateY(-50%);
	color: #4ea19e;
	font-size: 15px;
	z-index: 2;
}


/*CTAセクション*/
.front .end_cta{
	background:#FEFCE3;
	position: relative;
	left: 50%;
	right: 50%;
	width: 100vw;
	margin-left: -50vw;
	margin-right: -50vw;
	padding:5% 10%;
}
.front .end_cta h2{
	font-size:2.0em;
	font-weight:bold;
	line-height:1.7em;
	color:#514F50;
}
.front .end_cta .arrow{
	width:300px;
}
.front .end_cta .end_cta_image img{
	width:80%;
	filter: drop-shadow(5px 5px 5px #aaa);
}


/*CTAボタン*/
.front .cta_box{
	position:relative;
	padding:26px 16px 34px;
	border:2px solid #ddd;
	background:#fff;
	border-radius:4px;
	text-align:center;
	color:#333;
	font-weight:700;
	margin-top:50px;
	margin-left:auto;
	margin-right:auto;
	max-width:900px;
}

.front .cta_box .badge{
	position:absolute;
	left:0; 
	top:12px;
	padding:.5em 1em;
	background:#EC6C4C;
	color:#fff;
	border-radius:1px 20px 20px 1px;
	font-weight:700;
	font-size:1.2em;
}

.front .cta_box .lead{
	margin:12px 8px 18px;
	line-height:1.7;
	font-size:1.5em;
	font-weight:bold;
}

.front .cta_box .cta_btn {
	display: inline-block;
	padding: 18px 68px 18px 32px;
	background: linear-gradient(to bottom, #8fd3d0 0%, #5ca9a6 100%);
	border-radius: 999px;
	color: #fff;
	font-weight: 700;
	font-size: 20px;
	text-decoration: none;
	text-shadow: 0 2px 2px rgba(0,0,0,0.25);
	box-shadow:
		inset 0 2px 1px rgba(255,255,255,.65),
		0 5px 0 #3f8f8c,
		0 6px 8px rgba(0,0,0,.12);              
	position: relative;
	transition: box-shadow .25s ease, transform .25s ease;
}

.front .cta_box .cta_btn:hover {
	box-shadow:
		inset 0 1px 0 rgba(255,255,255,.5),  
		0 3px 0 #3f8f8c,                      
		0 4px 6px rgba(0,0,0,.12);          
	transform: translateY(2px);   
}

.front .cta_box .cta_btn::after {
	content: "";
	position: absolute;
	right: 18px;
	top: 50%;
	width: 30px;
	height: 30px;
	margin-top: -15px;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 2px 3px rgba(0,0,0,0.2);
	z-index: 1;
}

.front .cta_box .cta_btn::before {
	content: "＞";
	position: absolute;
	right: 25px;
	top: 50%;
	transform: translateY(-50%);
	color: #4ea19e;
	font-size: 15px;
	z-index: 2;
}

/*右下に固定するCTAボタン*/
.cta-wrapper {
	position: fixed;
	right: 20px;
	bottom: 20px;
	width: 30%;
	max-width: 300px;
	z-index: 9999;
	transform: translateY(320px);
	transition: .4s ease;
}

.cta-wrapper.show {
	transform: translateY(0);
}

.cta-close {
	position: absolute;
	top: -10px;
	right: -10px;
	background: #000;
	color: #fff;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	font-size: 18px;
	line-height: 24px;
	text-align: center;
	cursor: pointer;
}

.front .cta-fixed_sp{
	display:none;
}






/*お問い合わせフォーム*/
#mw_wp_form_mw-wp-form-11{
	background:#fff;
	margin:50px auto;
	padding:1% 2%;
	border: 2px solid #ddd;
}
.cform{
	width:85%;
	margin:8% auto;
}
.end_cta  th{
	width:40%;
	padding:30px 0 30px 10px;
	font-size:18px;
	border-bottom:solid 1px #fff;
}
.end_cta  td{
	border-bottom:solid 1px #fff;
}
.end_cta input, .end_cta textarea{
	width:100%;
	height:100%;
	outline: none;
	background:none;
	border: 2px solid #ddd;
}
.end_cta textarea::placeholder {
	padding-top:10%;
}
.end_cta .guide_box {
	width: 73%;
	margin: auto;
	font-size:14px;
}
.required-srt{
	background-color:red;
	color:#FFF;
	font-size:12px;
	padding:5px;
	margin-left:30px;
}
.any-srt{
	background:#0276C3;
	color:#FFF;
	font-size:12px;
	padding:5px;
	margin-left:30px;
}
.submit_div{
	text-align:center;
}
.submit_div input{
	width:250px;
	background:#ED6D4D;
	color:#fff;
	margin-top:20px;
	margin-bottom:10%;
	padding:15px;
	font-size:18px;
	border-radius:50px;
	border:none;
}
.submit_div input:hover{
	opacity:0.7;
}

.cform input[type="checkbox"] {
	position: relative;
	width: 16px;
	height: 16px;
	border: 1px solid #000;
	vertical-align: -5px;
	-webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
}
.cform input[type="checkbox"] {
	border-radius: 2px;
	-webkit-appearance: none;
     -moz-appearance: none;
	appearance: none;
	border:solid 1px #fff;
}
.cform input[type="checkbox"]:checked:before {
  position: absolute;
  top: 1px;
  left: 4px;
  transform: rotate(50deg);
  width: 4px;
  height: 8px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  content: '';
}

@media screen and (min-width:1460px){
	.front .point_box .point_matome .large_p{
		text-align:center;
	}
}
@media screen and (max-width:960px){
	.front .cta_box{
		padding:56px 16px 34px;
	}
	.front .brand_arc_center .brand_arc_comparison {
		width:95%;
	}
	.front .brand_arc_center_inner .matome .orange{
		font-size:1.6em;
	}
	.front .point_box .text-box h3{
		font-size:1.2em;
		white-space: wrap;
	}
	.front .point_box .text-box .subtitle {
		font-size:1.1em;
	}
	.front .point_box .point_matome{
		width:90%;
	}
	.front .reason h2 .large{
		font-size:1.3em;
	}
	.front .reason_box .flex{
		margin:50px auto;
	}
	.front .end_cta h2 {
		font-size:1.8em;
	}
	.front .cta-wrapper {
		display:none !important;
	}
	.front .cta-fixed_sp{
		width:100%;
		display:block;
		position:fixed;
		bottom:0;
		left:50%;
		transform: translateX(-50%);
		z-index:9999;
	}
}

@media screen and (max-width:767px){
	.cform th, .cform td{
		width:100%;
		display:block;
	}
	.cform th{
		text-align:center;
	}
	.cform td{
		height:50px;
	}
	.cform td.otoiawase{
		height:200px;
	}
	.cform input, .cform textarea{
		width:100%;
	}
	.submit_div input{
		width:80%;
	}
}


@media screen and (max-width:520px){
	/*実績*/
	.front .achievements{
		padding:10% 5%;
	}
	.front .achievements .ribbon {
		font-size:1em;
	}
	.front .achievements h2{
		font-size:1.3em;
		line-height:1.8em;
	}
	.front .brand_arc_center .arrow{
		margin-bottom:0;
	}
	
	/*広告と広報の違い*/
	.front .brand_arc{
		padding: 150px 5% 10px;
	}
	.front .brand_arc .brand_arc_lead{
		font-size:1.2em;
	}
	.front .brand_arc h2{
		font-size:1.5em;
	}
	.front .brand_arc h2 .large{
		font-size:1.5em;
	}
	.front .brand_arc_center .ad_or_pr_image_image{
		width:100%;
	}
	.front .brand_arc_center_inner h2{
		font-size:1.5em;
		line-height:1.7em;
	}
	.front .brand_arc_center_inner h2 .large{
		font-size:1.5em;
	}
	.front .brand_arc_center_inner .image_box{
		margin-top:15px;
	}
	.front .brand_arc_center_inner .image_box img{
		margin-top:20px;
	}	
	.front .brand_arc_center .brand_arc_comparison{
		width:100%;
	}
	.front .brand_arc_center .brand_arc_comparison h3{
		font-size:1.1em;
		margin-bottom: 30px;
	}
	.front .brand_arc_center .brand_arc_comparison h3 .markup{
		font-size:1.3em;
	}
	.front .brand_arc_center .matome{
		font-size:1.3em;
		line-height:2.3em;
	}
	.front .brand_arc_center_inner .matome .white{
		font-size:1em;
	}
	.front .brand_arc_center_inner .matome .orange{
		font-size:1.4em;
	}
	.front .brand_arc_bottom{
		padding:30px 20px 60px;
	}
	.front .brand_arc_bottom::before{
		height:100px;
	}
	
	/*メリット*/
	.front .merit{
		padding:8% 5% 5% 5%;
	}
	.front .merit h2{
		font-size:1.3em;
	}
	.front .merit h2 .dots{
		padding-top:.2em;
	}
	.front .merit h2 .large{
		font-size:1.2em;
	}
	.front .merit .markup{
		font-size:1em;
	}
	.front .merit .merit_text{
		font-size:0.9em;
	}
	
	/*ポイント*/
	.front .point_box .title_box{
		padding-top:5%;
	}
	.front .point_box .title_box .subtitle{
		font-size:1em;
	}
	.front .point_box .title_box h2{
		font-size:1.3em;
	}
	.front .point_box .title_box h2 .large{
		font-size:2.0em;
	}
	.front .point_box .text-box{
		margin-right:0;
	}
	.front .point_box .text-box .subtitle{
		font-size:1em;
	}
	.front .point_box .text-box .text{
		font-size:.8em;
		margin-top:20px;
	}
	.front .point_box .text-box.right{
		margin-left:0;
	}
	.front .point_box .point_matome{
		width:95%;
		margin-top:30px;
	}
	.front .point_box .point_matome .underline{
		font-size:.8em;
	}
	.front .point_box .point_matome .large{
		font-size:1.2em;
	}
	
	
	/*お客様の声*/
	.front .voice{
		padding:5%;
	}
	.front .voice h2{
		font-size:1.2em;
	}
	.front .voice .fukidashi .title{
		font-size:1.1em;
	}
	.front .voice .fukidashi .large{
		font-size:1.3em;
	}
	.front .voice .fukidashi .text{
		font-size:0.9em;
		line-height:2.2em;
	}
	
	/*なぜGoogleマップよりも*/
	.front .reason{
		padding:5%;
	}
	.front .reason h2{
		font-size:1.3em;
		letter-spacing:0;
	}
	.front .reason .reason_box{
		font-size:0.9em;
	}
	
	/*比較*/
	.front .comparison{
		padding:5%;
	}
	.front .comparison h2{
		font-size:1.5em;
	}
	.front .comparison .comparison_text{
		font-size:.9em;
	}
	.front .comparison .medialist_box{
		width:100%;
	}
	.front .comparison .medialist_box li{
		font-size:1.0em;
	}
	.front .comparison .medialist_box .em {
		font-size:1.3em;
	}
	.front .comparison .setsumei{
		width:100%;
		font-size:0.8em;
		line-height:2.1em;
	}
	.front .comparison .setsumei .markup{
		font-size:1.1em;
		padding:0 10px;
	}
	.front .comparison .comparison_image{
		overflow-x:scroll;
		margin-top: 15px;
	}
	.front .comparison .comparison_image img{
		width:800px;
		max-width:150%;
	}
	.front .comparison .scroll_guide{
		font-size:10px;
		margin-top:50px;
	}
	
	/*メッセージ*/
	.front .message{
		padding:5%;
	}
	.front .message h3{
		font-size:1.3em;
	}
	.front .message h3 .small{
		font-size:0.7em;
	}
	.front .message .text{
		font-size:0.8em;
	}
	.front .message .name{
		font-size:0.8em;
	}
	
	/*よくあるご質問*/
	.front .qa h2{
		font-size:1.7em;
	}
	.front .qa h2::after{
		height:80px;
	}
	.front .qa .qa_box{
		margin-top:30px;
	}
	.front .qa .qa_head h3{
		font-size:1.2em;
		padding-left:60px;
	}
	.front .qa .answer_text{
		font-size:0.8em;
	}
	
	/*明るい未来*/
	.front .future h2{
		font-size:1.1em;
		padding:3%;
		line-height:2em;
	}
	.front .future .text{
		font-size:1em;
	}
	.front .future .cta_btn{
		padding: 18px 78px 18px 42px;
	}
	
	/*end_cta*/
	.front .end_cta{
		padding:5%;
	}
	.front .end_cta h2{
		font-size:1.3em;
	}
	.front .end_cta .end_cta_image img{
		margin-top:15px;
	}
	
	/*CTAボタン*/
	.front .cta_box .lead{
		font-size:1.1em;
		text-align:left;
	}
	.front .cta_box .badge{
		font-size:1em;
	}
	.front .cta_box .cta_btn{
		font-size:17px;
	}
}


/* ダウンロード完了（download_complete）
------------------------------------------ */
.download_complete{
	padding:8% 5%;
}
/* ===========================================
 フッター（footer）
 * ======================================== */
.footer{
	width:100%;
	padding:20px;
	background:#fff;
	text-align:center;
}
.footer .logo{
	max-width:300px;
}
.footer .address{
	font-size:0.8em;
	font-weight:bold;
	margin-top:16px;
}
.footer .copyright{
	font-size:0.8em;
	font-weight:bold;
	margin-top:40px;
}
