/*================================================
 *  ドラッグストア・薬局向けソリューション　CSS設定
 ================================================*/
*{    font-family: YakuHanJP, 'Noto Sans JP', 'noto-fallback', 'rome_num', sans-serif;}
/*================================================
  タブレット設定
  ================================================*/

.pagetop {
	bottom: 250px;
}

.breadcrumbs {
	padding: 20px 10px;
}

.content {
	width: 100%;
	margin: 0 auto;
	padding: 10px;
}


.link {
	color: #005d96;
	font-size: 20px;
	border: 1px solid #005d96;
	border-radius: 30px;
	display: inherit;
	padding: 10px;
	width: 100%;
}

.link:hover {
	opacity: 0.7;
	background: #eafbff;
}

.link_box {
	width: 94%;
	max-width: 670px;
	margin: 0 auto 30px;
}

.btm_btn03 {
	display: block;
	text-align: center;
	width: 100%;
	padding: 2.0rem 0;
	position: relative;
	z-index: 1;
	background-color: #fff;
	border: 1px solid #176D92;
}

.btm_btn03 a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-indent: -999px;
	z-index: 2;
	/* 必要であればリンク要素の重なりのベース順序指定 */

}

.aTxt{
	color:#5788E5;
}
.aTxt:visited{
	color:#5788E5 ;
}
.aTxt::after{
	font-family:Font Awesome\ 5 Free;
	font-weight:600;	
	content:"\f35d";
	padding-left: 0.5em;
	}
.aTxt:hover{
	color: #37aaf7 ;
	text-decoration:underline;
}


/*tabの全体枠*/
.tab {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 1004px;
	margin: 0 auto 30px;
}

/*inputを非表示にする*/
.input {
	position: absolute;
	opacity: 0;
}

/*tabボタン部分*/
.tab-label {
	width: calc(100% / 3);
	border-right: 2px solid #fff;
	position: relative;
	padding: 20px;
	background: linear-gradient(to bottom, rgba(237, 237, 237, 1) 0%, rgba(252, 252, 252, 1) 100%);
	cursor: pointer;
	font-weight: bold;
	font-size: 1.4rem;
	color: #000;
	margin-bottom: 0;
	text-align: center;
	transition: background 0.1s, color 0.1s;
	border-radius: 0.5rem 0.5rem 0 0;
}

.tab-label:after {
	content: '';
	background: url(/product/business/images/arrow_bottom.svg);
	width: 8px;
	height: 8px;
	position: absolute;
	right: 10px;
	margin-top: -10px;
}

.tab-label:nth-of-type(3) {
	border-right: 0;
}

.tab-label:after {
	content: '';
	background: url(/product/business/images/arrow_bottom.svg);
	width: 8px;
	height: 8px;
	position: absolute;
	margin-top: -10px;
}

.tab-label:hover {
	background: #d8d8d8;
}

.tab-label:active {
	background: #ccc;
}

.input:checked + .tab-label {
	background: #7FBE25;
	color: #fff;
	text-align: center;
}

.tab-label span {
	display: block;
	height: 1.4rem;
}

.after_logo:after {
	content: '';
	display: inline-block;
	width: 80px;
	height: 20px;
	vertical-align: middle;
	background: url(/product/business/images/jtfs_logo.svg);
	background-size: 80px 20px;
	margin-left: 10px;
}

/*tabの本文エリア*/
.tab-panel {
	display: none;
	padding-top: 20px;
	background: #fff;
	width: 100%;
	order: 99;
}

.tab_border {
	border-top: 3px solid #7FBE25;
	width: 100%;
}

.input:checked + .tab-label + .tab-panel {
	display: block;
	border-top: 3px solid #7FBE25;
}

/*tabの本文エリア*/
.tab-panel {
	display: none;
	padding-top: 20px;
	background: #fff;
	width: 100%;
}

.tab_border {
	border-top: 3px solid #7FBE25;
	width: 100%;
}

.input:checked + .tab-label + .tab-panel {
	display: block;
	border-top: 3px solid #7FBE25;
}


.function_box {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px 10px;
	margin: 0 auto 30px;
}

.function_box > a {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
	background: #389a6d;
	padding: 10px;
	position: relative;
	transition: .3s;
}

.function_box > a:hover {
	opacity: 0.3;
}

.function_box > a::after {
	font-family: "Font Awesome 5 Free";
	content: "\f107";
	font-weight: 900;
	margin: 0 0 0 10px;
}


/*
.function {
	display: flex;
	justify-content: space-around;
}

.function a {
	width: calc(95%/3);
	background: #389a6d;
	color: #fff;
	font-size: 17px;
	font-weight: 400;
	padding: 20px 0;
	text-align: center;
	position: relative;
	cursor: pointer;
}

.function a:hover {

	opacity: .7;
}
*/

.small {

	vertical-align: super;
	display: contents !importnat;
}


.new2::before {
	position: absolute;
	content: "NEW";
	padding: 6px 15px;
	background: white;
	color: #aa0007;
	border: 2px solid #aa0007;
	border-radius: 5px;
	font-weight: 700;
	top: -30%;
	left: -2%;
}

#nsips .new2::before {
	top: 0%;
	left: 24%;
	font-size: 15px;
}

.line {
	height: 1px;
	border: none;
	background: #e3e3e3;
	margin: 0 0 10px 0;
}

.text_annotation {
	font-size: 1.1rem;
}

/*その他
 ---------------------------------------------------------------------------*/
.u-mb-20 {
	margin: 0 0 20px 0;
}

#field p{
	line-height:1.6;
}

.campaignBox{
	text-align:center;
	margin: 0 auto 7rem;
}
.campaignBox a{
	display: block;
	width:fit-content;
	text-align: center;
	margin: 0 auto;
	max-width: 96%;
}
.campaignBox a img{
	width:100%;
}


/*================================================
  section hero
  ================================================*/

section {
	width: 100%;
	padding: 0;
	margin: 0 auto;
}

.drug_hero_bg {
	width: 100%;
	background: url("/product/business/images/drug_bg.jpg") 0 20% no-repeat;
	background-size: cover;
	color: #fff;
	padding: 0;
	position: relative;
}

.drug_hero {
	text-align: center;
	height: 300px;
	display: flex;
}

.drug_hero_box {
	width: 100%;
	text-align: center;
	align-self: center;
}


.drug_hero h1 {
	font-size: 4.0rem;
	font-weight: 500;
	margin-bottom: 1.5rem;
}

.drug_hero span {
	display: block;
	font-size: 1.4rem;
}

.ap_anc_bnr_layout {
	display: flex;
	justify-content: space-between;
}

.ap_bnr {
	width: 49%;
	border: 1px solid #ccc;
	padding: 1.0rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	position: relative;
}

.ap_bnr a {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	text-indent: -999px;
}

.ap_bnr_box p {
	font-size: 1.2rem;
	color: #666;
}

/* .ap_bnr_box img {
   max-height: 30px;
 } */

.appos01.appos02 {
	width: 100%;
	margin: 0 auto;
	padding-top: 3.0rem;
}

.type_bcpos {
	border: 1px solid #00863C;
	border-radius: 15px;
	padding: 0.8rem;
	background-color: #fff;
	max-width: 150px;
	margin: 2.0rem auto 0;
	color: #00863C;
}

.type_hdpos {
	border: 1px solid #7FBE25;
	border-radius: 15px;
	padding: 0.8rem;
	background-color: #fff;
	max-width: 150px;
	margin: 2.0rem auto 0;
	color: #7FBE25;
}

.receipt img {
	max-width: 250px;
	margin: 0 auto;
}


.appos01 h2 {
	text-align: center;
	font-size: 3.0rem;
	color: #7FBE25;
}

.appos02 h2 {
	text-align: center;
	font-size: 3.0rem;
	color: #7FBE25;
	margin-top: 3.0rem;
}

.appos01 h3 {
	text-align: center;
	font-size: 3.0rem;
	color: #000;
}

.appos01 .hdpos_register h3 {
	text-align: center;
	font-size: 2.0rem;
	color: #7FBE25;
	margin-bottom: 20px;
}

.appos01 h4 {
	text-align: center;
	color: #000;
}

.appos01 h5 {
	color: #7FBE25;
	font-size: 1.6rem;
	font-weight: bold;
}

.appos01 span {
	text-align: center;
	font-size: 1.2rem;
	/*
display: block;
*/
}

.appos02 span {
	text-align: center;
	font-size: 1.2rem;
	color: #666;
	display: block;
}

.bnr_layout {
	display: flex;
}

.bnr_box {
	flex-basis: 130px;
}

.bnr_box:last-child {
	margin-left: 2.0rem;
}

.mmtyle {
	width: 100% !important;
	padding: 2.0rem !important;
	border: 2px solid #B1C73E;
	color: #B1C73E;
	margin-top: 3.0rem;
}


/* list */
table {
	width: 100%;
	background: #fff;
	text-align: center;
	margin: 0 auto;
}

table th {
	width: 100%;
}

table td {
	line-height: 1.5;
	border: solid 1px #ccc;
	padding: 5px;
}

table td:first-child {
	background: #f2f2f2;
}

#resecon_list{
	padding: 30px 0 10px;
	background:#f8f8f8;
}
#resecon_list h3{padding: 0 0 24px;
	color: #024f99;
	line-height: 1.4;
	font-size: 24px;
	font-weight: bold;}
.renkei_jisseki_box {
    height: 500px;
	overflow-y: scroll;
	resize: vertical;
}

.renkei_jisseki {
	text-align: left;
}

.renkei_jisseki tr:nth-of-type(1) td {
	text-align: center;
	background: #e0e0e0;
}

.renkei_jisseki tr td:nth-of-type(1),
.renkei_jisseki tr td:nth-of-type(2) {
	width: 40%;
}

.renkei_jisseki td {
	border: solid 1px #ccc;
	padding: 10px;
}

.renkei_jisseki td:first-child {
	background: #fff;
}

.renkei_jisseki .title2 {
	background: gray !important;
}

.renkei_jisseki .caption:hover .caption_child {
	display: inline;
}

.renkei_jisseki .caption_child:after {
	border-right: 12px solid rgba(200, 230, 255, 0.5);
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	left: -12px;
	top: 30%;
	content: "";
	position: absolute;
}


	.pconly_res{
		display:block;
	}
	.sponly_res{
		display:none;
	}

@media screen and (max-width:767px) {
	.pconly_res{
		display:none !important;
	}
	.sponly_res{
		display:block !important;
	}
}

/*************************************************************************************/
/*Sp Layout*/
/*************************************************************************************/


@media screen and (max-width:767px) {
	.pagetop {
		bottom: 90px;
	}

	.foot {
		padding-bottom: 80px;
	}

	.breadcrumbs {
		padding: 20px;
	}

	.tab-label {
		width: 100%;
		border-right: none;
	}

	.rt_bnr_box p {
		font-size: 1.2rem;
	}

	.drug_hero {
		height: 200px;
	}

	drug_hero_bg {
		width: 100%;
		background: url("/product/business/images/drug_bg.jpg") 50% 20% no-repeat;
	}

	.drug_hero h1 {
		font-size: 2.6rem;
	}

	.stat_hero {
		height: 200px;
	}

	.stat_hero h1 {
		font-size: 2.6rem;
	}

	.function_box {
		max-width: 400px;
		grid-template-columns: repeat(1, 1fr);
	}

	#nsips .new2::before {
		top: -40%;
		left: 34%;
		font-size: 15px;

	}

	#nsips img {
		padding: 0 50px;
	}

	.appos01 h3 {
		font-size: 2.0rem;
		line-height: 2.4rem;
		margin-top: 3.0rem;
		text-align: left;
	}

	.g_checklist ul {
		margin-left: 0.5rem;
		margin-top: 1.0rem;
	}

	.g_checklist ul li {
		padding-bottom: 5px;
		line-height: 2rem;
		text-indent: -2.4rem;
		padding-left: 2rem;
	}

	.appos01 h2 {
		font-size: 2.0rem;
	}

	.interlock h4 {
		font-size: 2.0rem;
	}

	.regi h6 {
		margin-top: 1.6rem;
	}

	.dflist p {
		margin-top: 2.0rem;
		line-height: 2.4rem;
	}

	.taxfree_layout h4 {
		font-size: 2.0rem;
	}

	.taxfree_layout h4:after {
		font-size: 1.2rem;
		padding: 0.5rem 1.0rem;
		margin-left: 1.0rem;
		position: absolute;
		top: 10%;
	}

	.taxfree_layout span {
		margin-top: 0.6rem;
		margin-bottom: 2.0rem;
	}

	.link {
		font-size: 1.4rem;
	}


/*  */
	.renkei_jisseki td:first-child {
		background: #eaeaea;
	}

	.renkei_jisseki tr td:nth-of-type(1),
	.renkei_jisseki tr td:nth-of-type(2),
	.renkei_jisseki tr td:nth-of-type(3) {
		display: table-cell;
		font-size: 1.1rem;
		padding: 10px 5px;
	}

	.renkei_jisseki tr td:nth-of-type(-n+2) {
		width: 39%;
	}
}

@media print {
	.tab-label {
		width: calc(100% / 3);
		border-right: 2px solid #fff;
		position: relative;
	}

	.tab-panel {
		order: 99;
	}

	.tab-label:nth-of-type(3) {
		border-right: 0;
	}
}

/* 202506 - FVリニューアル */

/*================================================
	section hero
	================================================*/

/* --------------------------------------------------
 1. CORE VARIABLES - easily change theme colors
 --------------------------------------------------*/
 :root {
--main-teal: #1B365D;
--badge-size: 100px;
--spacing-sm: 10px;
--spacing-md: 20px;
--spacing-lg: 30px;
--spacing-xl: 50px;
--border-radius: 4px;
}

/* --------------------------------------------------
 2. HERO BOX STRUCTURE - better responsiveness
 --------------------------------------------------*/
.renewal .hero-box {
background: #fff;
overflow: hidden;
position: relative;
width: 100%;
background-image:url("../images/pharmacy_img/pharmacy_bg.png");
/* background-color:rgb(248, 255, 254); */
background-size: cover;
background-position: bottom;
}

