@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
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*共通*/
.body {
	overflow-x: hidden;
}

.wrap {
	max-width: 1256px;
	width: 100%;
}

.article h2 {
	background-color:transparent;
}

.article h3 {
	border-left: none;
	border-right:none;
	border-top:none;
	border-bottom:none;
}

.article h4 {
	font-size: 1.2rem;
}

.navi-in a:hover {
	color: #ff6b35;
	background: initial;
}

a.site-name.site-name-text-link {
	transition: opacity .3s;
}

a.site-name.site-name-text-link:hover {
	opacity: .6;
}

.slick-dots {
	display: none;
}

.slick-slide img {
	transition: all .3s ease-in;
}

figure.carousel-entry-card-thumb.card-thumb {
	overflow: hidden;
}

.slick-slide:hover img {
	transform: scale(1.1);
}

@media screen and (min-width: 769px) {
	.hidden-pc {
		display: none;
	}
}

@media screen and (max-width: 768px) {
	.hidden-sp {
		display: none;
	}
}

@media screen and (max-width: 1023px) {
    .no-mobile-header-logo .header .header-in {
        display: none;
    }
}

.main {
	padding: 30px 20px;
	background: #4c4c4c;
}

@media screen and (max-width: 834px) {
	main.main {
		padding: 0;
		margin: 0;
	}
	
	.single-post main.main,
	.archive main.main {
		padding: 25px 15px;
	}
}

@media screen and (max-width: 480px) {
    .entry-title,
	.article h2,
	.article h3,
	.article h4 {
        padding: 0.6em 0.2em;
    }
}

.go-to-top-button {
	background: linear-gradient(135deg, #f4a261, #e76f51);
	border-radius: 50%;
}

.fa-chevron-up:before {
    position: absolute;
    top: 7px;
    left: 50%;
    transform: translateX(-50%);
}

label#navi-menu-open {
    color: #fff;
    font-weight: 700;
}

.mobile-header-menu-buttons {
	background: #4c4c4c;
}

.menu-close-button {
    background: #4c4c4c;
    color: #fff;
}

ul.menu-drawer {
    display: flex;
    flex-direction: column;
	gap: 1.5rem;
}

.menu-drawer a {
	font-weight: 700;
}

.menu-content .menu-drawer {
	padding: 1rem;
}

.header {
	background: #4C4C4C;
}

.copyright {
	color: #fff;
}

.breadcrumb,
.breadcrumb a {
	color: #fff;
}

.menu-content {
	background: url('https://kspgym.com/wp-content/uploads/565015767881089182.jpg') no-repeat center center / cover;
}

.menu-content::before {
	content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    z-index: -1;
}

.menu-drawer a {
	color: #fff;
	position: relative;
	border-bottom: 1px dotted #888;
}

.menu-drawer a::before {
	content: "\f152";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	display: inline-block;
	margin-right: 15px;
}

.drawer-link__items {
	display: flex;
	padding: 1rem;
	align-items: center;
    gap: 1rem;
}

.drawer-link__item a {
	color: #fff;
}

.drawer-link__item a:hover {
	color: #fff;
}

.drawer-banner a {
	display: block;
	width: 100px;
}

