@charset "UTF-8";
/*
Theme Name: taisyokuhosyou
*/

* {margin: 0;padding: 0;box-sizing: border-box;}
:root {
--c-base: #282828;
--c-white: #FFF;
--c-main: #072C69;
--c-b-dd: #c2d3e1;
/*--c-g-light: #7CE62E;*/	/* 明るい緑（ボタン） */
/*--c-g-dark: #00B437;*/	/* 濃い緑（アクセント） */

--c-g-light: #00ff88;
--c-g-dark: #00c851;
--c-g-eme: #00ffc8;		/* エメラルドグリーン */
--c-gray: #f8f9fa;		/* グレー */
}
body {font-family: 'Noto Sans JP', 'Yu Gothic', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
line-height: 1.6;color: #333;overflow-x: hidden;}

/* ヘッダー */
.header			{position: fixed;top: 0;width: 100%;background:var(--c-white);box-shadow: 0 2px 20px rgba(0,0,0,0.1);
backdrop-filter: blur(10px);z-index: 1000;padding: 15px 0;}
.header-content	{max-width: 1200px;display: flex;justify-content: space-between;align-items: center;margin: 0 auto;padding: 0 20px;}
.logo			{font-size: 24px;font-weight: bold;color: var(--c-base);text-decoration: none;display: flex;align-items: center;gap: 10px;}
.logo-image		{width: 40px;height: 40px;}

@media (max-width: 767px) {
.header-content {padding: 0 10px;}
.logo			{font-size: 20px;}
}

/* ファーストビュー */
.hero			{background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
padding: 120px 20px 30px;text-align: center;position: relative;overflow: hidden;}
.hero::before	{content: "";position: absolute;top: -50%;right: -50%;
width: 200%;height: 200%;
background: radial-gradient(circle, rgba(0, 255, 200, 0.1) 0%, transparent 70%);
animation: rotate 20s linear infinite;}
@keyframes rotate {from { transform: rotate(0deg); }to { transform: rotate(360deg); }}
.hero-content	{position: relative;z-index: 1;max-width: 800px;
margin: 0 auto;}
.hero-content p	{color:var(--c-white); margin: 20px 0; opacity: 0.9;}
.hero-content p.setu	{ font-size:0.9em; margin: 0 0 5px;}
.hero-badge		{display: inline-block;
background: #ff5e57;color: var(--c-white);
padding: 8px 20px;
font-size: 1.4rem;font-weight: bold;animation: pulse 1s ease-in-out infinite;}
@keyframes pulse {0%, 100% { transform: scale(1); }50% { transform: scale(1.05); }}
.hero-content p.hero-badge_text {margin-top: 5px;animation: blink 1s step-start infinite;}
@keyframes blink {50% {opacity: 0;}}


.hero-image-wrapper {position: relative;display: block;margin: 0 auto; text-align:center;}
.hero-image-wrapper img {display: block;width: 100%;height: auto;margin: 0 auto; text-align:center;}

.fv-image {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
}

.hero-stats { width:100%;position: absolute;
bottom: 5%;
left: 50%;
transform: translateX(-50%);
display: flex;
gap: 20px;
z-index: 2;
justify-content: center;flex-wrap: nowrap;}

.stat-box {
background: rgba(255, 255, 255, 0.1);
backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.2);
padding: 20px 15px;
border-radius: 20px;
min-width: 100px;
text-align: center;
color: white;
}
.stat-box:hover	{transform: translateY(-5px);box-shadow: 0 10px 30px rgba(0, 255, 200, 0.3);}