.renewal .hero-inner {
max-width: 1200px;
margin: 0 auto;
display: flex;
align-items: center;
justify-content: space-between;
padding: 30px 30px 0px;
min-height: 450px;
position: relative;
}

/* --------------------------------------------------
 3. LEFT COLUMN - cleaner badge positioning
 --------------------------------------------------*/
.renewal .hero-left {
flex: 1 1 50%;
max-width: 50%;
display: flex;
flex-direction: column;
position: relative;
z-index: 2;
}

.renewal .hero_textbox{
/* ↓padding-left で空きを作っていたのを削除 */
padding-left: 0;
/* ↓横並びレイアウトに変更 */
display: flex;
align-items: flex-start;       /* バッジの上端とテキストの上端をそろえる */
gap: 20px;                     /* 左右の余白（お好みで） */
}

.renewal .hero_heading{
display: flex;
flex-direction: column;
}

/* Badge styling - consistent positioning */
.renewal .badge {
width: var(--badge-size);
height: var(--badge-size);
background: var(--main-teal);
color: #fff;
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
font: 700 18px/1.4 "Noto Sans JP", sans-serif;
border-radius: var(--border-radius);
box-shadow: 0 2px 8px rgba(0,0,0,.15);
position: static;              /* もしくは entirely 削除 */
flex: 0 0 var(--badge-size);   /* 固定サイズで縮ませない */
margin: 0;                     /* ずれ防止 */
text-align: center;

}

/* Title elements - improved styling */
.renewal .sub {
font-size: 18px;
font-weight: 600;
color: var(--main-teal);
margin: 0 0 8px;
position: relative;
display: inline-block;
padding-bottom: 4px;
}

.renewal .sub::after {
content: "";
position: absolute;
left: 0;
bottom: 0;
width: 80%;
height: 3px;
background: var(--main-teal);
border-radius: 1.5px;
}


.renewal .title {
font-size: 62px;
font-weight: 900;
line-height: 1.1;
margin: 0 0 40px 0;
}

/* Features list - better spacing and alignment */
.renewal .features {
display: flex;
gap: 30px;
list-style: none;
margin: 0 0 20px;
padding: 0;
}

.renewal .features li {
position: relative;
padding-left: 34px;
font: 500 16px/1.3 "Noto Sans JP", sans-serif;
white-space: nowrap;
display: flex;
align-items: center;
}

.renewal .features li::before {
content: "";
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 26px;
height: 26px;
background: url(../images/pharmacy_img/check-icon.svg) center/contain no-repeat;
box-shadow: 0 2px 4px rgba(0,0,0,.1);
}