.tagline {
	display: none;
}




      /* メインビジュアル */
        .hero {
            background: rgba(0, 0, 0, 0.6) url('https://kspgym.com/wp-content/uploads/565015471343534186.jpg');
            background-size: cover;
            background-position: center;
			background-blend-mode: darken;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
            color: white;
        }

		@media screen and (max-width: 767px) {
			.hero {
				padding-inline: 15px;
			}
		}		

        .hero-content .head-title {
            font-size: 3rem;
            margin-bottom: 1rem;
            font-weight: 700;
			max-width: 100%;
        }

        .hero-content p {
            font-size: 1.3rem;
            margin-bottom: 2rem;
            max-width: 600px;
			margin-inline: auto;
        }

        .cta-buttons {
            display: flex;
            gap: 1rem;
            justify-content: center;
            flex-wrap: wrap;
        }

        .btn {
            padding: 15px 30px;
            border: none;
            border-radius: 50px;
            font-size: 1.1rem;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s;
            text-decoration: none;
            display: inline-block;
        }

		.carousel-in {
			background: #4c4c4c;
		}


        /* セクション共通 */
        .section {
            padding: 80px 0px;
            max-width: 100%;
            margin: 0 auto;
			position: relative;
			z-index: 0;
        }

		.info-cards__content._info-card__bg {
			position: relative;
			z-index: 0;
			padding-block: 80px;
			color: #fff;
		}

		.section::before,
		.qualifications._introduction-bg::before,
		.info-cards__content._info-card__bg::before {
			content: "";
 			inset: 0; /* top, right, bottom, left 全て0 */
 			left: 50%;
  			width: 100vw;
  			margin-left: -50vw;
			z-index: -1;
			position: absolute;
		}

		.section._feature-bg::before {
			background:url('https://kspgym.com/wp-content/uploads/566336325033132192.jpg') no-repeat center center / cover;
		}

		.section._contact-bg::before {
			background:url('https://kspgym.com/wp-content/uploads/566337360825418171.jpg') no-repeat center center / cover;
		}

		.section._faq-bg::before {
			background:url('https://kspgym.com/wp-content/uploads/566334277206409406.jpg') no-repeat center center / cover;
		}

		.qualifications._introduction-bg::before {
			background: url('https://kspgym.com/wp-content/uploads/566336373620474282.jpg') no-repeat center center / cover;
		}

		.info-cards__content._info-card__bg::before {
			background: url('https://kspgym.com/wp-content/uploads/566334277927829835.jpg') no-repeat center center / cover;
		}

		.section._shido-bg::before {
			background:url('https://kspgym.com/wp-content/uploads/566336334764441686.jpg') no-repeat center center / cover;
		}

		.section::after,
		.qualifications._introduction-bg::after,
		.info-cards__content._info-card__bg::after {
			content: "";
 			inset: 0; /* top, right, bottom, left 全て0 */
 			left: 50%;
  			width: 100vw;
  			margin-left: -50vw;
			z-index: -1;
			position: absolute;
		}

		.section._feature-bg::after,
        .section._contact-bg::after,
		.section._faq-bg::after,
		.qualifications._introduction-bg::after,
		.info-cards__content._info-card__bg::after,
		.section._shido-bg::after {
			background: rgba(0, 0, 0, .6);
		}

        .section-title {
            text-align: center;
            font-size: 2.5rem;
            margin-bottom: 3rem;
            color: #333;
            position: relative;
			text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
        }

        .section-title::after {
            content: '';
            display: block;
            width: 80px;
            height: 4px;
            background: linear-gradient(to right, #f4a261, #e76f51);
            margin: 1rem auto;
            border-radius: 2px;
        }

		.section-title._section-title__bg::after {
			background: linear-gradient(135deg, #2c5aa0 0%, #1e3d6f 100%);
		}

        /* 特徴セクション */
        .features {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 2rem;
            margin-top: 3rem;
        }

        .feature-card {
            background: white;
            padding: 2rem;
            border-radius: 15px;
            box-shadow: 0 5px 20px rgba(0,0,0,0.1);
            text-align: center;
            transition: transform 0.3s;
        }

        .feature-card:hover {
            transform: translateY(-5px);
        }

        .feature-icon {
            width: 80px;
            height: 80px;
            background: linear-gradient(135deg, #f4a261, #e76f51);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1rem;
            font-size: 2rem;
            color: white;
        }

        .feature-card h3 {
            font-size: 1.5rem;
            margin-bottom: 1rem;
            color: #333;
        }

        /* サービスセクション */
        .services {
            background: #4c4c4c;
        }

        .service-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
            gap: 3rem;
            margin-top: 3rem;
        }

        .service-card {
            border-radius: 15px;
            overflow: hidden;
            box-shadow: 0 5px 20px rgba(0,0,0,0.1);
            transition: transform 0.3s;
			display: flex;
			flex-direction: column;
        }

        .service-card:hover {
            transform: translateY(-5px);
        }

        .service-image {
            height: 250px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-size: 1.2rem;
			font-weight: 700;
			position: relative;
			z-index: 0;
        }

	.service-image::before {
			content: "";
			position: absolute;
  		  top: 0;
		    left: 0;
		    width: 100%;
		    height: 100%;
 		   background: rgba(0, 0, 0, 0.6);
		    z-index: -1;
		}

		.service-image._training {
			background: url('https://kspgym.com/wp-content/uploads/566336339864715538.jpg') no-repeat center 10% / cover;
		}

		.service-image._chiropractic {
			background: url('https://kspgym.com/wp-content/uploads/566336309296628240.jpg') no-repeat center center / cover;
		}

        .service-content {
            padding: 1.5rem;
			display: flex;
			flex-direction: column;
			justify-content: space-between;
			height: auto;
			background: #fff;
			flex: 1;
        }

		@media screen and (max-width: 768px) {
			.service-content {
				padding: 1rem;
			}
		}

        .service-content h3 {
            font-size: 1.8rem;
            margin-bottom: 1rem;
            color: #333;
        }

		@media screen and (max-width: 768px) {
			.service-content h3 {
				font-size: 1.4rem;
			}
		}

        .service-content p {
            color: #666;
            margin-bottom: 1.5rem;
        }

        .service-features {
            list-style: none;
            margin-bottom: 1.5rem;
        }

        .service-features li {
            padding: 0.5rem 0;
            border-bottom: 1px solid #ddd;
            color: #555;
        }

        .service-features li:last-child {
            border-bottom: none;
        }

        .service-features li::before {
            content: '✓';
            color: #f4a261;
            font-weight: bold;
            margin-right: 0.5rem;
        }

/*カルーセル*/
.carousel-content .a-wrap {
	box-shadow: 0 5px 20px rgba(0,0,0,0.1);
	background: #fff;
	border-radius: 6px;
}

        /* アクセスセクション */
        .access-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 3rem;
            margin-top: 3rem;
        }

        .access-info {
            background: white;
            padding: 2rem;
            border-radius: 15px;
            box-shadow: 0 5px 20px rgba(0,0,0,0.1);
        }

		@media screen and (max-width: 480px) {
			.access-info {
				padding: 1rem;
			}
		}

        .access-info h3 {
            font-size: 1.5rem;
            margin-bottom: 1rem;
            color: #333;
        }

		span.icon {
			display: inline-block;
			width: 30px;
			height: 30px;
		}

		@media screen and (max-width: 768px) {
			span.icon {
				width: 25px;
				height: 25px;
			}
		}

		.info-card h2,
		.parking-section h2,
		.map-section h2,
		.parking-note h2,
		.special-notice h3 {
			display: flex;
			align-items: center;
			gap: 10px;
			color: #fff;
		}

		@media screen and (max-width: 484px) {
			.special-notice h3 {
/* 				font-size: 21px; */
			}
		}

		.info-card {
			margin-bottom: 5rem;
		}

        .info-item {
            display: flex;
/*             align-items: center; */
            margin-bottom: 1rem;
            padding: 0.5rem 15px;
			max-width: 1000px;
			margin-inline: auto;
        }

		span.label {
			flex-shrink: 0;
			flex-basis: 120px;
			border-bottom: 1px solid #FF6B35;			
		}

		span.value {
			width: 75%;
			border-bottom: 1px solid #888;
			padding-bottom: 1rem;
		}

		span.label,
		span.value {
			color: #fff;
		}

        .info-icon {
            width: 35px;
            height: 35px;
            background: #f4a261;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-right: 1rem;
			flex-shrink: 0;
        }

		.info-icon img {
			width: 20px;
			height: 20px;
		}

		a.text-link {
    		text-underline-offset: 4px;
			transition: all .3s ease-in;
		}

		.parking-section h2 img,
		.parking-note h2 img,
		.map-section img {
			width: 30px;
			height: 30px;
		}

		@media screen and (max-width: 768px) {
			.parking-section h2 img,
			.parking-note h2 img,
			.map-section img {
				width: 25px;
				height: 25px;
			}
		}

		.parking-note ul li {
			color: #fff;
		}

		svg.svg-inline--fa.fa-line {
			font-size: 30px;
			color: #00C300;
		}

		@media screen and (max-width: 768px) {
			svg.svg-inline--fa.fa-line {
				font-size: 25px;
			}
		}

        .map-placeholder {
            background: #f8f9fa;
            height: auto;
            border-radius: 16px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: #666;
            font-size: 1.2rem;
        }

		@media screen and (max-width: 768px) {
			.map-placeholder {
				height: 300px;
			}
		}

		.map-placeholder iframe {
			border-radius: 16px;
		}

		@media screen and (max-width: 768px) {
			.contact-wrapper {
				padding-inline: 15px !important;
			}
		}

		.contact-item {
			flex: auto;
		}

		.contact-img {
			width: 40px;
			height: 40px; 
		}

        /* フッター */
        .footer {
            background: #4C4C4C;
            color: white;
            padding: 3rem 5% 1rem;
			margin-top: 0;
        }

        .footer-content {
            max-width: 1200px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 2rem;
        }

        .footer-section h3 {
            margin-bottom: 1rem;
            color: #f4a261;
        }

        .footer-section p, .footer-section a {
            color: #ccc;
            text-decoration: none;
            line-height: 1.8;
        }

        .footer-section a:hover {
            color: #f4a261;
        }

        .footer-bottom {
            text-align: center;
            margin-top: 0;
            padding-top: 2rem;
            border-top: 2px solid #FF6B35;
            color: #999;
        }

		footer.article-footer.entry-footer {
			display: none;
		}

		.navi {
			background: #4C4C4C;
		}

		.navi-in > ul {
			border-top: 2px solid #FF6B35;
		}

		.navi-in a {
			color: #fff;
			font-weight: 700;
		}

		.navi-in li.menu-item-has-children .fa.fa-angle-down {
			transition: all .3s ease-in-out;
			font-weight: 700;
		}

		.navi-in li.menu-item-has-children:hover .fa.fa-angle-down {
			transform: rotate(180deg);
			color: #FF6B35;
		}

		.navi-in > ul .sub-menu a {
			background: #4c4c4c;
		}

		.navi-footer-in a {
			color: #fff;
		}

		.navi-footer-in a:hover {
		    background-color: initial;
		    color: #fff;
		    opacity: .6;
		}

        /* レスポンシブ */
        @media screen and (max-width: 768px) {
            .nav-links {
                display: none;
            }
            
            .hamburger {
                display: flex;
            }
            
            .hero-content .head-title {
                font-size: 2rem;
            }
            
            .hero-content p {
                font-size: 1.1rem;
            }
			
			.hero-content p:nth-child(2) {
				text-align: left;
			}
            
            .cta-buttons {
                flex-direction: column;
                align-items: center;
            }
            
			.section {
				padding: 60px 0;
			}
            
            .section-title {
                font-size: 2rem;
            }
            
            .service-grid {
                grid-template-columns: 1fr;
            }
            
            .access-grid {
                grid-template-columns: 1fr;
            }
            
            .footer-content {
                grid-template-columns: 1fr;
                text-align: center;
            }
        }


/************************************
** head-title__bg
************************************/
article#post-7 .article-header {
/* 	background: url('http://dream-blog.net/ks-personal/wp-content/uploads/566337359164473464.jpg') no-repeat center 45% / cover; */
	display: none;
}

article#post-15 .article-header {
	background: url('https://kspgym.com/wp-content/uploads/566336378233684073.jpg') no-repeat center 25% / cover;
}

article#post-27 .article-header {
	background: url('https://kspgym.com/wp-content/uploads/566337360221438123.jpg') no-repeat center top / cover;
}

article#post-17 .article-header {
	background: url('https://kspgym.com/wp-content/uploads/566336363084644728.jpg') no-repeat center 40% / cover;
}

article#post-21 .article-header {
	background: url('https://kspgym.com/wp-content/uploads/566336330436182205.jpg') no-repeat center 55% / cover;
}

.article-header {
	position: relative;
	z-index: 0;
}

.article-header::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.6); /* 半透明の黒で暗くする */
	z-index: -1; /* 背景画像とテキストの間に配置 */
}


