@charset "utf-8";
/* CSS Document */

/* --- 1. 共通設定 --- */
        html { scroll-behavior: smooth; }

        
        #lp-wrap {
            margin: 0; padding: 0;
            font-family: 'Noto Sans JP', sans-serif !important;
            color: #333 !important;
            line-height: 1.8 !important;
            background-color: #fff !important;
            text-align: center !important;
            -webkit-font-smoothing: antialiased;
        }

        /* 既存サイトの明朝体指定などを強制上書き */
        #lp-wrap * {
            font-family: 'Noto Sans JP', sans-serif !important;
            box-sizing: border-box;
        }

        #lp-wrap img { max-width: 100% !important; height: auto !important; vertical-align: bottom !important; margin: 0 auto; }
        #lp-wrap .inner { max-width: 1000px !important; margin: 0 auto !important; padding: 0 5% !important; box-sizing: border-box !important; }

        /* --- 2. 導入部 (Section 1 & 2) --- */
        #lp-wrap #section1 { width: 100% !important; margin-bottom: 60px !important; }
        #lp-wrap #section2 { margin-bottom: 60px !important; }
        #lp-wrap .main-title { 
            font-size: 28px !important; font-weight: bold !important; 
            margin-bottom: 30px !important; letter-spacing: 0.1em !important;
            text-align: center !important; line-height: 1.5 !important;
        }
        #lp-wrap .lead-text { 
            font-size: 16px !important;
			color: #333 !important; 
            display: inline-block !important;
			max-width: 750px !important; 
            text-align: center !important;
			font-weight: 600;
			margin: 0 auto !important;
        }

        /* --- 3. アンカーナビ (Section 3) --- */
        #lp-wrap #section3 { 
			padding: 60px 0 !important;
			border-bottom: 1px solid #3D3D3D !important;
		}
		
        #lp-wrap .anchor-nav {
            display: flex !important;
			justify-content: center !important;
			align-items: stretch !important;
            gap: 15px !important;
			list-style: none !important;
			padding: 0 !important;
			margin: 0 auto!important;
			max-width: 800px !important;
        }
		
		#lp-wrap .anchor-nav li {
			flex: 1 !important; 
			margin: 0 !important;
		}
		
        #lp-wrap .anchor-nav a {
            display: flex!important;
			align-items: center !important;
			justify-content: center !important;
			text-decoration: none !important;
			color: #333 !important;
            font-size: 15px !important;
			font-weight: bold !important;
			letter-spacing: 0.1em !important;
            padding: 15px 10px !important;
			border: 2px solid #D3D3D3 !important;
            transition: all 0.3s ease !important;
			height: 100% !important;
            background-color: transparent !important;
        }
        #lp-wrap .anchor-nav a:hover { background-color: #333 !important; color: #fff !important; }

        /* --- 4. 特集コンテンツ (Section 4, 5, 6) --- */
        #lp-wrap .feature-section { padding: 120px 0 !important; width: 100% !important; }
        /* 背景色交互設定 */
        #lp-wrap section.feature-section:nth-of-type(odd) { background-color: #f9f9f9 !important; }
        #lp-wrap section.feature-section:nth-of-type(even) { background-color: #ffffff !important; }

        #lp-wrap .feature-content { max-width: 800px !important; margin: 0 auto 50px !important; }
        #lp-wrap .category-tag { font-size: 13px !important; letter-spacing: 0.2em !important; color: #888 !important; display: block !important; margin-bottom: 15px !important; font-weight: bold !important; }
        #lp-wrap .item-title { font-size: 26px !important; font-weight: 700 !important; margin-bottom: 25px !important; line-height: 1.4 !important; text-align: center !important; }
        #lp-wrap .description { 
            font-size: 16px !important;
			margin-bottom: 40px !important;
			color: #333 !important; 
            text-align: center !important;
			line-height: 1.8 !important;
			font-weight: 500;
        }

        #lp-wrap .feature-sub-image {
            width: 100% !important;
			max-width: 800px !important;
			margin: 0 auto 60px !important;
			line-height: 0 !important;
        }
		#lp-wrap .feature-sub-image img {
			width: 100% !important;
			height: auto !important;
			display: block !important;
		}

        /* 商品グリッド */
        #lp-wrap .item-grid {
            display: grid !important; grid-template-columns: 1fr 1fr !important;
            gap: 40px 20px !important; max-width: 800px !important; margin: 0 auto !important;
        }
        #lp-wrap .item-card { text-decoration: none !important; color: inherit !important; display: block !important; text-align: left !important; }
        #lp-wrap .item-image-wrapper { overflow: hidden !important; margin-bottom: 15px !important; background-color: #f0f0f0 !important; }
        #lp-wrap .item-image-wrapper img { width: 100% !important; transition: transform 0.5s ease, opacity 0.5s ease !important; }
        
        #lp-wrap .item-name { font-size: 14px !important; font-weight: bold !important; margin-bottom: 5px !important; line-height: 1.4 !important; color: #333 !important; }
        #lp-wrap .item-price { font-size: 14px !important; color: #666 !important; }
		
		#lp-wrap .sub-heading {
			display: block !important;
			text-align: left !important;
			max-width: 800px !important;
			margin: 0 auto 20px !important;
			padding-left: 8px !important;
			border-left: 5px solid #333 !important;
			font-size: 16px !important;
			font-weight: bold !important;
			letter-spacing: 0.1em !important;
			line-height: 1 !important;
			color: #333 !important;
		}
		
		/* --- Section 7の上に区切り線 --- */
		#section6 { 
			border-bottom: 3px solid #eee;
	   }
		
        /* --- Section 7 --- */
        #lp-wrap #section7 { 
			padding: 100px 0 !important; 
			background-color: #f9f9f9 !important;
		}
		
		
        #lp-wrap .btn-all-view {
            display: inline-block !important;
            width: 100% !important; max-width: 500px !important;
            padding: 20px 0 !important;
            background-color: #333 !important;
            color: #fff !important;
            text-decoration: none !important;
            font-size: 16px !important;
            font-weight: bold !important;
            letter-spacing: 0.15em !important;
            transition: opacity 0.3s ease !important;
            margin: 0 auto !important;
        }
		
		/* --- 改行コントロール --- */
		#lp-wrap .pc-only { display: inline !important; }
		#lp-wrap .sp-only { display: none !important; }
		

        /* --- 6. レスポンシブ調整 --- */
        @media (max-width: 768px) {
            #lp-wrap .main-title { font-size: 20px !important; padding: 0 5% !important; }
            #lp-wrap .lead-text { font-size: 14px !important; padding: 0 5% !important; }
            #lp-wrap .feature-section { padding: 60px 0 !important; }
            #lp-wrap .item-title { font-size: 18px !important; }
            #lp-wrap .description { font-size: 14px !important; line-height: 1.6 !important; }
			#lp-wrap .anchor-nav { gap: 8px !important; padding: 0 10px !important; }
            #lp-wrap .anchor-nav a { padding: 12px 5px !important; font-size: 11px !important; }
            #lp-wrap .btn-all-view { width: 90% !important; font-size: 14px !important; }
			#lp-wrap .item-name { font-size: 12px !important; }
			#lp-wrap #section3 {
				position: -webkit-sticky;
				position: sticky;
				top: 0;
				z-index: 1000;
				background: rgba(255, 255, 255, 0.95) !important;
				padding: 20px 0 !important;
				box-shadow: 0 2px 10px rgba(0,0,0,0.05);
			}
			#lp-wrap .anchor-nav a {
				font-size: 12px !important;
				padding: 10px 15px !important;
				min-width: 90px !important;
			}
			.floating-nav-btn { display: none !important; }
			
			#lp-wrap .sub-heading {
				font-size: 14px !important;
				max-width: 100% !important;
			}
			#lp-wrap .pc-only { display: none !important; }
			#lp-wrap .sp-only { display: block !important; content: ""; margin-top: 0; }
			#lp-wrap #section2 .lead-text {
				max-width: 95% !important;
				font-size: 14px !important;
				line-height: 1.7 !important;
			}
        }
		
		/* --- 小さめスマホ用（iPhone SE等） --- */
		@media (max-width: 375px) {
			#lp-wrap .anchor-nav a {
				font-size: 10px !important;
				letter-spacing: 0 !important;
				padding: 10px 2px !important;
			}
			
    #lp-wrap .main-title { font-size: 18px !important; }
    #lp-wrap .item-name { font-size: 11px !important; }
}
		
		
		/* --- 【PC用】フローティングボタン --- */
		.floating-nav-btn {
			display: none;
			position: fixed;
			bottom: 80px;
			right: 30px;
			z-index: 1001;
			background: #333;
			color: #fff !important;
			padding: 15px 25px;
			text-decoration: none;
			font-size: 14px;
			font-weight: bold;
			border-radius: 4px;
			box-shadow: 0 4px 15px rgba(0,0,0,0.2);
			transition: opacity 0.4s, transform 0.4s;
			opacity: 0;
			transform: translateY(20px);
		}
		
		.floating-nav-btn.is-visible {
			display: block;
			opacity: 1;
			transform: translateY(0);
		}