.renewal .badge {
	background: linear-gradient(135deg, #4A91C3 0%, #1A375E 30%, #1A375E 100%);
}


/* --------------------------------------------------
 4. STAFF & MEDALS SECTION - improved layout
 --------------------------------------------------*/
.renewal .medals-staff-container {
display: flex;
gap: 50px;
align-items: self-end;
max-width: 100%;
}

.renewal .staff-image {
width: 260px;
max-width: 100%;
border-radius: var(--border-radius);
filter: drop-shadow(0 4px 8px rgba(0,0,0,.1));
}

.renewal .medals {
display: flex;
gap: 40px;
}

.renewal .medal {
width: 100px;
filter: drop-shadow(0 4px 8px rgba(0,0,0,.15));
}

.renewal .medal img {
width: 100%;
object-fit: contain;
}

.renewal .medal .small {
	font-size: 10px;
	text-align: center;
	line-height: 1.0;
}

/* ─────────── メダル＋バナーの縦並びラッパー ─────────── */
.renewal .medals-group{
display: flex;
flex-direction: column;   /* メダル→バナー の縦並び */
align-items: center;      /* 横中央寄せ */
}

/* ─────────── バナーの基準幅（PC：120×2＋gap20＝260px） ─────────── */
.renewal .medal-banner{
display: block;
margin-top: 10px;         /* メダルとの間隔 */
width: calc(300px + 20px);/* → = 260px  */
margin-bottom: 20px;
box-shadow: 0 4px 8px rgba(0, 0, 0, .15);
}
.renewal .medal-banner img{
width: 100%;              /* ラッパー幅いっぱいで縮小表示 */
height: auto;
vertical-align: bottom;
}
.renewal .pconly3 {
	display: block;
}

/* --------------------------------------------------
 5. RIGHT COLUMN - better image positioning
 --------------------------------------------------*/
.renewal .hero-right {
flex: 1 1 50%;
max-width: 50%;
display: flex;
justify-content: flex-end;
align-self: flex-end;
}

.renewal .register {
width: 560px;
max-width: 100%;
align-self: flex-end;
margin-right: 0px;
filter: drop-shadow(0 5px 15px rgba(0,0,0,.1));
padding-bottom: 30px;
position:relative;
right: -60px;
}

.full-width a {
  transition: 0.3s;
}
.full-width a:hover {
	opacity: 0.3;
}
.renewal .subsidy-button {
  /* display: block; */
  background-color: rgb(238 102 79 / 95%);
  color: white;
  text-decoration: none;
  padding: 10px 2px;
  border-radius: 6px;
  max-width: 340px;
  min-width: 260px;
  font-family: 'Helvetica Neue', 'Hiragino Kaku Gothic ProN', 'YuGothic', 'Yu Gothic', sans-serif;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  transition: background-color 0.2s;
  text-align: center;
}
.renewal .subsidy-button-overlay {
  position: absolute;
  bottom: 15px;
  right: -10px;
  max-width: 300px;
  transform: scale(0.8);
  transform-origin: bottom right;
}
.renewal .main-text {
  display: block;
  font-size: 25px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.5px;
  margin-bottom: 3px;
  transform: scale(.95);
}
.renewal .it-text {
  font-weight: 700;
  font-size: 33px;
  font-family: 'Arial', 'Helvetica', sans-serif;
  font-style: italic;
  letter-spacing: -0.5px;
  margin-right: 5px;
  display: inline-block;
  transform: scaleY(1.1);
  transform-origin: bottom;
  line-height: 0.9;
}
.renewal .year-text {
  font-family: 'D-DIN', 'DIN Alternate', 'DIN Condensed', 'Arial', sans-serif;
  font-weight: 600;
  font-size: 29px;
  letter-spacing: 0.2px;
}
.renewal .sub-text {
  display: block;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: -0.2px;
  line-height: 1.3;
}

/* --------------------------------------------------
 6. PRICE STRIP - improved layout and alignment
 --------------------------------------------------*/
.renewal .hero-price {
background: var(--main-teal);
color: #fff;
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: center;
gap: 50px;
padding: 25px 20px;
position: relative;
}

/* Set contents styling - better borders and spacing */
.renewal .set-contents {
display: flex;
width: 670px;
max-width: 100%;
border-radius: 10px;
box-shadow: 0 4px 8px rgba(0,0,0,.15);
overflow: hidden;
background-color: #fff;
padding: 4px;
margin-top: 0;
}

.renewal .set-label {
flex: 0 0 160px;
background: #fff;
color: var(--main-teal);
font: 700 18px/1 "Noto Sans JP", sans-serif;
display: flex;
align-items: center;
justify-content: center;
padding: 18px 10px;
}

.renewal .set-items {
flex: 1;
padding: 0;
margin: 0;
list-style: none;
background: linear-gradient(135deg, #4A91C3 0%, #1A375E 30%, #1A375E 100%);
}

.renewal .set-items:nth-of-type(1) {
border-right: 1px solid #fff;;
}
.renewal .set-items li {
color: #fff;
font: 500 14px/1.2 "Noto Sans JP", sans-serif;
text-align: center;
padding: 7px 0;
}

.renewal .set-items li+li {
border-top: 1px solid rgba(255,255,255,0.35);
}
.renewal .sponly2 {
		display: none;
}
.renewal .sponly3 {
	display: none;
}

/* Price value styling - improved alignment */
.renewal .price-value {
text-align: center;
min-width: 260px;
}

.renewal .price-label {
position: relative;
font: 700 20px/1 "Noto Sans JP", sans-serif;
letter-spacing: .08em;
width: max-content;
margin: 0 auto 30px;
}

.renewal .price-label::before,
.renewal .price-label::after {
content: "";
position: absolute;
top: 50%;
width: 130px;
height: 1px;
background: rgba(255,255,255,.6);
}

.renewal .price-label::before {
right: 100%;
margin-right: 12px;
}

.renewal .price-label::after {
left: 100%;
margin-left: 12px;
}

.renewal .price-num {
display: inline-flex;
align-items: flex-end;
gap: 8px;
}

.renewal .price-num .num {
font-size: 56px;
font-weight: 900;
letter-spacing: -1px;
}

.renewal .price-num .yen {
font-size: 40px;
font-weight: 800;
position: relative;
}

.renewal .price-num .tax-note {
position: absolute;
left: 0;
bottom: 100%;
margin-bottom: 4px;
font-size: 14px;
font-weight: 300;
}


.onayamiBox{
	background:#DDE6F8;
	border-top: 10px solid #5788E5;
	border-radius: 0 ;
	text-align:center;
	margin: 5rem auto 19rem;
	padding: 5rem;
	position:relative;
}
.onayamiBox::after{


  content: "";
  position: absolute;
  right: 0;
  top: 100%;
  left: 0;
  width: 0px;
  height: 0px;
  margin: auto;
  border-style: solid;
  border-color: #DDE6F8 transparent transparent transparent;
  border-width: 170px 505px 0 505px;
}


.onayamiBox h2{
	background:#3D5A80;
	color:#fff;
	font-size:2.4rem;
	font-weight:400;
	display:block;
	margin: 0 auto 1rem;
	width:fit-content;
	padding: 0.5rem 2rem;
}
.onayamiBox h3{
	font-size:3.8rem;
	font-weight:bold;
	color:#000;
	margin-bottom: 4rem;
}
.onayamiBox h3 span{
	color:#5788E5;
	font-size:4.4rem;
}

.onayamiBox ul{
	display: grid;
	align-items:top;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}
.onayamiBox ul li{
}
.onayamiBox ul li img{
	max-width: 70px;
}
.onayamiBox ul li p{
	font-size: 1.8rem;
	font-weight:bold;
}
.onayamiBox ul li p span{
	color:#5788E5;
}


.reasonWrap{
	background-color:#DDE6F8;
	background-image: url(/product/business/images/pharmacy_img/bg_reason.png);
	background-repeat:no-repeat;
	background-size:contain;
	background-position:top;
	margin: 0 auto;
	padding: 4rem 0 0;
}

.reasonBox{
	max-width:1100px;
	margin: 0 auto;
	position:relative;
}



.reasonH2{
	position:relative;
	width:fit-content;
	margin: 0 auto;
}
.reasonH2:before{
	content:"";
	background:url(/product/business/images/pharmacy_img/pointKid.png) no-repeat;
	width: 52px;
	height: 47px;
	position:absolute;
	top: 0;
	right:-4rem;
}

.reasonSub{
	background:#fff;
	color:#000;
	display:flex;
	justify-content:center;
	align-items:center;
	padding: 1.5rem 2rem;
	border-radius: 10px;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
	position:absolute;
	width:fit-content;
	bottom:-12rem;
	z-index:1;
	left:calc(50% - 340px);
	gap: 0.5rem;
}
.reasonSub img{
	max-width: 230px;
	height:100%;
}
.reasonSub p{
	font-weight:bold;
	font-size:3.8rem;
	line-height:1;
}
.reasonSub p span{
	color:#5788E5;
}

.reasonBox h2{
	font-size:3.8rem;
	font-weight:bold;
	color:#000;
	margin-bottom: 9rem;
	padding-top:5rem;
}
.reasonBox h2 span{
	color:#5788E5;
	font-size:4.4rem;
}

.reason{
	background: white;
	border-radius: 0 0 10px 10px;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
	margin-bottom: 10rem;
	position: relative;
  }
.reason .reasonNum{
	position:absolute;
	font-family:Arial, Helvetica, sans-serif;
	top:-13rem;
	left:1rem;
	font-size:12rem;
	color:#EE6C4D;
	opacity:0.7;
	font-weight:bolder;
	z-index:1;
}
.reason:nth-of-type(even) .reasonNum{
	left:unset;
	right:1rem;
}
.reason .reasonVisual{
	display:flex;
	justify-content:center;
	align-items:stretch;
	flex-direction: row-reverse;
}
.reason:nth-of-type(even) .reasonVisual{
	flex-direction: row;
}


.reasonVisual > div{
background: #2F61C2;
background: linear-gradient(90deg, rgba(47, 97, 194, 1) 0%, rgba(87, 136, 229, 1) 100%);
justify-content:center;
align-items:center;
display:flex;
flex:1;
}

.reasonVisual > img{
	flex:1;
	max-width:50%;
}

.reasonVisual h3{
color:#fff;
font-size:3.2rem;
text-align:center;
}
.reasonVisual h3 span{
color:#fff;
font-size:2.8rem;
}
 .reason h4{
color:#5788E5;
font-size:2.4rem;
margin-bottom:1rem;
}
.reasonTxt{
	border-radius: 0 0 10px 10px;
	padding: 30px 40px 40px 40px;
	border:1px solid #5788E5;
}
.reasonTxt p{
	font-size: 16px;
	line-height: 1.6;
}
.reasonTxt img{
	max-width: 400px;
	flex: 1;
}
.reasonImg{
	width:100%;
	text-align:center;
}
.reasonImg img{
	max-width:100%;
}

.mlrc{
	margin-right:auto !important;
	margin-left:auto !important;
}

.w100{
	width:100%;
}
.w80{
	width:80% !important;
}
.flexIR{
	display:flex;
	flex-direction: row-reverse;
	width:100%;
	justify-content: space-between;
	gap:5rem;
}
.flexIL{
	display:flex;
	width:100%;
	justify-content: space-between;
	gap:5rem;
}
.reasonTxt dl{
	margin-top:1rem;
}
.reasonTxt dl dt{
	color:#3D5A80;
	font-size:1.6rem;
	font-weight:bold;
}
.reasonTxt dl dd{
	margin-bottom:1rem;
}
.reasonTxt dl dd:last-child{
	margin-bottom:0;
}

.mb-3{
	margin-bottom:3rem;
}

.reason:last-child {
	margin-bottom: 0;
  }

.column{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.flexGrow{
	flex-grow:1;
}

.clickUp,
.clickUp a{
	position:relative;
}


.otherWrap{
background-image: url(/product/business/images/pharmacy_img/bg_other.png),
linear-gradient(180deg, rgba(221, 230, 248, 1) 0%, rgba(255, 255, 255, 1) 50%);
background-repeat: no-repeat, no-repeat;
  background-position:
    bottom,
    left;
background-size: contain, contain;
margin: 10rem auto 0;
padding: 5rem 0 10rem;
}

.otherBox{
	max-width:1100px;
	margin: 0 auto;
	background:#F3F7FC;
	border-radius: 10px;
	padding: 3rem;
	border:1px solid #5788E5;
}

.otherBox h3{
	font-size:3.2rem;
	font-weight:bold;
	color:#000;
	text-align:center;
}
.otherBox h3 span{
	color:#5788E5;
}
.otherList{
	display:grid;
	grid-template-columns:repeat(3, 1fr);
	align-items:start;
	margin:0;
	padding:3rem;
	list-style:none;
	position:relative;
	gap:5rem;
}
.otherList li {
	align-self:stretch;
	}
.otherList li figure { width:100%; margin:0; padding:0; margin-bottom:2rem; }
.otherList li figure img { width:100%; height:auto; }
.otherListTxt { width:100%; margin:0; padding:0;
position: relative;}

.otherListTxt h4{
	color:#5788E5;
	font-size:2.4rem;
	font-weight:bold;
	line-height:1.4;
	margin-bottom: 1rem;
}
.otherListTxt p{
}
/*
.otherListTxt p{
    position: relative;
    max-height: 3.5em;
    margin-bottom: 0;
    overflow: hidden;
    transition: max-height 1s;
}
.otherListTxt:has(:checked) p {
    max-height: 100vh;
}

.otherListTxt p::after {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 60px;
    background: linear-gradient(to bottom, rgba(243, 247, 252, 0) 0%, rgba(243, 247, 252, 1.0) 60%);
    content: '';
}
*/

.otherListTxt:has(:checked) p::after {
    content: none;
}
.otherListTxt label {
    display: flex;
    align-items: center;
    gap: 0 4px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    color: #4f96f6;
    font-size: .8em;
}

.otherListTxt label:hover {
    color: #c7511f;
    text-decoration: underline;
    cursor: pointer;
}

.otherListTxt:has(:checked) label {
    display: none;
}
/*
.otherListTxt label::after {
    display: inline-block;
    width: 10px;
    height: 5px;
    background-color: #b6bdc3;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
}
*/
.otherListTxt input {
    display: none;
}



.flowBox{
	margin: 8rem auto 0;
}
.flowBox h2{
	font-size:4.4rem;
	font-weight:bold;
	color:#000;
	text-align:center;
	margin-bottom: 5rem;
}
.flowBox h2 + p{
	font-size:2.0rem;
	font-weight:500;
	color:#000;
	text-align:center;
	margin-bottom: 4rem;
}


  /* 個別の特徴セクション */
  .flow-section {
	background: white;
	border-radius: 10px;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
	/*padding: 30px 80px 40px 80px;*/
	padding: 0 0 40px 0;
	margin-bottom: 40px;
	position: relative;
	overflow: hidden;
  }
  
  .flow-section:last-child {
	margin-bottom: 0;
  }
  
  /* 番号ラベル - ピリオド付き数字に変更 
  .flow-number {
	position: absolute;
	top: 0;
	left: 0;
	width: 60px;
	height: 60px;
	background: var(--main-teal);
	color: white;
	font-size: 26px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0 0 10px 0;
	z-index: 1;
	font-family: 'Arial', sans-serif;
  }
  */

  .flow-renkei {
	position: absolute;
	top: 0;
	left: 0;
	width: 100px;
	height: 60px;
	background: var(--main-teal);
	color: white;
	font-size: 16px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0 0 10px 0;
	z-index: 1;
	font-family: 'Arial', sans-serif; /* 数字のフォントをはっきりさせる */
  }
  
  /* 特徴のヘッダー */
  .flow-header {
	margin-bottom: 30px;
	padding: 30px 80px 0 80px;
  }
  
  .flow-title {
    display: block;
    font-weight: 800;
    font-size: 15px;
    margin-bottom: 5px;
	color: var(--dark-teal);
  }

    
  .flow-title2 {
	font-size: 30px;
	font-weight: 700;
	background: var(--main-teal);
	color: white;
	text-align:center;
	padding: 1rem 0;
  }
  
  .option {
	font-size: 14px;
	font-weight: normal;
	background: var(--main-teal);
	color:#fff;
	padding: 0.2rem 2rem;
	display: inline-block;
	margin: 0 0 0.6rem 5rem;
	vertical-align: middle;
  }
  
  .flow-description {
	font-size: 16px;
	line-height: 1.6;
  }
  
  /* 特徴のコンテンツエリア */
  .flow-content {
	margin-top: 20px;
	padding: 0 80px 0 80px;
  }
  
  /* リストスタイル */
  .flow-list {
	list-style: none;
	padding: 0;
	margin: 20px 0;
  }
  
  .flow-list li {
	position: relative;
	padding-left: 30px;
	margin-bottom: 12px;
	font-size: 16px;
	font-weight:bold;
	line-height: 1.5;
  }
  
  .flow-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 2px;
	width: 20px;
	height: 20px;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><rect width='24' height='24' rx='4' fill='rgb(61, 90, 128)'/><path d='M9 16.17 4.83 12 3.41 13.41 9 19 21 7 19.59 5.59z' fill='white'/></svg>") center/contain no-repeat;
  }
  
  /* 画像コンテナ */
  .flow-image-container {
	margin: 30px 0 0;
	text-align: center;
	display: flex;
	justify-content: center;
  }
  
  .flow-image {
	max-width: 70%;
/*	border: 1px solid #eee;
	border-radius: 8px;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.05);*/
  }

.flow-cash {
/*
	padding: 1rem 2rem;
	background:#f7f7f7;
	*/
}

  /* 特徴フッター */
  .flow-footer {
	margin-top: 30px;
	text-align: center;
  }
  
  .flow-link {
	display: inline-block;
	color: #005d96;
	font-size: 16px;
	border: 1px solid #005d96;
	border-radius: 30px;
	padding: 10px 30px;
	text-decoration: none;
	transition: all 0.3s ease;
  }
  
  .flow-link:hover {
	background: #eafbff;
	transform: translateY(-2px);
  }







  /* 個別の特徴セクション */
  .set-section {
	background: white;
	border-radius: 10px;
	padding: 30px 40px 40px 40px;
	margin-bottom: 40px;
	position: relative;
	overflow: hidden;
	background:#F7F7F7;
  }
  
  .set-section:last-child {
	margin-bottom: 0;
  }
  
  /* 番号ラベル - ピリオド付き数字に変更 */
  .set-number {
	position: absolute;
	top: 0;
	left: 0;
	width: 60px;
	height: 60px;
	background: #89D9B4;
	background: linear-gradient(90deg,rgba(137, 217, 180, 1) 0%, rgba(16, 105, 94, 1) 100%);
	color: white;
	font-size: 26px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0 0 10px 0;
	z-index: 1;
	font-family: 'Arial', sans-serif; /* 数字のフォントをはっきりさせる */
  }


.tal{
	text-align:left !important;
}
.tac{
	text-align:center;
}
.tacM{
	margin: 0 auto;
}
.pcNot{
	display:none;
}
.spOnly_res{
	display:none;
}


.fBox{
	display:flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	padding-top: 4rem;
	margin-bottom:1rem;
}
.fBox .fUl{
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, 1fr);
  width:100%;
}
.fBox .fUl li{
	background:#f4f0ed;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}

.fBox .fUl li .fSet{
	display:flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	gap: 3rem;
	padding-bottom: 3rem;
}
.fBox .fUl li .fSet .fSub {
	background: #0d7f3c;
	color: #fff;
	font-size: 1.1rem;
	border-radius: 10rem;
	line-height: 1.4;
	width: 90%;
	padding: 1rem 0.2rem;
	margin-top: -3rem;
	text-align:center;
}

.fBox .fUl li .fSet .fImg {
	position:relative;
	border-radius: 0.2rem;
	background:#fff;
	width:150px;
	height:150px;
}
.fBox .fUl li .fSet .fImg img{
	max-width:150px;
	width:auto;
	max-height:150px;
}
.fBox .fUl li .fSet .fRegi {
	font-size: 1.8rem;
	font-weight:bold;
	color:#0d7f3c;
	text-align:center;
}
.fBox .fUl li .fSet .fRegi span{
	font-size: 1.6rem;
}

.fBox .fUl li .fSet .fMark{
	position:absolute;
	bottom: -30px;
	right: -30px;
	background:#e63117;
	color: #fff;
	padding: 1rem 0.2rem;
	line-height: 1.2;
	width: 70px;
	height: 70px;
	border-radius: 100px;
	display:flex;
	justify-content:center;
	align-items:center;
	z-index: 2;
}
.fBox .fUl li .fSet .fMark p{
	font-size: 1.0rem;
	text-align:center;
	line-height: 1.4;
}
.fBox .fUl li .fSet .fMark p span{
	font-size: 1.4rem;
}

.fBox .arrow{
	margin-top: 2rem;
	display: flex;
	justify-content: space-between;
	align-items:center;
	width: 92%;
	position:relative;
}
.fBox .arrow:after{
	background: #F4E6B3;
	background: linear-gradient(90deg,rgba(244, 230, 179, 1) 0%, rgba(228, 188, 40, 1) 100%);
	height: 35px;
	width: 102%;
	content:"";
	position:absolute;
}

.fBox .arrow li{
	z-index: 3;
	position:relative;
}
.fBox .arrow li:last-child::after{
	content:"\f0da";
	font-family: Font Awesome\ 5 Free;
	font-style: normal;
	font-weight: 900;
	color:#E4BC28;
	font-size: 60px;
	position:absolute;
	right: -38px;
	bottom: -3px;
}

.fBox .arrow li dl{
	text-align:center;
	background:#fff;
	border-radius: 1rem;
	border: 1px solid #e3bc2b;
	width: 150px;
	padding: 1rem ;
}
.fBox .arrow li dl dt{
	font-size:1.6rem;
	font-weight:bold;
	padding-bottom: 0.5rem;
}
.fBox .arrow li dl dd{
	font-size:1.2rem;
}


.fBox .arrow li:before{
}

.contactBtn {
    display: block;
    width: fit-content;
    margin: 5rem auto 5rem;
    padding: 1.5rem 10rem;
    border-radius: 64px;
    color: #ffffff !important;
    line-height: 1.6;
    font-size: 1.8rem;
    font-weight: bold;
    text-decoration: none;
    background: #5788E5;
    transition: 0.2s;
    text-align:center;
}

.contactBtn:hover {
    background: #10695e;
    transition: 0.2s;
}

.contactBtnIn {
    display: block;
    width: fit-content;
    margin: 0 auto;
    padding: 1.5rem 10rem;
    border-radius: 64px;
    color: #ffffff !important;
    line-height: 1.6;
    font-size: 1.8rem;
    font-weight: bold;
    text-decoration: none;
    background: #5788E5;
    transition: 0.2s;
    text-align:center;
}

.contactBtnIn:hover {
    background: #10695e;
    transition: 0.2s;
	opacity:0.3;
}


/* hikaku - 色修正版 */
#hikaku {
	background-color: #f8f8f8;
	padding: 0;
	overflow: hidden;
  }
  
  .register-comparison-container {
	position: relative;
	width: 100%;
	padding-top: 3rem;
	padding-bottom: 5rem;
  }
  
  .register-comparison-title-container {
	width: 100%;
	text-align: center;
	margin-bottom: 0px;
	position: relative;
	/* z-index: 10; */
  }
  
  .register-comparison-title {
	color: #5788E5; /* テーマ色 */
	font-size: 28px;
	font-weight: 800;
	margin: 0;
	padding: 30px 0 10px;
	text-align: center;
  }
  
  .register-comparison-content {
	display: flex;
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
  }
  
  /* 左右のカラム */
  .register-comparison-col {
	width: 50%;
	position: relative;
	padding: 0 15px 10px;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
  }
  
  /* 左右の背景 */
  .register-comparison-col.left {
	background-color: #d7e2f5; /* 左側の薄い青 */
	padding: 0 15px 10px 80px;
  }
  
  .register-comparison-col.right {
	background-color: #e6e6e6; /* 右側の薄いグレー - 修正 */
	padding: 0  80px 10px 15px;
  }
  
  /* タイトルコンテナ */
  .title-container {
	width: 100%;
	text-align: center;
    margin: 15px 0;
  }
  
  /* ボタンスタイル */
  .register-comparison-system-title {
	background: #5788E5; /* 左側の青緑色ボタン */
	color: #fff;
	padding: 10px 40px;
	border-radius: 30px;
	display: inline-block;
	font-size: 18px;
	font-weight: 600;
	min-width: 180px;
	text-align: center;
  }
  
  .register-system-title-right {
	background: #4d4d4d; /* 右側の濃いグレーボタン */
  }
  
  /* イラスト部分 */
  .register-comparison-icon-container {
	height: 150px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 15px;
	width: 100%;
  }
  
  .register-comparison-icon-container img {
	/* max-width: 150px; */
	height: auto;
  }
  
  /* 白いカード箱 */
  .register-comparison-box {
	background-color: #fff;
	border-radius: 8px;
	padding: 5px;
	margin: 0 auto;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
	width: 100%;
    max-width: 410px;
  }
  
  /* 特徴リスト */
  .register-comparison-features {
	list-style: none;
	padding: 20px;
	margin: 0;
  }
  
  .feature-item {
	position: relative;
	margin-bottom: 20px;
	padding-left: 18px; /* チェックマークのスペース */
	text-align: left;
  }
  
  .feature-item:last-child {
	margin-bottom: 0;
  }
  
  .check-mark {
	position: absolute;
	left: 0;
	top: 2px;
	color: #5788E5; /* 左側のチェックマーク色 */
	font-size: 15px;
  }
  
  .register-comparison-col.right .check-mark {
	color: #4d4d4d; /* 右側のチェックマーク色 - 修正 */
  }
  
  .feature-title {
	display: block;
	color: #5788E5; /* 左側の特徴タイトル色 */
    font-weight: 800;
	font-size: 15px;
	margin-bottom: 5px;
  }
  
  .register-comparison-col.right .feature-title {
	color: #4d4d4d; /* 右側の特徴タイトル色 - 修正 */
  }
  
  .feature-desc {
	margin: 0;
	padding: 0;
	color: #333;
	font-size: 14px;
	line-height: 1.5;
  }
  
  .price-highlight {
	color: #E74C3C; /* 金額の赤色 */
	font-weight: 700;
  }


  @media (max-width: 1023px) {
  .flow-header {
	  padding: 3rem 5rem 0;
  }
  .flow-content {
	  padding: 0 5rem;
  }
  }

  /* レスポンシブ対応 */
  @media (max-width: 767px) {
  .flow-header {
	  padding: 3rem 3rem 0;
  }
  .flow-content {
	  padding: 0 3rem;
  }

.register-comparison-content {
	  flex-direction: column;
	}

	 /* 左右の背景 */
	 .register-comparison-col.left {
		background-color: #d7e2f5; /* 左側の薄い青緑色 */
		padding: 0 15px 10px 15px;
	  }
	  
	  .register-comparison-col.right {
		background-color: #e6e6e6; /* 右側の薄いグレー - 修正 */
		padding: 0  15px 10px 15px;
	  }
	
	.register-comparison-col {
	  width: 100%;
	  padding: 20px 15px;
	}
	
	.register-comparison-title {
	  font-size: 22px;
	  padding: 30px 15px 10px;
	}
	
	.register-comparison-system-title {
	  padding: 10px 30px;
	  font-size: 16px;
	  margin-bottom: 15px;
	}
	
	.register-comparison-icon-container {
	  height: 120px;
	  margin-bottom: 30px;
	}
	
	.feature-title {
	  font-size: 16px;
	}
	
	.feature-desc {
	  font-size: 13px;
	}
	
	.register-comparison-box {
	  /* max-width: 100%; */
	  width: 90%;
	}
  }
/* hikaku */

.recommendation-column {
    max-width: 1200px;
            margin: 20px auto 40px;
            line-height: 1.8;
        }
        
        .column-box {
            background: #f2f7fe;
            border: 1px solid #e4edfa;
            border-radius: 12px;
            padding: 32px;
            position: relative;
            box-shadow: 0 8px 32px rgba(0, 166, 147, 0.1);
            overflow: hidden;
        }
        
        
        @keyframes shimmer {
            0%, 100% { background-position: 200% 0; }
            50% { background-position: -200% 0; }
        }
        
        .column-title {
            display: flex;
            align-items: center;
            margin-bottom: 10px;
            font-size: 20px;
            font-weight: bold;
            color: #5788E5;
            position: relative;
        }
        
        .column-title::before {
            content: '\f0eb';
			font-family: "Font Awesome 5 Free";
            font-size: 28px;
            margin-right: 12px;
        }
        
        .column-title::after {
            content: '';
            flex: 1;
            height: 1px;
            background: linear-gradient(90deg, #5788E5, transparent);
            margin-left: 16px;
            border-radius: 1px;
        }
        
        .column-content {
            font-size: 18px;
            color: #333;
            text-align: justify;
            position: relative;
            z-index: 1;
        }

		.column-content p{
            font-size: 16px;

		}

        
        .highlight-text {
            background: linear-gradient(120deg, rgba(87, 136, 229, 0.15) 0%, rgba(87, 200, 248, 0.15) 100%);
            padding: 2px 6px;
            border-radius: 4px;
            font-weight: 600;
            color: #5788E5;
        }
        
        .emphasis-point {
            position: relative;
            padding-left: 20px;
            margin: 16px 0;
        }
        
        .emphasis-point::before {
            content: '✓';
            position: absolute;
            left: 0;
            top: 2px;
            color: #00a693;
            font-weight: bold;
            font-size: 18px;
        }
        
        /* レスポンシブ対応 */
        @media (max-width: 768px) {
            .recommendation-column {
                margin: 20px auto;
                padding: 0 16px;
            }
            
            .column-box {
                padding: 24px 20px;
            }
            
            .column-title {
                font-size: 20px;
                align-items: flex-start;
                text-align: left;
			justify-content: center;
			align-items: center;
            }
            
            .column-title::after {
                display: none;
            }
            
            .column-content {
                font-size: 15px;
            }
			.column-content p {
    font-size: 14px;
}
		}


/* ズームアイコンのスタイル */

/* ズームアイコン */
.zoom-icon {
	position: absolute;
	bottom: -10px;
	right: 0;
	background-color: rgb(234 236 237 / 80%);
	padding: 5px;
	border-radius: 50%;
	width: 35px;
	height: 35px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 4px rgba(0,0,0,0.1);
	cursor: pointer;
  }
  
  .zoom-icon svg {
	width: 20px;
	height: 20px;
  }
  
  /* モーダルクローズボタン */
  .modal-close {
	position: absolute;
	top: -20px;
	right: -20px;
	width: 40px;
	height: 40px;
	background-color: #333;
	color: white;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 24px;
	line-height: 1;
	border: 2px solid white;
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  }
  
  .modal-close:hover {
	background-color: #555;
  }
  
  /* アニメーション */
  @keyframes fadeIn {
	from { opacity: 0; transform: scale(0.95); }
	to { opacity: 1; transform: scale(1); }
  }
  
  .fade-in {
	animation: fadeIn 0.2s ease-out;
  }



@media screen and (max-width: 1024px) {
	.renewal .hero-inner {
		padding: 40px 20px 20px;
		min-height: 400px;
	}
	.renewal .register {
		width: 48rem;
		padding-bottom: 15rem;
		right:0;
	}
	.renewal .hero-price {
		flex-direction: column;
		gap: 10px;
		padding: 20px 15px;
	}
	.renewal .hero-price .price-value {
		order: -1;
		transform: scale(0.8);
	}
	.renewal .features {
		flex-wrap: wrap;
	}
.onayamiBox::after{
  border-width: 170px 49vw 0 49vw;
}
}
@media screen and (max-width: 768px) {
.onayamiBox::after{
  border-width: 170px 50vw 0 50vw;
}
}

@media screen and (max-width: 767px) {
	.renewal .hero-inner {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
		column-gap: 18px;
		row-gap: 5px;
	}
	.renewal .hero-left {
		display: contents;
		flex: 1 1 auto;
		max-width: 100%;
		text-align: center;
		align-items: center;
	}
	.renewal .hero_textbox {
		align-items: anchor-center;
		justify-content: center;
		gap: 15px;
		padding-left: 0px;
		margin-bottom: 10px;
		width: 100%;
	}
	.renewal .hero_textbox,
	.renewal .features {
		flex: 1 1 100%;
	}
	.renewal .features {
		flex-wrap: wrap;
		justify-content: center;
		padding: 0 10px;
		box-sizing: border-box;
		flex-direction: row;
		gap: 10px 20px;
		margin: 0 auto 10px;
		max-width: 100%;
	}
	.renewal .badge {
		width: 60px;
		height: 80px;
		font-size: 12px;
		left: -40px;
	}
	.renewal .sub, .title {
		text-align: left;
	}
	.renewal .sub {
		margin-bottom: 8px;
	}
	.renewal .features li {
		white-space: normal;
		padding-left: 26px;
	}
	.renewal .features li {
		font-size: 14px;
	}
	.renewal .features li::before {
		width: 20px;
		height: 20px;
	}
	.renewal .medals-staff-container {
		order: 2;
		max-width: 45%;
		justify-content: flex-start;
		margin-bottom: 0;
		flex-direction: column;
		gap: 10px;
	}
	.renewal .staff-image {
		display: none;
	}
	.renewal .medals-group {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.renewal .medals {
		display: flex;
		flex-direction: column;
		gap: 10px;
		align-items: center;
	}
	.renewal .medal {
		width: 80px;
	}
	.renewal .medal-banner {
		width: 100%;
		max-width: 330px;
		margin: 0px auto 0;
		order: 4;
		align-self: center;
	}
	.renewal .pconly3 {
		display: none;
	}
	.renewal .sponly3 {
		display: block;
	}
	.renewal .hero-right {
		order: 1;
		flex: 0 0 100%;
		max-width: 70%;
		justify-content: center;
	}
	.renewal .subsidy-button {
		max-width: 330px;
		width: 70%;
		min-width: auto;
		margin: 10px auto;
		padding: 6px 2px;
	}
	.renewal .subsidy-button-overlay {
    position: relative;
    bottom: auto;
    right: auto;
    margin: 20px auto;
    transform: scale(1);
    max-width: 90%;
  }
	.renewal .register {
		margin: 0;
		width: 100%;
		padding-bottom: 0px;
		/* max-width: 200px; */
	}
	.renewal .hero-inner::after {
		content: "";
		display: block;
		width: 100%;
		order: 3;
		height: 0;
	}
	.renewal .set-contents {
		width: 100%;
		max-width: 100%;
		transform: scale(0.8);
	}
	.renewal .set-label {
		flex: 0 0 120px;
		font-size: 16px;
	}
	.renewal .sponly2 {
		display: block !important;
	}
	.renewal .hero-price .price-value {
		order: -1;
		transform: scale(0.8);
	}
	.renewal .price-label::before,
	.renewal .price-label::after {
		width: 80px;
	}
}

@media (max-width: 480px) {
	.renewal .badge {
		width: 80px;
		height: 70px;
		font-size: 14px;
	}
	.renewal .sub {
		font-size: 16px;
	}
	.renewal .title {
		font-size: 36px;
	}
	.renewal .features li {
		font-size: 14px;
	}
	.renewal .staff-image {
		width: 200px;
	}
	.renewal .medal {
		width: 70px;
	}
	.renewal .set-label {
		flex: 0 0 100px;
		font-size: 14px;
	}
	.renewal .set-items li {
		font-size: 12px;
		padding: 6px 0;
		height: 4rem;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.renewal .set-items li {
		font-size: 12px;
		padding: 6px 0;
		height: 4rem;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.renewal .price-num .num {
		font-size: 46px;
	}
	.renewal .price-num .yen {
		font-size: 32px;
	}
	.renewal .price-num .tax-note {
		font-size: 12px;
	}
}


/* お知らせ */
.renewal .oshirase_box {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  border: solid #ccc;
  border-width: 1px 0;
  padding: 0 0px 0 0;
}
.renewal .oshirase_box > div:first-of-type {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background-color: #3D5A80;
}
.renewal .oshirase_box > div:first-of-type,
.renewal .ver_box > div:first-of-type {
  width: 20%;
  text-align: center;
  padding: 20px;
}
.renewal .infobox {
  display: flex;
  width: 100%;
  padding: 15px 10px;
}
.renewal .oshirase_box > div:nth-of-type(2) {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.renewal .oshirase_box > div:nth-of-type(2),
.renewal .ver_box > div:nth-of-type(2) {
  justify-content: flex-start;
  align-items: center;
  width: 80%;
  line-height: 1.5;
}
.renewal .infobox>div:first-child {
  width: 10%;
  text-align: center;
}
.renewal .oshirase_box > div:nth-of-type(2) div:first-of-type {
	margin: 0 30px 0 0;
}
.renewal .oshirase_box > div:nth-of-type(2) div:first-of-type {
	margin: 0 30px 0 0;
}
.renewal .infobox>div>p {
  background: rgb(56, 55, 55);
  color: #fff;
  font-size: 12px;
  border-radius: 5px;
}
.renewal .infobox a {
  color: #005d96;
}
.renewal .oshirase_box a,
.renewal .oshirase_box_02 a,
.renewal .ver_box a {
  color: #005d96;
  text-decoration: none;
  transition: .3s;
}
@media screen and (max-width: 1024px) {
  .renewal .oshirase_box, .ver_box {
    padding: 0;
  }
	.renewal .oshirase_box > div:first-of-type, .ver_box > div:first-of-type {
		width: 100%;
		padding: 10px 0;
	}
	.renewal .oshirase_box > div:nth-of-type(2),
	.renewal .ver_box > div:nth-of-type(2) {
    width: 100%;
    padding: 20px 10px;
  }
	.renewal .oshirase_box > div:last-of-type, .ver_box > div:last-of-type {
		width: 100%;
		text-align: center;
		padding: 10px 10px;
	}
	.renewal .infobox>div:first-child {
		width: 100%;
		margin: auto;
		text-align: center;
	}
	.renewal .infobox>div>p {
  }
	.renewal .infobox a {
    text-align: left;
    display: block;
	}
}
body section.Intro {
	padding-top: 40px;
	background: transparent;
}

/* 導入事例 */
.Case {
	background-color: #DDE6F8;
}
.Case .flex {
	display: flex;
	gap: 3rem;
}
.Case .flexR{
	flex-direction: row-reverse;
}

.Case h2.headline {
	padding: 0 0 20px 0;
}
.Case .flex h3 {
	font-size: 24px;
	margin-bottom: 15px;
}
.Case .CaseLead {
	text-align: center;
	margin-bottom: 30px;
	padding: 0 0 0px 0;
	line-height: 1.5;
	font-size: 16px;
}

.Case .CaseFlex{
	display:flex;
	flex-wrap:wrap;
	gap: 2rem;
	justify-content: space-between;
}
.Case .CaseFlex img{
	border-radius: 8px;
}
.Case .CaseFlex img:nth-of-type(2),
.Case .CaseFlex img:nth-of-type(3){
	max-width:48%;
}

.Case .CaseInner {
	display: block;
	width: 90%;
  max-width: 1120px;
  margin: 0 auto;
	background: transparent;
}
.Case .CaseSummary {
	margin: 6rem auto;
  padding: 16px;
  border-radius: 8px;
  border: #126DD8 1px solid;
  background: #fff;
  width: 80%;
}
.Case .CaseText {
	width: 100%;
}
.Case .CaseCatch {
	margin: 20px auto 0 auto;
	font-size: 16px;
	line-height: 2.0;
	width: 100%;
	padding: 0;
}
.case-gallery-section {
  background-color: white;
  padding: 25px;
  text-align: center;
	margin-top: 6rem;
}

.Case .cta-button2 a{
	padding: 0 38px;
}

.gallery-header {
  margin-bottom: 20px;
  position: relative;
  background: #f7f7f7;
  border-radius: 8px;
  padding: 18px 0;
  box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.03);
}
.gallery-subtitle {
  display: block;
  font-size: 11px;
  letter-spacing: 3px;
  color: #3D5A80;
  font-weight: 600;
  margin-bottom: 3px;
  opacity: 0.8;
}
.gallery-header h3 {
  font-size: 24px;
  font-weight: 800;
  color: #3D5A80;
  position: relative;
  display: inline-block;
}
.gallery-header p {
  font-size: 15px;
  color: #666;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.4;
}
.case-gallery-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.gallery-item {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
  transition: var(--transition);
}
.gallery-link {
  display: block;
  height: 110px;
}
.gallery-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition);
}
.case-gallery-actions {
  margin-top: 18px;
  text-align: center;
}
.gallery-button {
  display: inline-block;
  background-color: var(--main-teal);
  color: white;
  font-size: 16px;
  font-weight: 600;
  padding: 10px 25px;
  border-radius: 30px;
  text-decoration: none;
  transition: var(--transition);
  min-width: 220px;
}


@media (max-width: 1023px) {
.Case .CaseFlex img:nth-of-type(2),
.Case .CaseFlex img:nth-of-type(3){
	max-width: 47%;
}
.Case .CaseSummary {
 width: 100%;
}
}

@media (max-width: 768px) {
.Case .CaseSummary {
 width: 100%;
}
.Case .CaseFlex{
	margin-bottom:2rem;
}
	.Case .cta-button2 {
		margin-top: 20px;
	}
	.Case .flex {
		display: block;
	}
	.gallery-header {
		padding: 15px 0;
	}
	.gallery-header h3 {
		font-size: 20px;
	}
	.gallery-header p {
    font-size: 14px;
  }
	.case-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
	.gallery-link {
    height: 90px;
  }
	.gallery-button {
		width: 100%;
		max-width: 280px;
	}
}

/* 選べるPOSレジラインアップ */
.bpRe-product {
  margin: 0;
  padding: 80px 0 20px 0;
}
.bpRe-product-inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
}
.bpRe-product h2 {
  text-align: center;
	margin-bottom: 5rem;
	font-size: 4.4rem;
	color:#000;
}
.bpRe-product h2 span{
	color:#5788E5;
}
.bpRe-product-inner .t-center {
	text-align: center;
	margin-bottom: 4rem;
}
.bpRe-product-inner .t-center h3 {
	margin:0 auto 2rem;
	width:fit-content;
	padding: 1rem 5rem;
	font-size: 2.4rem;
	background:#000;
	color:#fff;
	display:block;
}
.bpRe-product-inner .t-center h3 + p {
	font-size:2.0rem;
	font-weight:500;
}
.bpRe-product-option {
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: 3rem;
	position: relative;
	width: 100%;
	margin: 0 auto 5rem;
	padding: 3rem 2rem;
	list-style: none;
	background:#DDE6F8;
}

.bpRe-product-option li {
	background:#fff;
	border:1px solid #D0D6F0;
	border-radius: 1rem;
	display: flex;
	flex-direction:column;
	justify-content: center;
	align-items:center;
	gap:1rem;
	flex:1;
	padding: 3rem 2rem 2rem;
}
.bpRe-product-option li img {
	max-height: 48px;
}
.bpRe-product-option li p {
	font-size: 1.4rem;
	font-weight:500;
}
.bpRe-product-option li:nth-child(2) {
	position: relative;
	z-index: 2;
}
.bpRe-product-option li:nth-child(2)::before {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -40px;
	width: 56px;
	height: 56px;
	background: url(../images/pharmacy_img/icon-add.png) no-repeat;
	transform: translate(0, -25px);
}
.bpRe-product-option li:nth-child(3) {
	position: relative;
	z-index: 3;
}
.bpRe-product-option li:nth-child(3)::before {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -40px;
	width: 56px;
	height: 56px;
	background: url(../images/pharmacy_img/icon-add.png) no-repeat;
	transform: translate(0, -25px);
}
.bpRe-product-option figure {
  display: block;
  margin: 0;
  padding: 0;
  flex-grow:1;
}
.bpRe-product-option img {
	width: 100%;
}
.bpRe-product-item {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  gap:3rem;
}
.bpRe-product-item li {
  /* width: 47%; */
  flex: 1;
  margin: 0;
  padding: 2rem;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
	border-radius:8px;
}
.bpRe-product-photo {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
}
.bpRe-product-item li .bpRe-product-photo picture {
	order: 2;
}
.bpRe-reason-photo img {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	object-fit: contain;
 	 max-width: 320px;
}
.bpRe-product-item li .bpRe-product-photo-name {
	order: 1;
	width: 100%;
}
.bpRe-product-photo-name h4 {
	margin: 0;
	padding: 1rem;
	width: 100%;
	color: #fff;
	line-height: 1.5;
	font-size: 2.8rem;
	font-weight: bold;
	background: #3D5A80;
	text-align:center;
}
.bpRe-product-photo-name h4 br {
  display: inline;
}
.bpRe-product-photo-name p {
  margin: 3rem 0;
  padding: 0;
  color: #E74C3C;
  line-height: 1.2;
  font-size: 3.2rem;
  font-weight: bold;
  text-align:center;
}
/*
.bpRe-product-photo-name b {
	padding-right: 2px;
	font-family: 'Roboto', sans-serif;
	font-size: 40px;
}
*/
.bpRe-product-photo-name .label {
  position: relative;
  font-size:1.4rem;
  padding:0 0 24px;
  color:#000;
  font-weight:normal;
}
.bpRe-product-photo-name sup {
	position: relative;
	top: 0;
	left: 4px;
	color: #333;
	font-size: 10px;
	font-weight: normal;
}
.bpRe-product-text {
  margin: 0 auto;
  padding: 1.5rem 0 0;
  line-height: 1.5;
  font-size: 1.6rem;
  width:80%;
}
.bpRe-product-text dl {
  margin: 0;
  padding: 0;
}
.bpRe-product-text dt {
  margin: 0;
  padding: 0 0 1rem;
  font-size:2rem;
  font-weight:bold;
}
.bpRe-product-text dt svg {
	position: relative;
	top: 0.2rem;
	width: auto;
	height: 1em;
	margin: 0 1rem 0 0;
}
.bpRe-product-text dd {
	display: list-item;
	margin: 0 0 0 2rem;
	padding: 0 0 1rem 3rem;
	font-weight: normal;
	position:relative;
}

.bpRe-product-text dd::before {
	content: "";
	position: absolute;
	left: 0;
	top: 2px;
	width: 18px;
	height: 18px;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><rect width='24' height='24' rx='4' fill='rgb(61, 90, 128)'/><path d='M9 16.17 4.83 12 3.41 13.41 9 19 21 7 19.59 5.59z' fill='white'/></svg>") center/contain no-repeat;
  }

.pos-new-product-container {
  max-width: 1100px;
  margin: 4rem auto 2rem;
  border: 1px solid #5788E5;
  border-radius: 1rem;
  box-shadow: 0 5px 20px rgba(24, 128, 58, 0.1);
  background: #ffffff;
  overflow: hidden;
  position: relative;
}
.pos-new-product-title {
background: #2F61C2;
background: linear-gradient(90deg, rgba(47, 97, 194, 1) 0%, rgba(87, 136, 229, 1) 100%);
	text-align: center;
	font-size: 2.8rem;
	font-weight: bold;
	color: #fff;
	position: relative;
	padding: 2rem;
	letter-spacing: 1px;
}
.pos-new-product-title span {
  background: #E74C3C;
  color: white;
  font-size: 2.0rem;
  font-weight: bold;
  padding: 0 3rem;
  margin-right: 1.5rem;
  display:inline-block;
}

.pos-new-product-image {
	width:40%;
	text-align:center;
}
.pos-new-product-image img {
	width: auto;
	height: auto;
	max-height: 800px;
	margin: auto;
}


.pos-new-product-content {
  display: flex;
  padding:5rem;
  justify-content:center;
  gap:4rem;
}
.pos-new-product-info{
	width: 60%;
}

.pos-new-product-feature {
	display: block;
	margin: 0 0 1rem 2rem;
	padding: 0 0 1rem 3.5rem;
	font-weight: 500;
	font-size:2.0rem;
	position:relative;
}
.pos-new-product-feature + p {
	font-size:1.6rem;
}

.pos-new-product-feature::before {
	content: "";
	position: absolute;
	left: 0;
	top: 6px;
	width: 22px;
	height: 22px;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><rect width='24' height='24' rx='4' fill='rgb(61, 90, 128)'/><path d='M9 16.17 4.83 12 3.41 13.41 9 19 21 7 19.59 5.59z' fill='white'/></svg>") center/contain no-repeat;
  }

.pos-new-product-name {
  font-size: 2.8rem;
  font-weight: bold;
  margin-bottom: 20px;
  color: #fff;
  line-height: 1.2;
  padding: 1rem;
  background:#3D5A80;
  text-align:center;
  width:100%;
}
.pos-new-product-price-container {
}
.pos-new-product-price {
  font-size: 4.4rem;
  color: #e74c3c;
  font-weight: bold;
  display: block;
  padding: 0;
  text-align:center;
  margin: 0 auto 1rem;
}
.pos-new-product-price span {
  font-size: 1.4rem;
  color: #000;
  font-weight:normal;
  padding: 0 0 24px;
}
.bpRe-product-more {
	margin: 0;
	padding: 0;
	text-align: center;
}
.bpRe-product-more a {
  width: 100%;
  max-width: 480px;
}
.bpRe-btn {
  display: block;
  width: 90%;
  max-width: 480px;
  margin: 40px auto 0;
  padding: 0 16px;
  border: #5788E5 1px solid;
  border-radius: 64px;
  color: #fff !important;
  line-height: 64px;
  font-size: 18px;
  font-weight: bold;
  text-decoration: none;
  background: #5788E5;
  transition: 0.2s;
}
.bpRe-btn:hover {
	transition: 0.2s;
	opacity: 0.9;
}
@media (max-width: 767px) {
	.bpRe-product {
    margin: 0;
    padding: 40px 0;
	}
	.bpRe-product-inner {
	    width: 90%;
	    margin: 0 auto;
	}
	.bpRe-product h2 {
    text-align: center;
		font-size: 24px;
	}
	.section-headline {
    margin: 0;
    padding: 0 0 16px;
    font-size: 20px;
    font-weight: bold;
	}

}

/* 自動釣り銭機は全て循環式 */
.jyunkanshiki_box {
  background: #fff;
  border: 1px solid #ccc;
  padding: 20px;
}
.jyunkanshiki_box>p {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: left;
  margin: 0 0 20px;
}
.jyunkanshiki_box>div {
  gap: 30px 0;
  text-align: left;
}
.rsb {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}




/* バナー */
.bnr {
	max-width: 1000px;
  margin: 0 auto!important;
  width: 92%!important;
}


/* 料金プラン */
.bpRe-price {
	position: relative;
	overflow-x: hidden;
	width: 100%;
	max-width: 1100px;
	margin: 6rem auto 8rem;
	padding: 0;
	border: 0;
	background: #d7e2f5;
}
.bpRe-price-inner {
  width: 95%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 0;
  border: 0;
  text-align: center;
}
.bpRe-price-inner .section-headline {
	color: #666;
	margin-bottom: 40px;
}
.bpRe-price-list {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: flex-start;
	position: relative;
	z-index: 2;
	width: 100%;
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: left;
	gap:3rem;
}
.bpRe-price-list h3 {
	margin: 0;
	padding: 8px 0 16px;
	line-height: 1;
	font-size: 21px;
	color: #122d54;
	position:relative;
}
.bpRe-price-list li {
	align-self: stretch;
	/*width: 32%;*/
	flex:1;
	margin: 0;
	padding: 24px;
	border-radius: 8px;
	background: #fff;
	box-shadow: inset 0 2px 4px 0 #000000 16%;
	box-sizing: border-box;
	text-align:center;
	display: flex;
	flex-direction: column;
}
.bpRe-price-list li:nth-child(1) h3 {
  color: #519dd6;
}
.bpRe-price-list h3 small {
	display: block;
	margin: 0;
	padding: 8px 0 0;
	line-height: 1;
	font-family: 'Roboto', sans-serif;
	font-size: 12px;
	font-weight: normal;
	text-transform: uppercase;
}
.bpRe-price-list h3 + p {
	margin: 0;
	padding: 0 0 16px;
	border-bottom: #666666 1px solid;
	line-height: 1.4;
	font-size: 14px;
	flex-grow:1;
}
.bpRe-price-label {
	display: block;
	margin: 18px 0 8px;
	padding: 0;
	line-height: 1;
	font-size: 16px;
	text-align:center;
}
.bpRe-price-label img {
  max-width: 100%;
}
.bcpos-re img {
	width: auto;
	height: auto;
	max-height: 440px;
	margin: auto;
}
.bpRe-price-spec {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: center;
	margin: 0;
	padding: 0;
	line-height: 1;
}
.bpRe-price-spec dt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-self: stretch;
  width: 50%;
  margin: 0;
  padding: 16px 0 16px 8em;
  border-top: #666666 1px solid;
  color: #aaaaaa;
  font-size: 13px;
  text-align:left;
}
.bpRe-price-spec dd {
	display: flex;
	flex-direction: row;
	justify-content: flex-start;
	align-items: center;
	align-self: stretch;
	width: 50%;
	margin: 0;
	padding: 16px 0 16px 2em;
	border-top: #666666 1px solid;
	color: #aaaaaa;
	font-size: 16px;
	text-align: right;
}
.bpRe-price-spec dd b {
  font-family: 'Roboto', sans-serif;
  font-size: 20px;
}
.bpRe-price-spec dd svg {
  position: relative;
	top: 0;
  width: auto;
  height: 18px;
  margin-right: 2px;
}
.bpRe-price-spec dd .sizeAdjust {
	font-size: 20px;
}
.bpRe-price-spec dd .meritAdjust {
	font-size: 20px;
	font-weight: bold;
}
.bpRe-price-list li:nth-child(1) h3 {
	color: #14ae5c;
}
.bpRe-price-list li:nth-child(2) h3 img {
  margin-left: 8px;
  position:absolute;
}
.bpRe-price-list li:nth-child(1) .bpRe-price-spec dd b,
.bpRe-price-list li:nth-child(1) .bpRe-price-spec dd .meritAdjust,
.bpRe-price-list li:nth-child(1) .bpRe-price-spec dd b,
.bpRe-price-list li:nth-child(1) .bpRe-price-spec dd .meritAdjust {
	color: #14ae5c;
}
.bpRe-price-list li:nth-child(2) .bpRe-price-spec dd b,
.bpRe-price-list li:nth-child(2) .bpRe-price-spec dd .meritAdjust,
.bpRe-price-list li:nth-child(2) .bpRe-price-spec dd b,
.bpRe-price-list li:nth-child(2) .bpRe-price-spec dd .meritAdjust {
  color: #14ae5c;
}

@media (max-width: 1023px) {
.bpRe-price-spec dt {
  padding: 16px 0 16px 2em;
}
.bpRe-price-spec dd {
	padding: 16px 0 16px 2em;
}
}
@media (max-width: 767px) {
	.bpRe-price {
    position: relative;
    overflow-x: hidden;
    width: 100%;
    margin: 40px 0;
    padding: 0;
    border: 0;
    background-size: 90px auto;
	}
	.bpRe-price-inner {
    width: 90%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 40px 0;
    border: 0;
    text-align: center;
	}
	.section-headline {
    margin: 0;
    padding: 0 0 16px;
    font-size: 20px;
    font-weight: bold;
	}
	.bpRe-price-list {
    display: flex;
    flex-flow: column wrap;
    justify-content: flex-start;
    align-items: flex-start;
    position: relative;
    z-index: 3;
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
    text-align: left;
	}
	.bpRe-price-list li {
    align-self: stretch;
    width: 100%;
    margin: 12px 0 0;
    padding: 24px;
    border-radius: 8px;
    box-sizing: border-box;
	}
	.bpRe-price-list h3 {
    margin: 0;
    padding: 8px 0 16px;
    line-height: 1;
    font-size: 21px;
	}
	.bpRe-price-list h3 + p {
    margin: 0;
    padding: 0 0 16px;
    line-height: 1.4;
    font-size: 14px;
	}
	.bpRe-price-label {
    display: block;
    margin: 16px 0 8px;
    padding: 0;
    line-height: 1;
    font-size: 16px;
	}
	.bcpos-re img {
    width: auto;
    height: auto;
	}
	.bpRe-price-spec {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    margin: 0;
    padding: 0;
    line-height: 1;
	}
	.bpRe-price-spec dt {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-self: stretch;
    width: 10em;
    margin: 0;
    padding: 16px 0;
    font-size: 13px;
	}
	.bpRe-price-spec dd {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    align-self: stretch;
    width: calc(100% - 8.15em);
    margin: 0;
    padding: 16px 0;
    font-size: 16px;
    text-align: right;
	}
	.bpRe-price-spec dt {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-self: stretch;
    width: 10em;
    margin: 0;
    padding: 16px 0;
    font-size: 13px;
	}
	.bpRe-price-inner .section-headline {
		margin-bottom: 0;
	}
}

/* オプション */
.bpRe-plan-option {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  z-index: 2;
  width: 100%;
  margin: 56px 0 0;
  padding: 24px 40px;
  box-sizing: border-box;
  background-image: url(https://www.busicom.co.jp/product/bcpos/images/index/bg-option01.png), url(https://www.busicom.co.jp/product/bcpos/images/index/bg-option02.png);
  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, right 0;
  background-size: 5px 100%, 5px 100%;
  /* backdrop-filter: blur(40px); */
}
.bpRe-plan-option h3 {
	align-self: stretch;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	width: 176px;
	margin: 0 24px 0 0;
	padding: 0 24px 0 0;
	border-right: #dcdcdc 1px solid;
	text-align: left;
	box-sizing: border-box;
	color:#3D5A80;
}
.bpRe-plan-option h3 small {
	display: block;
	position: relative;
	top: inherit;
	padding: 0;
	font-family: 'Roboto', sans-serif;
	font-size: 13px;
	font-weight: normal;
}
.bpRe-plan-option ul {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: flex-start;
  width: calc(100% - 224px);
  margin: 0;
  padding: 0;
  list-style: none;
}
.bpRe-plan-option li {
	width: 100%;
	margin: 0;
	padding: 0;
	border-radius: 0;
	text-align: left;
	box-sizing: border-box;
	background: none;
	display: flex;
	justify-content: center;
	align-items: center;
	gap:4rem;
}
.bpRe-plan-option figure {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: flex-end;
	width: 100%;
	max-width: 252px;
	margin: 0;
	padding: 0;
}
.bpRe-plan-option figure > img {
  display: block;
}
.bpRe-plan-option img {
  width: 100%;
  height: auto;
  max-height: 440px;
  margin: auto;
}
.bpRe-plan-option-text {
	margin: 0;
	padding: 16px 0 0;
}
.bpRe-plan-option-text h4 {
	margin: 0;
	padding: 0 0 8px;
	line-height: 1;
	font-size: 18px;
}
.bpRe-plan-option-text p {
	margin: 0;
	padding: 0;
	line-height: 1.4;
	font-size: 14px;
}
.bpRe-plan-option-text a {
	color: #5788E5;
}

@media (max-width: 768px) {
	.bpRe-plan-option {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    z-index: 2;
    width: 100%;
    margin: 24px 0 0;
    padding: 0;
    box-sizing: border-box;
		background-image: none;
	}
	.bpRe-plan-option h3 {
    align-self: stretch;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    width: 100%;
    margin: 0;
    padding: 0;
    text-align: center;
    box-sizing: border-box;
	}
	.bpRe-plan-option h3 small {
    display: block;
    position: relative;
    top: 0.65em;
    padding: 0 0 0 8px;
    font-family: 'Roboto', sans-serif;
    font-size: 13px;
    font-weight: normal;
	}
	.bpRe-plan-option ul {
    display: flex;
    flex-flow: column wrap;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
	}
	.bpRe-price .bpRe-plan-option li {
    width: 100%;
    margin: 16px 0 0;
    padding: 24px;
    border-radius: 8px;
    text-align: left;
    box-sizing: border-box;
    background: #fff;
	}
	.bpRe-plan-option figure {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: flex-end;
    width: 100%;
    margin: 0;
    padding: 0;
	}
	.bpRe-plan-option-text {
    margin: 0;
    padding: 16px 0 0;
	}
	.bpRe-plan-option-text h4 {
    margin: 0;
    padding: 0 0 8px;
    line-height: 1;
    font-size: 17px;
	}
	.bpRe-plan-option-text p {
    margin: 0;
    padding: 0;
    line-height: 1.4;
    font-size: 14px;
	}

}


/* IT導入補助金について */
.ithojo {
	margin-bottom: 60px;
}
.ithojo .inr_wrapper {
	margin: 0 auto;
	max-width: 900px;
	width: 92%;
}
.ithojo h2 {
	margin-bottom: 20px;
}
.ithojo p.mb {
	font-size: 16px;
	line-height: 1.6;
	max-width: 900px;
	margin: 0 auto 40px auto;
	width: 92%;
}
.ithojo .set h3 {
	font-size: 2.8rem;
	font-weight:bold;
	background-color: #3D5A80;
	color: #fff;
	text-align: center;
	padding: 1rem;
}
.ithojo .set .box {
	border: 1px solid #3D5A80;
	border-top: none;
	border-radius: 0 0 10px 10px;
	padding: 3rem;
	box-sizing: border-box;
}

.it-pos-new-product-container {
  max-width: 1100px;
  margin: 4rem auto 2rem;
  border: 1px solid #5788E5;
  border-radius: 1rem;
  box-shadow: 0 5px 20px rgba(24, 128, 58, 0.1);
  background: #ffffff;
  overflow: hidden;
  position: relative;
}
.it-pos-new-product-title {
background: #2F61C2;
background: linear-gradient(90deg, rgba(47, 97, 194, 1) 0%, rgba(87, 136, 229, 1) 100%);
	text-align: center;
	font-size: 2.8rem;
	font-weight: bold;
	color: #fff;
	position: relative;
	padding: 2rem;
	letter-spacing: 1px;
}
.it-pos-new-product-title span {
  background: #E74C3C;
  color: white;
  font-size: 2.0rem;
  font-weight: bold;
  padding: 0 3rem;
  margin-right: 1.5rem;
  display:inline-block;
}

.it-pos-new-product-image {
	width:55%;
	text-align:center;
}
.it-pos-new-product-image img {
	width: auto;
	height: auto;
	max-height: 476px;
	margin: auto;
}

.set{
  border: 1px solid #5788E5;
  border-radius: 1rem;
  box-shadow: 0 5px 20px rgba(24, 128, 58, 0.1);
}
/* 全体のコンテナ */
.set-components {
    display: flex;
    justify-content: center;
    gap: 15px;
    margin-top: 0px;
    margin-bottom: 20px;
}

/* 「+」記号 */
.plus-symbol {
    font-size: 36px;
    font-weight: 300;
    color: #3D5A80;
    display: flex;
    justify-content: center;
    align-items: center;
	
}

/* 各構成要素の箱 */
.component-box {
	border:1px solid #5788E5;
    border-radius: 8px;
    overflow: hidden; /* 角丸を適用 */
    text-align: center;
    flex: 1; /* 横幅を均等に */
    display: flex;
    flex-direction: column;
}

/* ヘッダー部分 */
.component-header {
    padding: 8px;
    color: #fff;
    font-weight: bold;
    font-size: 1.6rem;
	background:#5788E5;
}

/* ボディ部分 */
.component-body {
    padding: 16px 6px;
    background-color: #fff;
    color: #333;
    font-size: 1.4rem;
    font-weight: bold;
    flex-grow: 1; /* 高さを揃える */
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 60px;
	text-align:left;
}

.set-details {
    font-size: 1.2rem;
    line-height: 1.6;
    margin-bottom: 1.4rem;
    padding: 10px;
    background-color: #F4F4F4;
    border-left: 3px solid #ddd;
}

.it-pos-new-product-content {
  display: flex;
  padding:3rem;
  justify-content:center;
  align-items: center;
  gap:3rem;
}
.it-pos-new-product-info{
	width: 55%;
}

.it-pos-new-product-feature {
	display: block;
	margin: 0 0 1rem 2rem;
	padding: 0 0 1rem 3.5rem;
	font-weight: 500;
	font-size:2.0rem;
	position:relative;
	  align-items: center;
}
.it-pos-new-product-feature + p {
	font-size:1.6rem;
}

.it-pos-new-product-feature::before {
	content: "";
	position: absolute;
	left: 0;
	top: 6px;
	width: 22px;
	height: 22px;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><rect width='24' height='24' rx='4' fill='rgb(61, 90, 128)'/><path d='M9 16.17 4.83 12 3.41 13.41 9 19 21 7 19.59 5.59z' fill='white'/></svg>") center/contain no-repeat;
  }

.it-pos-new-product-name {
  font-size: 2.8rem;
  font-weight: bold;
  margin-bottom: 20px;
  color: #fff;
  line-height: 1.2;
  padding: 1rem;
  background:#3D5A80;
  text-align:center;
  width:100%;
}
.it-pos-new-product-price-container {
}
.it-pos-new-product-price {
  font-size: 4.4rem;
  color: #e74c3c;
  font-weight: bold;
  display: block;
  padding: 0;
  text-align:center;
  margin: 0 auto 1rem;
}
.it-pos-new-product-price span {
  font-size: 1.4rem;
  color: #000;
  font-weight:normal;
  padding: 0 0 24px;
}

.posset-Re-priceBox {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  gap: 8rem;
  position: relative;
  width: 100%;
  padding: 24px;
  letter-spacing: 0;
  background: #F2FBFF;
	margin-bottom: 20px;
}
.posset-Re-priceBox p {
  line-height: 1.3;
  font-size: 32px;
  font-weight: bold;
}
.posset-Re-price-normal {
  position: relative;
  zoom: 0.85;
}
.posset-Re-price-normal b {
  font-size: 14px;
}
.posset-Re-price-normal small {
  font-size: 11px;
	font-weight: normal;
}
.posset-Re-price-normal::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% - 16px);
  border: transparent 16px solid;
  border-left: #D9D9D9 20px solid;
  right: -60px;
}
.posset-Re-priceBox p {
  line-height: 1.3;
  font-size: 32px;
  font-weight: bold;
	zoom: 1.2;
}
.posset-Re-priceBox p.zoomfix {
	zoom: 0.8;
}
.posset-Re-priceBox b {
  display: block;
  font-size: 16px;
  font-weight: bold;
}
.posset-Re-priceBox span {
  color: #D9534F;
}
.posset-Re-priceBox small {
  font-size: 12px;
  font-weight: normal;
}
.ithojo .set .box table th {
	width: auto;
}
.ithojo .set .box table td:first-child {
	background: transparent;
	text-align: left;
	font-size: 16px;
}
.ithojo .set .box table td:first-child span {
	background-color: #0D8C45;
	color: #fff;
	font-weight: bold;
	padding: 0 5px;
}
.ithojo .set .box table td {
	border: none;
	border-top: 1px solid #ccc;
	white-space: nowrap;
	font-size: 24px;
	font-weight: bold;
}
.ithojo .set .box table .red {
	color: #D9534F;
}
.ithojo .set .box table td .small {
	vertical-align: baseline;
	font-size: 16px;
	font-weight: normal;
}