/************************************
** 当ジムについて
************************************/
/*タイトル*/
        .article-header {
/*             background: linear-gradient(135deg, rgba(244, 162, 97, 0.9), rgba(231, 111, 81, 0.9)); */
			background: url('https://kspgym.com/wp-content/uploads/566337029223744050.jpg') no-repeat center center / cover;
            color: white;
            padding: 80px 5% 80px;
            text-align: center;
        }

		@media screen and (min-width: 541px) {
			.article-header {
/* 				background: linear-gradient(135deg, rgba(244, 162, 97, 0.9), rgba(231, 111, 81, 0.9)); */
				background: url('https://kspgym.com/wp-content/uploads/566337029223744050.jpg') no-repeat center center / cover;
				color: white;
				padding: 120px 5% 80px;
				text-align: center;
   		     margin-top: 80px;
			}
	
			body:not(.home) .article-header {
   		     margin-top: 0px;
			}
		}

        .article h1 {
            font-size: 2.5rem;
            margin-bottom: 1rem;
            font-weight: 700;
        }

		@media screen and (max-width: 768px) {
			.article h1 {
				font-size: 1.47rem;
			}	
		}


     /* コンセプトセクション */
        .concept-content {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 4rem;
            align-items: center;
            margin-bottom: 4rem;
        }

		@media screen and (max-width: 768px) {
			.concept-content {
				grid-template-columns: repeat(1, 1fr);
			}
		}

        .concept-text h3 {
            font-size: 1.8rem;
            margin-bottom: 1.5rem;
            color: #fff;
        }

		@media screen and (max-width: 460px) {
			.concept-text h3 {
				font-size: 1.49rem;
			}
		}

        .concept-text p {
            color: #fff;
            margin-bottom: 1.5rem;
        }

        .concept-image {
/*             background: linear-gradient(135deg, #f4a261, #e76f51);
            height: 300px;
            border-radius: 15px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-size: 1.2rem;
            text-align: center; */
        }

		.concept-image img {
			border-radius: 15px;
		}

       /* 特徴カード */
        .features-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 2rem;
            margin-top: 3rem;
        }

		@media screen and (max-width: 1023px) {
			.features-grid {
				grid-template-columns: repeat(2, 1fr);
			}
		}

		@media screen and (max-width: 768px) {
			.features-grid {
				grid-template-columns: repeat(1, 1fr);
			}
		}

        .feature-card {
            background: white;
            padding: 2.5rem;
            border-radius: 15px;
            box-shadow: 0 5px 20px rgba(0,0,0,0.1);
            text-align: center;
            transition: transform 0.3s;
            border: 1px solid #f0f0f0;
        }

        .feature-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 30px rgba(0,0,0,0.15);
        }

        .feature-icon {
            width: 80px;
            height: 80px;
            background: linear-gradient(135deg, #f4a261, #e76f51);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1.5rem;
            font-size: 2rem;
            color: white;
        }

		.feature-icon img {
			width: 30px;
			height: 30px;
		}

        .feature-card h4 {
            font-size: 1.2rem;
            margin-bottom: 1rem;
            color: #333;
			padding-inline: .2em;
        }

        .feature-card p {
            color: #666;
            line-height: 1.7;
			text-align: left;
        }

        /* ご利用の流れ */
        .flow-section {
/*             background: #f8f9fa; */
        }

        .flow-steps {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 5rem 2rem;
            margin-top: 3rem;
        }

		@media screen and (max-width: 1023px) {
			 .flow-steps {
				 grid-template-columns: repeat(2, 1fr);
			}
		}

		@media screen and (max-width: 768px) {
			 .flow-steps {
				 grid-template-columns: repeat(1, 1fr);
				 gap: 5rem;
			}
		}

        .flow-step {
            background: white;
            padding: 2rem;
            border-radius: 15px;
            text-align: center;
            position: relative;
            box-shadow: 0 5px 20px rgba(0,0,0,0.1);
        }

        .flow-step::before {
            content: attr(data-step);
            position: absolute;
            top: -15px;
            left: 50%;
            transform: translateX(-50%);
            width: 40px;
            height: 40px;
            background: linear-gradient(135deg, #f4a261, #e76f51);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-weight: bold;
            font-size: 1.1rem;
        }

		.flow-step img {
			border-radius: 16px;
		}

        .flow-step h4 {
            font-size: 1.2rem;
            margin: 1.5rem 0 1rem;
            color: #333;
			padding-inline: .2em;
        }

        .flow-step p {
            color: #666;
            line-height: 1.6;
			text-align: left;
        }

        /* FAQ */
        .faq-list {
            max-width: 800px;
            margin: 3rem auto 0;
        }

        .faq-item {
            background: white;
            border-radius: 10px;
            margin-bottom: 2rem;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1);
            overflow: hidden;
			flex-direction: column;
        }

		 .faq-item.is-open .faq-box__head-toggle::before {
			transform: translate(-50%, -50%);
		}

        .faq-question {
            background: #f8f9fa;
            padding: 1.5rem;
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-weight: 600;
            color: #333;
            transition: background 0.3s;
			margin-bottom: 0;
        }

        .faq-question:hover {
            background: #f0f0f0;
        }

		.faq-box__head-toggle {
			width: 26.182px;
			height: 26.182px;
			display: block;
			position: relative;
			background: linear-gradient(135deg, #f4a261, #e76f51);
			border-radius: 50%;
			flex-shrink: 0;
		}

		@media screen and (min-width: 769px) {
			.faq-box__head-toggle {
				width: 48px;
				height: 48px;
			}
		}

		.faq-box__head-toggle::before,
		.faq-box__head-toggle::after {
			content: "";
 		    position: absolute;
 		    top: 50%;
 		    left: 50%;
 		    width: 10px;
 		    height: 2px;
 		    background: #fff;
 	  	    border-radius: 50px;
 		    transition: transform 0.3s;
 		    transform: translate(-50%, -50%);
		}		

		@media screen and (min-width: 769px) {
			.faq-box__head-toggle::before,
			.faq-box__head-toggle::after {
				width: 19px;
				height: 3px;
			}
		}

		.faq-box__head-toggle::before {
	 		   transform: translate(-50%, -50%) rotate(90deg);
		}

		.faq-box__head-toggle::after {
			
		}

/*         .faq-question::after {
            content: '+';
            font-size: 1.5rem;
            color: #f4a261;
            transition: transform 0.3s;
        }

        .faq-question.active::after {
            transform: rotate(45deg);
        }
 */
        .faq-answer {
            padding: 1.5rem;
			display: none;
/*             max-height: 0; */
/*             overflow: hidden; */
/*             transition: all 0.3s ease; */
            background: white;
        }

        .faq-item.is-open .faq-answer {
/*             padding: 1.5rem; */
/*             max-height: 200px; */
        }

        .faq-answer p {
            color: #666;
            line-height: 1.7;
        }

		.faq-link {
			text-underline-offset: 4px;
			transition: all .3s ease-in;
		}

        /* CTA セクション */
        .cta-section {
            color: white;
            text-align: center;
            padding: 4rem 5%;
			position: relative;
			z-index: 0;
        }

        .cta-section::before {
            background: linear-gradient(135deg, #f4a261, #e76f51);
			inset: 0; /* top, right, bottom, left 全て0 */
			left: 50%;
			width: 100vw;
			margin-left: -50vw;
			content: "";
			position: absolute;
			z-index: -1;
        }


        .cta-section h3 {
            font-size: 2rem;
            margin-bottom: 1rem;
        }

        .cta-section p {
            font-size: 1.2rem;
            margin-bottom: 2rem;
            opacity: 0.9;
        }

		@media screen and (max-width: 768px) {
			.cta-section p {
				text-align: left;
			}
		}

		@media screen and (max-width: 768px) {
			a.btn.btn-white {
				margin-bottom: 1.5rem;
			}
		}

		a.btn.btn-white:hover {
			background: #ff6b35;
			color: #fff !important;
		}
		


        .btn {
            padding: 15px 30px;
            border: none;
            border-radius: 50px;
            font-size: 1.1rem;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s;
            text-decoration: none;
            display: inline-block;
            margin: 0 0.5rem;
        }

        .btn-white {
            background: white;
            color: #f4a261;
        }

        .btn-white:hover {
            background: #f8f9fa;
            transform: translateY(-2px);
        }

        .btn-outline {
            background: transparent;
            color: white;
            border: 2px solid white;
        }

        .btn-outline:hover {
            background: white;
            color: #FF6B35;
        }

/************************************
** 代表紹介
************************************/
       .profile-section {
            background: white;
            border-radius: 20px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.1);
            overflow: hidden;
            margin-bottom: 60px;
        }

        .profile-hero {
            display: grid;
            grid-template-columns: 1fr 2fr;
            gap: 40px;
            padding: 60px;
            align-items: center;
        }

        .profile-image {
            position: relative;
        }

        .profile-image img {
            width: 100%;
            height: 400px;
            object-fit: cover;
            border-radius: 15px;
            box-shadow: 0 10px 20px rgba(255,107,53,0.3);
        }

        .profile-image::after {
            content: '';
            position: absolute;
            top: -10px;
            left: -10px;
            right: 10px;
            bottom: 10px;
            border: 3px solid #ff6b35;
            border-radius: 15px;
            z-index: -1;
        }

        .profile-info h2 {
            font-size: 2.2rem;
            color: #ff6b35;
            margin-bottom: 20px;
        }

        .profile-info .role {
            color: #666;
            margin-bottom: 30px;
            padding: 10px 20px;
            background: #f8f8f8;
            border-radius: 25px;
            display: inline-block;
        }

		@media screen and (max-width: 420px) {
			.profile-info .role {
				padding: 10px 0;
				font-size: 15.5px;
			}
		}

        .profile-info p {
            margin-bottom: 20px;
        }

		@media screen and (max-width: 768px) {
			.profile-info p {
				text-align: left;
			}
		}

        /* Qualifications Section */
        .qualifications {
            color: white;
            padding: 60px;
            margin: 40px 0;
			position: relative;
			z-index: 0;
        }

        .qualifications h3 {
            font-size: 2rem;
            text-align: center;
            margin-bottom: 40px;
            text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
        }

        .qual-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 30px;
        }

        .qual-item {
            background: rgba(255,255,255,0.15);
            padding: 25px;
            border-radius: 15px;
            backdrop-filter: blur(10px);
            border: 1px solid rgba(255,255,255,0.2);
        }

        .qual-item h4 {
            font-size: 1.2rem;
            margin-bottom: 10px;
            color: #fff;
        }

		h4.qual-head__title {
			display: flex;
			justify-content: center;
			align-items: center;
			gap: 10px;
			padding-inline: 0;
		}

		h4.qual-head__title img {
			width: 25px;
			height: 25px;
		}

        .qual-item p {
            opacity: 0.9;
            line-height: 1.6;
        }

        /* Message Section */
        .message-section {
            background: white;
            padding: 60px;
            border-radius: 20px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.1);
            position: relative;
            overflow: hidden;
        }