#lp-wrap .feature-icons-container {
    display: flex !important;
    flex-direction: row !important;  /* 横に並べる */
    justify-content: center !important;
    align-items: flex-start !important;
    gap: 20px 40px !important;       /* アイコン同士の間隔（縦・横） */
    margin: 20px auto 10px !important;
    max-width: 800px !important;
    list-style: none !important;
    padding: 0 10px !important;
}

/* 個別のアイコン＋テキストのセット */
#lp-wrap .icon-set {
    display: flex !important;
    flex-direction: column !important; /* 画像と文字を上下に並べる */
    align-items: center !important;    /* 中央揃え */
    flex: 0 0 120px !important;        /* 1つの幅を固定して安定させる */
}

/* アイコン画像のデザイン調整 */
#lp-wrap .icon-set img {
    width: 60px !important;            /* アイコンのサイズ */
    height: auto !important;
    margin-bottom: 8px !important;     /* 画像と文字の間隔 */
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* アイコン下のテキスト調整 */
#lp-wrap .icon-set span {
    font-size: 13px !important;
    font-weight: bold !important;
    color: #333 !important;
    line-height: 1.2 !important;
    text-align: center !important;
    white-space: nowrap !important;
    display: block !important;
}

/* スマホ表示 (768px以下) */
@media (max-width: 768px) {
    #lp-wrap .feature-icons-container {
        gap: 15px 10px !important;
    }
    #lp-wrap .icon-set {
        flex: 0 0 90px !important;
    }
    #lp-wrap .icon-set img {
        width: 45px !important;
    }
    #lp-wrap .icon-set span {
        font-size: 10px !important;
    }
}