@media (max-width: 768px) {
	.ithojo .set .box .spscroll {
		overflow-x: scroll;
	}
	.ithojo .set h3 {
		font-size: 20px;
	}
}

/* CTA */
.cta {
background: #2F61C2;
background: linear-gradient(90deg, rgba(47, 97, 194, 1) 0%, rgba(87, 136, 229, 1) 100%);
	padding: 30px 0 40px 0;
	width: 100%;
}
.cta h3 {
	background-color: #0040B6;
	color: #fff;
	text-align: center;
	font-size: 3.0rem;
	padding: 2rem 0;
	line-height: 1.6;
	margin-bottom: 3rem;
}
.cta h3 span {
	display: block;
	font-size: 2.4rem;
}
.cta .flex {
	display: flex;
	justify-content: center;
	align-items: center;
}
.cta .flex p {
	color: #fff;
	font-size: 2.4rem;
	font-weight:bold;
	line-height: 1.6;
	margin-bottom: 2rem;
	text-align: center;
}
.cta .flex .left {
	margin-right: 5rem;
}
.cta .flex .txt {
	display: flex;
	margin: 0 0 2rem 0;
}
.cta .flex .txt p {
	margin-bottom: 0;
}
.cta .flex .txt figure {
	display: flex;
	align-items: center;
}
.cta .flex .txt figure img {
	height: 60px;
	width: auto;
	margin-right: 1rem;
}
.cta .flex .btn {
	background: #EB5E36;
	background: linear-gradient(90deg, rgba(235, 94, 54, 1) 0%, rgba(236, 144, 49, 1) 100%);
	color: #fff;
	border: 1px solid #fff;
	border-radius: 100px;
	font-size: 16px;
	font-weight: bold;
	width: 300px;
}
.cta .flex .btn:hover {
	opacity: 0.8;
}
.cta .flex .btn.white {
	background: #fff;
	color: #333;
}