/*         .message-section::before {
            content: '"';
            position: absolute;
            top: 20px;
            left: 30px;
            font-size: 6rem;
            color: #ff6b35;
            opacity: 0.1;
            font-family: serif;
        } */

        .message-section h3 {
            font-size: 2rem;
            color: #ff6b35;
            text-align: center;
            margin-bottom: 40px;
        }

        .message-content {
            position: relative;
            z-index: 2;
        }

        .message-content p {
/*             font-size: 1.2rem; */
            line-height: 2;
            margin-bottom: 25px;
            text-align: justify;
        }

		.message-flex {
			display: flex;
			justify-content: center;
			align-items: center;
			gap: 2.5rem;
		}

		@media screen and (max-width: 768px) {
			.message-flex {
				flex-direction: column;
			}
		}

		.left-content {
			flex: 1;
		}

		.right-content {
			flex-basis: 35%;
		}

		.right-content img {
			border-radius: 15px;
		}

        .signature {
            text-align: right;
            margin-top: 40px;
            font-size: 1.3rem;
            color: #ff6b35;
            font-weight: bold;
        }

		.text-position {
			text-align: left;
			width: 212px;
			display: inline-block;
		}

        /* Competition Section */
        .competition-section {
            background: linear-gradient(45deg, #f8f8f8 0%, #fff 100%);
            padding: 60px;
            margin: 40px 0;
            border-radius: 20px;
            border-left: 5px solid #ff6b35;
        }

        .competition-section h3 {
            font-size: 2rem;
            color: #ff6b35;
            margin-bottom: 30px;
            text-align: center;
        }

        .competition-content {
            display: grid;
            grid-template-columns: 2fr 1fr;
            gap: 40px;
            align-items: center;
        }

        .competition-text p {
/*             font-size: 1.1rem; */
            line-height: 1.8;
            margin-bottom: 20px;
        }

        .competition-highlight {
            background: #ff6b35;
            color: white;
            padding: 30px;
            border-radius: 15px;
            text-align: center;
        }

        .competition-highlight h4 {
            font-size: 1.5rem;
            margin-bottom: 15px;
			display: flex;
			justify-content: center;
			gap: 10px;
			padding-inline: 0;
        }

		.competition-highlight h4 img {
			width: 30px;
			height: 30px;
		}

        .competition-highlight p {
            font-size: 1.1rem;
            margin: 0;
        }
       /* Contact CTA */
        .contact-cta {
            color: white;
            padding: 60px 20px;
            text-align: center;
            border-radius: 20px;
            margin-top: 60px;
			position: relative;
			z-index: 0;
        }

        .contact-cta::before {
            background: linear-gradient(135deg, #ff6b35 0%, #ff8c42 100%);
			inset: 0; /* top, right, bottom, left 全て0 */
			left: 50%;
			width: 100vw;
			margin-left: -50vw;
			content: "";
			position: absolute;
			z-index: -1;
        }

        .contact-cta h3 {
            font-size: 2rem;
            margin-bottom: 20px;
        }

        .contact-cta p {
            font-size: 1.2rem;
            margin-bottom: 30px;
            opacity: 0.9;
        }

        .cta-buttons {
            display: flex;
            gap: 20px;
            justify-content: center;
            flex-wrap: wrap;
        }

		.cta-img {
			width: 25px;
			height: 25px;
		}

        .btn {
            padding: 15px 30px;
            background: white;
            color: #ff6b35;
            text-decoration: none;
            border-radius: 50px;
            font-weight: bold;
            font-size: 1.1rem;
            transition: all 0.3s ease;
            display: inline-flex;
            align-items: center;
            gap: 10px;
        }

        .btn:hover {
            transform: translateY(-3px);
            box-shadow: 0 10px 20px rgba(0,0,0,0.2);
        }

        .btn-line {
            background: #00c300;
            color: white;
        }

		.btn-tel:hover {
			color:  #ff6b35 !important;
		}

		.btn-tel._text-color {
			color: #2c5aa0;
		}

		.btn-tel._text-color:hover {
			color: #2c5aa0 !important;
		}

        /* Responsive */
        @media (max-width: 768px) {
            .header h1 {
                font-size: 2rem;
            }

            .profile-hero {
                grid-template-columns: 1fr;
                padding: 40px 20px;
                text-align: center;
            }

            .qualifications, .message-section, .competition-section {
                padding: 40px 15px;
            }

            .competition-content {
                grid-template-columns: 1fr;
            }

            .cta-buttons {
                flex-direction: column;
                align-items: center;
            }

            .btn {
                width: 80%;
                justify-content: center;
            }
        }

/************************************
** 店舗情報・アクセス
************************************/
.info-wrapper {
	display: flex;
	justify-content: center;
	padding: 20px;
}

@media screen and (max-width: 768px) {
	.info-wrapper {
		flex-direction: column;
	}
}

.info-cards {
	flex-grow: 1;
	flex-shrink: 0;
}

.access-wrapper {
	flex-grow: 1;
}

@media screen and (min-width: 769px) {
	.map-container .map-placeholder {
	aspect-ratio: 1 / 1.25;
}
}

@media screen and (max-width: 768px) {
/* 	.map-container .map-placeholder	{
		height: 300px;
	} */
}

@media screen and (min-width: 769px) {
	.info-cards__content span.label {
		flex-basis: 300px;
	}
}

.contact-methods {
	display: flex;
}

@media screen and (max-width: 768px) {
	.contact-methods {
		flex-direction: column;
		gap: 2rem;
	}
}

.contact-method {
	flex: 1;
	text-align: center;
}

.contact-icon {
	display: flex;
	margin-inline: auto;
	width: 70px;
	height: 70px;
	border-radius: 50%;
	justify-content: center;
	align-items: center;
}

.line-icon {
	background: #00C300;
}

.tel-icon {
	background: #FF6B35;
}

.contact-icon img {
	width: 40px;
	height: auto;
}

i.fab.fa-line {
	color: #00C300;
}

.parking-info {
	flex: 1;
}

.parking-info h4 {
	border-block-color: #FF6B35;
	color: #fff;
}

.parking-info p {
	color: #fff;
}

.parking-details {
	display: flex;
	gap: 2rem;
}

@media screen and (max-width: 768px) {
	.parking-details {
		flex-direction: column;
	}
}

.parking-highlight h3,
.parking-highlight p {
	color: #fff;
}

/************************************
** 整体
************************************/
h3.step-title {
	padding-inline: .2em;
}

/************************************
** メニュー・料金
************************************/
       .popular-badge {
		   background: linear-gradient(135deg, #ff6b6b, #ee5a52);
           color: white;
           padding: 8px 16px;
           border-radius: 20px;
           font-size: 0.9rem;
           font-weight: bold;
           display: inline-flex;
		   align-items: center;
		   gap: 10px;
           margin-bottom: 15px;
           animation: pulse 2s infinite;
		}

       .popular-badge img {
		   width: 20px;
		   height: auto;
		}

        @keyframes pulse {
            0% { transform: scale(1); }
            50% { transform: scale(1.05); }
            100% { transform: scale(1); }
        }

        .menu-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
            gap: 25px;
            margin-top: 30px;
        }

        .menu-card {
            background: white;
            border-radius: 15px;
            padding: 25px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
            border: 2px solid transparent;
            display: flex;
            flex-direction: column;
        }

		@media screen and (max-width: 768px) {
			.menu-card {
				padding: 25px 20px;
			}
		}

        .menu-image {
            width: 100%;
            height: auto;
            border-radius: 10px;
            margin-bottom: 20px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .menu-image img {
            border-radius: 10px;
        }

        .menu-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(135deg, #ff7b54, #ff6b35);
        }

        .menu-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
            border-color: #ff6b35;
        }

        .menu-card.featured {
            border: 2px solid #ff6b35;
            background: #fff;
        }

        .menu-card.featured::before {
            height: 6px;
            background: linear-gradient(135deg, #ff6b6b, #ee5a52);
        }

        .menu-title {
            font-size: 1.3rem;
            font-weight: bold;
            color: #333;
            margin-bottom: 10px;
        }

        .menu-description {
            color: #666;
            margin-bottom: 15px;
            line-height: 1.6;
        }

        .menu-details {
            font-size: 0.9rem;
            color: #777;
            margin-bottom: 20px;
        }

        .price {
            font-size: 1.8rem;
            font-weight: bold;
            color: #ff6b35;
            text-align: center;
            padding: 15px;
            background: rgba(255, 123, 84, 0.1);
            border-radius: 10px;
            margin-top: auto;
        }

        .price.free {
            color: #ff6b6b;
            background: rgba(255, 107, 107, 0.1);
        }

        .highlight-section {
            background: #FCECEA;
            border-radius: 15px;
            padding: 30px;
            margin-bottom: 40px;
        }

		@media screen and (max-width: 768px) {
			.highlight-section {
				padding: 30px 15px;
			}	
		}

        .highlight-title {
            font-size: 1.5rem;
            color: #ff6b35;
            margin-bottom: 20px;
            text-align: center;
        }

        .tags {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin-bottom: 10px;
        }

        .tag {
            background: rgba(255, 123, 84, 0.1);
            color: #ff6b35;
            padding: 4px 12px;
            border-radius: 15px;
            font-size: 0.8rem;
        }

		@media screen and (max-width: 834px) {
			.content {
				padding: 20px 15px;
			}
		}

        @media (max-width: 768px) {
            .header h1 {
                font-size: 2rem;
            }
            
            .menu-grid {
                grid-template-columns: 1fr;
            }
        }
       /* ポイントカード制度のスタイル */
        .points-section {
            background: linear-gradient(135deg, #ffd700 0%, #ffed4a 100%);
            border-radius: 20px;
            padding: 40px 30px;
            margin-bottom: 50px;
            position: relative;
            overflow: hidden;
            box-shadow: 0 15px 35px rgba(255, 215, 0, 0.3);
        }

		@media screen and (max-width: 768px) {
			.points-section {
				padding-inline: 15px;
			}
		}

        .points-section::before {
            content: '';
            position: absolute;
            top: -50%;
            right: -50%;
            width: 200%;
            height: 200%;
            background: radial-gradient(circle, rgba(255,255,255,0.2) 1px, transparent 1px);
            background-size: 30px 30px;
            animation: sparkle 15s linear infinite;
        }

        @keyframes sparkle {
            0% { transform: translate(-50%, -50%) rotate(0deg); }
            100% { transform: translate(-50%, -50%) rotate(360deg); }
        }

		.points-title__content {
			text-align: center;
		}

        h2.points-title {
            font-size: 2.2rem;
            color: #d97706;
            margin-bottom: 30px;
            position: relative;
            z-index: 1;
            text-shadow: 0 2px 4px rgba(0,0,0,0.1);
			display: inline-block;
			padding-left: 55px;
        }

		@media screen and (max-width: 768px) {
			h2.points-title {
				font-size: 1.6rem;
				padding-left: 45px;
			}	
		}

		@media screen and (max-width: 480px) {
				h2.points-title {
				font-size: 1.4rem;
				padding-left: 35px;
			}	
		}

        .points-title::before {
            content: "";
			background: url('https://kspgym.com/wp-content/uploads/c5086e6533452ff77a1d89f275def74d.png') no-repeat center center / contain;
			width: 50px;
			height: 50px;
			position: absolute;
			top: 50%;
			transform: translateY(-50%);
			left: 0;
        }

		@media screen and (max-width: 768px) {
			.points-title::before {
				width: 40px;
				height: 40px;
			}	
		}

		@media screen and (max-width: 480px) {
			.points-title::before {
				width: 30px;
				height: 30px;
			}	
		}

        .points-content {
            position: relative;
            z-index: 1;
        }

        .points-card {
            background: white;
            border-radius: 15px;
            padding: 30px;
            box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
            margin-bottom: 25px;
            border: 3px solid #ffd700;
            position: relative;
            overflow: hidden;
        }

		@media screen and (max-width: 768px) {
			.points-card {
				padding-inline: 15px;
			}
		}

        .points-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 5px;
            background: linear-gradient(135deg, #ffd700, #ffed4a);
        }

        .points-card-title {
            font-size: 1.5rem;
            color: #d97706;
            margin-bottom: 15px;
            font-weight: bold;
            display: flex;
            align-items: center;
			position: relative;
			padding-left: 35px;
        }

		@media screen and (max-width: 768px) {
			 .points-card-title {
				 padding-left: 25px;
				 font-size: 1.4rem;
			}
		}

		@media screen and (max-width: 480px) {
			 .points-card-title {
				 font-size: 1.05rem;
			}
		}

        .points-card-title::before {
            content: "";
			background: url('https://kspgym.com/wp-content/uploads/257f5040bc99a32ae8b5d5ba49412bdb.png') no-repeat center center / contain;
			width: 30px;
			height: 30px;
			position: absolute;
			top: 50%;
			transform: translateY(-50%);
			left: 0;
        }

		@media screen and (max-width: 768px) {
			 .points-card-title::before {
				width: 20px;
				 height: 20px;
			}
		}

        .points-description {
            color: #666;
/*             font-size: 1.1rem; */
            margin-bottom: 20px;
            line-height: 1.7;
        }

        .points-steps {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 20px;
            margin-top: 25px;
        }

        .points-step {
            background: linear-gradient(135deg, rgba(255, 215, 0, 0.1), rgba(255, 237, 74, 0.1));
            padding: 20px;
            border-radius: 12px;
            text-align: center;
            border: 2px solid #ffd700;
            transition: all 0.3s ease;
        }

        .points-step:hover {
            transform: translateY(-3px);
            box-shadow: 0 8px 20px rgba(255, 215, 0, 0.2);
        }

        .points-step-number {
            background: #ffd700;
            color: #d97706;
            width: 40px;
            height: 40px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
            font-size: 1.2rem;
            margin: 0 auto 15px;
        }

        .points-step-title {
            font-size: 1.1rem;
            font-weight: bold;
            color: #d97706;
            margin-bottom: 10px;
        }

        .points-step-description {
            color: #666;
            font-size: 0.8rem;
			text-align: left;
        }

		.discount-highlight {
			display: flex;
			align-items: center;
			margin-top: 10px;
			gap: 10px;
		}

		@media screen and (max-width: 768px) {
			.discount-highlight {
				font-size: .9rem;
			}
		}

		.discount-highlight img {
			width: 30px;
			height: auto;
		}

		@media screen and (max-width: 768px) {
			.discount-highlight img {
				width: 20px;
				height: auto;
			}
		}

		.points-other-benefits {
			margin-top: 20px;
			padding: 15px;
  			background: #f8f8f8;
			border-left: 4px solid #4caf50;
			border-radius: 5px;
		}

		.points-other-title {
			font-weight: bold;
  			font-size: 1.1em;
  			margin-bottom: 1rem;
		}

		.points-other-description p {
			font-size: 0.95em;
  			color: #555;
		}

		.points-other-description .text-link {
			text-decoration: none;
			display: block;
			text-align: right;
		}

		.points-other-description .text-link i.fa-solid.fa-angle-right {
			margin-left: 10px;
		}


/************************************
** パーソナルトレーニング
************************************/

        /* Training Content */
		p.section-description {
			text-align: center;
			color: #fff;
		}

        .training-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 30px;
            margin-bottom: 40px;
        }

        .training-card {
            background: #f8f9fa;
            border-radius: 10px;
            padding: 30px;
            text-align: center;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            border: 2px solid transparent;
        }

        .training-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 25px rgba(255, 107, 53, 0.15);
            border-color: #ff6b35;
        }

        .training-icon {
            width: 60px;
            height: 60px;
            background: linear-gradient(45deg, #ff6b35, #ff8c42);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 20px;
            font-size: 1.5rem;
            color: white;
        }

		.training-icon img {
			width: 40px;
			height: auto;
		}

        .training-card h3 {
            font-size: 1.3rem;
            color: #333;
            margin-bottom: 15px;
        }

        .training-card p {
            color: #666;
            line-height: 1.6;
			text-align: left;
        }

        /* Features Section */
        .features-list {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 20px;
        }

		._personal-training {
			grid-template-columns: repeat(3, 1fr);
		}

		@media screen and (max-width: 1023px) {
				._personal-training {
					grid-template-columns: repeat(2, 1fr);
				}	
		}

		@media screen and (max-width: 768px) {
				._personal-training {
					grid-template-columns: repeat(1, 1fr);
				}	
		}

        .feature-item {
            display: flex;
            align-items: flex-start;
            padding: 20px;
            background: #f8f9fa;
            border-radius: 8px;
            transition: background 0.3s ease;
        }

        .feature-item:hover {
            background: #fff4f0;
        }

        .feature-icon {
            width: 50px;
            height: 50px;
            background: #ff6b35;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            margin-right: 15px;
            flex-shrink: 0;
        }

		.feature-content {
			flex-grow: 1;
		}

        .feature-content h4 {
            font-size: 1.1rem;
            color: #333;
            margin-bottom: 5px;
        }

        .feature-content p {
            color: #666;
            font-size: 0.9rem;
        }

		.button-content{
			text-align: center;
			margin-top: 30px;
		}

        /* Payment Section */
		.payment-head {
			display: flex;
			align-items: center;
			gap: 10px;
		}

		.payment-head img {
			width: 40px;
			height: auto;
		}

        .payment-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 20px;
            margin-bottom: 30px;
        }

		@media screen and (max-width: 1023px) {
			.payment-grid {
				grid-template-columns: repeat(2, 1fr);
			}
		}

		@media screen and (max-width: 768px) {
			.payment-grid {
				grid-template-columns: repeat(1, 1fr);
			}
		}

        .payment-card {
            background: #f8f9fa;
            border-radius: 8px;
            padding: 20px;
            text-align: center;
            border: 2px solid #e9ecef;
            transition: all 0.3s ease;
        }

		@media screen and (max-width: 1023px) {
			.payment-card {
				padding: 25px;
			}
		}

        .payment-card:hover {
            border-color: #ff6b35;
            background: #fff4f0;
        }

        .payment-card h4 {
            color: #ff6b35;
            font-size: 1.1rem;
            margin-bottom: 10px;
			display: flex;
			align-items: center;
			justify-content: center;
			gap: 10px;
			padding-inline: 0;
        }

        .payment-card h4 img {
			width: 30px;
			height: auto;
        }

		.payment-card p {
			text-align: left;
		}

        .reservation-info {
            background: #F8CD9E;
            border-radius: 10px;
            padding: 30px;
            margin-top: 30px;
            border-left: 5px solid #ff6b35;
        }

		@media screen and (max-width: 768px) {
			.reservation-info {
				padding-inline: 15px;
			}
		}

        .reservation-info h4 {
            color: #ff6b35;
            font-size: 1.3rem;
            margin-bottom: 15px;
			display: flex;
			align-items: center;
			gap: 10px;
        }

		.reservation-info h4 img {
			width: 30px;
			height: auto;
		}

        .contact-buttons {
            display: flex;
            gap: 15px;
            margin-top: 20px;
            flex-wrap: wrap;
        }

		.trial-content h4 {
			display: flex;
			align-items: center;
			gap: 10px;
		}

		.trial-content h4 img {
			width: 30px;
			height: auto;
		}

		.trial-content .text-link {
			text-decoration: none;
		}

		.trial-content .text-link i.fa-solid.fa-angle-right {
			margin-left: 10px;
		}

        .btn {
            display: inline-flex;
            align-items: center;
            padding: 12px 25px;
            border-radius: 25px;
            text-decoration: none;
            font-weight: bold;
            transition: all 0.3s ease;
            border: none;
            cursor: pointer;
			white-space: nowrap;
        }

        .btn-primary {
            background: linear-gradient(180deg, #ff6b35, #ff8c42);
            color: white;
			border: 2px solid transparent;
        }

        .btn-primary:hover {
            box-shadow: 0 5px 15px rgba(255, 107, 53, 0.3);
			border: 2px solid currentColor;
			background: #fff;
			color: #ff6b35;
        }

        .btn-secondary {
            background: white;
            color: #ff6b35;
            border: 2px solid #ff6b35;
        }

        .btn-secondary:hover {
            background: #ff6b35;
            color: white;
			border: 2px solid transparent;
        }

		.btn-s {
			width: fit-content;
			align-self: flex-end;
		}



        /* Responsive */
        @media (max-width: 768px) {
            .header-title {
                font-size: 2rem;
            }

            .header-subtitle {
                font-size: 1rem;
            }

            .section-content {
                padding: 25px 15px;
            }

            .training-grid {
                grid-template-columns: 1fr;
            }

            .contact-buttons {
                flex-direction: column;
            }

            .btn {
                text-align: center;
                justify-content: center;
            }
        }

		@media screen and (max-width: 420px) {
			.btn-width {
				width: auto;
			}
		}

        /* Animations */
        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .section {
            animation: fadeInUp 0.6s ease forwards;
        }


/************************************
** カイロプラクティック
************************************/

        /* Features Grid */
		.features-text {
			text-align: center;
		}

		@media screen and (max-width: 768px) {
			.features-text {
				text-align: left;
			}
		}

/*         .features-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 30px;
            margin-top: 50px;
        } */

        .feature-card {
            background: white;
            padding: 40px 30px;
            border-radius: 20px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
            text-align: center;
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
        }

        .feature-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(44, 90, 160, 0.1), transparent);
            transition: left 0.5s;
        }

        .feature-card:hover::before {
            left: 100%;
        }

        .feature-card:hover {
            transform: translateY(-10px);
            box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
        }

/*         .feature-icon {
            font-size: 3rem;
            color: #2c5aa0;
            margin-bottom: 20px;
        } */

		.feature-icon._icon-bg {
			background: linear-gradient(135deg, #2c5aa0 0%, #1e3d6f 100%);
		}

        .feature-title {
            font-size: 1.4rem;
            color: #333;
            margin-bottom: 15px;
            font-weight: 600;
        }

        .feature-description {
            color: #666;
            line-height: 1.6;
        }

        /* Recommendations */

		section._recommendations-bg {
			position: relative;
			z-index: 0;
		}


		section._recommendations-bg::before {
			background: #fff;
			inset: 0;
			left: 50%;
			width: 100vw;
			margin-left: -50vw;
			content: "";
			position: absolute;
			z-index: -1;
		}

        .recommendations {
            padding: 50px 20px;
            border-radius: 20px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
            margin-top: 50px;
			position: relative;
			z-index: 0;
        }

		@media screen and (max-width: 768px) {
			.recommendations {
				padding-inline: 15px;
			}
		}

        .recommendations-list {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 20px;
            margin-top: 30px;
        }

        .recommendation-item {
            padding: 25px 15px;
            background: linear-gradient(135deg, #f8fffe 0%, #e8f5f3 100%);
            border-radius: 15px;
            border-left: 4px solid #2c5aa0;
            transition: all 0.3s ease;
        }

        .recommendation-item:hover {
            transform: translateX(10px);
            box-shadow: 0 5px 15px rgba(44, 90, 160, 0.2);
        }

        .recommendation-item h4 {
            color: #2c5aa0;
            margin-bottom: 10px;
            font-weight: 700;
			padding-inline: .2em;
			font-size: 1.1rem;
        }

        /* Process Steps */
        .process-steps {
            margin-top: 50px;
        }

        .steps-container {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 5rem 2rem;
            margin-top: 40px;
        }

        .step {
            background: white;
            padding: 35px 25px;
            border-radius: 20px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
            position: relative;
            transition: all 0.3s ease;
        }

        .step:hover {
            transform: translateY(-5px);
            box-shadow: 0 15px 35px rgba(0, 0, 0, 0.15);
        }

        .step-number {
            position: absolute;
            top: -15px;
            left: 25px;
            background: linear-gradient(135deg, #2c5aa0 0%, #1e3d6f 100%);
            color: white;
            width: 40px;
            height: 40px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
            font-size: 1.2rem;
        }

		.step img {
			border-radius: 16px;
		}

        .step-title {
            color: #2c5aa0;
            font-size: 1.3rem;
            margin-bottom: 15px;
            margin-top: 10px;
            font-weight: 600;
        }

        .step-description {
            color: #666;
            line-height: 1.6;
        }

        /* CTA Section */
        .cta-section._bg {
            color: white;
            padding: 60px 15px;
            text-align: center;
            border-radius: 20px;
            margin-top: 80px;
            position: relative;
			z-index: 0;
        }

        .cta-section._bg::before {
            background: linear-gradient(135deg, #2c5aa0 0%, #1e3d6f 100%);
			inset: 0; /* top, right, bottom, left 全て0 */
			left: 50%;
			width: 100vw;
			margin-left: -50vw;
			content: "";
			position: absolute;
			z-index: -1;
        }

/*         .cta-section::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.1)"/></svg>') repeat;
            animation: sparkle 3s ease-in-out infinite;
        }

        @keyframes sparkle {
            0%, 100% { opacity: 0.3; }
            50% { opacity: 0.8; }
        } */

        .cta-content {
            position: relative;
            z-index: 2;
        }

        .cta-title {
            font-size: 2.2rem;
            margin-bottom: 20px;
            font-weight: 300;
        }

        .cta-buttons {
            display: flex;
            justify-content: center;
            gap: 20px;
            margin-top: 30px;
            flex-wrap: wrap;
        }

        .cta-button {
            background: white;
            color: #2c5aa0;
            padding: 15px 35px;
            border: none;
            border-radius: 50px;
            font-size: 1.1rem;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
            text-decoration: none;
            display: inline-block;
        }

        .cta-button:hover {
            transform: translateY(-3px);
            box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
            background: #f0f8ff;
			color: #234780;
        }

        .cta-button.secondary {
            background: transparent;
            color: white;
            border: 2px solid white;
        }

        .cta-button.secondary:hover {
            background: white;
            color: #2c5aa0;
        }

		.cta-button.secondary._bg {
			background: #2c5aa0;
			border: 2px solid transparent;
		}

		.cta-button.secondary._bg:hover {
			background: #fff;
			color: #2c5aa0;
			border: 2px solid currentColor;
		}


/************************************
** ブログ
************************************/
@media screen and (max-width: 1023px) {
	.no-mobile-sidebar .sidebar {
		display: block;
	}
}

aside#block-3 h2.wp-block-heading,
aside#block-5 h2.wp-block-heading,
aside#block-6 h2.wp-block-heading {
	position: relative;
	padding-left: 40px;
	background: initial;
	border-bottom: 1px solid #888;
	font-size: 18px;
}

@media screen and (max-width: 480px) {
	aside#block-3 h2.wp-block-heading,
	aside#block-5 h2.wp-block-heading,
	aside#block-6 h2.wp-block-heading {
		font-size: 16px;
	}
}

aside#block-3 h2.wp-block-heading::before,
aside#block-5 h2.wp-block-heading::before,
aside#block-6 h2.wp-block-heading::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY( -50%);
	width: 25px;
	height: 25px;
}

aside#block-3 h2.wp-block-heading::before {
	background: url('https://kspgym.com/wp-content/uploads/2370870c33278c7e2253e566c8f1b718.png') no-repeat center center /contain;
}

aside#block-5 h2.wp-block-heading::before {
	background: url('https://kspgym.com/wp-content/uploads/5b9f3ae09d6278718dccc0379542b2b0.png') no-repeat center center /contain;	
}

