@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/* アピールエリア---------------------------------------------- *
/*全体*/
a:hover{
	color: #f2f2f2;
}

.item-label {
    background: linear-gradient(#5089bf 0 0) bottom /var(--d, 0) 2px no-repeat;
    transition: 0.5s;
}
.item-label:hover {
	--d: 70%;
}
.navi-in a:hover {
	background-color: transparent;
	transition: initial;
    color: initial;
}

/*記事一覧投稿日更新日アイコン*/
.widget-entry-cards.large-thumb-on .card-content{
	max-height: 75%;
}
.new-entry-card-date.widget-entry-card-date.display-none {
    display: block;
}
.new-entry-card-post-date.widget-entry-card-post-date.post-date{
	position: relative;
}
.new-entry-card-post-date.widget-entry-card-post-date.post-date::before{
	font-family: "Font Awesome 5 Free";
	content: "\f304";
	font-weight: 900;
}
span.new-entry-card-update-date.widget-entry-card-update-date.post-update{
	position: relative;
}
span.new-entry-card-update-date.widget-entry-card-update-date.post-update::before{
	font-family: "Font Awesome 5 Free";
	content: "\f01e";
	font-weight: 900;
}


/*見出し*/
.article h1{
  font-size: 26px;
  font-size: 2rem;
  position: relative;
  padding: 1.5rem;
  text-align: center;
	margin-bottom: 40px;
}
.article h1::after {
  position: absolute;
  content: '';
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  width: 100px;
  height: 4px;
  background: #5089bf;
}

.article h2::before {
    position: absolute;
    content: '';
    width: 1200px;
    height: 2px;
    background-color: #5089bf;
    left: -1200px;
}
.article h2::after {
	content: attr(data-en);
	display: block;
	font-size: 170%;
    text-transform: uppercase;
    position: absolute;
    top: -16px;
    left: 0;
    font-style: italic;
	font-family: serif;
    color: rgba(80, 137, 191,0.6);
	z-index: -1;
}
@media screen and (max-width: 480px){
	.article h2::after {
		font-size: 100%;
   }
}

.article h2{
	background: none!important;
	position: relative;
	z-index: 100;
}
.article h3 {
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    padding-left: 0;
}

/*見出しここまで*/


.front-top-page #main .entry-title{
  display: none;
}
.front-top-page #main .date-tags{
  display: none;
}
.front-top-page #main .author-info{
	display: none;
}

.page #main .date-tags{
  display: none;
}
.page #main .author-info{
	display: none;
}

.wp-block-cover{
	  margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    width: auto;
}

.logo-menu-button img {
    max-height: 36px;
	padding-top: 7px;
}

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

.is-header-fixed .header-container {
    z-index: 3;
    height: 80px!important;
    padding: 10px 0;
}
@media screen and (max-width: 1023px){
.is-header-fixed .header-container {
    z-index: 3;
    height: auto!important;
    padding: 0;
}
.appeal {
    background-position: 40% center;
	 height: calc(100vh - 50px);
	}
}

.appeal {
	 height: calc(100vh - 80px);
}

.appeal-in {
   min-height: 100%;/*パソコンでの高さ調整*/
	min-width:100%;/*幅を最大に*/	
	background-color:rgba(255,255,255,.5);/*背景色、白を透過させる*/
	backdrop-filter: blur(3px);/*ぼかし*/
	 padding: 0 5% 3% 5%;
}

/*480px以下*/
@media screen and (max-width: 480px){
	.appeal-in {
		min-height: 100%!important;/*スマホでの高さ調整*/
	}
}

/*コンテンツエリア*/
.appeal-content {
	width:1000px;
   max-width: 1000px;
	padding:2em 1em;/*内側余白調整*/
	background-color:transparent;/*コンテンツエリアの背景無効化*/
	/*text-align: left;*/
}
/*@media screen and (max-width: 480px){
	.appeal-content {
		text-align: left;
	}
}*/


/*タイトル*/
.appeal-title{
padding-bottom:1.5em;/*タイトル下の余白*/
font-weight:bold;/*文字の太さ*/
font-size:1.8em;/*タイトル文字の大きさ*/
}