@media (max-width: 768px) {
	.pc {
		display: none;
	}
	.cta {
    padding: 0 0 30px 0;
	}
	.cta h2 span {
    font-size: 18px;
	}
	.cta .flex {
		display: block;
	}
	.cta .flex .left {
		margin: 0 0 20px 0;
		border-bottom: 1px solid #DDE6F8;
		padding-bottom: 20px;
	}
	.cta .flex .txt {
		justify-content: center;
	}
	.cta .flex h3 {
		font-size: 20px;
	}
}

/* レセコン連携実績一覧 */
#resecon_list ul {
	text-align: left;
  font-size: 12px;
  margin: 10px auto 20px auto;
  width: fit-content;
}

/* よくある質問 */
#faq {
	background-color: #D7E2F5;
  padding: 40px 0;
	margin: 30px 0;
}
.faq-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
}
.faq-title {
  text-align: center;
  font-size: 28px;
  font-weight: 800;
  color: #325A80;
  margin-bottom: 10px;
  position: relative;
}
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.faq-item {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  transition: all 0.3s ease;
  border: 1px solid rgba(0, 133, 123, 0.1);
}
.faq-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 600;
  color: #333;
  cursor: pointer;
  list-style: none;
  position: relative;
  transition: all 0.3s ease;
  background: linear-gradient(to right, transparent, rgba(51, 181, 163, 0.02));
}
.faq-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, #2D3A4D, #3A5476);
  border-radius: 50%;
  color: white;
  font-size: 13px;
  font-weight: bold;
  margin-right: 14px;
  flex-shrink: 0;
  position: relative;
}
.faq-icon::before {
  content: "Q";
  font-family: 'Arial', sans-serif;
}
.faq-question {
  flex: 1;
  line-height: 1.4;
  padding-right: 14px;
}
.faq-toggle {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #f0f7ff;
  border: 2px solid #3D5A80;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  flex-shrink: 0;
  position: relative;
}
.faq-toggle::before {
  width: 10px;
  height: 2px;
}
.faq-toggle::after {
  width: 2px;
  height: 10px;
}
.faq-toggle::before, .faq-toggle::after {
  content: "";
  position: absolute;
  background: #3D5A80;
  transition: all 0.3s ease;
}
.faq-answer {
  padding: 0 20px 18px 60px;
  font-size: 14px;
  line-height: 1.6;
  color: #555;
  animation: fadeInDown 0.3s ease;
  border-top: 1px solid rgba(51, 181, 163, 0.1);
  margin-top: -1px;
  background: rgba(248, 255, 254, 0.3);
}
.faq-answer p {
  margin: 12px 0 0 0;
  position: relative;
  padding-left: 32px;
}
.faq-answer p::before {
  content: "A";
  position: absolute;
  left: 0;
  top: 5px;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, #ff6b6b, #e74c3c);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: bold;
  line-height: 20px;
}
.faq-item[open] {
  background: linear-gradient(to right, rgba(255, 255, 255, 1), rgba(248, 255, 254, 0.8));
	box-shadow: 0 8px 25px #e0fbfc;
  border-color: #2b3d54;
}
.faq-item[open] .faq-summary {
  background: #bdcbe2;
  color: #293241;
}
.faq-item[open] .faq-icon {
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(51, 181, 163, 0.3);
}
.faq-item[open] .faq-toggle {
  background: #293D51;
  transform: rotate(0deg);
}
.faq-item[open] .faq-toggle::before, .faq-item[open] .faq-toggle::after {
  background: white;
}
.faq-item[open] .faq-toggle::after {
  opacity: 0;
}
.faq-item[open] .faq-toggle::before, .faq-item[open] .faq-toggle::after {
  background: white;
}
@media (max-width: 768px) {
  .faq-answer {
      padding: 0 16px 16px 54px;
      font-size: 13px;
  }
}
@media (max-width: 480px) {
  .faq-answer {
      padding-left: 20px;
  }
}