aside#block-6 h2.wp-block-heading::before {
	background: url('https://kspgym.com/wp-content/uploads/d93ddcb588b88ba3f4c943d23ea3428e.png') no-repeat center center /contain;
}

ul.wp-block-latest-posts__list.wp-block-latest-posts a,
ul.wp-block-archives-list.wp-block-archives a,
ul.wp-block-categories-list.wp-block-categories a {
	background: initial;
}

ul.wp-block-latest-posts__list.wp-block-latest-posts a:hover,
ul.wp-block-archives-list.wp-block-archives a:hover,
ul.wp-block-categories-list.wp-block-categories a:hover {
	background: initial;
	color: #FF6B35;
}

.a-wrap img {
	transition: transform 0.3s ease-in;
}

figure.entry-card-thumb.card-thumb.e-card-thumb,
figure.related-entry-card-thumb.card-thumb.e-card-thumb,
figure.next-post-thumb.card-thumb,
figure.prev-post-thumb.card-thumb {
	overflow: hidden;
}

.a-wrap:hover img {
	transform: scale(1.1);
}

span.cat-label.cat-label-3 {
	background-color: #F68655;
}

span.cat-label.cat-label-4 {
	background-color: #61C359;
}

.ect-vertical-card .entry-card-wrap {
    background: #fff;
    border-radius: 6px;
}

