@charset "UTF-8";

@media (prefers-reduced-motion: no-preference) {
:root{
	--forest-green:#17613e;
	--gold:#B29156;
	--gold-light:#D6B941;
	--off-white:#F9F7F2;
}
}

body{
font-family:"Yu Gothic", "游ゴシック体","Hiragino Kaku Gothic ProN","Meiryo", sans-serif;
font-size: 16px;
background-color: var(--off-white);
line-height: 1.5;
font-weight: 500;
color: var(--forest-green);
}
main.second{
	padding-top: 77px;
}
/* utilities */
.text-forest{ color: var(--forest-green)!important; }
.text-gold{ color: var(--gold)!important; }
.text-gold-light{ color: var(--gold-light)!important; }
.bg-forest{ background: var(--forest-green)!important; color: var(--off-white); }
.bg-green{
		background: url(./img/bg_greeen.png) no-repeat var(--forest-green);
		background-size: cover;
}
.bg-cream{ background: var(--off-white)!important; }
.bg-circle{
		background-image: url(./img/bg_about_l.png), url(./img/bg_about_r.png);
		background-color: var(--off-white)!important;
		background-repeat: no-repeat, no-repeat;
		background-size: contain;
		background-position: top left, top right;
		padding-top: 125px;
		padding-bottom: 100px;
}


.border-gold{ border-color: rgba(169, 127, 54, 0.45)!important; }
.shadow-soft{ box-shadow: 0 12px 30px rgba(0,0,0,.10); }

html,body,h1,h2,h3,h4,ul,ol,li,p,span,iframe,footer,address,h1,h2,h3,h4,h5,dl,dt,dd{
margin: 0;
padding:0;
}
.btn:focus, .btn.focus {
		outline: 0;
		box-shadow: none;
}
*:focus {
		outline: none;
}
/* font
------------------------------*/
.min-font,.hero-title,.section-title{
		font-family: "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
}
.serif { 
		font-family: 'Noto Serif JP', serif; 
}

/* link
------------------------------*/
a{
		color: var(--forest-green);
		transition : color 0.5s ease 0s;
		text-decoration: none;
}
a:focus {
		outline: none;
}
a:hover{
		text-decoration: none;
		color: #000;
}
.underline_link{
		text-decoration: underline!important;
}