.upWrap{
	width:100%;
	background:#DDE6F8;
}
.upBox{
	width:100%;
	max-width:1100px;
	padding:8rem 0;
	margin: 0 auto;
}
.upBox h2{
	font-size:4.4rem;
	font-weight:bold;
	color:#000;
	margin: 0 auto 8rem;
	text-align:center;
}
.upBox h2 span{
	color:#5788E5;
}

.upFlex{
	display:flex;
	justify-content:space-between;
	gap: 2rem;
}

.upFlex li{
	background:#fff;
	padding:6rem 2rem 2rem;
	border-top:  3px solid #5788E5;
	border-radius: 0 0 1rem 1rem;
	position:relative;
}

.upPoint{
	color:#5788E5;
	background:#fff;
	border:1px solid #5788E5;
	border-radius: 50%;
	font-size:1.6rem;
	position:absolute;
	left:calc(50% - 50px);
	top: -50px;
	width:100px;
	height:100px;
	text-align:center;
	display: flex;
	text-align:center;
	flex-direction: column;
	justify-content: center;
	}
.upPoint span{
	font-size:4rem;
	font-weight:bold;
	line-height:1;
}


.upBox h3{
	font-size:3.2rem;
	color:#000;
	display: flex;
	text-align:center;
	justify-content: center;
	align-items: center;
	margin: 0 auto 2rem;
}
.upBox h3 span{
	display:inline-block;
	font-size:1.8rem;
	color:#fff;
	background:#3D5A80;
	padding: 0.5rem;
	margin-left: 1rem;
	vertical-align: text-top;
}
.upSub{
	font-size:1.8rem;
	font-weight:bold;
	color:#000;
	text-align:center;
	margin:0 auto 2rem;
	position:relative;
	display:block;
	padding: 0 2rem;
	width:fit-content;
	
}
.upSub::before,
.upSub::after {
    position: absolute;
    top: 0.2rem;
    height: 2.4rem;
    content: '';
}
.upSub::before {
    border-left: solid 1px;
    left: 0;
    transform: rotate(-45deg);
}