.single .main,
.archive .main,
.category .main{
	background: #fff;
}

/* .related-entry-heading,
.comment-title {
	color: #fff;
}

.related-entry-card-title,
.entry-card-title,
.pager-post-navi a.prev-post .prev-post-title,
.pager-post-navi a.next-post .next-post-title {
    text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
} */

/************************************
** contactform
************************************/
.wp-block-contact-form-7-contact-form-selector {
	background: #fff;
	border-radius: 6px;
	padding: 20px;
}

@media screen and (max-width: 768px) {
	.wp-block-contact-form-7-contact-form-selector {
		padding-inline: 15px;
	}
}

.l-inner {
	padding-inline: 10px;
}

/* contactformのレイアウト */
.contact__items {
  margin-top: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 32px;
}
@media screen and (min-width: 768px) {
  .contact__items {
    margin-top: 51px;
    max-width: 1000px;
    margin-inline: auto;
  }
}

/* headとinputのレイアウト */
.contact-control {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
}

@media screen and (min-width: 768px) {
  .contact-control {
    gap: 4px;
  }
}

/* headのレイアウト */
.contact-control__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}

@media screen and (min-width: 768px) {
  .contact-control__head {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    gap: 16px;
  }
}

/* ラベルのフォントサイズ */
@media screen and (min-width: 768px) {
  .contact__label {
    font-size: 18px;
  }
}