/*本文*/
.appeal-message {
 font-size: 1em;/*本文文字の大きさ*/
}
/*480px以下*/
@media screen and (max-width: 480px){
.appeal-message {
 font-size: .8em;/*スマホ表示する文字の大きさ*/
}	
}

/*ボタン*/
.appeal-button{
background-color:transparent!important;/*ボタンの背景色無効化*/
font-weight:normal;/*文字の太さ*/
color: #555; /*ボタン部分文字とアイコンの色*/
}

/*アイコンを追加*/
.appeal-button:before{
display:block;
font-family: "Font Awesome 5 Free";
font-weight:bold;
content: "\f103";/*アイコン指定*/
font-size: 1.6em;/*アイコンの大きさ*/
animation: move 1s infinite alternate ease-in-out;/*以下、アイコンを動かすアニメーション*/
}

@keyframes move{
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(10px);
  }
}

/*スムーズにスクロール*/
html { scroll-behavior: smooth;}

/*フッターサイドお問い合わせボタン*/
.footer-right .scrollcontact p{
    position: fixed;
    bottom: 20%;
    right: 0;
    display: block;
    width: 45px;
	filter: drop-shadow(0px 3px 5px #aaa);
	z-index: 100;
	animation: scrollcontact 1s ease 1.5s forwards;
	opacity: 0;
}
@keyframes scrollcontact {
  0% {
	  opacity: 1;
    transform: translateX(45px);
  }
  100% {
	  opacity: 1;
    transform: translateX(0);
  }
}
.footer-mobile .scrollcontact p {
    position: fixed;
    bottom: 4px;
    left: 0;
    display: block;
    width: 200px;
	filter: drop-shadow(0px 3px 5px #aaa);
	z-index: 100;
	animation: smascrollcontact 1s ease 1.5s forwards;
	opacity: 0;
	perspective: 1000; 
}
@keyframes smascrollcontact {
  0% {
	  opacity: 1;
    transform: translateX(-200px);
  }
  100% {
	  opacity: 1;
    transform: translateX(0);
  }
}

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}


/* --- Cocoonアピールエリア カスタマイズ --- */

/* アピールエリア全体の設定 */
.appeal-area {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
}

/* 背景画像の上に黒いオーバーレイをかける */
.appeal-area::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 1;
}

/* コンテンツをオーバーレイの上に表示 */
.custom-appeal-content {
  position: relative;
  z-index: 2;
  padding: 20px;
}

/* Instagramバッジ */
.instagram-badge {
  display: inline-flex;
  align-items: center;
  background-color: #fff;
  color: #000;
  padding: 8px 20px;
  border-radius: 9999px;
  margin-bottom: 24px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}

.instagram-icon {
  color: #E1306C; /* Instagramのピンク色 */
  margin-right: 8px;
}

.instagram-text {
  font-weight: bold;
  font-size: 16px;
}

/* メインキャッチコピー */
.main-catchphrase {
  font-size: 32px;
  font-weight: 900;
  line-height: 1.5;
  margin-bottom: 16px;
  text-shadow: 0 2px 4px rgba(0,0,0,0.5);
  color: #4d4d4d; /* 文字色を白に指定 */
}

/* サブキャッチコピー */
.sub-catchphrase {
  font-size: 18px;
  margin-bottom: 32px;
  color: #4d4d4d; /* 文字色を白に指定 */
}

/* CTAボタン */
.cta-button {
  display: inline-block;
  background-color: #FBBF24; /* 黄色 */
  color: #000;
  font-weight: bold;
  font-size: 18px;
  padding: 16px 40px;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(251, 191, 36, 0.4);
}

.cta-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(251, 191, 36, 0.6);
}

.cta-subtext {
  margin-top: 16px;
  font-size: 14px;
  font-weight: bold;
  color: #4d4d4d;
}

/* スマートフォン向けの調整 */
@media (max-width: 768px) {
  .main-catchphrase {
    font-size: 24px;
  }
  .sub-catchphrase {
    font-size: 16px;
  }
  .instagram-text {
    font-size: 14px;
  }
  .cta-button {
    font-size: 16px;
    padding: 14px 30px;
  }
}