.stat-number	{font-size: 36px;font-weight: bold;color: var(--c-g-eme);display: block;}
.stat-label		{color: var(--c-white);font-size: 14px;}
.hero-catch		{color: var(--c-white);max-width: 600px;font-size: 1.6rem;line-height: 1.8;margin: 0 auto;padding: 12px 24px 0;}
@keyframes glowFade {
0%, 100% { box-shadow: 0 0 10px rgba(0, 255, 200, 0.3); }
50% { box-shadow: 0 0 20px rgba(0, 255, 200, 0.6); }
}
.hero-main			{margin-top: 2rem;text-align:center;}
.hero-image			{}
.hero-image img		{width: 100%;max-width: 500px;height: auto;display: block;margin: 0 auto;}
.hero-description	{color: var(--c-white); opacity: 1;max-width: 600px;font-size: 20px;margin: 30px auto;line-height: 1.8;}

@media (max-width: 767px) {
.hero			{padding: 105px 20px 30px;}
.hero-badge		{padding: .5em .5em;font-size: 1.1em;}
.hero-content p	{margin: 20px 0;}
.hero-catch		{font-size: 1rem;line-height: 1.8;margin: 0 auto;padding: .5em .5em 0;}
.hero h1		{font-size: 6vw;}
.hero-highlight	{font-size: 7vw;}
.hero-desc_s	{font-size:14px;}
.hero-mid		{font-size: 6vw;}
.hero-stats {position: static;
transform: none;
margin-top: -2em;
/*flex-direction: column;*/
flex-direction: row;
align-items: center;
gap: 10px;
}
.stat-box		{/* width:80%;*/padding:0.5em 0.2em;width: calc(33.3333% - 10px);border-radius: 20px; min-height:4em; line-height:1;}
.stat-number	{font-size: 5vw;}

.hero-description	{font-size: 1.2rem;line-height: 1.4;}
}