/* 必須のラベルのレイアウト */
.form-label__required {
  font-size: 12px;
  color: #fff;
  background: #F43E43;
  border-radius: 6px;
  padding: 2px 7px 3px 7px;
}
@media screen and (min-width: 768px) {
  .contact-control__input {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}

/* 入力欄のレイアウト */
.contact__input {
  width: 100%;
  height: 56px;
  background: #fff;
  border: 1px solid #2f2f2f;
  font-size: 16px;
  padding: 16px;
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}

@media screen and (min-width: 768px) {
  .contact__input {
    height: 50px;
    padding: 13px 13px 14px 23px;
  }
}

/* 入力欄にフォーカスがあたったときのレイアウト */
.contact__input:focus {
  outline: #ff6b35 1px;
  -webkit-box-shadow: 0px 0px 4px 0px #ff6b35;
          box-shadow: 0px 0px 4px 0px #ff6b35;
  border-color: #ff6b35;
}

/* お問い合わせ欄のレイアウト */
.contact__textarea {
  width: 100%;
  background: #fff;
  height: 160px;
  resize: vertical;
  font-size: 16px;
/*   border: 1px solid #2f2f2f; */
  padding: 13px 13px 13px 16px;
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}

@media screen and (min-width: 768px) {
  .contact__textarea {
    padding: 13px 13px 14px 23px;
  }
}

/* テキストエリアにフォーカスがあたったときのレイアウト */
.contact__textarea:focus {
  outline: #ff6b35 1px;
  -webkit-box-shadow: 0px 0px 4px 0px #ff6b35;
          box-shadow: 0px 0px 4px 0px #ff6b35;
  border-color: #ff6b35;
}

/* 確認チェックボックスにフォーカスがあたったときのレイアウト */
input.form-confirmation:focus {
	  outline: #ff6b35 1px;
  -webkit-box-shadow: 0px 0px 4px 0px #ff6b35;
          box-shadow: 0px 0px 4px 0px #ff6b35;
  border-color: #ff6b35;
}

/* 確認チェックボックスのレイアウト */
span.wpcf7-list-item {
	margin-left: 0rem;
	margin-top: 1rem;
}

/* 確認チェックボックスのレイアウト */
@media (min-width: 1700px) {
	span.wpcf7-list-item {
	margin-left: 9em;
	margin-top: 1rem;
}
}

/* contactボタンの配置 */
.contact__button {
  margin-top: 40px;
  text-align: center;
}

/* contactボタンのレイアウト */
input[type=submit] {
    display: inline-block;
	width: 300px;
    min-width: 300px;
    padding: 15px 4px;
    background: #ff6b35;
    color: #fff;
    font-size: 18px;
    letter-spacing: 0.9px;
    font-weight: 700;
    text-align: center;
    -webkit-transition: ease-in-out 0.3s;
    transition: ease-in-out 0.3s;
    position: relative;
}

/* 無効時のボタンレイアウト */
input[type=submit]:disabled {
	background: #EBEBE4;
	color: #808080;
	border-color: currentcolor;
	outline: 2px solid transparent;
}

/* 無効時にホバーが効かないように */
input[type=submit]:disabled:hover {
	cursor: not-allowed;
}

/* 無効時にホバーを効かないように */
input[type=submit]:not(:disabled):hover {
	background: #fff;
	color: #ff6b35;
	border: 1px solid currentcolor;
}

/* 送信ボタン下余白調整 */
.l-contact-box .contact__button {
	margin-bottom: 1.8rem !important;
}

/* 送信後メッセージ下の余白調整 */
.wpcf7 form .wpcf7-response-output {
	margin: 2em 0.5em 1rem !important;
}

/* 確認チェックボタンの配置調整 */
span.wpcf7-form-control.wpcf7-acceptance {
	display: block;
	max-width: 1000px;
	margin-inline: auto;
}

/************************************
** footer-sns
************************************/
.footer-sns__items {
	display: flex;
	align-items: center;
	gap: 1rem;
	max-width: 1256px;
    margin-inline: auto;
}

.footer-sns__item a {
	color: #fff;
	transition: opacity .3s;
}

.footer-sns__item a:hover {
	color: #fff;
	opacity: .6;
}

.footer-sns__item._banner a {
	display: block;
	width: 130px;
}

/************************************
** パーソナルジム、整体ページ
************************************/
.attention-text {
	color: #fff;
	font-size: 14px;
}

/************************************
** プライバシーポリシー
************************************/
.wp-block-group.policy-content {
	background: #fff;
	padding: 60px 20px;
}

@media screen and (max-width: 768px) {
	.wp-block-group.policy-content {
		padding: 30px 15px;
	}
}

@media screen and (max-width: 480px) {
    .privacy-policy .article h4 {
        font-size: 17px;
    }
}


/************************************
** 統一css
************************************/

/* Cocoon対応 - ケーズパーソナルジム統一CSS */
/* 既存のCocoonスタイルと競合しないよう、特定性を高めて記述 */

/* カスタムプロパティ（統一カラーパレット） */
:root {
    --kp-primary-color: #ea580c;
    --kp-primary-dark: #c2410c;
    --kp-secondary-color: #f97316;
    --kp-accent-color: #fed7aa;
    --kp-text-primary: #1f2937;
    --kp-text-secondary: #6b7280;
    --kp-text-light: #9ca3af;
    --kp-bg-primary: #ffffff;
    --kp-bg-secondary: #fff7ed;
    --kp-bg-dark: #431407;
    --kp-border-light: #fed7aa;
    --kp-border-medium: #fdba74;
    --kp-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --kp-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --kp-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --kp-radius-sm: 6px;
    --kp-radius-md: 8px;
    --kp-radius-lg: 12px;
}

/* Cocoonのコンテンツエリア内でのみ適用 */
.entry-content .kp-section,
.page-content .kp-section,
.post-content .kp-section {
    padding: 3rem 0;
    margin: 2rem 0;
    position: relative;
}

.entry-content .kp-section:nth-child(even),
.page-content .kp-section:nth-child(even),
.post-content .kp-section:nth-child(even) {
    background-color: var(--kp-bg-secondary);
    margin-left: -2rem;
    margin-right: -2rem;
    padding-left: 2rem;
    padding-right: 2rem;
    border-radius: var(--kp-radius-md);
}

/* セクションタイトル */
.entry-content .kp-title,
.page-content .kp-title,
.post-content .kp-title {
    font-size: 2rem !important;
    font-weight: 700 !important;
    text-align: center;
    margin-bottom: 2rem !important;
    color: var(--kp-text-primary) !important;
    position: relative;
    line-height: 1.4 !important;
}

.entry-content .kp-title::after,
.page-content .kp-title::after,
.post-content .kp-title::after {
    content: '';
    display: block;
    width: 60px;
    height: 4px;
    background: linear-gradient(to right, var(--kp-primary-color), var(--kp-secondary-color));
    margin: 1rem auto;
    border-radius: 2px;
}

/* カードグリッド */
.entry-content .kp-grid,
.page-content .kp-grid,
.post-content .kp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    margin: 2rem 0;
}

