/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Feb 17 2026 | 02:31:36 */
/*-------------------------------*/
/*プラン/製品詳細ページ*/
/*-------------------------------*/

/*他社比較表*/
figure.price_chart_wrap.wp-block-table table td,
figure.price_chart_wrap.wp-block-table table th {
  border: 3px solid #F5F5F5;
  padding: 1em .75em;
  line-height: 1.4em;
}
/*-------------------------------*/
/*会社概要ページ*/
/*-------------------------------*/
.company_profile_table .wp-block-table td, .wp-block-table th,
.company_profile_table .wp-block-table td, .wp-block-table td{
    padding: .8em .6em;
}
/* アーカイブ　hover時に opacity*/
.post-type-archive-construction .l-mainContent__inner .p-postList__item .p-postList__body:hover{
	opacity:1;
}
.-ps-style-normal .p-postList__item:hover .p-postList__body, .-type-card .p-postList__item:hover .p-postList__body, .-type-list .p-postList__item:hover .p-postList__body {
	opacity:1;
}
/* -------------
投稿にボタンの追加
-----------------------------*/
.-type-card .p-postList__meta:after {
	content: "詳細はこちら »";
	display: inline-block;
	width: 100%;
	padding: 0.8rem 1.2rem;
	margin: 1.2em auto 0;
	background:var(--color_main);
	color: #fff;
	text-align: center;
	font-weight: 600;
	border-radius: 50px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
	transition: all 0.3s ease;
	cursor: pointer;
	letter-spacing: 0.05em;
	text-transform: none;
	font-size:14px;
}

/* hover時のエフェクト */
.-type-card .p-postList__meta:hover:after {
	transform: translateY(-3px);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.25);
}

.p-postList__link {
display: flex;
flex-direction: column;
}
/* .p-postList__body {
position: relative;
transition: opacity .25s;
flex-grow: 1;
display: flex;
flex-direction: column;
} */
/* .p-postList .p-postList__title {
flex-grow: 1;
} */
/* -------------
一覧ページ記事設定
-----------------------------*/
.-type-card .p-postList__title, .-type-list .p-postList__title, .-type-list2 .p-postList__title{
  position: relative;
  display: inline-block;
  padding-bottom: 5px;
}
.-type-card .p-postList__title::after , .-type-list .p-postList__title::after , .-type-list2 .p-postList__title::after {
  content: "";
  position: absolute;
  bottom: 0;
    left: 0;
    width: 30%;
    height: 0.5px;
  background-color: #000; /* 下線の色 */
}
@media (min-width: 960px) {
    .-sidebar-on .-type-card.-pc-col3 .p-postList__item, .-sidebar-on .-type-thumb.-pc-col3 .p-postList__item {
        width: 33.33333%;
    }
}
@media (min-width: 600px) {
    #sidebar .-type-list .p-postList__title, .-type-card .p-postList__excerpt {
        font-size: 12px;
    }
}
@media (min-width: 600px) {
  #sidebar .-type-card .p-postList__title, .-related .p-postList__title, .-type-thumb .p-postList__title, .w-footer:not(.-col1) .p-postList__title {
        font-size: 12px;
    }
}
/* スマホ時少し余白調整 */
@media (max-width: 600px) {
.c-tabBody__item .p-postList .p-postList__title, .-type-card .p-postList__excerpt{
    font-size: 0.8em;
}
}
/* 本文部分（タイトル＋抜粋＋日時）を伸縮させる */
.p-postList__body {
    display: flex;
    flex-direction: column;
    flex: 1;
}

/* 抜粋部分を伸び縮みさせて高さを調整 */
.p-postList__excerpt {
    flex: 1;
}
/* -------------
サイドバーの設定
-----------------------------*/
.p-profileBox {
  position: relative;
  padding: 16px;
  overflow: hidden;
  z-index: 1;
}
.p-profileBox::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 1px;
  background: linear-gradient(135deg, #000000, #cccccc); /* 黒→グレー */
  border-radius: inherit;
  z-index: -1;
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}
.p-profileBox__btn a{
	    width: 100%;
}
/* -------------
投稿の詳細ページ
-----------------------------*/
@media (min-width: 600px) {
	.single .c-postTitle__ttl {
		margin: 0 0.4em 0;
		border-top: 1px solid #ddd;
		border-bottom: 1px solid #ddd;
		padding: 0.3em 0;
	}
}
.c-postTitle__date {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 70px; /* 円のサイズ */
	height: 70px;
	border-radius: 50%;
	background: var(--color_main); /* メインカラーを使用 */
	color: #fff;
	font-weight: 600;
	text-align: center;
	line-height: 1.2;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
	flex: none;
    margin: 0;
	padding:0;
}