/* CTA ボタン */
.cta-button {display: inline-flex;align-items: center;
gap: 15px;
background: linear-gradient(45deg, #00c851, #00ff88);
color: #000;
padding: 20px 40px;
border-radius: 50px;
font-size: 18px;
font-weight: bold;text-decoration: none;transition: all 0.3s;
box-shadow: 0 10px 30px rgba(0, 200, 81, 0.4);
animation: bounce 2s ease-in-out infinite;}
@keyframes bounce {
0%, 100% { transform: translateY(0); }
50% { transform: translateY(-10px); }
}
.cta-button:hover	{transform: scale(1.05);box-shadow: 0 15px 40px rgba(0, 200, 81, 0.6);}

.line-icon			{width: 30px;height: 30px;
background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="white"><path d="M19.365 9.863c.349 0 .63.285.63.631 0 .345-.281.63-.63.63H17.61v1.125h1.755c.349 0 .63.283.63.63 0 .344-.281.629-.63.629h-2.386c-.345 0-.627-.285-.627-.629V8.108c0-.345.282-.63.63-.63h2.386c.346 0 .627.285.627.63 0 .349-.281.63-.63.63H17.61v1.125h1.755zm-3.855 3.016c0 .27-.174.51-.432.596-.064.021-.133.031-.199.031-.211 0-.391-.09-.51-.25l-2.443-3.317v2.94c0 .344-.279.629-.631.629-.346 0-.626-.285-.626-.629V8.108c0-.27.173-.51.43-.595.06-.023.136-.033.194-.033.195 0 .375.104.495.254l2.462 3.33V8.108c0-.345.282-.63.63-.63.345 0 .63.285.63.63v4.771zm-5.741 0c0 .344-.282.629-.631.629-.345 0-.627-.285-.627-.629V8.108c0-.345.282-.63.627-.63.348 0 .631.285.631.63v4.771zm-2.466.629H4.917c-.345 0-.63-.285-.63-.629V8.108c0-.345.285-.63.63-.63.348 0 .63.285.63.63v4.141h1.756c.348 0 .629.283.629.63 0 .344-.282.629-.629.629M24 10.314C24 4.943 18.615.572 12 .572S0 4.943 0 10.314c0 4.811 4.27 8.842 10.035 9.608.391.082.923.258 1.058.59.12.301.079.766.038 1.08l-.164 1.02c-.045.301-.24 1.186 1.049.645 1.291-.539 6.916-4.078 9.436-6.975C23.176 14.393 24 12.458 24 10.314"/></svg>') no-repeat center;
background-size: contain;}

.cta-button2			{width:360px;display: inline-flex;align-items: center;
gap: 15px;
background: linear-gradient(180deg, var(--c-g-light), var(--c-g-dark));
color: #000;
padding: 16px 30px;
border-radius: 10px;
font-size: 18px;font-weight: bold;text-decoration: none;animation: bounce 2s ease-in-out infinite;}
.cta-button2:hover		{box-shadow: none;background: var(--c-g-dark);}
.cta-button2 p			{margin-block-start: .2em;margin-block-end: .4em;}
.cta-button2 .text		{font-size: 1.2em;width: 100%;line-height:1.8rem;font-weight: 500;letter-spacing: .1em; color:var(--c-white);}
.cta-button2 .large		{font-size: 1.6rem;  font-weight: 600; color:var(--c-white); letter-spacing: .1em;}
.cta-button2 > .line-icon	{width: 2em;height: 2em;}
.cta-button2::before,
.cta-button2::after		{position: absolute;content: "";width: 9px;height: 1px;background:var(--c-white);border-radius: 1px;bottom: 5px;}
.cta-button2::before	{transform-origin: center right;transform: rotate(45deg);left: calc(50% - 10px);}
.cta-button2::after		{transform-origin: center left;transform: rotate(-45deg);left: calc(50% - 2px);}

.line-call-to-action	{margin-top: 3rem;padding: 2rem 1rem;text-align: center;
background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
color: var(--c-white);}
.line-call-to-action a	{margin-top:1em;}
.line-call-to-action p	{font-size: 1.4rem;margin: 0.5rem 0;}

@media (max-width: 767px) {
.cta-button		{gap: 5px;
padding: 1em .8em;
border-radius: 10px;
font-size: 1em;
box-shadow: 0 5px 10px rgba(0, 200, 81, 0.4);}
.cta-button2			{width:90%; max-width:292px;
gap: 5px;
padding: 16px 30px;
font-size: 1rem;
}
.cta-button2 .large		{font-size: 1.4rem;}
}

/* セクション共通 */
.section		{max-width: 1200px;
padding: 80px 20px;
margin: 0 auto;}
.section-title	{position: relative;
font-size: 2.4rem;font-weight: 900;text-align: center;
margin-bottom: 50px;
line-height:1.3em;}
.section-title::after {content: "";position: absolute;transform: translateX(-50%);
bottom: -15px;
left: 50%;
width: 80px;
height: 4px;
background: linear-gradient(45deg, var(--c-g-eme), #00d9ff);
border-radius: 2px;}
.section-title span{font-size: 1.8rem;}
@media (max-width: 767px) {
.section h2			{font-size: 1.8rem;}
.section-title span	{font-size: 1.4rem;}
}

.sp-br, .pc-br {display: none;}
@media screen and (max-width: 767px) {.sp-br {display: inline;}}
@media screen and (min-width: 768px) {.pc-br {display: inline;}}


/* 特徴セクション */
.features		{background: var(--c-gray); padding: 80px 0 0;}
/*.features h2::after{background: #ffbd00;}*/
.feature-grid	{padding:2rem 1rem;display: grid;grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 30px;margin-top: 50px;}
.feature-card	{position: relative;overflow: hidden;transition: all 0.3s;
background: var(--c-white);
padding: 40px 30px;
border-radius: 20px;
box-shadow: 0 10px 30px rgba(0,0,0,0.1);
text-align: center;}
.feature-card::before {content: "";position: absolute;
top: 0;
left: 0;
right: 0;
height: 5px;
background: linear-gradient(45deg, var(--c-g-eme), #00d9ff);}

.feature-card:hover {transform: translateY(-10px);box-shadow: 0 20px 40px rgba(0,0,0,0.15);}
.feature-icon	{margin-bottom: 20px;}
.feature-icon img{width:100px; height:100px;}
.feature-title	{font-size: 24px;font-weight: bold;margin-bottom: 15px;}

.feature-chance{margin-top:2em;}
.features h2.feature-chance::after{background: #fd6666;}

.features ul {list-style: none;padding-left: 0;text-align: left;margin: 0 auto;display: block;max-width: 70%;
background-color:var(--c-gray); padding:0.8em 0.8em 1.2em;}
.features li  {position: relative;
padding-left: 2em;margin: 0.5rem 0;text-align: left;font-size: 1.3rem;}
.features li::before {content: "";position: absolute;left: 0;top: 0.2em;
width: 1.5em;height: 1.5em;background-image: url("image/check02.png");
background-size: contain;background-repeat: no-repeat;background-position: center;}


@media (max-width: 767px) {
.features h2	{font-size: 1.4rem;}
.feature-card	{padding: 30px 20px;}
.feature-icon	{margin-bottom: 2px;}
.features ul	{font-size: 1rem;max-width: 96%; padding:0.5em;}
.features li	{font-size: 1.2rem;padding-left: 1.5em;}
.features li::before {width: 1.2em;height: 1.2em;}	
}

/* 事例セクション */
.cases {
background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
color: var(--c-white);
}

.case-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 40px;
margin-top: 50px;
}

.case-card {
background: rgba(255, 255, 255, 0.1);
backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.2);
padding: 40px;
border-radius: 20px;
text-align: center;
transition: all 0.3s;
}

.case-card:hover {
transform: scale(1.05);
background: rgba(255, 255, 255, 0.15);
}

.case-card img{border-radius: 50px; width:300px; max-width:100%;}

.case-number {
font-size: 1.4rem;
background:linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
border-radius:20px;
/*color: var(--c-g-eme);*/
color: var(--c-white);
margin-bottom: 20px;
font-weight: bold;
}

.amount-increase {
font-size: 42px;
font-weight: 900;
color: var(--c-g-eme);
margin-bottom: 30px;
}

.amount-comparison { padding-top:1em;
display: flex;
flex-direction: column;
gap: 20px;
align-items: center;
}

.amount-before, .amount-after {
padding: 15px 30px;
border-radius: 10px;
font-size: 20px;
font-weight: bold;
}

.amount-before { min-width:14em;
background: rgba(255, 255, 255, 0.1);
text-decoration: line-through;
opacity: 0.7;
}

.amount-after { min-width:14em;
color: var(--c-white);
background: #f88a32;}

/* お悩みセクション */
.about				{padding: 2rem 1rem;text-align: center;}
.about p			{ padding-top:1em;}
.about-intro h2		{font-size: 2.4rem;margin-bottom: 1rem;}
.about-intro p		{font-size: 1.2rem;line-height: 1.6;}
.about-table		{margin: 2rem 0;}
.about-table h3		{font-size: 1.2rem;margin-bottom: 1rem;}
.about-table table	{width: 100%;max-width: 100%;border-collapse: collapse;margin: 0 auto;font-size: 1.05rem;}
.about-table th,
.about-table td		{padding: 0.5rem;border: 1px solid #ccc;text-align: center;}
.about-table .note	{font-size: 0.85rem;color: #666;margin-top: 0.5rem;}
.about-highlight	{margin-top: 2rem;}
.about-highlight p	{font-size: 1.3rem;margin: 0.5rem 0;}
.about-highlight strong	{font-size: 1.8rem;display: block;margin-bottom: 0.5rem;}
.about-highlight .note		{font-size: 0.85rem;color: #666;margin-top: 0.5rem;}

@media (max-width: 767px) {
.about-intro h2		{font-size: 1.8rem;}
.about-intro p		{font-size: 1.1rem;}
.about-table table	{font-size: 1rem;}
.about-highlight p	{font-size: 1.2rem;}
.about-highlight strong	{font-size: 1.6rem;}
}


/* お悩み */
.benefits_sec{text-align: center;}
.benefits			{padding: 2rem 1rem;}
.benefits-intro{}
.benefits-intro h2 {font-size: 2.4rem;margin-bottom: 0;
background-image: url("image/onayami_t.svg");background-size: cover;background-position: center;
color: white;padding: 2rem 1rem;}

.h2-label {display: inline-block;background-color: #fff; border:#07263b 2px solid;
padding: 0.5rem 1rem;border-radius: 50px;margin-bottom: -2rem;margin-top: 1rem;font-size: 1rem;
animation: bounce 2s ease-in-out infinite;}

.benefits-intro img	{max-width:100%;}
.benefits-intro p	{font-size: 1.1rem;margin-bottom: 1rem;}
.benefits-intro ul	{display: block;
max-width: 70%;
list-style: none;
margin: 0 auto;
text-align: left;
background-color:#FFF;
padding:0.8em 0.8em 1.2em 0.5em;}
.benefits-intro li	{position: relative;
font-size: 1.3rem;
text-align: left;
padding-left: 2em;
margin: 0.5rem 0;}
.benefits-intro li::before {content: "";position: absolute;
left: 0;top: 0.2em;
width: 1.5em;
height: 1.5em;
background-image: url("image/check01.png");background-size: contain;background-repeat: no-repeat;background-position: center;}


/* できることをご紹介 */
.benefits-detail	{margin-top: 2rem;}
.benefits-detail h3 {font-size: 2.4rem;margin-bottom: 1.5rem;}
.benefit-block		{padding-top:2em;}
.benefit-block h4	{font-size: 1.8rem;margin-bottom: 0.5rem; font-weight:500;}
.benefit-block h4 span{background:var(--c-main); color:var(--c-white); padding:0.2em 1em; border-radius:50px;}
.benefit-block p	{font-size: 1.3rem;line-height: 1.6;}
.benefit-block p.highlight			{font-size: 1.4rem;font-weight: bold;margin-top: 0.5rem;}
.benefits-detail img{width:400px;}
@media (max-width: 767px) {
.benefits-detail h3 {font-size: 1.8rem;}
.benefits-detail img{width:300px;}
.benefit-block p	{font-size: 1.1rem;line-height: 1.4;}
.benefits-intro h2 {font-size: 1.8rem;}
.benefits-intro ul	{font-size: 1rem;max-width: 96%; padding:0.5em;}
.benefits-intro li	{font-size: 1.2rem;padding-left: 1.5em;}
.benefits-intro li::before {width: 1.2em;height: 1.2em;}
.benefit-block h4	{font-size: 1.2rem;}
.benefit-block p.highlight			{font-size: 1.1rem;}
}


/* 安心ポイント */
.points				{background: var(--c-gray); padding:0 0 80px;}
.points h2::after	{background: #072c69;}
.point-icon img		{width:160px;}
.support-grid		{display: grid;grid-template-columns: repeat(2, 1fr);
margin:0 4rem;
gap: 4rem;
text-align: center;}
.support-item		{position: relative;padding-top: 2rem;}
.support-item h3	{font-size: 1.4rem;padding-left:1.5em; padding-bottom:.5em;}
.point-icon			{position: absolute;z-index: 2;
top: 24px;
left: 10px;
width: 60px;}
.point-icon img		{display: block;width: 100%;}
.img-placeholder2	{
padding: 2rem;
background-color: #f9f9f9;
background: var(--c-white);
border-radius: 15px;
box-shadow: 0 5px 20px rgba(0,0,0,0.1);}
.img-placeholder2:hover {transform: translateY(-5px);
box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}
.img-placeholder2 img{width:160px;}
@media (max-width: 767px) {
.support-grid		{grid-template-columns: repeat(1, 1fr);margin:0 .5rem;gap: 1rem;}
.support-item h3	{font-size: 6vw;padding-bottom: .2rem;}
.img-placeholder2	{padding: 1.4rem 1rem;}
.img-placeholder2 img{width:120px;}
}

/* お客様の声 */
.testimonials		{background: var(--c-white);}
.testimonials h2::after{background: var(--c-b-dd);}

.testimonial-grid	{display: grid;grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 30px;
margin-top: 50px;}
.testimonial-card	{position: relative;transition: all 0.3s;
background: var(--c-gray);
padding: 30px;
border-radius: 15px;}
.testimonial-card::before {content: "";position: absolute;opacity: 0.3;
top: 10px;
left: 20px;
font-size: 60px;
color: #00c851;
}
.testimonial-card:hover {transform: scale(1.02);box-shadow: 0 10px 30px rgba(0,0,0,0.1);}
.testimonial-text	{margin-bottom: 20px;line-height: 1.8;}
.testimonial-author	{color: #666;font-weight: bold;}
.voice-text p strong{background:var(--c-b-dd);
padding:4px 20px;
border-radius:20px;
line-height:3em;}
.voice-image		{display: flex;justify-content: center;align-items: center;
width: 130px;
height: 130px;
background-color: #eee;
border: 3px solid var(--c-b-dd);
border-radius: 50%;
margin: 0 auto;}
.voice-image img	{width:100%;border-radius:50%;}

/* 実績 */
.achievements		{background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
color: var(--c-white);text-align: center;}
.achievements h2::after{background: #2b344e;}

.achievement-grid		{display: grid;grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 40px;
margin-top: 50px;}
.achievement-item		{padding: 20px;}
.item-consultation,
.item-consultation2,
.item-consultation3		{position: relative;z-index: 0;}

.item-consultation::before {content: "";position: absolute;
top: 50%;
left: 50%;
width: 230px;
height: 230px;
background-image: url('image/achievement_icon_01.svg');background-size: contain;background-repeat: no-repeat;background-position: center;
transform: translate(-50%, -50%);opacity: 0.1;z-index: -1;}

.item-consultation2::before {content: "";position: absolute;
top: 50%;
left: 50%;
width: 180px;
height: 180px;
background-image: url('image/achievement_icon_02.svg');
background-size: contain;background-repeat: no-repeat;background-position: center;transform: translate(-50%, -50%);opacity: 0.1;z-index: -1;}

.item-consultation3::before {content: "";position: absolute;
top: 50%;
left: 50%;
width: 180px;
height: 180px;
background-image: url('image/achievement_icon_03.svg');
background-size: contain;background-repeat: no-repeat;background-position: center;transform: translate(-50%, -50%);opacity: 0.1;z-index: -1;}

.achievement-number	{
font-size: 2.8rem;font-weight: 900;
line-height:1.2;
margin-bottom: 10px;
text-shadow: 2px 2px 4px rgba(0,0,0,0.2);}
.achievement-number span{font-size: 2rem;}
.achievement-label	{opacity: 0.9;
font-size: 18px;}
@media (max-width: 768px) {
.achievement-number	{line-height:0.9;}
}


/* ステップ */
.steps				{background: var(--c-gray);}
/*.steps h2::after{background: #56ac77;}*/
.steps h2::after	{background: linear-gradient(45deg, #56ac77, #00f780);}
.steps h2 img		{max-width:100%;}

.step-list			{max-width: 800px;
margin: 50px auto 0;}

.step-item			{display: flex;align-items: center;position: relative;
gap: 30px;
margin-bottom: 40px;}
.step-item:not(:last-child)::after {content: "";position: absolute;
left: 35px;
top: 120px;
width: 2px;
height: calc(100% + 20px);background: #ddd; z-index:-1;}
.step-number		{display: flex;align-items: center;justify-content: center;
width: 70px;
height: 70px;
background: linear-gradient(45deg, #56ac77, #00f780);
border-radius: 50%;
font-size: 24px;font-weight: bold;
color: var(--c-white);flex-shrink: 0;box-shadow: 0 5px 20px rgba(0, 200, 81, 0.4);}
.step-content		{background-color:var(--c-white); width:100%; padding:1em;border-radius: 10px;}
.step-content h4	{font-size: 20px;margin-bottom: 10px;}
.step-content img	{width:160px; border:var(--c-gray) 2px solid; border-radius:50%;}

@media (max-width: 768px) {
.step-number		{width: 60px;height: 60px;font-size: 24px;
box-shadow: 0 2px 8px rgba(0, 200, 81, 0.4);}
.step-item			{flex-direction: column;text-align: center;gap: 10px;}
.step-item:not(:last-child)::after	{display: none;}
.step-content img	{width:130px;}
}


/* FAQ */
.faq				{background: var(--c-white);}
.faq h2::after		{background: #c2d3e1;}

.faq-list			{max-width: 800px;
margin: 50px auto 0;}

.faq-item			{background: var(--c-gray);
margin-bottom: 20px;
border-radius: 10px;
overflow: hidden;transition: all 0.3s;}

.faq-item:hover		{box-shadow: 0 5px 20px rgba(0,0,0,0.1);}
.faq-question		{position:relative;cursor: pointer;display: flex;justify-content: flex-start;align-items: center;font-weight: bold;
padding: 25px 30px;
font-size: 18px;}
.faq-question::before {content: "";display: inline-block;
width: 40px;
height: 40px;
background-image: url("image/faq_q.png");background-size: contain;background-repeat: no-repeat;vertical-align: middle;
margin-right: 0.5em;}
.faq-toggle			{position: absolute;transition: transform 0.3s;
width: 20px;
height: 20px;
right: 1rem;}
.faq-toggle::before,
.faq-toggle::after	{content: "";position: absolute;
background-color: #333;
transition: transform 0.3s;}
.faq-toggle::before {
top: 50%;
left: 0;
width: 100%;
height: 2px;
transform: translateY(-50%);}
.faq-toggle::after	{left: 50%;top: 0;
width: 2px;
height: 100%;
transform: translateX(-50%);}
.faq-toggle.open	{transform: rotate(45deg);}
.faq-answer			{max-height: 0;overflow: hidden;transition: max-height 0.3s;}
.faq-answer-content {padding: 0 30px 25px;line-height: 1.8;}
.faq-answer-content::before {content: "";display: inline-block;
width: 24px;
height: 24px;
margin-right: 8px;
background-image: url("image/faq_a.png");background-size: contain;background-repeat: no-repeat;vertical-align: middle;}

@media (max-width: 768px) {
.faq-question		{padding: 14px 40px 14px 14px;}
.faq-question::before {width: 30px;height: 30px; min-width:30px;}
.faq-answer-content::before {width: 24px;height: 24px;}
}


/* フッター */
.footer {background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);text-align: center;
color: var(--c-white);padding: 40px 20px 7.5em;}

.footer-links		{display: flex;justify-content: center;flex-wrap: wrap;
gap: 30px;
margin-bottom: 20px;}
.footer-links a		{color: var(--c-white);text-decoration: none;opacity: 0.8;transition: opacity 0.3s;}
.footer-links a:hover {opacity: 1;}

/* 最下部CTA */
.floating-cta		{position: fixed;z-index: 999;text-align:center;
/*background: rgba(0, 0, 0, 0.6);*/
background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
color:var(--c-white);
width:100%;
bottom:0;
}
.floating-cta .cta-button3 {display: inline-flex;align-items: center;
width:360px;
gap: 30px;
color: var(--c-white);
background: linear-gradient(180deg, var(--c-g-light), var(--c-g-dark));
font-weight: bold;text-decoration: none;
padding: 16px 30px;
margin:.2em auto .5em;
border-radius: 10px;
font-size: 1rem;
}
.cta-button3 .text		{font-size: 1.2rem;font-weight: 500;line-height: 1.8rem;}
.cta-button3 .large		{font-size: 1.4rem;font-weight: 600;padding-left:.2em;}
.cta-button3:hover		{box-shadow: none;background: var(--c-g-dark);}
@keyframes float {
0%, 100% { transform: translateY(0); }
50% { transform: translateY(-10px); }
}

@media (max-width: 768px) {
.floating-cta .cta-button3 {width:90%;
max-width:292px;
gap: 5px;}
}


.site-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: 120px 20px 30px;
}

.riyoukiyaku {
  line-height: 1.8;
  color: #333;
  margin: 0 auto;
  padding: 2em 1em;
}

.riyoukiyaku h2 {
  font-size: 1.2em;
  margin-top: 2em;
  margin-bottom: 0.5em;
  border-left: 4px solid #666;
  padding-left: 0.5em;
  color: #222;
}

.riyoukiyaku ol {
  padding-left: 1.5em;
  margin-bottom: 1.5em;
}

.riyoukiyaku ol li {
  margin-bottom: 0.5em;
}

.riyoukiyaku ol ol {
  padding-left: 1.5em;
  margin-top: 0.5em;
}

.riyoukiyaku p {
  margin-bottom: 1.2em;
}



.privacy-policy {
  margin: 0 auto;
  padding: 2em 1em;
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

.privacy-policy h1 {
  font-size: 1.8em;
  border-bottom: 2px solid #666;
  padding-bottom: 0.4em;
  margin-bottom: 1em;
}

.privacy-policy h2 {
  font-size: 1.2em;
  margin-top: 2em;
  margin-bottom: 0.5em;
  border-left: 4px solid #999;
  padding-left: 0.6em;
  color: #222;
}

.privacy-policy p {
  margin-bottom: 1.2em;
}

.privacy-policy ul {
  padding-left: 1.5em;
  margin-bottom: 1.5em;
}

.privacy-policy ul li {
  margin-bottom: 0.6em;
  list-style: disc;
}

@media screen and (max-width: 600px) {
  .privacy-policy {
    font-size: 15px;
    padding: 1.5em 1em;
  }

  .privacy-policy h1 {
    font-size: 1.5em;
  }

  .privacy-policy h2 {
    font-size: 1em;
  }
}





.legal-notice {
  margin: 0 auto;
  padding: 2em 1em;
  font-size: 16px;
  line-height: 1.7;
  color: #333;
  background-color: #fff;
}

.legal-notice h1 {
  font-size: 1.8em;
  margin-bottom: 1em;
  border-bottom: 2px solid #666;
  padding-bottom: 0.4em;
  color: #222;
}

.legal-notice dl {
  display: grid;
  grid-template-columns: 180px 1fr;
  row-gap: 1em;
  column-gap: 1em;
}

.legal-notice dt {
  font-weight: bold;
  color: #111;
}

.legal-notice dd {
  margin: 0;
}

.legal-notice a {
  color: #0066cc;
  text-decoration: none;
}

.legal-notice a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 600px) {
  .legal-notice dl {
    grid-template-columns: 1fr;
  }

  .legal-notice dt {
    margin-top: 1em;
  }
}




.company-info {
  margin: 0 auto;
  padding: 2em 1em;
  font-size: 16px;
  line-height: 1.7;
  color: #333;
  background-color: #fff;
}

.company-info h1 {
  font-size: 1.8em;
  margin-bottom: 1em;
  border-bottom: 2px solid #666;
  padding-bottom: 0.4em;
  color: #222;
}

.company-info dl {
  display: grid;
  grid-template-columns: 150px 1fr;
  row-gap: 1em;
  column-gap: 1em;
}

.company-info dt {
  font-weight: bold;
  color: #111;
}

.company-info dd {
  margin: 0;
}

.company-info a {
  color: #0066cc;
  text-decoration: none;
}

.company-info a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 600px) {
  .company-info dl {
    grid-template-columns: 1fr;
  }

  .company-info dt {
    margin-top: 1em;
  }
}

.step-list.setu	{ font-size:0.9em;color: #666;}
.text_r	{ color:#e32a2a;font-size:1.2rem;}