.upSub::after {
    border-right: solid 1px;
    right: 0;
    transform: rotate(45deg);
}


.upTxt{
	background:#F4F8FF;
	border-radius:1rem;
	padding: 2rem;
	font-size:1.6rem;
	margin-bottom:2rem;
}
.upTxt h4{
	font-size:2.4rem;
	color:#000;
	text-align:center;
	line-height: 1.4;
	margin-bottom:1rem;
}

.upDl{
}
.upDl dt{
	font-size:1.8rem;
	font-weight:bold;
	color:#5788E5;
	padding:0 0 1rem 0;
}
.upDl dd{
	font-size:1.6rem;
}
.upDl dt:last-of-type{
	padding:2rem 0 1rem 0;
}
.upDl .upDdC:last-child{
	margin-top: 0;
	margin-bottom: 2rem;
}
.upDl .upDdC{
	font-size:1.4rem;
	position:relative;
	margin-top: 2rem;
	padding-left: 2rem;
}
.upDl .upDdC::before {
	content: "";
	position: absolute;
	left: 0;
	top: 6px;
	width: 14px;
	height: 14px;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><rect width='24' height='24' rx='4' fill='rgb(61, 90, 128)'/><path d='M9 16.17 4.83 12 3.41 13.41 9 19 21 7 19.59 5.59z' fill='white'/></svg>") center/contain no-repeat;
  }

.an{
	font-size:1.1rem;
	line-height:1.2;
}
.upImg{
	max-width:193px;
	height:100%;
	
}


.GenelicInner{
	flex-flow:wrap column !important;
	padding: 2rem !important;
	width: 100% !important;
}
.GenelicText{
	width: 100% !important;
}
.GenelicText h4{
	color:#F16181;
	font-weight:bold;
	font-size: 2.1rem;
	padding-bottom: 16px;
}
.GenelicInner figure{
	width:100% !important;
}


/* Support */
.supportWrap{
	background:#F3F7FC;
}
.support_btm {
	text-align: center;
	position: relative
}

.support_btm h2 {
	font-size: 4.4rem;
	font-weight: bold;
	color: #000;
	margin-bottom: 6rem;
	line-height:1.4;
}
.support_btm h2 span{
	color: #5788E5;
}

.support_btm p {
	font-size: 1.2rem;
	line-height: 1.6;
}

.support_layout {
	align-items: flex-start
}

.support_layout img {
	max-width: 110px;
}

.support_layout h3 {
	font-size: 2.0rem;
	font-weight: 500;
	margin-top: 1.0rem;
	margin-bottom: 1.4rem;
	color: #5788E5;
}

.support_layout span {
	font-size: 1.2rem;
	color: #666;
	display: block;
}

.pcOnly{
	display:block;
}



/*メールフォーム*/

.form_title h2 {
	width: fit-content;
	display: flex;
	align-items: baseline;
	text-align: center;
	line-height: 1.5;
	position: relative;
	margin: 0 auto 20px;
}

.form_box {
	display: flex;
	flex-flow: column;
	justify-content: center;
	background: #fff;
	border: 1px solid #ccc;
	padding: 40px;
	margin: 0 auto;
}

.form_box h4 {
	text-align: center;
	line-height: 1.5;
	margin: 0 0 10px;
}

.form_box h4+div {
	color: #ff0000;
	text-align: center;
	margin: 0 0 30px;
}

.form_box a {
	color: #296fb2;
	transition: 0.3s;
}

.form_box a:hover {
	opacity: 0.3;
}

.form_box table {
	margin: 0 0 30px;
}

.form_box table tr th,
.form_box table tr td {
	width: auto;
	text-align: left;
	font-weight: normal;
	border: none;
	padding: 20px 0;
}


.form_box table tr th span {
	color: #fff;
	background: #3A60BA;
	border-radius: 5px;
	padding: 5px;
	margin: 0 5px 0 0;
}

.form_box label {
	line-height: 1.5;
}

.form_box input[type="text"],
.form_box input[type="email"],
.form_box input[type="tel"],
.form_box textarea,
.form_box select {
	width: 100%;
}

.form_box input.short {
	max-width: 200px;
}

.form_box input,
.form_box textarea,
.form_box select {
	background: #f9f9f9;
	border: 1px solid #ececec;
	border-radius: 5px;
	resize: vertical;
	padding: 10px;
}

.form_box>p.front {
	text-align: center;
	margin: 0 0 30px;
}

.form_box>p input {
	width: 100%;
	max-width: 300px;
	display: block;
	color: #005d96;
	font-size: 1.6rem;
	font-weight: bold;
	border: 1px solid #005d96;
	border-radius: 30px;
	cursor: pointer;
	padding: 10px;
	margin: 0 auto;
	transition: 0.3s;
}

.form_box>p input.back {
	color: #fff;
	background: #999;
	border: none;
}

.form_box>p input:hover {
	opacity: 0.3;
}

.form_box .columns {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 20px;
}

.form_box table.kakunin_table tr th,
.form_box table.kakunin_table tr td {
	border: 1px solid #ccc;
	padding: 20px;
}

.form_box table.kakunin_table tr th {
	display: table-cell;
	font-weight: bold;
	background: #eee;
}

.form_box table.kakunin_table+p {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 30px;
}

.form_header {
	background: #fff;
	padding: 10px 30px;
}

.form_header img {
	width: 100%;
	max-width: 120px;
}

/*メールフォームここまで*/


.modal {
  padding: 0 0;
}

.innerModal {
  width: min(100%, 1120px);
  margin: 0 auto;
  padding: 0 20px;
}

/* モーダルを開くボタン */
.modal__trigger {
  cursor: pointer;
}

.modal__trigger:nth-child(n + 2) {
  margin-top: 60px;
}

/* モーダル本体 */
.modal__wrapper {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
}

.modal__layer {
  height: 100%;
  background: rgba(50, 50, 50, .85);
  cursor: pointer;
}

.modal__container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(calc(100% - 40px), 800px);
  height: calc(100% - 100px);
  line-height: unset;
  padding: 20px;
  background: #fff;
}

.modal__inner {
  position: relative;
  overflow-y: auto;
  height: 100%;
  padding: 80px 20px 20px;
}

/* モーダルを閉じるボタン */
.modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 44px;
  height: 44px;
  background: rgba(50, 50, 50, 1);
  cursor: pointer;
  transition: opacity .6s;
}