.btn-gold{
	--bs-btn-color:#fff;
	--bs-btn-bg: var(--gold);
	--bs-btn-border-color: var(--gold);
	--bs-btn-hover-bg: #B29156;
	--bs-btn-hover-border-color:#B29156;
	--bs-btn-focus-shadow-rgb: 178,145,86;
	border-radius: 999px;
	padding: .9rem 1.25rem;
	letter-spacing: .06em;
	transition: 0.3s;
}
.btn-outline-gold{
	--bs-btn-color: var(--gold);
	--bs-btn-border-color: rgba(178,145,86,.85);
	--bs-btn-hover-bg: rgba(178,145,86,.12);
	--bs-btn-hover-border-color: rgba(178,145,86,1);
	--bs-btn-hover-color: var(--gold);
	border-radius: 999px;
	padding: .9rem 1.25rem;
	letter-spacing: .06em;
	background: transparent;
	transition: 0.3s;
}
.btn-gold:hover{
		text-decoration: none;
		color: #FFF;
		/* outline: 1px solid #B29156; */
}
.btn-gold:hover { 
		background-color: #9c7b41;
		/* outline: 1px solid #B29156; */
}
/* header */
nav{color:#fff}
nav .nav-link{color:#fff}
nav .navbar-brand{color:#fff}
.lp-nav{
	backdrop-filter: blur(10px);
	background: rgb(32 168 102 / 57%);
	border-bottom: 1px solid rgba(178,145,86,.25);
}
.brand-mark{
	width: 42px; height: 42px;
	border-radius: 14px;
	background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), rgba(255,255,255,0)),
							linear-gradient(135deg, rgba(178,145,86,.35), rgba(23,97,62,.35));
	border: 1px solid rgba(178,145,86,.35);
}

/* hero */
.hero{
	position: relative;
	overflow:hidden;
	min-height: 100vh;
	/* background:
		radial-gradient(900px 600px at 20% 20%, rgba(23,97,62,.16), rgba(23,97,62,0) 60%),
		radial-gradient(900px 600px at 80% 0%, rgba(178,145,86,.18), rgba(178,145,86,0) 55%),
		linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0)); */
}
.hero:before{
	content:"";
	position:absolute; inset:-2px;
	background: 
		/* radial-gradient(900px 600px at 20% 20%, rgba(33, 143, 91, 0.418), rgba(11, 173, 97, 0.187) 60%),
		radial-gradient(900px 600px at 80% 0%, rgba(0, 248, 132, 0.418), rgba(145, 187, 8, 0.418) 55%),
		linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0)),  */
		url('https://images.unsplash.com/photo-1535131749006-b7f58c99034b?q=80&w=2070') center/cover no-repeat;
	filter: saturate(.9) contrast(.95) brightness(.85);
	transform: scale(1.03);
	/* opacity:.25; */
	pointer-events:none;
}
.hero-inner{ position:relative; z-index:1; }
.hero-kicker{
	display:inline-flex;
	gap:.5rem;
	align-items:center;
	padding:.4rem .75rem;
	border-radius:999px;
	border:1px solid rgba(178,145,86,.45);
	background: rgba(249,247,242,.75);
	color:#3b3b3b;
	font-size:.95rem;
}
.hero-title{
	letter-spacing:.08em;
	line-height:1.22;
}
.hero-lead{
	max-width: 56ch;
	color: rgba(0,0,0,.78);
}

/* section */
.section{ padding: 4.5rem 0; }
.section-title{
	letter-spacing:.08em;
	line-height:1.25;
}
.section-subline{
	width: 84px; height: 2px;
	background: linear-gradient(90deg, var(--gold), rgba(178,145,86,0));
	border-radius: 2px;
	margin-top: .75rem;
}
.anchor-offset{ scroll-margin-top: 92px; }

/* cards */
.classic-card{
	border: 0px solid rgba(178,145,86,.22);
	border-radius: 15px;
	background: rgba(255,255,255,.72);
}
.hero .classic-card{
	max-width: 600px;
}

.feature-icon{
	width: 44px; height: 44px;
	border-radius: 16px;
	display:grid; place-items:center;
	border: 1px solid rgba(178,145,86,.35);
	background: rgba(178,145,86,.10);
	color: var(--forest-green);
	font-weight:700;
}

/* list styling */
.classic-list li{
	padding:.65rem .75rem;
	border-bottom:1px dashed rgba(178,145,86,.25);
}
.classic-list li:last-child{ border-bottom:none; }

/* flow */
.flow-step{
	border-left: 2px solid rgba(178,145,86,.35);
	padding-left: 1rem;
}
.flow-badge{
	width: 34px; height: 34px;
	border-radius: 999px;
	background: #cc452d;
	border: 1px solid #e43617;
	color: #ffffff;
	display:grid; place-items:center;
	font-weight:700;
	flex: 0 0 auto;
	outline-offset: -3px;
}


.badge-green {
		display: inline-block;
		padding: 8px 5px;
		margin-right: 5px;
		/* 2025年らしい上品なゴールドの輝き */
		background: linear-gradient(135deg, #e2c053 0%, #f5eac8 50%, #e2c053 100%);
		color: #1a1a1a;
		font-family: "Noto Serif JP", serif;
		font-weight: 700;
		font-size: 1rem;
		letter-spacing: 0.1em;
		border-radius: 50px; /* 曲線を入れることで優雅さを演出 */
		border: 1px solid rgba(0,0,0,0.05);
		box-shadow: 0 4px 10px rgba(212, 175, 55, 0.3);
		position: relative;
		bottom: 5px;
		text-align: center;
		width: 100%;
		text-align: center;
}


p{
		line-height: 1.8;
}
/* accordion
------------------------------*/
/* .accordion-button:not(.collapsed) {
		background-color: #898053;
		color: #FFF;
} */
	.accordion-item{
		border: none;
	}
	.accordion-body{
		background-color: #f3f2ea;
	}
	.accordion-item:last-of-type>.accordion-collapse{
		overflow: hidden;
}
.accordion-button:focus{
		box-shadow: none;
}
.accordion-button:not(.collapsed){
		background-color: #898053;
		color: #FFF;
}
.accordion-button:not(.collapsed)::after {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}
/* button
------------------------------*/
.button {
line-height: 1.5;
position: relative;
/* padding: 1rem 4rem; */
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-transition: all 0.3s;
transition: all 0.3s;
text-align: center;
vertical-align: middle;
text-decoration: none;
}

.shiryou_button,.kengaku_button{
		font-weight: 700;
		outline-offset: -5px;
		border-radius: 0;
		display: flex;
		align-items: center;
		width: 250px;
		max-width: 100%;
		justify-content: center;
		font-size: clamp(1.13rem, 800.00vw + -382.38rem, 1.63rem);
		letter-spacing: .1em;
		text-indent: .1em;
		height: 80px;
}
.contact_area .shiryou_button,.contact_area .kengaku_button{
		width: 350px;
}
a.shiryou_button,a.shiryou_button:active, .shiryou_button:visited{
		background-color: #ad951d;
		color: #FFF;
		border: none;
		outline: 1px solid #d4bf53;
		transition: 0.3s;
}
a.shiryou_button:hover,a.kengaku_button:hover{
		text-decoration: none;
		color: #FFF;
		
}
.shiryou_button:hover { 
		background-color: rgb(124, 108, 28);
		outline: 1px solid #bba741;
}
.kengaku_button{
		background-color: #cc452d;
		color: #FFF;
		border: none;
		outline:1px solid #e88372
}
.kengaku_button:hover { 
		background-color: #ae3a26;
		outline: 1px solid #e88372;
}

a.shiryou_head,a.shiryou_head:active, .shiryou_head:visited{
		background-color: #ad951d;
		color: #FFF;
		border: none;
		outline: 1px solid #d4bf53;
		outline-offset: -4px;
		transition: 0.3s;
}
.shiryou_head:hover,.kengaku_head:hover{
		text-decoration: none;
		color: #FFF;
}
.shiryou_head:hover { 
	background-color: rgb(124, 108, 28);
		outline: 1px solid #bba741;
}
.kengaku_head{
		background-color: #cc452d;
		color: #FFF;
		border: none;
		outline:1px solid #e88372;
		outline-offset: -4px;
}
.kengaku_head:hover { 
		background-color: #ae3a26;
		color: #FFF;
		outline: 1px solid #e88372;
}
button.submit_button{
		outline-offset: -5px;
		border-radius: 0;
		display: flex;
		align-items: center;
		width: 250px;
		max-width: 100%;
		justify-content: center;
		font-size: 18px;
		letter-spacing: .1em;
		text-indent: .1em;
		height: 50px;
		background-color: #0d7d49;
		color: #FFF;
		box-shadow: none;
		outline: none;
		border: none;
}
button.submit_button:hover{
		background-color: #09502f;
}
/* finale */
.finale{
	border-top: 1px solid rgba(178,145,86,.20);
}

footer{
	border-top: 1px solid rgba(178,145,86,.20);
	background: rgba(249,247,242,.9);
}

/* -------- Scroll Fade-in Animation -------- */
.reveal{
	opacity: 0;
	transform: translateY(16px);
	transition: opacity .8s ease, transform .8s ease;
	will-change: opacity, transform;
}
.reveal.is-visible{
	opacity: 1;
	transform: translateY(0);
}
@media (prefers-reduced-motion: reduce){
	.reveal{ opacity: 1; transform:none; transition:none; }
}

@media (min-width: 992px){
	.hero{ padding-top: 7rem; padding-bottom: 6.5rem; }
}
@media (max-width: 991.98px){
	.hero{ padding-top: 6.25rem; padding-bottom: 4.5rem; }
}