/* 年部分 */
.c-postTitle__date .__y {
	font-size: 0.75rem;
	opacity: 0.8;
}
@media (min-width: 600px) {
	.c-postTitle__date .__y {
		font-size: 13px;
	}
}
@media (min-width: 600px) {
	.c-postTitle__date .__md {
		font-size: 13px;
	}
}
/* -------------
-type-listの装飾
-----------------------------*/

.-type-list .p-postList__item {
	margin-bottom: 0;
	margin-top: 0;
	border-bottom: 1px dashed #ddd;
	padding: 1em 0;
}
.c-tabBody__item .p-postList__body {
	position: relative;
	transition: opacity .25s;
/* 	flex-grow: 1; */
	display: flex;
	flex-direction: column;
	background-image: linear-gradient(transparent calc(100% - 1px), var(--color_gray) 50%, var(--color_gray)), linear-gradient(90deg, transparent calc(100% - 1px), var(--color_gray) 50%, var(--color_gray));
	background-repeat: repeat;
	background-size: 16px 16px;
    margin: 0.4em 0.6em;
}
/* .c-tabBody__item .p-postList .p-postList__title {
	flex-grow: 1;
} */
.c-tabBody__item .p-postList__meta {
	display: block;
	text-align: center;
}
/* -------------
サイドバー設定
-----------------------------*/
.widget_archive select, .widget_categories select, .wp-block-archives select, .wp-block-categories select {
	border: 1px solid #00000094;
}
.c-listMenu a {
	border-bottom: 1px dashed var(--color_main);
}
.p-profileBox {
	background-image: repeating-linear-gradient(45deg, #045c3d14, #045c3d14 2px, transparent 2px, transparent 9px);
	box-shadow: 1px 2px 9px #ddd;
	border: none;
}
.widget_archive select, .widget_categories select, .wp-block-archives select, .wp-block-categories select {
	border: 1px solid #00000094;
}
.widget_archive .c-listMenu a {
	border-bottom: 1px solid var(--color_main);
}
.widget_categories>ul>.cat-item>a:before, .wp-block-categories-list>li>a:before {
	color: var(--color_main);
}

/* -------------
目次の設定
-----------------------------*/
/* ===== ハウスクリーニング用 目次スタイル ===== */
.post_content .p-toc__list {
  border: 2px solid var(--color_main);
  padding: 1.2em 1.5em;
  box-shadow: 0 3px 8px rgba(0,0,0,0.05);
}

ul.is-style-index li {
  position: relative;
  list-style: none;
  margin: 0.6em 0;
  padding-left: 1.8em;
  font-weight: 500;
}

/* アイコン変更：掃除用スプレーアイコン */
ul.is-style-index li:before {
  font-family: "Font Awesome 6 Free";
  content: "\f1eb"; /* スプレーアイコン */
  font-weight: 900;
  color: var(--color_main, #009fe8);
  position: absolute;
  left: 0;
  top: 0.1em;
}

/* リンクデザイン */
.p-toc__link {
  position: relative;
  text-decoration: none;
  color: #333;
  transition: all 0.3s ease;
  border-bottom: 1px dashed #0000004d;
  padding-bottom: 2px;
}

.p-toc__link:hover {
  color: var(--color_main, #009fe8);
  border-bottom: 1px solid var(--color_main, #009fe8);
}

.p-toc__link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0;
  height: 2px;
  background: var(--color_main, #009fe8);
  transition: width 0.3s ease;
}

.p-toc__link:hover::after {
  width: 100%;
}

/* スマホ時少し余白調整 */
@media (max-width: 600px) {
  ul.is-style-index {
    padding: 1em;
  }
  ul.is-style-index li {
    margin: 0.4em 0;
  }
}

/*  */
/* 著者ボックス全体 */
.p-authorBox {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background: #fff;
  border: 2px solid var(--color_main);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  transition: all 0.3s ease;
}

.p-authorBox:hover {
  box-shadow: 0 6px 16px rgba(0,0,0,0.1);
  transform: translateY(-2px);
}

/* 左側（画像＋名前） */
.p-authorBox__l {
  text-align: center;
  flex-shrink: 0;
}

.p-authorBox .avatar{
  border: 3px solid var(--color_main);
  width: 140px;
  height: 140px;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.p-authorBox__l img:hover {
  transform: scale(1.05);
}

.p-authorBox__name {
  display: inline-block;
  margin-top: 10px;
  font-weight: 600;
  color: var(--color_main);
  text-decoration: none;
  transition: color 0.3s ease;
font-size:14px!important;
}

.p-authorBox__name:hover {
  color: #000;
}

/* 右側（説明文） */
.p-authorBox__r {
  flex: 1;
border-left:none;
}

.p-authorBox__desc {
  font-size: 0.85rem;
  line-height: 1.8;
  border-left: 4px solid var(--color_main);
  padding-left: 15px;
}

/* スマホ対応 */
@media (max-width: 768px) {
  .p-authorBox {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .p-authorBox__desc {
    border-left: none;
    border-top: 3px solid var(--color_main);
    padding-left: 0;
    padding-top: 10px;
  }
}
/* フォーム全体のスタイル */
.wpcf7 {
margin: auto;
}
.label_wrap{
border-radius:20px;
border:2px solid #000;
background-color:#fff;
padding:2em;
	margin-bottom:2em;
}
/* 2列の器 */
.two_col{
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

/* 2列の各カラム */
.two_col .col{
  flex: 1;
  min-width: 0;
  position: relative;
}

/* CF7のwrapを幅100%に */
.two_col .wpcf7-form-control-wrap{
  display: block;
  width: 100%;
}

/* inputをきっちり100% */
.two_col input{
  width: 100%;
  box-sizing: border-box;
}


.two_col{
  padding-bottom: 1.5em;
}


/*各項目のスタイル*/
.form_item{
	background-color:#222222;
	padding:.5em;
	border-radius:5px;
	color: #fff;
	display:block;
	width:100%;
	font-weight:bold;
	font-size: 18px;
}
/*ラベルを2カラムにする場合*/
.column_label .wpcf7-form-control-wrap {
    display: inline;
}

.column_label_left{
	margin-right:1%;
}
/* ラベルのスタイル */
.wpcf7-form label {
display: block;
}
.wpcf7-form-control-wrap{
	display:block;
	padding-bottom:1.5em;
}
/* 必須フィールドのラベルスタイル */
.wpcf7-form .required {
background-color: #ff0000; /* レッド */
color: white;
padding: 2px 5px;
border-radius: 3px;
margin-left: 10px;
font-size: 12px;
}
.label_wrap input {
    width: 100%;
    background-color: #ebebeb;
    border: none;
    border-radius: 5px;
    color: #333;
    padding: .8em .5em;
	font-size: 18px;
	margin:1.5em 0 0;
}
/* インプットフィールドのスタイル */
.wpcf7-form textarea {
width: 100%;
padding: 10px;
border: 1px solid #cccccc; /* ライトグレー */
border-radius: 5px;
margin-bottom: 20px;
font-size: 16px;
background-color: #ffffff; /* 白 */
}
/*チェックボックス*/
.wpcf7-list-item {
    display: inline-block;
    margin: 0 1em 0 0;
}
input[type="checkbox"] {
    width: 15px;
	border: 1px solid #000;
	border-radius: 3px;
	margin:1em 0;
}
/* チェックボックス＋文字を中央揃えにする */
.wpcf7-checkbox .wpcf7-list-item label{
  display: inline-flex;
  align-items: center;
  gap: .4em;          /* 文字との間隔 */
}
span.wpcf7-list-item-label {
    font-size: 16px;
}
 .time_check_wrap {
    margin-top: 1em;
}
/* テキストエリアのスタイル */
.wpcf7-form textarea {
height: 150px;
resize: vertical;
}
/*住所*/
.address_wrap {
font-weight:bold;
color:#323436;
margin-bottom:.5em;
}
.address_wrap input{
	margin:0;
}
/*都道府県プルダウン*/
.address_wrap select {
    background-color: #EAEAEA;
    border: none;
    border-radius: 5px;
    color: #333;
    padding: 1em;
    font-weight: bold;
}
/* 送信ボタンのスタイル */
.wpcf7-form input[type="submit"] {
    background-color: #000;
    color: white;
    cursor: pointer;
    transition: background-color 0.3s ease;
    border: none;
    display: block;
    margin: 0 auto;
    min-width: 180px;
    padding: .5em 1em;
    font-weight: 700;
    border-radius: 5px;
    font-size: 1.3em;
}
.wpcf7-form input[type="submit"]:hover {
background-color: #53C728;
}
/* エラーメッセージと成功メッセージのスタイル */
.wpcf7-form .wpcf7-not-valid-tip {
color: red;
font-size: 14px;
}
.wpcf7-form .wpcf7-mail-sent-ok {
color: green;
font-size: 16px;
margin-bottom: 20px;
}

@media (min-width: 600px) {
br.spbr {
    display: none;
}
}
@media (max-width: 599px) {
 .label_wrap {
    padding: 2em 1em;
}
 .form_item{
	font-size: 16px;
}
 .time_check_wrap input {
        margin: 0;
    }
}