/* カード */
.entry-content .kp-card,
.page-content .kp-card,
.post-content .kp-card {
    background: var(--kp-bg-primary) !important;
    border-radius: var(--kp-radius-lg) !important;
    padding: 2rem !important;
    box-shadow: var(--kp-shadow-md) !important;
    transition: all 0.3s ease !important;
    border: 1px solid var(--kp-border-light) !important;
    position: relative;
    overflow: hidden;
    margin-bottom: 1rem !important;
}

.entry-content .kp-card::before,
.page-content .kp-card::before,
.post-content .kp-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(to right, var(--kp-primary-color), var(--kp-secondary-color));
}

.entry-content .kp-card:hover,
.page-content .kp-card:hover,
.post-content .kp-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--kp-shadow-lg) !important;
}

.entry-content .kp-card h3,
.page-content .kp-card h3,
.post-content .kp-card h3 {
    font-size: 1.3rem !important;
    font-weight: 600 !important;
    margin-bottom: 1rem !important;
    color: var(--kp-text-primary) !important;
    line-height: 1.4 !important;
}

.entry-content .kp-card p,
.page-content .kp-card p,
.post-content .kp-card p {
    color: var(--kp-text-secondary) !important;
    line-height: 1.7 !important;
    margin-bottom: 0 !important;
}

/* アイコン */
.entry-content .kp-icon,
.page-content .kp-icon,
.post-content .kp-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--kp-primary-color), var(--kp-secondary-color)) !important;
    border-radius: 50% !important;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
    color: white !important;
    font-size: 1.5rem;
}

/* 情報グリッド */
.entry-content .kp-info-grid,
.page-content .kp-info-grid,
.post-content .kp-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin: 2rem 0;
}

.entry-content .kp-info-card,
.page-content .kp-info-card,
.post-content .kp-info-card {
    background: var(--kp-bg-primary) !important;
    border-radius: var(--kp-radius-lg) !important;
    padding: 2rem !important;
    box-shadow: var(--kp-shadow-md) !important;
    border: 1px solid var(--kp-border-light) !important;
}

.entry-content .kp-info-card h3,
.page-content .kp-info-card h3,
.post-content .kp-info-card h3 {
    font-size: 1.3rem !important;
    font-weight: 600 !important;
    margin-bottom: 1.5rem !important;
    color: var(--kp-primary-color) !important;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.entry-content .kp-info-item,
.page-content .kp-info-item,
.post-content .kp-info-item {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--kp-border-light);
}

.entry-content .kp-info-item:last-child,
.page-content .kp-info-item:last-child,
.post-content .kp-info-item:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.entry-content .kp-info-label,
.page-content .kp-info-label,
.post-content .kp-info-label {
    font-weight: 600 !important;
    color: var(--kp-text-primary) !important;
    margin-bottom: 0.5rem !important;
    font-size: 0.9rem !important;
}

.entry-content .kp-info-value,
.page-content .kp-info-value,
.post-content .kp-info-value {
    color: var(--kp-text-secondary) !important;
    line-height: 1.6 !important;
}

/* ボタン */
.entry-content .kp-btn,
.page-content .kp-btn,
.post-content .kp-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 2rem !important;
    border-radius: var(--kp-radius-md) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    transition: all 0.3s ease !important;
    cursor: pointer;
    border: none !important;
    font-size: 1rem !important;
    text-align: center;
    justify-content: center;
    margin: 0.5rem;
}

.entry-content .kp-btn-primary,
.page-content .kp-btn-primary,
.post-content .kp-btn-primary {
    background: linear-gradient(135deg, var(--kp-primary-color) 0%, var(--kp-secondary-color) 100%) !important;
    color: white !important;
}

.entry-content .kp-btn-primary:hover,
.page-content .kp-btn-primary:hover,
.post-content .kp-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(234, 88, 12, 0.3) !important;
    color: white !important;
}

.entry-content .kp-btn-secondary,
.page-content .kp-btn-secondary,
.post-content .kp-btn-secondary {
    background: transparent !important;
    color: var(--kp-primary-color) !important;
    border: 2px solid var(--kp-primary-color) !important;
}

.entry-content .kp-btn-secondary:hover,
.page-content .kp-btn-secondary:hover,
.post-content .kp-btn-secondary:hover {
    background: var(--kp-primary-color) !important;
    color: white !important;
}

/* 強調テキスト */
.entry-content .kp-highlight,
.page-content .kp-highlight,
.post-content .kp-highlight {
    background: linear-gradient(120deg, var(--kp-accent-color) 0%, transparent 100%) !important;
    padding: 0.2rem 0.4rem !important;
    border-radius: var(--kp-radius-sm) !important;
    font-weight: 600 !important;
    color: var(--kp-primary-dark) !important;
}

/* CTA セクション */
.entry-content .kp-cta,
.page-content .kp-cta,
.post-content .kp-cta {
    background: linear-gradient(135deg, var(--kp-bg-dark) 0%, #374151 100%) !important;
    color: white !important;
    text-align: center;
    padding: 3rem 2rem !important;
    margin: 2rem -2rem !important;
    border-radius: var(--kp-radius-md) !important;
}

.entry-content .kp-cta h2,
.page-content .kp-cta h2,
.post-content .kp-cta h2 {
    font-size: 2rem !important;
    font-weight: 700 !important;
    margin-bottom: 1rem !important;
    color: white !important;
}

.entry-content .kp-cta p,
.page-content .kp-cta p,
.post-content .kp-cta p {
    font-size: 1.1rem !important;
    opacity: 0.9;
    margin-bottom: 2rem !important;
    color: white !important;
}

.entry-content .kp-cta .kp-btn,
.page-content .kp-cta .kp-btn,
.post-content .kp-cta .kp-btn {
    background: transparent !important;
    color: white !important;
    border: 2px solid rgba(255, 255, 255, 0.3) !important;
}

.entry-content .kp-cta .kp-btn:hover,
.page-content .kp-cta .kp-btn:hover,
.post-content .kp-cta .kp-btn:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.5) !important;
    color: white !important;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
    .entry-content .kp-title,
    .page-content .kp-title,
    .post-content .kp-title {
        font-size: 1.6rem !important;
    }

    .entry-content .kp-section,
    .page-content .kp-section,
    .post-content .kp-section {
        padding: 2rem 0;
    }

    .entry-content .kp-section:nth-child(even),
    .page-content .kp-section:nth-child(even),
    .post-content .kp-section:nth-child(even) {
        margin-left: -1rem;
        margin-right: -1rem;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .entry-content .kp-grid,
    .page-content .kp-grid,
    .post-content .kp-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .entry-content .kp-info-grid,
    .page-content .kp-info-grid,
    .post-content .kp-info-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .entry-content .kp-card,
    .page-content .kp-card,
    .post-content .kp-card {
        padding: 1.5rem !important;
    }

    .entry-content .kp-info-card,
    .page-content .kp-info-card,
    .post-content .kp-info-card {
        padding: 1.5rem !important;
    }

    .entry-content .kp-cta,
    .page-content .kp-cta,
    .post-content .kp-cta {
        margin: 2rem -1rem !important;
        padding: 2rem 1rem !important;
    }

    .entry-content .kp-btn,
    .page-content .kp-btn,
    .post-content .kp-btn {
        width: 100%;
        max-width: 300px;
    }
}

/* アニメーション */
@keyframes kp-fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.entry-content .kp-card,
.page-content .kp-card,
.post-content .kp-card,
.entry-content .kp-info-card,
.page-content .kp-info-card,
.post-content .kp-info-card {
    animation: kp-fadeInUp 0.6s ease-out;
}

.entry-content .kp-card:nth-child(2),
.page-content .kp-card:nth-child(2),
.post-content .kp-card:nth-child(2) {
    animation-delay: 0.1s;
}

.entry-content .kp-card:nth-child(3),
.page-content .kp-card:nth-child(3),
.post-content .kp-card:nth-child(3) {
    animation-delay: 0.2s;
}

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

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

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