.modal__close:hover {
  opacity: .6;
}

.modal__close:before,
.modal__close:after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 1px;
  background: #fff;
  content: '';
}

.modal__close:before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.modal__close:after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* モーダル内のコンテンツ */
.modal__content {
}
.modal__title {
	color:#5788E5;
	text-align:center;
	font-size:24px;
	font-weight:bold;
  margin-bottom: 5px;
  line-height:25px;
}
.modal__text {
  text-align:left;
	font-size:1.4rem;
  line-height:25px;
}

.modal__content ul{
	font-size:14px;
	margin: 20px 0;
}
.modal__content ul li{
	list-style:disc;
	list-style-position:inside;
	line-height: 1.4;
}
.modal__content ul li a{
	color: #133aa9;
}

.md-overlay{
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: .7;
  z-index: 9999;
}
 
.md-contents{
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(calc(100% - 40px), 800px);
  max-height: calc(100% - 100px);
  line-height: unset;
  padding: 20px;
  background: #fff;
  overflow-y:auto;
  z-index: 10000;
}
 
 
.md-inner{
  padding: 24px 40px;
  background: #fff;
  height: auto;
}
 
 
 
.md-xmark{
  position: absolute;
  top: 34px;
  right: 20px;
  width: 25px;
  height: 22px;
  z-index: 9999;
  cursor: pointer;
}
 
.md-xmark span {
  height: auto;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #333;
  border-radius: 4px;
}
 
.md-xmark span:nth-of-type(1) {
  top: 0;
  transform: translateY(10px) rotate(-45deg);
}
 
 
.md-xmark span:nth-of-type(2) {
  bottom: 0;
  transform: translateY(-10px) rotate(45deg);
}

@media screen and (max-width: 1024px) {
	.sponly{
		display:none !important;
	}
	.infobox{display: block;
		width: 100%;
		padding: 10px 10px;}

		.infobox>div:first-child {
			width: 30%;
			margin: auto;
			text-align: center;
			max-width: 250px;
		}

		.infobox>div>p {
			width: 100%;
		}

		.infobox a {
		text-align: left;
		display: block;
		}
		
		.reasonBox,
		.otherBox,
		.bpRe-product-item,
		.pos-new-product-container{
			width:92%;
		}
		.bpRe-product-text{
			width:90%;
		}
		.column-box,
		.upFlex{
			width:92%;
			margin:0 auto;
		}

}
@media screen and (max-width: 1023px) {
	.sponly{
		display:none !important;
	}
	.reasonVisual h3{
		font-size: 2.8rem;
	}
.reasonTxt img{
	max-width: 220px;
}
.reasonImg{
	width:100%;
	text-align:center;
}
.reasonImg img{
	max-width:100%;
}

.otherList{
	grid-template-columns: repeat(2, 1fr);
}
.renewal .title{
	font-size: 3.4rem;
}
renewal .hero-left {flex: 1 1 80%;max-width: 100%;}
.renewal .medals-staff-container{
	gap: 10px;
}
.renewal .staff-image {width: 220px;}
.renewal .medal-banner{width: calc(200px + 20px);}
.renewal .subsidy-button-overlay{
	bottom: 8%;
	right:15px;
	max-width:320px;
}
	.renewal .register {
		width: 48rem;
		padding-bottom: 10rem;
		position: absolute;
		right: 5px;
		bottom: 0;
	}
		.upFlex{
			flex-direction: column;
			gap:6rem;
		}
		.upFlex .upFlex{
			flex-direction: row;
		}

.onayamiBox{
	padding: 5rem 3rem;
}

.bpRe-product-item {
  flex-direction: column;
}
.bpRe-product-item li{
	width: 80%;
}

.campaignBox{
	margin: 0 auto 4rem;
}

}


@media screen and (max-width: 767px) {
.md-contents{
max-height:calc(100% - 100px);
}
.md-inner{
	padding: 20px;
}

/*メールフォーム*/
	
		.form_title h2 {
			font-size: 2.4rem;
			align-items: flex-end;
		}
	
		.form_box {
			padding: 20px 20px 40px;
		}
	
		.form_box table {
			max-width: 100%;
		}
	
		.form_box table td {
			font-size: 1.4rem;
		}
	
		.form_box table tr th {
			padding: 20px 0 0;
		}
	
		.form_box input.short {
			max-width: 100%;
		}
		.form_box th,
		.form_box td{
			display:block;
		}
	
		/* form2 */
		.form_box2 {
			padding: 20px 20px 40px;
		}
	
		.form_box2 table {
			max-width: 100%;
		}
	
		.form_box2 table td {
			font-size: 1.4rem;
		}
	
		.form_box2 table tr th {
			padding: 15px 0 5px;
		}
	
		.form_box2 input.short {
			max-width: 100%;
		}
	
		/*メールフォームここまで*/

.renewal .hero-inner{
	padding: 20px 15px 0;
}
.renewal .title{
	margin:0;
}
.w80{
	width:100% !important;
}

.renewal .register {
		width: 100%;
		padding-bottom: 10rem;
		position: unset;
	}
	.renewal .sub::after{
		width:100%;
	}
	.renewal .register{
		padding:0;
	}
	.renewal .medal-banner{
    width: 100%;
    max-width: 330px; /* Increased from 180px */
    margin: 0px auto 0; /* Add more top margin and center horizontally */
    order: 4; /* Ensure it comes after both columns */
    align-self: center; /* Center horizontally */
	}
	.renewal .subsidy-button-overlay{
	bottom: auto;
	right: auto;
	max-width: 330px;
	margin: 10px auto;
}
	.renewal .hero_textbox {
		justify-content: start;
	}
.renewal .badge{
	flex: 0 0 70px;
}
.onayamiBox h2,
.reasonVisual h3,
.reason h4,
.otherListTxt h4,
.flow-title2{
	font-size:2.0rem;
}
.reasonVisual h3 span{
	font-size:1.6rem;
}
.onayamiBox h3,
.reasonBox h2,
.otherBox h3{
	font-size:2.6rem;
}
.onayamiBox h3 span,
.reasonBox h2 span,
.flowBox h2{
	font-size:2.8rem;
}
.reasonBox h2{
	padding-top: 2rem;
	margin-bottom: 6rem;
}

.onayamiBox{
	padding: 30px 20px;
	margin-bottom: 12rem;
}
.onayamiBox::after{
  border-width: 100px 50vw 0 50vw;
}
.onayamiBox ul{
	grid-template-columns: repeat(2, 1fr);
}
.reasonSub{
	padding: 1.0rem 1rem;
	transform: translateX(43%);
	gap:0;
	bottom: -6rem;
}

.reasonH2:before{
	width: 32px;
	height: 27px;
	background-size:contain;
	position:absolute;
	top: 0;
	right:-2.5rem;
}
.reasonSub img{
	max-width: 120px;
}
.reasonSub p{
	font-size:2.0rem;
}
.reasonSub p span{
	font-size:2.2rem;
}

.reason{
	margin-bottom: 6rem;
}
.reason .reasonNum{
	top: -8rem;
	font-size: 8rem;
}
.reason .reasonVisual,
.reason:nth-of-type(even) .reasonVisual{
	flex-direction: column-reverse;
}
.reasonVisual > img{
	max-width:100%;
	width:100%;
}
.reasonVisual > div {
	padding: 0.5rem;
}
.reasonTxt{
	padding: 2rem;
}
.reasonTxt p{
	font-size: 15px;
}
.reasonTxt img{
	max-width: 80%;
	margin: 0 auto;
}
.reasonImg{
	width:100%;
	text-align:center;
}
.reasonImg img{
	max-width:100%;
}

.flexIR,
.flexIL{
	flex-direction: column;
	gap: 2rem;
}
.clickUp{
	text-align:center;
}
.otherWrap{
	margin: 0 auto;
}
.otherList{
	grid-template-columns: repeat(1, 1fr);
	padding: 3rem 0;
	gap:3rem;
}
.flowBox{
	margin: 3rem auto 0;
}
.flowBox h2{
	margin-bottom: 2rem;
}
.flowBox h2 + p{
	font-size: 1.8rem;
}
	.flow-section {
	  padding: 0 0 30px;
	  margin-bottom: 30px;
	}
	
	.flow-number {
	  width: 50px;
	  height: 50px;
	  font-size: 22px;
	}
	  .flow-header {
	margin-left: 0;
	margin-bottom: 30px;
	}
.contactBtn {
    margin: 5rem auto 0;
    padding: 1.5rem 4rem;
    font-size: 1.8rem;
}
.contactBtnIn {
    margin: 0 auto;
    padding: 1.5rem 4rem;
    font-size: 1.8rem;
}

.bpRe-product h2 {
	margin-bottom: 2rem;
}
.bpRe-product-inner .t-center {
	text-align: center;
	margin-bottom: 4rem;
}
.bpRe-product-inner .t-center h3 {
	margin:0 auto 2rem;
	padding: 0.5rem 5rem;
	font-size: 2.0rem;
}
.bpRe-product-inner .t-center h3 + p{
	font-size: 1.6rem;
}

.bpRe-product-item{
	margin-top: 5rem;
	width: 100%;
}
.bpRe-product-item li{
	width:100%;
}

	.bpRe-product-option {
    /* display: flex; */
    flex-direction: column;
    /* justify-content: center; */
    /* align-items: center; */
    gap: 3rem;
    /* position: relative; */
    /* width: fit-content; */
    /* margin: 0 auto; */
    padding: 2rem;
    /* list-style: none; */
    width: 100%;
 }
 .bpRe-product-option li:nth-child(2)::before,
 .bpRe-product-option li:nth-child(3)::before {
	content: '';
	display: block;
	position: absolute;
	top: calc(6% - 15px);
	left: calc(50% - 15px);
	width: 30px;
	height: 30px;
	background: url(../images/pharmacy_img/icon-add.png) no-repeat;
	background-size: contain;
	transform: translate(0, -25px);
}
.bpRe-product-photo-name h4{
	font-size: 2.2rem;
}
.bpRe-product-photo-name p{
	margin:1rem 0;
}
.bpRe-product-item li .bpRe-product-photo picture{
	max-width:88%;
}
		.bpRe-product-text{
			width: 100%;
		}
		.bpRe-product-text dt {
  font-size: 1.6rem;
		}
.bpRe-product-text dt svg {
	margin: 0 0.5rem 0 0;
}
.pos-new-product-title {background: #2F61C2;background: linear-gradient(90deg, rgba(47, 97, 194, 1) 0%, rgba(87, 136, 229, 1) 100%);text-align: center;font-size: 2.4rem;font-weight: bold;color: #fff;position: relative;padding: 1rem 1rem;letter-spacing: 1px;}
.pos-new-product-title span {
  background: #E74C3C;
  color: white;
  font-size: 2.0rem;
  font-weight: bold;
  padding: 0 3rem;
  margin-right: 1.5rem;
  display:inline-block;
}

.pos-new-product-image {
	width: 100%;
	text-align:center;
}
.pos-new-product-image img {
	width: auto;
	height: auto;
	max-height: 284px;
	margin: auto;
}


.pos-new-product-content {
  display: flex;
  padding: 2rem;
  justify-content:center;
  flex-direction: column;
  gap: 2rem;
}
.pos-new-product-info{
	width: 100%;
}

.pos-new-product-feature {
	display: block;
	margin: 0 0 1rem 0rem;
	padding: 0 0 1rem 3rem;
	font-weight: 500;
	font-size: 1.6rem;
	position:relative;
}
.pos-new-product-feature + p {
	font-size:1.6rem;
}

.pos-new-product-feature::before {
	content: "";
	position: absolute;
	left: 0;
	top: 4px;
	width: 20px;
	height: 20px;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><rect width='24' height='24' rx='4' fill='rgb(61, 90, 128)'/><path d='M9 16.17 4.83 12 3.41 13.41 9 19 21 7 19.59 5.59z' fill='white'/></svg>") center/contain no-repeat;
	}

.pos-new-product-name {
  font-size: 2.6rem;
  font-weight: bold;
  margin-bottom: 1rem;
  color: #fff;
  line-height: 1.2;
  padding: 1rem;
  background:#3D5A80;
  text-align:center;
  width:100%;
}
.pos-new-product-price-container {
}
.pos-new-product-price {
  font-size: 3.2rem;
  color: #e74c3c;
  font-weight: bold;
  display: block;
  padding: 0;
  text-align:center;
  margin: 0 auto 1rem;
}
.bpRe-btn {
  display: block;
  width: 90%;
  max-width: 480px;
  margin: 40px auto 0;
  padding: 0 16px;
  border: #5788E5 1px solid;
  border-radius: 64px;
  color: #fff !important;
  line-height: 3;
  font-size: 1.6rem;
  font-weight: bold;
  text-decoration: none;
  background: #5788E5;
  transition: 0.2s;
}

.it-pos-new-product-content {
  padding: 2rem;
  gap:3rem;
  flex-direction: column;
}


.posset-Re-priceBox {
  gap: 5rem;
}

.posset-Re-price-normal::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% - -40px);
  border: transparent 16px solid;
  border-top: #D9D9D9 20px solid;
  right: calc(50% - 16px);
}
.it-pos-new-product-image{
	width: 80%;
}
.upBox{
	padding: 5rem 0;
}
.upBox h2{
	font-size:2.8rem;
	margin: 0 auto 8rem;
}
.upBox h3{
	font-size: 2.4rem;
	flex-direction: column-reverse;
	gap: 1rem;
	margin: 0 auto 2rem;
}
.upBox h3 span{
	font-size:1.8rem;
	padding: 0.5rem;
	margin-left: 0;
}
.upFlex .upFlex{
	flex-direction:column;
	gap:1rem;
}
.upImg{
	max-width:70%;
	height:100%;
	margin: 0 auto 2rem;
}
.support_btm h2 {
	font-size: 2.6rem;
	margin-bottom: 3rem;
	line-height:1.4;
}
.banner_box{
	width:90% !important;
	margin:0 auto !important;
}
.sponly{
	display:block !important;
}
.pcOnly{
	display:none !important;
}

}