@charset "UTF-8";

/*================================================
 *  地方自治体向けPOSレジ　CSS設定
 ================================================*/

.tar{
	text-align: right;
}
.w80per{
	width:80%;
}
.w70per{
	width:70%;
}
.w60per{
	width:60%;
}
.mg-2{
	margin: 2rem auto;
}
.mg-3{
    margin: 3rem auto !important;
}
.mg-5{
    margin: 5rem auto !important;
}
.mg-10{
    margin: 10rem auto !important;
}
.pb-10{
	padding-bottom:1rem;
}
.m50{
	margin: 5rem auto;
}
.pt30{
	padding-top: 3rem;
}
.pd30{
	padding: 3rem 0;
}
.mt30{
	margin-top: 3rem !important;
}
.mt50{
	margin-top: 5rem !important;
}
.mb30{
	margin-bottom: 3rem !important;
}
.mb40{
	margin-bottom: 4rem !important;
}
.mb50{
	margin-bottom: 5rem !important;
}

 /*  s1000 mk*/

.pos-new-product-container {
	max-width: 800px;
	margin: 40px auto;
	padding: 25px 30px 30px;
	border: 1px solid #e0e0e0;
	border-radius: 6px;
	box-shadow: 0 5px 20px rgba(24, 128, 58, 0.1);
	background: #ffffff;
	overflow: hidden;
	position: relative;
  }
  
  .pos-new-product-container::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(to right, #2080ce, #2080ce);
  }
  
  .pos-new-product-title {
	text-align: center;
	font-size: 22px;
	font-weight: 700;
	margin-bottom: 25px;
	color: #333;
	position: relative;
	padding-bottom: 10px;
	letter-spacing: 1px;
  }
  
  .pos-new-product-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 50px;
	height: 2px;
	background: #2080ce;
  }
  
  .pos-new-product-content {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 40px;
	position: relative;
  }
  
  .pos-new-product-image {
	flex: 1;
	max-width: 50%;
	display: flex;
	justify-content: center;
	position: relative;
  }
  
  .pos-new-product-image::after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 50%;
	width: 80%;
	height: 10px;
	transform: translateX(-50%);
	background: radial-gradient(ellipse at center, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0) 70%);
	border-radius: 50%;
  }
  
  .pos-new-product-image img {
	max-width: 100%;
	height: auto;
	max-height: 280px;
	object-fit: contain;
	margin: auto;
	transition: transform 0.4s ease;
  }
  
  .pos-new-product-container:hover .pos-new-product-image img {
	transform: translateY(-5px);
  }
  
  .pos-new-product-info {
	flex: 1;
	max-width: 50%;
	padding: 0 0 0 10px;
	text-align: left;

  }
  
  .pos-new-product-feature {
	display: inline-block;
	background: #f8f9fa;
	border-left: 3px solid #18803a;
	padding: 8px 12px;
	margin-bottom: 15px;
	font-size: 15px;
	color: #444;
	border-radius: 0 4px 4px 0;
  }
  
  .pos-new-product-name {
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 20px;
	color: #2080ce;
	line-height: 1.2;
  }
  
  .pos-new-product-price-container {
	margin-top: 15px;
  }
  
  .pos-new-product-price-label {
	font-size: 14px;
	color: #666;
	margin-bottom: 5px;
  }
  
  .pos-new-product-price {
	font-size: 28px;
	color: #e74c3c;
	font-weight: bold;
	display: inline-block;
	padding: 0 0 4px 0;
  }
  
  .pos-new-product-price-tax {
	font-size: 14px;
	color: #666;
	margin-left: 5px;
  }
  
  .pos-new-product-badge {
	position: absolute;
	top: 15px;
	left: -12px;
	background: linear-gradient(135deg, #e74c3c, #c0392b);
	color: white;
	font-size: 14px;
	font-weight: bold;
	padding: 8px 18px 8px 20px;
	box-shadow: 0 2px 5px rgba(0,0,0,0.15);
	z-index: 2;
	letter-spacing: 1px;
	clip-path: polygon(0 0, 100% 0, 100% 70%, 85% 100%, 0 100%, 0% 50%);
  }
  
  .pos-new-product-badge::after {
	content: "";
	position: absolute;
	bottom: -8px;
	left: 0;
	width: 12px;
	height: 8px;
	background: #8e2c24;
	clip-path: polygon(0 0, 100% 0, 100% 100%);
  }
  
  .pos-new-product-button {
	display: inline-block;
	margin-top: 20px;
	padding: 10px 24px;
	background: #2080ce;
	color: white;
	border-radius: 4px;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	transition: background-color 0.3s ease;
  }
  
  .pos-new-product-button:hover {
	background-color: #25a04d;
  }

  .bpRe-btn {
    display: block;
    margin: 20px auto;
    padding: 10px 50px;
    border:#10695e 1px solid;
    border-radius: 30px;
    color: #10695E !important;
    line-height: 1.5;
    font-size: 1.4rem;
    transition: 0.2s;
	width: fit-content;
}

.bpRe-btn:hover {
    transition: 0.2s;
}



.contactBtn {
    display: block;
    width: fit-content;
    margin: 0rem auto;
    padding: 1rem 5rem;
    border:#10695e 1px solid;
    border-radius: 64px;
    color: #ffffff !important;
    line-height: 1.6;
    font-size: 2.2rem;
    font-weight: 500;
    text-decoration: none;
    background: #10695e;
    transition: 0.2s;
    text-align:center;
}

.contactBtn:hover {
    background: #10695e;
    transition: 0.2s;
}


  /* レスポンシブ対応 */
  @media (max-width: 768px) {
	.pos-new-product-content {
	  flex-direction: column;
	  gap: 20px;
	}
  
	.pos-new-product-image,
	.pos-new-product-info {
	  max-width: 100%;
	}
	
	.pos-new-product-badge {
	  top: 10px;
	  left: -8px;
	}
  }
/*s1000 mk  */
 .sponly2 {
    display: none;
}

.pt60{padding-top: 60px!important;}

.pb50{padding-bottom: 5rem!important;}

.h2L{
	font-size:4.2rem;
	/* font-weight:600; */
	margin: 1rem auto 2rem;
}

/*
#case,#jichitai_pos,#flow,#set,#hasyutu,#rearegi,#cloud{padding-top: 40px;
	padding-bottom: 40px;}
*/

.pagetop {
	bottom: 250px;
}

h2 {
	color: #10695e;
	font-weight: 800;
	text-align: center;
	line-height: 1.4;
	font-size: 4.2rem;
}

h2 span {
	font-weight: 400;
	font-size: 60%;
}

h3 {
	font-size: 2rem;
	color: #484848;
	font-weight: 400;
	line-height: 1.5;
}

h3 span {
	font-size: 1.4rem;
	color: #000;
	font-weight: bold;
	vertical-align: baseline;
}

.green {
	color: #007b00 !important;
	font-weight: 800 !important;
}

.small {
	font-size: 1.4rem;
}

.link {
	display: inline-block;
	color: #005d96;
	font-size: 1.4rem;
	text-align: center;
	line-height: 1.5;
	border: 1px solid #005d96;
	border-radius: 30px;
}

.link a {
	color: #005d96;
}

.link:hover {
	opacity: 0.7;
	background: #eafbff;
}

.full-width a {
	transition: 0.3s;
}

.full-width a:hover {
	opacity: 0.3;
}

.btm_btn03 {
	display: block;
	text-align: center;
	width: 100%;
	padding: 2rem 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;
	/* 必要であればリンク要素の重なりのベース順序指定 */
}




.line {
	height: 1px;
	border: none;
	background: #acb3cb;
	margin: 0 0 10px 0;
}

/*inputを非表示にする*/
.input {
	position: absolute;
	opacity: 0;
}

.after_logo:after {
	/* content: url(/product/business/images/jtfs_logo.svg);
   display: inline-block;
   vertical-align: middle;
   margin-left: 1.0rem;
   max-width: 70px; */
	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;
}

.btn-02 a {
	display: block;
	max-width: 280px;
	font-size: 1em;
	color: #2f2f2f;
	border: 2px solid #2f2f2f;
	text-align: center;
	padding: 10px;
	margin: 0 auto;
}

.btn-02 a:hover {
	transition: 0.3s;
	color: #fff;
	background: rgba(87, 201, 191, 0.5);
	border: 2px solid #fff;
}

.after_logo:after {
	/* content: url(/product/business/images/jtfs_logo.svg);
   display: inline-block;
   vertical-align: middle;
   margin-left: 1.0rem;
   max-width: 70px; */
	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;
}

.box_gray {
	border: 1px solid #b4bcc9;
	padding: 15px;
}

#square_t,
#jmups {
	display: none;
}
/*  */
.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;
}

.oshirase_box a,
.oshirase_box_02 a,
.ver_box a {
	color: #434343;
	text-decoration: none;
	transition: .3s;
}

.oshirase_box a:hover,
.oshirase_box_02 a:hover,
.ver_box a:hover {
	color: #438c5a;
}

.oshirase_box > div:first-of-type {
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	background-color: #438c5a;
}

.oshirase_box > div:nth-of-type(2) {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}

.oshirase_box > div:nth-of-type(2) div:first-of-type {
	margin: 0 30px 0 0;
}

.oshirase_box > div:first-of-type,
.ver_box > div:first-of-type {
	width: 20%;
	text-align: center;
	padding: 20px;
}

.oshirase_box > div:nth-of-type(2),
.ver_box > div:nth-of-type(2) {
	/* display: flex; */
	justify-content: flex-start;
	align-items: center;
	width: 80%;
	line-height: 1.5;
}
.infobox{display: flex;
width: 100%;
padding: 15px 10px;}

/* .infobox:first-child{border-bottom: dotted #a7a7a7 1px;} */

/* .oshirase_box > div:last-of-type,
.ver_box > div:last-of-type {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 20%;
	text-align: right;
} */

.infobox a{color: #005d96;}

.infobox>div:first-child{width: 10%;
text-align: center;}

.infobox>div>p{background: rgb(56, 55, 55);
color: #fff;
font-size: 12px;
border-radius: 5px;}

/*  */


/*その他
 ---------------------------------------------------------------------------*/
.u-mb-20 {
	margin: 0 0 20px 0;
}

.pa_sm {
	padding: 1% 1% !important;
}

.pa_sl {
	padding: 1% 3% !important;
}

.pa_2_1 {
	padding: 20px 0;
}

.bg_g {
	background:#EFF3FC;
}
.bg_gray {
	background:#F7F7F7;
}

.bg_g1 {
	background: #6aa3e3;
	background: linear-gradient(180deg, #5d9387 0%, #45908a 100%);
}

.bg_g2 {
	background: #eff3fb;
}

.bg_g3 {
	background: #FBFBFB;
}

.bg_w {
	background: #FFF !important;
	padding: 30px 0;
}



.bg_blue_box {
	width: 100%;
	max-width: 400px;
	background: #eafbff;
	padding: 5px;
	margin: 0 auto;
}

.text_w {
	color: #fff !important;
}

.text_b {
	font-size: 2.4rem;
	color: #10695e;
	font-weight: 700;
	line-height: 1.5;
}

.colorbox {
	text-align: center;
	margin-top: 10px;
	width: 100%;
}

.colorwrap {
	display: flex;
	justify-content: space-around;
	border: solid 1px #c6c6c6;
	margin: 10px;
	padding: 5px;
	vertical-align: middle;
	background: #fff;
}

.colorB {
	margin-right: 10px;
}

.colorB::before {
	content: "●";
	font-size: 23px;
	margin-right: 10px;
}

.colorW::before {
	content: "〇";
	font-size: 23px;
	margin-right: 10px;
}

.kaichu {
	position: relative;
	max-width: 350px;
	margin: 0 auto;
	z-index: 1;
}

.kaichu .kaichu_icon {
	content: "";
	position: absolute;
	top: 5px;
	display: flex;
	right: 10px;
	width: 3vw !important;
	max-width: 170px;
	min-width: 100px !important;
}

.op_kessai_box {
	display: flex;
	justify-content: space-around;
	align-items: flex-end;
	flex-wrap: wrap;
	width: 100%;
	margin: auto 0;
	text-align: center;
}

.price {
	display: flex;
	font-size: 3rem !important;
	color: #a81128 !important;
	font-weight: 600;
	line-height: 28px !important;
	justify-content: center;
	align-items: baseline;
}

.price_small {
	display: block !important;
	font-size: 20px !important;
	color: #a81128 !important;
	font-weight: 600;
	justify-content: center;
	margin-bottom: 15px;
}

.price_small span {
	font-size: 1.2rem;
}

.name {
	font-size: 2.5rem !important;
}

.text_blue {
	line-height: 28px !important;
	font-size: 1.6rem !important;
	background: #ebf4f7;
	padding: 5px 10px;
	color: #0956be;
	font-weight: 500;
}

.text_annotation {
	font-size: 1.1rem;
	line-height: 1.6;
}

.text_pa_b {
	padding-bottom: 2.4rem;
}

.img_dounyu {
	max-height: 235px;
	object-fit: contain;
}

.w_150 {
	width: 100%;
	max-width: 150px;
}

.w_200 {
	width: 100%;
	max-width: 200px;
}

.w_350 {
	width: 100%;
	max-width: 350px;
}

.w_300 {
	width: 100%;
	max-width: 300px;
}

.w_400 {
	width: 100%;
	max-width: 400px;
}

.w_600 {
	width: 100%;
	max-width: 600px;
}
.w_950 {
	width: 100%;
	max-width: 950px;
	margin: 0 auto;
}
.img_verifone {
	width: 100% !important;
	max-width: 380px;
}

.w_fit {
	width: fit-content;
}

.box_fit {
	width: fit-content;
	width: -moz-fit-content;
	margin: 0 auto;
}

.box_medium {
	max-width: 800px;
	margin: 0 auto;
}

#credit h4 {
	text-align: left;
	font-size: 20px;
	margin-bottom: 10px;
	border-bottom: 1px solid gray;
	padding-bottom: 5px;
}

.bgW{
	background:#fff;
}


.jListH{
	font-size: 2.4rem;
	color: #484848;
	font-weight: 600;
	margin: 2rem;
	}




/*================================================
  section hero
  ================================================*/
/*  */


/* --------------------------------------------------
   1. CORE VARIABLES - easily change theme colors
   --------------------------------------------------*/
   :root {
	--main-teal: #10695E;
	--dark-teal: #00857b;
	--bg-green:#f6fbfb;
	--light-teal: #e4f7f5;
	--badge-size: 100px;
	--spacing-sm: 10px;
	--spacing-md: 20px;
	--spacing-lg: 30px;
	--spacing-xl: 50px;
	--border-radius: 4px;
  }
  
  /* --------------------------------------------------
	 2. HERO BOX STRUCTURE - better responsiveness
	 --------------------------------------------------*/
  .hero-box {
	background: #fff;
	overflow: hidden;
	position: relative;
	width: 100%;
	background-image:url("/product/business/images/jichitai_img/jichitai_bk.png");
	/* background-color:rgb(248, 255, 254); */
  background-size: cover;
  background-position: bottom;
  }
  
  .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
	 --------------------------------------------------*/
  .hero-left {
	flex: 1 1 50%;
	max-width: 50%;
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 2;
  }
  
  .hero_textbox{
	/* ↓padding-left で空きを作っていたのを削除 */
	padding-left: 0;
	/* ↓横並びレイアウトに変更 */
	display: flex;
	align-items: flex-start;       /* バッジの上端とテキストの上端をそろえる */
	gap: 20px;                     /* 左右の余白（お好みで） */
  }
  
  .hero_heading{
	display: flex;
	flex-direction: column;
  }
  
  /* Badge styling - consistent positioning */
  .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 */
  .sub {
	font-size: 18px;
	font-weight: 600;
	color: var(--main-teal);
	margin: 0 0 8px;
	position: relative;
	display: inline-block;
	padding-bottom: 4px;
  }
  
  .sub::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 80%;
	height: 3px;
	background: var(--main-teal);
	border-radius: 1.5px;
  }
  
  .title {
	font-size: 44px;
	font-weight: 900;
	line-height: 1.1;
	margin: 10px 0 40px;
  }
  
  /* Features list - better spacing and alignment */
  .features {
	display: flex;
	gap: 30px;
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
  }
  
  .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;
  }
  
  .features li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 26px;
	height: 26px;
	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='%2310695E'/><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;
	box-shadow: 0 2px 4px rgba(0,0,0,.1);
  }
  
  /* --------------------------------------------------
	 4. STAFF & MEDALS SECTION - improved layout
	 --------------------------------------------------*/
  .medals-staff-container {
	display: flex;
	gap: 50px;
	align-items: self-end;
	max-width: 100%;
  }
  
  .staff-image {
	width: 260px;
	max-width: 100%;
	border-radius: var(--border-radius);
	filter: drop-shadow(0 4px 8px rgba(0,0,0,.1));
  }
  
  .medals {
	display: flex;
	gap: 40px;
  }
  
  .medal {
	width: 100px;
	filter: drop-shadow(0 4px 8px rgba(0,0,0,.15));
  }
  
  .medal img {
	width: 100%;
	object-fit: contain;
  }
  
  /* ─────────── メダル＋バナーの縦並びラッパー ─────────── */
  .medals-group{
	display: flex;
	flex-direction: column;   /* メダル→バナー の縦並び */
	align-items: center;      /* 横中央寄せ */
  }
  
  /* ─────────── バナーの基準幅（PC：120×2＋gap20＝260px） ─────────── */
  .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);
  }
  .medal-banner img{
	width: 100%;              /* ラッパー幅いっぱいで縮小表示 */
	height: auto;
  }
  
  /* --------------------------------------------------
	 5. RIGHT COLUMN - better image positioning
	 --------------------------------------------------*/
  .hero-right {
	flex: 1 1 50%;
	max-width: 50%;
	display: flex;
	justify-content: flex-end;
	align-self: flex-end;
  }
  
  .register {
	width: 480px;
	max-width: 100%;
	align-self: flex-end;
	margin-right: 0px;
	filter: drop-shadow(0 5px 15px rgba(0,0,0,.1));
	padding-bottom: 30px;
  }
  
  /* --------------------------------------------------
	 6. PRICE STRIP - improved layout and alignment
	 --------------------------------------------------*/
  .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 */
  .set-contents {
	display: flex;
	width: 670px;
	max-width: 100%;
	border: 4px solid #fff;
	border-radius: 10px;
	box-shadow: 0 4px 8px rgba(0,0,0,.15);
	overflow: hidden;
  }
  
  .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;
	border-right: 2px solid var(--main-teal);
  }
  
  .set-items {
	flex: 1;
	padding: 0;
	margin: 0;
	list-style: none;
	}
  .set-items:nth-of-type(1) {
	border-right: 1px solid #fff;;
  }
  .set-items li {
	background: var(--main-teal);
	color: #fff;
	font: 500 14px/1.2 "Noto Sans JP", sans-serif;
	text-align: center;
	padding: 7px 0;
  }
  
  .set-items li+li {
	border-top: 1px solid rgba(255,255,255,0.35);
  }
  
  /* Price value styling - improved alignment */
  .price-value {
	text-align: center;
	min-width: 260px;
  }
  
  .price-label {
	position: relative;
	font: 700 20px/1 "Noto Sans JP", sans-serif;
	letter-spacing: .08em;
	width: max-content;
	margin: 0 auto 30px;
  }
  
  .price-label::before,
  .price-label::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 130px;
	height: 1px;
	background: rgba(255,255,255,.6);
  }
  
  .price-label::before {
	right: 100%;
	margin-right: 12px;
  }
  
  .price-label::after {
	left: 100%;
	margin-left: 12px;
  }
  
  .price-num {
	display: inline-flex;
	align-items: flex-end;
	gap: 8px;
  }
  
  .price-num .num {
	font-size: 56px;
	font-weight: 900;
	letter-spacing: -1px;
  }
  
  .price-num .yen {
	font-size: 40px;
	font-weight: 800;
	position: relative;
  }
  
  .price-num .tax-note {
	position: absolute;
	left: 0;
	bottom: 100%;
	margin-bottom: 4px;
	font-size: 14px;
	font-weight: 300;
  }








/* cashless */


.slider_box {
	margin: 0 0 30px;
}
.swiper-area2{
	position: relative;   /* 矢印の基準点 */
  }
  

.swiper-container2{
	position: relative;   /* 矢印の基準点に必須 */
	overflow: hidden;     /* はみ出したスライドを隠す */
	width: 100%;
  }
  .swiper-container2 .swiper-wrapper2{
	width: 100%;
		justify-content:space-between;

  }
  
  .swiper-container2 .swiper-button-prev,
  .swiper-container2 .swiper-button-next{
	position:absolute;    /* 本来のデフォルト */
	top:50%;
	transform:translateY(-50%);
  }

.swiper-slide2 {
	width: var(--swiper-slide-size, auto); /* ← Swiper の計算値を優先させる */
	height: auto;
	display: flex;
	flex-flow: column;
	justify-content: center;
	align-items: center;
	font-size: 1.6rem;
	text-align: center;
	background: #fff;
	border: 1px solid #e3e3e3;
	border-radius: 5px;
	padding: 10px;
}

.swiper-slide2 img {
	width: 130px;
	height: 80px;
	object-fit: contain;
}

.swiper-wrapper2 {
	position: relative;
	width: 100%;
	height: 100%;
	display: flex;                 /* Core flexbox implementation */
	transition-property: transform;
	box-sizing: content-box;
	  

  }
  
  .swiper-slide2 {
	flex-shrink: 0;                /* ← 幅固定 */
	width: auto;                   /* Swiper が inline-style で width を上書き */
	
  }
/* ul を div に替えた場合は不要だが、念のためリセット */
.swiper-container2 ul       { margin:0; padding:0; list-style:none;  }

.swiper-container2 .swiper-slide2 {
  text-align:center;
  padding: 1rem;
  width: 23%;


  /* Swiper が inline-style で width を付けるので
     display:block のままで OK */
}


/* 共通設定 ------------------------------------------------ */
.swiper-button-prev2,
.swiper-button-next2{
  position: absolute;
  top: 50%;
  width: 44px; height: 44px;
  margin-top: -22px;      /* 垂直中央 */
  z-index: 10;
  cursor: pointer;
  background: rgba(0,0,0,.4);
  border-radius: 50%;
  transition: background .3s;
  display:none; /* 1024px以上は非表示 */
  text-align:center;
}
.swiper-button-prev2:hover,
.swiper-button-next2:hover{
  background: rgba(0,0,0,.6);
}

/* 左右位置 ------------------------------------------------ */
.swiper-button-prev2 { left:  -14px; } /* 44px+20px */
.swiper-button-next2 { right: -14px; }

/* アイコン（Font Awesome を使う場合）-------------------- */
.swiper-button-prev2::before,
.swiper-button-next2::before{
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 18px;
  color:#fff;
  line-height:44px;
  text-align:center;
}
.swiper-button-prev2::before{content: "\f053";} /* &lt; */
.swiper-button-next2::before{content: "\f054";} /* &gt; */

.pconly3{display: block;}
.sponly3{display: none;}







/*================================================
  section hero
  ================================================*/
.drug_hero_bg {
	width: 100%;
	background: url("/product/business/images/jichitai_img/jichitai_hero2.png") 0 20% no-repeat;
	background-size: cover;
	padding: 0;
	position: relative;
	padding-bottom: 1px;
}

.drug_hero {
	width: 100%;
	padding-bottom: 20px;
	padding-top: 40px;
	text-align: right;
	display: flex;
	justify-content: flex-end;
}

.drug_hero_box {
	padding-right: 50px;
	padding-top: 10px;
	text-align: center;
}

.drug_hero_box_p {
	color: #10695e;
	font-weight: 800;
	font-size: 2rem !important;
	line-height: 28px !important;
	margin-bottom: 1.5rem;
	text-shadow: 0 0 10px #fff, 0 0 15px #fff;
}

.drug_hero_box h2 {
	font-size: 4.4rem;
	font-weight: 800;
	margin-bottom: 3rem;
	color: #10695e;
	text-shadow: 0 0 10px #fff, 0 0 15px #fff;
}

.drug_hero_box span {
	display: block;
	font-size: 1.4rem;
}

.drug_hero_box .text_box {
	margin-top: 15px;
	font-size: 37px !important;
}

.drug_hero_box .text_box_p {
	color: #3e3e3e;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 600;
	text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, 0-1px 0 #FFF,
		-1px 0 0 #FFF, 1px 0 0 #FFF;
	margin-bottom: 0.1rem;
}

.clinic_box {
	background: rgba(244, 244, 244, 0.72);
	padding: 10px 0;
	width: 65%;
	margin: 0 auto 20px;
	border-radius: 5px;
}

.clinic_box ul {
	display: flex;
	flex-wrap: wrap;
}

.clinic_box ul li {
	font-size: 15px;
	margin: auto;
	color: #10695e;
	font-weight: 600;
	line-height: 30px;
}

#breadcrumbs {
	border-top: 1px solid #e8e8e8;
	border-bottom: 1px solid #e8e8e8;
}

#breadcrumbs .breadcrumbs {
	padding: 15px 10px;
}

#breadcrumbs .breadcrumbs a {
	color: #10695e;
}

p.price span {
	font-size: 70%;
	vertical-align: bottom;
	display: contents;
}

#intro_set .setbox .title {
	background: #e1eef7 !important;
	font-size: 16px !important;
	text-align: center !important;
	display: block !important;
	padding: 8px !important;
	color: #0f7d9f !important;
	font-weight: 600 !important;
}

#intro_set .setbox ul {
	counter-reset: number 0;
}

#intro_set .setbox ul li {
	font-weight: 500;
	line-height: 1.5;
	text-indent: -3.5rem;
	padding: 0 0 0 35px;
	margin: 0 0 10px;
}

#intro_set .setbox ul li:first-child {
	margin-top: 10px;
}

#intro_set .setbox ul li::before {
	counter-increment: number 1;
	content: counter(number);
	color: #0f7d9f;
	font-weight: 600;
	background: #e1eef7;
	padding: 5px 10px;
	margin: 0 5px 0 0;
}

#okomari .okomari_box {
	display: flex;
	justify-content: space-around;
}

#okomari .okomari_box .okomari_inner {
	width: calc(90%/4);
	text-align: center;
	font-weight: 500;
}

#okomari .okomari_box .okomari_inner img {
	width: 60%;
	margin-bottom: 5px;
}

#semiself {
	width: 98%;
	margin: 3rem auto 0;
}

#semiself .slick-next {
	right: 0px !important;
	z-index: 2;
}

#semiself .slick-prev {
	left: 0px !important;
	z-index: 2;
}

#semiself .semiselfbox {
	margin-top: 10px;
}

#semiself .semiselfbox ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
}

#semiself .semiselfbox ul li {
	width: calc(75%/6);
}

#option .option_box {
	align-items: unset;
	justify-content: space-around;
}

#option .col-3 {
	display: flex;
	width: calc(97%/3) !important;
	flex-direction: column;
	padding: 15px 5px;
}

#option .col-3 .imgbox {
	margin: 0 auto;
}

#option .col-3 .imgbox img {
	max-height: 160px;
	width: auto;
	display: block;
	flex-direction: column;
}

#option .col-3 p {
	font-size: 15px;
	letter-spacing: -0.7px;
}

#option .col-3 .option_textbox {
	display: flex;
	flex-direction: column;
	height: 105px;
}

#option .col-3 .option_textbox h3 {
	display: flex;
	flex-direction: column;
	font-size: 18px !important;
}

#option .col-3 .option_textbox h4 {
	font-size: 18px;
}

#option .col-3 .option_textbox p {
	display: flex;
	flex-direction: column;
}

#option .col-3 .option_textbox .price {
	font-size: 20px;
}

.keywordbox {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	flex-wrap: wrap;
	text-align: center;
	border: 1px solid #000;
	padding: 10px;
	margin: 0 0 10px;
}

#option2 .option_box {
	align-items: unset;
	justify-content: space-between;
}

#option2 .col-3 {
	display: flex;
	width: 98% !important;
	flex-direction: column;
	padding: 15px 5px;
	margin: auto;
}

#option2 .col-3 .imgbox {
	margin: 0 auto;
}

#option2 .col-3 .imgbox img {
	max-height: 160px;
	width: auto;
	display: block;
	flex-direction: column;
}

#option2 .col-3 p {
	font-size: 15px;
	letter-spacing: -0.7px;
}

#option2 .col-3 .option_textbox {
	display: flex;
	flex-direction: column;
}

#option2 .col-3 .option_textbox h3 {
	display: flex;
	flex-direction: column;
	font-size: 18px !important;
}

#option2 .col-3 .option_textbox h4 {
	font-size: 18px;
}

#option2 .col-3 .option_textbox p {
	display: flex;
	flex-direction: column;
}

#option2 .col-3 .option_textbox .price {
	font-size: 20px;
}

#semiself_use h3 {
	color: #10695e;
	font-size: 2.4rem;
	font-weight: 800;
}

.movie,
.movie02 {
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: 560px;
	height: auto;
	margin: 0 auto;
	position: relative;
}




.pick{
	margin: 0 auto 0;
	padding: 2px 1em;
	background:#10695e;
	color:#fff;
	border-radius: 8px 8px 0 0;
	width: fit-content;
	font-weight:bold;
}
.pickup{
	margin: 0 auto 0;
	padding: 30px;
	background:#fff;
	width: 90%;
	font-weight:600;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 15px; /* 間隔を削減 */
	align-items:center;
}

.pickup p{
	font-size: 22px;
	line-height: 1.6;
}
.pickup p span{
	font-size: 30px;
}

.pickup a{
	margin: 20px auto 0;
	display:block;
}


.youtube {
	position: relative;
	width: 100%;
	padding: 30px;
	border-radius: 8px;
	background:#eff3fb;
}

.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

/*

#set h3 {
	color: #10695e;
	font-size: 3.4rem;
	font-weight: 600;
	text-align: center;
	padding: 0;
}

#set h3 + p{
	font-size: 1.4rem;
	text-align: center;
	margin: 0 auto 30px;
}

#set h3 span {
	font-size: 16px;
	color: #fff;
	margin: auto 0;
}

#set h3.text_bold {
	color: #04867c;
	background: none;
	font-weight: 800;
	padding: 0;
}

#set .cost {
	margin-top: 6px;
	text-align: right;
	display: flex;
	font-size: 3rem;
	color: #cc0000;
	font-weight: 600;
	justify-content: flex-end;
	margin-bottom: 15px;
}

#set .cost span {
	font-size: 15px;
	color: #cc0000;
	margin: auto 0;
}

#set a {
	color: #00863C;
	text-decoration: none;
}
*/

table {
	margin: 0 auto;
	width: 95%;
	background: #fff;
	text-align: center;
}

table th {
	width: 100%;
}

table td {
	border: solid 1px #ccc;
	padding: 5px;
}

table td:first-child {
	background: #f2f2f2;
}

.cashless_icon {
	display: flex;
}

.cashlessbox {
	background-color: rgba(255, 255, 255, 0.7);
	display: flex;
}

.cashlessbox div {
	width: calc(99%/3);
}

.cashlessbox div img {
	width: 100%;
}

.apply {
	height: 100px;
}

.resecon-list li {
	width: 100%;
	margin-top: 10px;
	margin-bottom: 10px;
	padding-left: 30px !important;
	font-weight: 600;
}

table.spec,
table.spec_static {
	width: 100%;
	margin: 0px;
	font-size: 16px;
}

table.spec tr,
table.spec_static tr {
	border-top: 1px solid #dedede;
}

table.spec tr:last-child,
table.spec_static tr:last-child {
	border-bottom: 1px solid #dedede;
}

table.spec th,
table.spec_static th {
	background: #f2f2f2;
	width: 30%;
	border-top: 1px solid #dedede;
	padding: 0;
	font-weight: 700;
	padding: 7px 0;
}

table.spec td,
table.spec_static td {
	/* width:70%; */
	padding: 16px;
}

.point_box {
	display: flex;
	justify-content: space-between;
	text-align: center;
}

.point_box img {
	width: 100%;
	max-width: 250px;
	height: 185px;
	object-fit: contain;
}

.point_box > div {
	width: calc(95%/3);
}

.point_box > div > div {
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.5;
	background: #737980;
	border-radius: 3px;
	padding: 10px;
}

.check_box {
	margin-bottom: 20px;
}

.check_box li {
	text-align: left;
	line-height: 1.5;
	text-indent: -2rem;
	border-bottom: 1px dashed #6E82DA;
	padding: 0 0 0 25px;
	margin: 0 0 10px;
}

.check_box li::before {
	content: "";
	font-family: "Font Awesome 5 Free";
	font-weight: 600;
	color: #10695e;
	margin: 0 5px 0 0;
}

.purchase_box {
	border: 1px solid #e6e6e6;
	margin: 0 auto;
	display: block;
}

.purchase_box .purchace_imagebox {
	border-bottom: 1px dotted #e6e6e6;
	padding: 0px 0;
	width: 100%;
}

.purchase_box .purchace_imagebox img {
	max-width: 300px;
}

.purchase_box .purchace_list ul li {
	text-align: center;
	margin: 20px;
}

.purchase_box .purchace_list ul li p {
	font-size: 18px;
	color: #fff;
	width: 240px;
}

.purchase_box .purchace_list ul li a {
	background: #45654e;
	padding: 7px 25px;
	display: inline-flex;
	border-radius: 20px;
	margin: auto;
}

.purchase_box .purchace_list ul li a i {
	padding: 7px;
	color: #fff;
}

.purchase_box .purchace_list ul li a:hover {
	opacity: 0.8;
}

.bcposlf_info {
	border: 1px solid #ccc;
	border-radius: 5px;
	background-color: #fff;
	padding: 1rem;
	text-align: center;
	display: flex;
	justify-content: center;
}

.bcposlf_info01 {
	align-self: center;
}

.bcposlf_info02 {
	align-self: center;
	text-align: left;
	margin-left: 1.5rem;
}

.bcposlf_info02 p {
	font-size: 1.2rem !important;
}

.purchase {
	padding-bottom: 30px;
}

.purchase h3 {
	line-height: 35px;
}

.purchase .purchace_box {
	display: flex;
	margin: 30px 0 20px;
}

.purchase .purchace_inner {
	display: flex;
	margin: auto;
	width: calc(98%/2);
	border: 1px solid #d1d1d1;
	border-radius: 8px;
	justify-content: space-between;
	margin-bottom: 10px;
	align-items: center;
	text-align: center;
}

.purchase .purchace_inner img {
	width: 30%;
}

.purchase .purchace_inner p {
	font-size: 20px;
	display: flex;
	width: 40%;
	font-weight: 500;
	margin: auto 0;
	padding: 15px 0;
	justify-content: center;
}

.purchase .purchace_inner a {
	display: flex;
	justify-content: center;
}

.purchase .purchace_inner i {
	margin-left: 20px;
	display: flex;
	align-items: center;
}





.purchase .otoiawase a {
	color: #4182b2;
	text-decoration: underline;
	padding: 0 5px;
}

/*  */
.rearegi_kessai .logo{
	max-width: 300px;
margin: auto;
display: flex;
}

.rearegi_kessai .product_image{
	max-width: 500px;
margin: auto;
display: flex;
	
}

/*  */

.renkei_jisseki td {
	border: solid 1px #ccc;
	padding: 10px;
}

.renkei_jisseki td:first-child {
	background: #ffffff;
}

.example_box {
	max-width: 860px;
	height: 273px;
	border: 1px solid #d9d9d9;
	overflow: scroll;
	padding: 20px;
	margin: 0 auto;
resize: vertical;
}

.example_box_frame {
	width: 100%;
	max-width: fit-content;
	padding: 0 20px;
	margin: 0 auto 20px auto;
}

.example {
	width: 800px;
	line-height: 1.5;
	table-layout: fixed;
}

.example th {
	width: 15%;
	background: #f2f2f2;
	font-weight: bold;
	text-align: center;
	vertical-align: middle;
}

.example th,
.example td {
	padding: 5px 10px;
	border: solid 1px #ccc;
}

table.example td:first-child {
	background: #fff;
}

table.example td.w_yakusyo {
	width: 25%;
}

table.example td.w_mado {
	width: 60%;
	text-align: left;
}

.green_border_box {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}

.green_border_box div {
	text-align: center;
	border: 1px solid #10695e;
	border-radius: 6px;
	padding: 10px;
}

.swiper-container {
	position: relative;
	overflow: hidden;
	padding: 0 20px;
}

.swiper-slide img {
	object-fit: contain;
}

.swiper-slide {
	border: none;
}

.posset_box {
	margin: 0 0 60px;
}

.posset_box:last-of-type {
	margin: 0;
}

.posset_box h2 {
	width: 100%;
	display: flex;
	justify-content: center;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 400;
	text-align: center;
	line-height: 1.5;
	background: #10695e;
	padding: 5px 0;
	margin: 0 0 30px;
}

.posset_box .icon_box {
	display: flex;
	align-items: center;
	position: relative;
	margin: 0 0 30px;
}

.posset_box .icon_box > div {
	width: 80px;
	height: 80px;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 2px solid #10695e;
	border-radius: 40px;
	box-shadow: 0 2px 3px 0 rgb(0, 0, 0, 30%);
	position: absolute;
	right: 20%;
}

.posset_box .icon_box h2 {
	margin: 0;
}

.posset_box .icon_box > div img {
	width: 100%;
	max-width: 50px;
	position: absolute;
	top: -13px;
}

.posset_box .icon_box > div p {
	color: #10695e;
	font-size: 2rem;
	font-weight: bold;
	line-height: 0.8;
	margin: 25px 0 0;
}

.posset_box .icon_box > div p span {
	color: #111;
	font-size: 1.1rem;
	font-weight: normal;
}

.posset_box p {
	line-height: 1.5;
}

.posset_box > p:nth-of-type(1) {
	font-size: 3rem;
	color: #a81128;
	font-weight: bold;
	text-align: center;
	margin: 0 0 10px;
}

.posset_box > p:nth-of-type(2) {
	text-align: right;
}

.posset_box > p span {
	font-size: 1.4rem;
}

.posset_box .content {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	align-items: end;
	gap: 30px;
	margin: 0 auto 10px;
}

.posset_box .content > div:nth-of-type(1) > p {
	font-weight: bold;
	margin: 0 0 10px;
}

.posset_box .content > div:nth-of-type(1) > table {
	width: 100%;
	line-height: 1.5;
}

.posset_box .content > div:nth-of-type(1) > table td {
	border: solid 1px #ccc;
	padding: 5px;
}

.posset_box .content > div:nth-of-type(1) > table td:first-child {
	background: #f2f2f2;
}

.posset_box .content > div:nth-of-type(2) > p:nth-of-type(-n+2) {
	color: #0956be;
	font-size: 1.6rem;
	font-weight: bold;
	background: #ebf4f7;
	padding: 5px 10px;
	margin: 0 0 10px;
}

.posset_box .content > div:nth-of-type(2) > p:nth-of-type(2) {
	margin: 0 0 20px;
}

.posset_box .content > div:nth-of-type(2) > p:nth-of-type(1) span {
	color: #000;
	font-size: 1.1rem;
	margin: 0 0 0 10px;
}

.posset_box .content > div:nth-of-type(2) > p:nth-of-type(3) {
	margin: 0 0 10px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(1) {
	max-width: 350px;
	display: flex;
	align-items: center;
	justify-content: space-around;
	border: 1px solid;
	padding: 10px;
	margin: 0 auto 10px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(1) > p {
	display: flex;
	position: relative;
	align-items: center;
	margin: 0 0 0 25px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(1) > p:nth-of-type(1)::before {
	content: "●";
	font-size: 2rem;
	position: absolute;
	left: -25px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(1) > p:nth-of-type(2)::before {
	content: "○";
	font-size: 2rem;
	position: absolute;
	left: -25px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(2) {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background-color: #fff;
	border: 1px solid #ccc;
	padding: 10px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(2) img {
	width: 100%;
	max-width: 100px;
	min-width: 100px;
}

.posset_box .content > div:nth-of-type(2) > div:nth-of-type(2) p {
	font-size: 1.2rem;
	text-align: left;
}

.koukin_box {
	background: url(/product/bcpos/dispenser/img/apparel_shop.png) center;
	background-size: cover;
}

.koukin_box > section > div:nth-of-type(1) {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 30px;
	margin: 0 0 20px;
}

.koukin_box > section > div:nth-of-type(1) h2 {
	color: #3c3c3c;
	font-size: 3.5rem;
	line-height: 1.5;
	text-align: center;
	text-shadow: 0px 0px 5px #fff;
	margin: 0 0 10px;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(1) {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
	margin: 0 0 20px;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(1) p {
	color: #fff;
	text-align: center;
	padding: 5px 20px;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(1) p:nth-of-type(1) {
	background: #6E82DA;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(1) p:nth-of-type(2) {
	background: #A77FBD;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(2) {
	width: fit-content;
	display: flex;
	flex-flow: column;
	align-items: flex-end;
	gap: 10px;
	margin: 0 auto;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(2) h3 {
	color: #333;
	font-size: 1.4rem;
	font-weight: bold;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(1) > div:nth-of-type(2) h4 {
	color: #c00;
	font-size: 3.6rem;
	font-weight: bold;
}

.koukin_box > section > div:nth-of-type(1) > div:nth-of-type(2) img {
	width: 100%;
}

.koukin_box > section > div:nth-of-type(2) {
	width: 100%;
	background: rgba(0, 0, 0, 0.5);
	padding: 10px;
}

.koukin_box > section > div:nth-of-type(2) ul {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	text-align: center;
}

.koukin_box > section > div:nth-of-type(2) ul li:first-child {
	color: #fff;
	font-weight: bold;
}

.koukin_box > section > div:nth-of-type(2) ul li:nth-child(n+2) {
	font-size: 1rem;
	background: #fff;
	border-radius: 5px;
	padding: 5px;
}

.renkei_box {
	display: grid;
	grid-template-columns: 350px 1fr;
	gap: 30px;
}

.renkei_box h2 {
	color: #484848;
	font-size: 2rem;
	text-align: center;
	line-height: 1.5;
	margin: 0 0 10px;
}

.renkei_box h3 {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
	margin: 0 0 10px;
}

.renkei_box img {
	width: 100%;
}

.renkei_box > p {
	grid-column: 2/3;
	text-align: right;
}

.renkei_box > p a {
	color: #00863C;
}

.renkei_box > div ul {
	width: fit-content;
	display: flex;
	flex-flow: column;
	gap: 10px;
}

.renkei_box > div ul li {
	list-style: disc;
	line-height: 1.5;
	margin: 0 0 0 2rem;
}

.renkei_box > div:nth-of-type(1) {
	display: flex;
	flex-flow: column;
	align-items: center;
	gap: 10px;
}

.renkei_box > div:nth-of-type(1) > div > div {
	min-height: 346px;
	display: flex;
	flex-flow: column;
	justify-content: flex-end;
	text-align: center;
	align-items: center;
	border: 1px solid #003b9f;
	border-radius: 10px;
	position: relative;
	padding: 20px 40px;
}

.renkei_box > div:nth-of-type(1) > div > div img {
	margin: 0 0 10px;
}

.renkei_box > div:nth-of-type(1) > div > div > p {
	min-height: 50px;
}

.renkei_box > div:nth-of-type(1) > div > div > div {
	display: flex;
	align-items: center;
	position: relative;
}

.renkei_box > div:nth-of-type(1) > div > div > div > p {
	font-weight: bold;
	background: #fff;
	border-top: 1px solid #003b9f;
	border-bottom: 1px solid #003b9f;
	position: absolute;
	right: -100px;
	z-index: 2;
	padding: 10px;
}

.renkei_box > div:nth-of-type(2) {
	display: flex;
	flex-flow: column;
	align-items: center;
	gap: 0 10px;
}

.renkei_box > div:nth-of-type(2) > div {
	display: grid;
	justify-items: center;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
	background: #fff;
	border: 1px solid #10695e;
	border-radius: 10px;
	padding: 20px 40px;
	margin: 0 0 10px;
}

.renkei_box > div:nth-of-type(2) > div > div {
	width: 100%;
	text-align: center;
}

.renkei_box > div:nth-of-type(2) > div > div > div {
	width: 100%;
	display: flex;
	align-items: center;
	border: 1px solid #003b9f;
	border-radius: 10px;
	position: relative;
	padding: 20px;
	margin: 0 0 10px;
}

.renkei_box > div:nth-of-type(2) > div > div > div > img {
	height: 150px;
	object-fit: contain;
}

.bcpos_box h2 {
	text-align: center;
	margin: 0 0 30px;
}

.bcpos_box h3 {
	margin: 0 0 20px;
}

.bcpos_box img {
	width: 100%;
}

.bcpos_box > div {
	margin: 0 0 50px;
}

.bcpos_box > div:last-of-type {
	margin: 0;
}

.bcpos_box > div:nth-of-type(1) > div,
.bcpos_box > div:nth-of-type(2) > div,
.bcpos_box > div:nth-of-type(3) > div {
	display: grid;
	grid-template-columns: 60% auto;
	gap: 30px;
}

.bcpos_box > div:nth-of-type(10) > div {
	display: grid;
	grid-template-columns: 50% auto;
	gap: 30px;
}

.bcpos_box .tenpo_box {
	display: grid;
	justify-content: center;
	grid-template-columns: repeat(2, 150px);
	gap: 30px;
	text-align: center;
	margin: 20px 0 0;
}

.bcpos_box .tenpo_box p {
	font-size: 1.2rem;
	color: #fff;
	line-height: 1.5;
	background: #003b9f;
	padding: 5px 30px;
}

.hasyutu_box > h2 {
	margin: 0 0 10px;
}

.hasyutu_box > p {
	text-align: center;
	margin: 0 0 30px;
}

.hasyutu_box .system > h3 {
	font-weight: bold;
	text-align: center;
	margin: 0 0 10px;
}

.hasyutu_box .system > div {
	display: grid;
	justify-items: center;
	grid-template-columns: 300px 300px 1fr;
	gap: 30px;
	background: #fff;
	border: 1px solid #10695e;
	border-radius: 10px;
	padding: 30px;
	margin: 0 0 30px;
}

.hasyutu_box .system > div > div {
	width: 100%;
	display: flex;
	flex-flow: column;
	align-items: center;
}

.hasyutu_box .system > div > div h4 {
	min-height: 45px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	line-height: 1.5;
	margin: 0 0 10px;
}

.hasyutu_box .system > div > div > div p {
	font-weight: bold;
	background: #fff;
	border-top: 1px solid #003b9f;
	border-bottom: 1px solid #003b9f;
	position: absolute;
	right: -62px;
	z-index: 2;
	padding: 10px;
}

.hasyutu_box .system > div > div > div {
	width: 100%;
	display: flex;
	align-items: center;
	border: 1px solid #003b9f;
	border-radius: 10px;
	position: relative;
	padding: 20px 50px;
	margin: 0 0 10px;
}

.hasyutu_box .system > div > div > div img {
	width: 100%;
	height: 150px;
	object-fit: contain;
}

.hasyutu_box .nagare > h3 {
	font-weight: bold;
	margin: 0 0 10px;
}

.hasyutu_box .nagare > ol {
	display: flex;
	flex-flow: column;
	gap: 10px;
}

.hasyutu_box .nagare > ol li {
	list-style: decimal;
	line-height: 1.5;
	margin: 0 0 0 2rem;
}

.tanmatu_box {
	background: #fff;
	border: 2px solid #003b9f;
	border-radius: 10px;
	padding: 30px;
}

.tanmatu_box > div {
	display: grid;
	align-items: center;
	justify-content: center;
	grid-template-columns: repeat(auto-fit, minmax(100px, 180px));
	gap: 30px;
	margin: 0 0 20px;
}

.tanmatu_box > div img {
	width: 100%;
	height: 100px;
	object-fit: contain;
}

.regiset_box {
	display: grid;
	grid-template-columns: 300px 1fr;
	gap: 30px;
	padding: 0 30px;
	margin: 0 0 60px;
}

.regiset_box img {
	width: 100%;
}

.regiset_box > div:nth-of-type(1) {
	text-align: center;
}

.regiset_box > div:nth-of-type(1) > p {
	margin: 0 0 10px;
}

.regiset_box > div:nth-of-type(1) > p:nth-of-type(3) {
	font-size: 3rem;
	color: #a81128;
	font-weight: bold;
	text-align: center;
	margin: 0;
}

.regiset_box > div:nth-of-type(1) > p:nth-of-type(3) span {
	font-size: 1.4rem;
}

#semiself_use .regiset_box > div:nth-of-type(2) h3 {
	color: #04867c;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	margin: 0 0 10px;
}

.regiset_box > div:nth-of-type(2) > p {
	color: #0f7d9f;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	background: #e1eef7;
	padding: 8px;
	margin: 0 0 10px;
}

.regiset_box > div:nth-of-type(2) > ul {
	display: flex;
	flex-flow: column;
	gap: 15px;
	counter-reset: number 0;
	padding: 0 0 0 34px;
}

.regiset_box > div:nth-of-type(2) > ul li {
	line-height: 1.5;
}

.regiset_box > div:nth-of-type(2) > ul li::before {
	counter-increment: number 1;
	content: counter(number);
	color: #0f7d9f;
	font-weight: bold;
	background: #e1eef7;
	padding: 5px 10px;
	margin: 0 5px 0 -3.4rem;
}

a.link_text {
	color: #00863C;
}



/*----- slickスライダー -----*/

.slick_box p {
	margin: 0 0 10px;
}

.slick_box .slick-slide img {
	margin: 0 auto;
}

.slick_box > div > div > div {
	width: 100%;
	height: auto;
	transform: scale(0.7);
	transition: 0.5s;
}

.slick_box > div > div > div.slick-center {
	transform: scale(1);
}

.slick_box .slick-prev {
	left: 0 !important;
	z-index: 2;
}

.slick_box .slick-next {
	right: 0 !important;
	z-index: 2;
}

/*----- slickスライダーここまで-----*/


a.text_link_window {
	color: #005d96;
	border-bottom: 1px solid;
	position: relative;
	transition: 0.3s;
}

a.text_link_window:hover {
	opacity: 0.3;
}

a.text_link_window::after {
	content: "\f35d";
	font-family: Font Awesome\ 5 Free;
	font-weight: 600;
	margin: 0 0 0 5px;
}

/*----- 外部読み込みページ -----*/

.jyunkanshiki_box {
	background: #fff;
	border: 1px solid #c7c8c7;
	border-radius: 5px;
	padding: 20px;
	margin: 60px 0 0;
}

.jyunkanshiki_box > p {
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0 0 20px;
}

.jyunkanshiki_box > div {
	gap: 30px 0;
}

.jyunkanshiki_box img {
	max-width: 300px;
}

 /*240903  */
 
 .content2_2{background: #f7f7f7;	;
	padding-bottom: 10px;
}


.banner_box2 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    gap: 20px;
    padding: 30px 0 ;
    margin: 0 auto;
    max-width: 950px;
}

.banner_box2 img {
    width: 100%;
   /* max-width: 300px; */
    height: auto;
    filter: drop-shadow(2px 2px 3px rgba(0, 0, 0, 0.2));
    padding: 0;
}

/*
.banner_box2 img:nth-child(1) {
margin-right: 20px;
}
*/
 /*240903  */
 
 
 


  /* ギャラリーセクション - パディング削減 */
  .case-gallery-section {
	background-color: #eff3fb;
	border-radius: var(--border-radius);
	padding: 25px; /* パディングを削減 */
	box-shadow: var(--shadow);
	text-align: center;
  }
  
  /* ギャラリーヘッダー - パディング削減 */
  .gallery-header {
	margin-bottom: 0; /* マージンを削減 */
	position: relative;
	background: var(--dark-teal);
	padding: 12px 0; /* パディングを削減 */
	text-align:center;
  }
  
  /* 英語サブタイトル */
  .gallery-subtitle {
	display: block;
	font-size: 11px;
	letter-spacing: 3px;
	color: var(--dark-teal);
	font-weight: 600;
	margin-bottom: 3px; /* マージンを削減 */
	opacity: 0.8;
  }
  
  .gallery-header h3 {
	font-size: 24px;
	font-weight: 600;
	background: var(--dark-teal);
	margin-bottom: 0; /* マージンを削減 */
	position: relative;
	display: inline-block;
	color: #fff;
	text-align:center;
  }
  
  .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(3, 2fr);
	gap: 20px; /* 間隔を削減 */
	margin-bottom: 3rem; /* マージンを削減 */
  }
  
  .gallery-item {
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
	transition: var(--transition);
	padding: 10px;
	background: #fff;
	}
  
/*  .gallery-item:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);
  }
  */
  .gallery-link {
	display: block;
/*	height: 110px;  高さを削減 */
	overflow: hidden;
  }
  
  .gallery-link img {
	width: 100%;
	height: 150px;
	object-fit: cover;
	transition: var(--transition);
	border-radius: 6px;
	overflow: hidden;
	transition: 0.3s;
  }
  
  .gallery-item:hover img {
	transform: scale(1.08);
  }
  
  
  .gallery-item dl{
	  display: flex;
	  justify-content: space-between;
	  align-items: center;
	  margin: 10px 0 0;
	  position:relative;
	  font-weight:600;
  }
  .gallery-item dl::after{
  position: absolute;
  bottom: 0;
  right: 0;
  border-left: 10px solid transparent;
  border-bottom: 10px solid #10695e;
  content:"";
  }

.gallery-item dl dt{
	  font-size: 16px;
  }
  .gallery-item dl dt span{
	  font-size: 0.8em;
  }
  .gallery-item dl dd{
	  background:#eff3fb;
	  font-size: 0.8em;
	  padding: 0.2em 0.5em ;
	  margin-right: 2em;
  }
  
  /* ギャラリーボタン - マージン削減 */
  .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; /* 幅を削減 */
  }
  
  .gallery-button:hover {
	background-color: var(--darker-teal);
	transform: translateY(-2px);
	box-shadow: 0 5px 12px rgba(0, 0, 0, 0.1);
	opacity: 1;
  }
  
  /* クリック可能カードのフォーカススタイル */
  .case-card:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(51, 181, 163, 0.4), var(--shadow);
  }
  
  /* レスポンシブ対応 */
  @media screen and (max-width: 1100px) {
	.case-gallery-grid {
	  grid-template-columns: repeat(3, 1fr);
	}
  }
  
  @media screen and (max-width: 900px) {
	.case-studies-grid {
	  grid-template-columns: 1fr;
	  max-width: 550px; /* 1カラム時のカード幅を制限 */
	}
	
	.case-card-image {
	  height: 200px; /* 画像サイズを調整 */
	}
	
	.case-studies-header h2 {
	  font-size: 40px;
	}
  }
  
  @media screen and (max-width: 767px) {
	.case-studies-bg {
	  padding: 10px 10px;
	}
	
	.case-studies-header h2 {
	  font-size: 32px;
	}
	
	.case-studies-header p {
	  font-size: 16px;
	}
	
	.case-card-image {
	  height: 180px; /* スマホではさらにコンパクトに */
	}
	
	.case-card-content {
	  padding: 15px; /* パディングをさらに削減 */
	}
	
	.case-gallery-grid {
	  grid-template-columns: repeat(2, 1fr);
	  gap: 8px; /* 間隔をさらに削減 */
	}
	
.gallery-link img{
	height: 80px;
}
  .gallery-item dl{
	  flex-direction: column;
	  gap: 1rem;
	 }
	 .gallery-item dl dd{
		 margin:0 auto;
	 }
	
	.gallery-header {
	  padding: 15px 0; /* パディングをさらに削減 */
	}
	
	.gallery-header h3 {
	  font-size: 20px;
	}
	
	.gallery-header p {
	  font-size: 14px;
	}
	
	.gallery-button {
	  width: 100%;
	  max-width: 280px;
	}
	
.pickup{
		grid-template-columns: repeat(1, 2fr);
}
	
.pickup .order1{
	order:2;
}
.pickup .order2{
	order:1;
}
.jListH{
	font-size: 1.8rem;
}
.h2L{
	font-size: 2.6rem;
}



}
  
  /* 印刷時の対応 */
  @media print {
	.case-studies-bg {
	  background-color: white !important;
	  color: black !important;
	}
	
	.case-studies-header h2,
	.case-studies-header p {
	  color: black !important;
	}
	
	.case-studies-header h2:after {
	  background-color: #ccc !important;
	}
  }
 




  .set-box-image img {
	max-height: 150px;
	object-fit: contain;
  }
/*  */
/* 
.price2 p:nth-child(1) {
	font-weight: bold;
	margin: 0 0 10px;
} */

.price2 {
	font-size: 3.2rem!important;
	color: #D91717!important;
	font-weight: 600;
	text-align: center;
	/* margin: 0 0 10px; */
}
.price2 span{
	font-size: 1.4rem;
	color: #111;
	font-weight:normal;
}

.jichitai-product-grid .price2 {
	font-size: 3.2rem!important;
	color: #D91717!important;
	font-weight: 600;
	text-align: center;
	margin: -1rem 0 2rem;
}

.jichitai-product-grid h6{
	font-size: 1.6rem;
	font-weight:bold;
}

.price3 {
	font-size: 2.5rem!important;
	color: #a81128!important;
	font-weight: bold;
	text-align: center;
	/* margin: 0 0 10px; */
}
.price3 span{font-size: 50%;
	color: #333!important;
padding-left: 10px;}


.set {
    vertical-align: middle;
    display: flex;
    align-items: center;
	/* border: 1px solid rgb(235, 235, 235); */
}


.set-header{
    background: #10695e;
    width: 160px;
	min-height: 105px;
    align-items: center;
    display: flex;
    justify-content: center;
    color: #fff;
    font-size:1.3rem;
}
.set-header p{
    align-items: stretch;
    display: flex;
    justify-content: center;
}

.set-content-list {
    width: 100%;
    height: 100%;
    padding: 1rem 1rem 1rem 1.5rem;
    margin: auto; /* ulの余白をなくす */
    list-style-position: inside; /* liのリストアイコンをUL内に収める */
    line-height: 17px;
    font-weight:normal;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.set-content-list li {
    list-style: disc;
    text-align: left; /* 左揃え */
    margin-left: 1em; /* liのアイコンとテキストを適切に配置 */
	font-size: 1.2rem;
}

.set-content-wrapper {
    font-weight: bold;
    width: 100%;
    height: 100%;
    vertical-align: middle;
    display: flex;
    align-items: stretch;
    justify-content: center;
    margin: 0; /* 不要な余白をなくす */
    background: #fff;
    padding: 0;
}

.set p:nth-child(2) {
    width: fit-content;
    background: #f2f2f2;
    padding: 10px;
    margin: 0 auto 30px;
}


.setBox{
	background:#fff;
	padding: 3rem;
}

.jichitai-lineup-heading {
background: #89D9B4;
background: linear-gradient(125deg,rgba(137, 217, 180, 1) 0%, rgba(16, 105, 94, 1) 100%);
color:#fff;
font-size: 2.6rem;
text-align:center;
width:100%;
padding: 2rem;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
	font-weight:600;
	margin: 0 auto 2rem;
}

.jichitai-lineup-container {
padding: 2rem;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
  }


.jichitai-lineup-container .hTit{
	font-weight:bold;
	font-size: 2.4rem;
	text-align:center;
	margin: 2.5rem auto 5rem;
	display: flex;
	gap: 6rem;
	align-items: center;
	justify-content: flex-start;
	padding-left:1rem;
}
.jichitai-lineup-container .hTit img{
	max-height: 40px;
	width: auto;
}
.jichitai-lineup-container .hTit span{
}

  .jichitai-product-card {
	flex: 0 0 48%;
	border-radius: 10px;
	/*	box-shadow: 0 3px 8px rgba(0,0,0,0.08);
	padding: 20px;
	border: 1px solid #eaeaea;
	*/
	display: flex;
	flex-direction: column;
	gap: 3rem;
	align-items: center;
  }
  .jichitai-product-grid .jichitai-product-card {
	gap: 2rem;
  }
  
  .jichitai-product-title {
	background: #373737;
	color: white !important;
	padding: 15px 10px !important;
	display: block;
	font-size: 1.4rem !important;
	font-weight: 400 !important;
	width: 200px;
	text-align:center !important;
	margin-left: 4rem;
  }

  .jichitai-product-sub {
	font-weight:bold;
	font-size: 2.3rem;
	}

.productFlex{
	display: flex;
	gap: 1rem;
	align-items: center;
	justify-content: space-between;
	width:100%;
}
.productFlexIn{
	display: flex;
	gap: 4rem;
	align-items: center;
	justify-content: space-between;
	width:100%;
}
  /* リストスタイル */
  .pro-list {
	list-style: none;
	padding: 0;
	margin: 2rem 0 3rem;
  }
  
  .pro-list li {
	position: relative;
	padding-left: 30px;
	margin-bottom: 12px;
	font-size: 16px;
	line-height: 1.5;
  }
  .pro-list li span {
	  font-size: 14px;
	  font-weight:300;
  }
  .pro-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='%2310695E'/><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;
  }

.jichitai-product-card img{
	max-width: 310px;
}

  .jichitai-action-button {
	display: inline-block;
	background: #2080ce;
	color: white;
	font-size: 22px;
	font-weight: bold;
	padding: 25px 30px;
	border-radius: 8px;
	text-decoration: none;
	box-shadow: 0 4px 8px rgba(0,0,0,0.15);
	transition: all 0.3s ease;
	text-align: center;
	width: 100%;
	}
  
  .jichitai-action-button:hover {
	background: #1a6caf;
	transform: translateY(-3px);
	box-shadow: 0 6px 12px rgba(0,0,0,0.2);
  }
  
  .jichitai-action-button.primary {
	background: #D64550;
	box-shadow: 0 4px 12px rgba(214, 69, 80, 0.3);
  }
  
  .jichitai-action-button.primary:hover {
	background: #c03844;
  }
  
  .jichitai-button-arrow {
	display: inline-block;
	margin-left: 10px;
  }
  
  .jichitai-section-title {
	color:#0f7d9f;
	font-weight: 800;
	font-size: 22px;
	text-align: left;
	margin-bottom: 20px;
  }
  
  .jichitai-intro-text {
	text-align: left;
	line-height: 1.6;
	margin-bottom: 20px;
  }
  
  .jichitai-set-content {
	/* border: 1px solid #ddd; */
	border-radius: 8px;
	overflow: hidden;
  }
  
  .jichitai-set-title {
	background: #0f7d9f;
	color: white;
	padding: 10px;
	font-weight: 600;
	text-align: center;
  }
  
  .jichitai-set-list {
	padding: 10px 20px;
	margin: 0;
	list-style: none;
  }
  
  .jichitai-set-list li {
	position: relative;
	padding-left: 18px;
	margin-bottom: 5px;
	line-height: 1.4;
  }
  
  .jichitai-set-list li:last-child {
	margin-bottom: 0;
  }
  
  /* POSレジアイコンスタイル */
  .jichitai-set-list li::before {
	content: "■";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--dark-teal);
	font-weight: bold;
	font-size: 12px;
  }
  
  .posset_title{
	  margin: 0 auto 3rem;
  }
  .space{
	  margin-bottom: 5rem !important;
  }
  .space img{
  max-height: 300px;
  width: auto;
}
  
  .jichitai-product-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-between;
	text-align:center;
	margin: 0 auto 5rem;
  }
  .jichitai-product-grid:last-child {
	margin: 0 auto ;
  }
  


.rearegi-section{
	background: white;
	border-radius: 10px;
	padding: 0 0 0 20px ;
	margin-bottom: 0;
	position: relative;
	overflow: hidden;
}

.rearegiBox .hTit{
	margin: 0 auto 2rem;
}

.rearegi-section .flex{
	display: flex;
/*	flex-wrap: wrap;*/
	gap: 10px;
	justify-content: center;
	text-align:center;
	align-items:center;
	margin-top: 2rem;
}
.rearegi-section .subTxt{
	background:#373737;
	color:#fff;
	padding: 0 1rem;
	width: 26%;
}
.rearegi-section .en{
	line-height:1.2;
}
.rearegi-section .cost{
	font-size: 3.2rem;
	font-weight:bold;
	color:#D91717!important;
}
.rearegi-section .app{
	border:1px solid #111;
	border-radius: 1rem;
	font-size: 1rem;
	padding: 0.2rem 0.5rem ;
	width:fit-content;
	display:inline-block;
	margin-bottom: 0.8rem;
}
.rearegi-section .month{
	height:fit-content;
	writing-mode: vertical-rl;
	vertical-align: sub;
	margin-right: 0rem;
}
.rearegi-section .senyou{
	background:#369DA7;
	color:#fff;
	border-radius: 0.4rem;
	font-size: 1.8rem;
	padding: 1rem ;
	width:fit-content;
	margin-top: 1rem;
}
.rearegi-section .senyou span{
	font-size: 1.2rem;
}

.rearegi-section .ano{
	font-size: 1.1rem;
	font-weight:300;
	line-height: 1.4;
}






/* Support */
.support_btm {
	text-align: center;
	position: relative
}

.support_btm h2 {
	font-size: 2.6rem;
	font-weight: bold;
	color: #000
}

.support_btm p {
	font-size: 1.2rem;
}

.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: #10695e;
}

.support_layout span {
	font-size: 1.2rem;
	color: #666;
	display: block
}



.posregisoft{
	padding: 3rem;
}
.planBox{
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-between;
	text-align:center;
	margin: 0 auto 2rem;
}
.planBox dl{
	width: 48%;
	display: flex;
	flex-wrap: wrap;
	gap: 0px;
	justify-content: space-between;
	text-align:center;
	margin: 0 auto;
	flex-direction:column;
}
.planBox h4{
	background: #10695E;
	color: white;
	padding: 1.2rem ;
	display: block;
	font-size: 2.2rem;
	font-weight: 400;
	width: 100%;
	text-align:center;
}
.planBox img{
	max-height: 70px;
	width:100%;
	margin: 2rem 0 0;
}
.planBox .cap{
	color:#00857A;
	font-size:1.2rem;
	line-height: 1.4;
}

.planBox dl{
	border: 2px solid #00857A;
	border-radius: 6px;
		box-shadow: 0 5px 20px rgba(24, 128, 58, 0.1);
}
.planBox dl dt{
	background:#00857A;
	color:#fff;
	padding: 1rem;
	font-size: 1.8rem;
	position:relative;
}

.planBox dl dt .dlMark{
	position:absolute;
	top: -2rem;
	left: -2rem;
	color: #fff;
	background: #F5A623;
	width: 70px;
	height: 70px;
	display: flex;
	border-radius: 100px;
	/* padding: 1rem; */
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.planBox .blackDl{
	border: 2px solid #373737;
}
.planBox .blackDt{
	background:#373737;
}

.planBox dl dd{
	text-align:center;
	margin: 0 auto;
	padding: 2rem 1rem 1rem;
	width: 100%;
}
.planBox dl dd .flex{
	display: flex;
/*	flex-wrap: wrap;*/
	gap: 30px;
	justify-content: center;
	text-align:center;
	align-items:center;
}


.planBox dl dd .subTxt{
	background:#373737;
	color:#fff;
	padding: 0 1rem;
	width: 30%;
}
.planBox dl dd .en{
	line-height:1.2;
}
.planBox dl dd .cost{
	font-size: 3.2rem;
	font-weight:bold;
	color:#D91717!important;
}

.planBox .month{
	height:fit-content;
	writing-mode: vertical-rl;
	vertical-align: sub;
	margin-right: 1rem;
}


.planTxt{
	font-weight:bold;
	font-size: 2.4rem;
	text-align:center;
	margin: 3rem auto ;
}

.planTxt i {
	font-size: 14rem;
background: linear-gradient(180deg,rgba(137, 217, 180, 1) 0%, rgba(16, 105, 94, 1) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
line-height: 0.6;
}


.planBox .softhow{
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	justify-content: center;
	text-align:center;
	margin: 2.6rem auto 0;
	align-items:center;
	width:100%;
	}
.planBox .softhow > div{
	width: 48%;
	background:#10695E;
	color:#fff;
	padding: 2rem 1rem;
	font-size: 1.8rem;
	border-radius: 6px;
		box-shadow: 0 5px 20px rgba(24, 128, 58, 0.1);
}
.planBox .softhow > div > p{
	font-size: 1.8rem;
	line-height: 1.2;
}
.planBox .softhow > div > p > span{
	font-size: 4.2rem;
	font-weight:bold;
}
.planBox .softhow > div > .unyou{
	font-size: 2rem;
	font-weight:bold;
}




.tenpovisorBox {
	padding: 3rem;
	margin: 0 auto 3rem;
	background:#fff;
}
.tenpovisor {
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
	border-radius: 10px;
	overflow: hidden;
	background:#F7F7F7;
	padding: 0 ;
}

.tenpovisor .plan{
	display: grid;
	grid-template-columns: 50% 1fr;
	gap: 0;
	align-items:center;
}

.tenpovisor h3{
	margin-top: 0 !important;
	margin-bottom: 1rem !important;
}
.tenpovisor p{
	color:#111;
}

.tenpovisor .point{
	color:#004098;
	font-weight:600;
}
.tenpovisor .mark{
	max-height:50px;
	width:auto;
}
.tenpovisor .sample{
	max-height:210px;
	width:auto;
	padding: 2rem 0rem 0 2rem;
}



.tenpovisor .flex{
	display: flex;
/*	flex-wrap: wrap;*/
	gap: 30px;
	justify-content: center;
	text-align:center;
	align-items:center;
}

.tenpovisor .subTxt{
	background:#373737;
	color:#fff;
	padding: 0 1rem;
	width: 30%;
	text-align:center;
}
.tenpovisor .en{
	line-height:1.2;
}
.tenpovisor .cost{
	font-size: 3.2rem;
	font-weight:bold;
	color:#D91717!important;
}

.tenpovisor .month{
	height:fit-content;
	writing-mode: vertical-rl;
	vertical-align: sub;
	margin-right: 1rem;
}


.tenpovisor .kome{
	font-size: 1.2rem;
	margin-top:0.5rem;
	text-align:center;
}
/*
.tenpovisor > div > div {
	background: #dbe5f3;
}
*/
.tenpovisor > div > div > div{
	padding: 0;
	text-align:center;
}
.tenpovisor > div > div > div:last-child{
/*	padding: 1rem 0;*/
}

.btnBox{
  -webkit-transition: all .3s;
  transition: all .3s;
}
.btnBox:hover{
  opacity: 0.6 !important;
}
.btnBox .tenpovisor{
  -webkit-transition: all .3s;
  transition: all .3s;
}
.btnBox:hover .tenpovisor {
  transform: scale(1.05,1.05);
}


/*
.tenpovisorBox > a > div > div:nth-of-type(2) > div {
	margin: 0 auto;
}

.tenpovisorBox > a > div > div > div > div:nth-of-type(1) > p:nth-of-type(1) {
	font-size: 4.2rem;
	font-weight: bold;
	margin: 0 0 4rem;
}

.tenpovisorBox > a > div > div > div > div:nth-of-type(1) > p:nth-of-type(1) span {
	color: #fff;
	text-align: center;
	padding: 0 5px;
	margin: 0 0 0 10px;
}

.tenpovisorBox > a > div > div:nth-of-type(1) > div > div:nth-of-type(1) > p:nth-of-type(1) span {
	background: #e5006e;
}

.tenpovisorBox > a > div > div:nth-of-type(2) > div > div:nth-of-type(1) > p:nth-of-type(1) span {
	background: #014099;
}

.tenpovisorBox > a > div > div > div > div:nth-of-type(1) p:nth-of-type(2) {
	font-size: 3.2rem;
	font-weight: bold;
	margin: 0 0 3.5rem;
}

.tenpovisorBox > a > div > div:nth-of-type(1) > div > div:nth-of-type(1) p:nth-of-type(2) span {
	color: #e5006e;
}

.tenpovisorBox > a > div > div > div:nth-of-type(2) > p {
	margin: 0 0 30px;
}

.tenpovisorBox > a > div > div:nth-of-type(2) > div > div:nth-of-type(1) p:nth-of-type(2) span {
	color: #014099;
}


.tenpovisorBox > a > div > div > div:nth-of-type(2) img {
	max-width: 320px;
}
*/





  /* 個別の特徴セクション */
  .feature-section {
	background: white;
	border-radius: 10px;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
	padding: 30px 40px 40px 40px;
	margin-bottom: 40px;
	position: relative;
	overflow: hidden;
  }
  
  .feature-section:last-child {
	margin-bottom: 0;
  }
  
  /* 番号ラベル - ピリオド付き数字に変更 */
  .feature-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; /* 数字のフォントをはっきりさせる */
  }

  .feature-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; /* 数字のフォントをはっきりさせる */
  }
  
  /* 特徴のヘッダー */
  .feature-header {
	margin-left: 80px;
	margin-bottom: 30px;
  }
  
  .feature-title {
    display: block;
    font-weight: 800;
    font-size: 15px;
    margin-bottom: 5px;
	color: var(--dark-teal);
  }

    
  .feature-title2 {
	font-size: 30px;
	font-weight: 700;
	color: var(--main-teal);
	margin-bottom: 15px;
  }
  
  .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;
  }
  
  .feature-description {
	font-size: 16px;
	line-height: 1.6;
	color: #555;
  }
  
  /* 特徴のコンテンツエリア */
  .feature-content {
	margin-top: 20px;
  }
  
  /* リストスタイル */
  .feature-list {
	list-style: none;
	padding: 0;
	margin: 20px 0;
  }
  
  .feature-list li {
	position: relative;
	padding-left: 30px;
	margin-bottom: 12px;
	font-size: 16px;
	line-height: 1.5;
  }
  
  .feature-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='%2310695E'/><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;
  }
  
  /* 画像コンテナ */
  .feature-image-container {
	margin: 30px 0;
	text-align: center;
	display: flex;
	justify-content: center;
  }
  
  .feature-image {
	max-width: 70%;
/*	border: 1px solid #eee;
	border-radius: 8px;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.05);*/
  }

.feature-cash {
/*
	padding: 1rem 2rem;
	background:#f7f7f7;
	*/
}

  /* 特徴フッター */
  .feature-footer {
	margin-top: 30px;
	text-align: center;
  }
  
  .feature-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;
  }
  
  .feature-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{
}


.syukeiFlex{
	display:flex;
	justify-content:center;
	align-items:center;
	gap: 2rem;
	padding: 0 5rem;
	margin: 0 auto 3rem;
}
.syukeiFlex:last-child{
	margin: 0 auto;
}
.syukeiFlex img{
	max-width:100%;
}
.syukeiFlex div:hover img{
	transform: scale(1.08);
	transition: transform 0.4s ease;
  }
.syukeiH{
	color: #fff;
	background: #10695e;
	font-size: 2.0rem;
	font-weight: 600;
	text-align:center;
	width:80%;
	margin: 1rem auto;
	padding: 1rem 0.5rem;
}


/* CTA */
.cta {
background: #89D9B4;
background: linear-gradient(-90deg,rgba(137, 217, 180, 1) 0%, rgba(16, 105, 94, 1) 100%);
	padding: 30px 0 40px 0;
	width: 100%;
}
.cta h3 {
	background-color: #10695e;
	color: #fff;
	text-align: center;
	font-size: 3.0rem;
	padding: 2rem 0;
	line-height: 1.6;
	margin-bottom: 3rem;
	font-weight:700;
}
.cta h3 span {
	display: block;
	font-size: 2.4rem;
	color:#fff;
}
.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 screen and (max-width: 1024px) {
.pcNot{
	display:block;
}

.hero-inner {
	  padding: 40px 20px 20px;
	  min-height: 400px;
	}
.features{
	flex-wrap: wrap;
}
.register{
	width: 46rem;
	padding-bottom: 15rem;
}
.planBox .softhow{
	gap: 1vw;
}
.planBox h4{
	font-size: 2.0rem;
}
.planBox dl dd p span{
/*	font-size: 3.0rem;*/
}

.planBox .softhow > div{
	font-size: 1.6rem;
}
.planBox .softhow > div > p{
	font-size: 1.2rem;
}
.planBox .softhow > div > .unyou{
	font-size: 1.6rem;
}
.planBox .cap{
	font-size: 1.0rem;
}

.planBox .softhow > div > p > span{
	font-size: 3.6rem;
}
.planBox dl dd{
	padding: 1rem;
}
.planBox dl dd .flex{
	gap: 0.8rem;
}
.planBox dl dd .subTxt{
	font-size:1.2rem;
	padding: 0;
	width: 28%;
}
.planBox dl dd .month{
	margin-right: 0.2rem;
}




  .swiper-container2 .swiper-wrapper2{
		justify-content:unset;

  }
.swiper-container2 .swiper-slide2 {
  width: unset;
  margin-right:15%;
}

	
	
/*  */
.oshirase_box,
	.ver_box {
		padding: 0;
	}

	.oshirase_box > div:first-of-type,
	.ver_box > div:first-of-type {
		width: 100%;
		padding: 10px 0;
	}

	.oshirase_box > div:nth-of-type(2),
	.ver_box > div:nth-of-type(2) {
		width: 100%;
		padding: 20px 10px
	}

	.oshirase_box > div:last-of-type,
	.ver_box > div:last-of-type {
		width: 100%;
		text-align: center;
		padding: 10px 10px;
	}

	.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;
		}
/*  */
	.posset_box .content {
		max-width: 700px;
		grid-template-columns: repeat(1, 1fr);
	}

	.keywordbox {
		font-size: 1.2rem;
	}

	.point_box > div > div {
		height: 70px;
	}

	.drug_hero_bg {
		width: 100%;
		background: url("/product/business/images/jichitai_img/jichitai_hero2.png") 0 20% no-repeat;
		background-size: cover;
		padding: 0;
		position: relative;
		padding-bottom: 1px;
		background-position: 22% 6%;
	}

	.green_border_box div {
		padding: 10px 5px;
	}

	.green_border_box div p {
		font-size: 1.3rem;
	}

	table td {
		font-size: 1.3rem;
	}

	.tbonly {
		display: block;
	}

	.koukin_box > section > div:nth-of-type(2) ul {
		flex-wrap: wrap;
	}

	.koukin_box > section > div:nth-of-type(2) ul li:first-child {
		width: 100%;
	}

	.renkei_box {
		max-width: 600px;
		grid-template-columns: repeat(1, 1fr);
		margin: 0 auto;
	}

	.renkei_box h2 {
		font-size: 1.8rem;
	}

	.renkei_box h3,
	.renkei_box p {
		font-size: 1.2rem;
	}

	.renkei_box > p {
		grid-column: auto;
	}

	.renkei_box > div:nth-of-type(1) {
		flex-flow: row;
		margin: 0 0 70px;
	}

	.renkei_box > div:nth-of-type(1) > div > div {
		width: 200px;
		min-height: auto;
		padding: 20px 10px;
	}

	.renkei_box > div:nth-of-type(1) > div > div > p {
		min-height: auto;
	}

	.renkei_box > div:nth-of-type(2) > div {
		padding: 20px;
	}

	.renkei_box > div:nth-of-type(2) > div > div > div > img {
		height: 100px;
	}

	.renkei_box > div:nth-of-type(1) > div > div > div > p {
		white-space: nowrap;
		writing-mode: vertical-rl;
		text-orientation: upright;
		border-top: 0;
		border-bottom: 0;
		border-left: 1px solid #003b9f;
		border-right: 1px solid #003b9f;
		position: absolute;
		top: 200px;
		right: 65px;
	}

	.renkei_box > div:nth-of-type(1) > div > div > div > p span {
		font-family: auto;
	}

	.hasyutu_box .system > div {
		max-width: 400px;
		justify-content: center;
		grid-template-columns: 140px 140px;
		padding: 30px 10px;
		margin: 0 auto 30px;
	}

	.hasyutu_box .system > div > div h4 {
		min-height: auto;
		font-size: 1.3rem;
	}

	.hasyutu_box .system > div > div > p {
		font-size: 1.3rem;
	}

	.hasyutu_box .system > div > div > div {
		max-width: 140px;
		justify-content: center;
		padding: 20px 10px;
	}

	.hasyutu_box .system > div > div > div img {
		width: 100px;
		height: 100px;
	}

	.hasyutu_box .system > div > div > div p {
		font-size: 1.2rem;
		right: -46px;
		padding: 10px 0;
	}

	.hasyutu_box .system > div > div:nth-of-type(3) {
		grid-column: 1/3;
	}
		.hero-price {
	  flex-direction: column;
		  gap: 10px;
		  padding: 20px 15px;
	}
  
	.hero-price .price-value {
	  order: -1; /* Move to the top */
	  transform: scale(0.8);
	}
}

@media screen and (max-width: 1023px) {
.swiper-button-prev2,
.swiper-button-next2{
	display:block;
}
.banner_box2 img{
	padding: 0 20px;
}
  .feature-header {
	margin-left: 7rem;
	margin-bottom: 3rem;
	}
  .option {
	margin: 0 0 0.6rem 1rem;
	}
.mg-5{
    margin: 5rem auto !important;
}
.mg-10{
    margin: 7rem auto !important;
}
.pb-10{
	padding-bottom:1rem;
}
.productFlex {
    flex-direction: column;
}
.productFlexIn{
	flex-direction: column;
	gap: 2rem;
}
.productFlexIn .price2{
	text-align: center !important;
}
  .pro-list {
	margin: 2rem auto 3rem;
	width: fit-content;
}
.jichitai-product-grid{
	gap: 5rem;
}
  .jichitai-product-card {
	flex: 100%;
  }
.jichitai-lineup-container .hTit{
	flex-wrap: wrap;
	gap: 2rem;
	justify-content: center;
	padding-left:0;
}
.tenpovisor .plan{
grid-template-columns:repeat(1, 1fr);
padding: 2rem;
}


.fBox .arrow li:last-child::after{
	right:-34px;
}
.fBox .fUl li .fSet .fSub{
	font-size: 0.9rem;
	width:100%;
}
.fBox .fUl li .fSet .fImg {
	max-width:150px;
	max-height:150px;
	width:100%;
}
.fBox .fUl li .fSet .fMark {
	transform: scale(0.8)
}
}
/*************************************************************************************/
/*Sp Layout*/
/*************************************************************************************/
@media screen and (max-width: 767px) {
.w80per{
	width:100%;
}
.w70per{
	width:100%;
}
.w60per{
	width:100%;
}


	:root {
		--badge-size: 70px;   /* ← 好きな値にするだけ */
	  }

	.pconly3{display:none;}
.sponly3{display:block;}
  /* Main hero container layout */
  .hero-inner {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 18px;
    row-gap: 5px;
  }

	.hero-price .price-value {
	  order: -1; /* Move to the top */
	  transform: scale(0.8);
	}

  /* Full width elements (first and second rows) */
  .hero_textbox,
  .features {
    flex: 1 1 100%;
  }
  
  /* Features section styling */
  .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%;
  }
  
  .features li {
    white-space: normal;
    padding-left: 26px;
  }
  
  .features li::before {
    width: 20px;
    height: 20px;
  }
  
  .hero_textbox,
  .features {
    flex: 1 1 100%;
  }
  
  /* Hero left section (display as contents to allow children to be positioned independently) */
  .hero-left {
    display: contents;
    flex: 1 1 auto;
    max-width: 100%;
    text-align: center;
    align-items: center;
  }



  /* Hero right section (register image) */
  .hero-right {
    order: 1;
	flex: 0 0 100%;
	max-width: 70%;
	justify-content: center;
  }
  
  .register {
    margin: 0;
    width: 100%;
	padding-bottom: 0px;

    /* max-width: 200px; */
  }
  
  /* MODIFIED: Medals and staff container */
  .medals-staff-container {
    order: 2;
    /* flex: 0 0 45%; */
    max-width: 45%;
    justify-content: flex-start;
    margin-bottom: 0;
    flex-direction: column;
    gap: 10px;
  }
  
  /* Staff image hidden on mobile */
  .staff-image {
    display: none;
  }
  
  /* Medals group styling */
  .medals-group {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .hero-inner::after {
    content: "";
    display: block;
    width: 100%;
    order: 3;
    height: 0; /* Zero height, just for forcing banner to new row */
  }
  
  /* Medals vertical layout */
  .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 */
  }
  
  .medals {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
  }

  /* Keep existing medal styles */
  .medal {
    width: 80px; /* Slightly reduced from 90px */
  }
  
  .medal-banner-container {
    order: 3;
    flex: 1 1 100%; 
    display: flex;
    justify-content: center;
    margin-top: 15px;
  }
  
  /* Hero textbox styling */
  .hero_textbox {
    align-items: anchor-center;
    justify-content: center;
    gap: 15px;
    padding-left: 0px;
    margin-bottom: 10px;
    width: 100%;
  }
  
  /* Badge styling */
  .badge {
	width: 60px;     /* ← 好みの幅に変更 */
    /* 高さをそのままにするなら変更不要。
       縦横比を保ちたいなら height も同じ 60px に。 */
    height: 80px;    /* 例：少し細長い長方形にする場合 */
    font-size: 12px; /* 文字も気持ち小さくすると収まりが良い */
    left: -40px;
  }
  
  /* Text styling */
  .sub,
  .title {
    text-align: left;
  }
  
  .sub {
    margin-bottom: 8px;
  }
  
  .sub::after {
    width: 100%;
  }
  
  .title {
    font-size: 40px;
    margin: 0;
    text-align: left;
  }
  
  /* Set contents */
  .set-contents {
    width: 100%;
    max-width: 100%;
    transform: scale(0.8);
  }
  
  .set-label {
    flex: 0 0 120px;
    font-size: 16px;
  }
  
  /* Price label styling */
  .price-label::before,
  .price-label::after {
    width: 80px;
  }
  
  /* Swiper navigation buttons */
  .swiper-button-prev2,
  .swiper-button-next2 {
    width: 36px;
    height: 36px;
    margin-top: -18px;
	display:block;
  }
  
  .swiper-button-prev2::before,
  .swiper-button-next2::before {
    font-size: 14px;
    line-height: 36px;
  }

  
	
	
	.drug_hero_bg {
		padding-top: 10px !important;
		padding-bottom: 10px !important;
		height: auto !important;
		min-height: unset !important;
	}
	.drug_hero_box {
		padding-top: 5px !important;
		padding-bottom: 5px !important;
		margin-bottom: 0 !important;
	}
	.drug_hero_box_p,
	.drug_hero_box .text_box,
	.drug_hero_box h2 {
		margin-bottom: 5px !important;
	}
	.heroimg {
		height: 180px !important;
		object-fit: cover;
	}
	 
	.sponly2 {
        display: block !important;
    }

	.pagetop {
		bottom: 90px;
	}

	.foot {
		padding-bottom: 80px;
	}

	.rr {
		display: flex;
		flex-direction: column-reverse;
		flex-wrap: wrap;
	}

	h2 {
		font-size: 2.6rem;;
	}

	.single-item {
		width: 95%;
		margin: auto;
		padding: 5px 10px;
	}

	.link {
		font-size: 12px;
	}

	td:first-child {
		border: solid 1px #ccc;
		width: 100%;
		background: #f2f2f2;
	}

	th,
	td {
		display: block !important;
		width: 100%;
	}

	.spec_static th,
	.spec_static td {
		display: table-cell !important;
		width: auto;
	}

	.example th,
	.example td {
		display: table-cell !important;
	}

	.drug_hero {
		padding-bottom: 10px;
		padding-top: 10px;
	}

	.drug_hero_box {
		padding-right: 0px;
		padding-top: 10px;
		text-align: center;
		margin: auto;
	}

	.drug_hero_box h2 {
		font-size: 30px;
		margin-bottom: 0;
	}

	.drug_hero_bg {
		width: 100%;
		height: 715px;
		background-image: none!important;
		background-position: center bottom;
		background-size: auto 200px;
	}

	.drug_hero h1 {
		font-size: 2.6rem;
	}

	.swiper-button-next {
		right: 0;
	}

	.swiper-button-prev {
		left: 0;
	}

	.posset_box .icon_box > div {
		top: 60px;
		right: 0;
		z-index: 3;
	}

	#okomari .okomari_box {
		display: flex;
		flex-wrap: wrap;
	}

	#okomari .okomari_box .okomari_inner {
		width: calc(100%/2);
		height: 190px;
		text-align: center;
		margin: auto;
		font-weight: 500;
	}

	#okomari .okomari_box .okomari_inner p {
		font-size: 14px;
		letter-spacing: -1px;
	}

	#okomari .okomari_box .okomari_inner img {
		max-width: 100px;
		margin-top: 10px;
	}

	.semiselfbox ul {
		justify-content: space-evenly !important;
	}

	.semiselfbox ul li {
		margin-top: 10px;
		width: calc(76%/3) !important;
	}

	.point_box {
		flex-flow: column;
	}

	.point_box > div {
		width: 100%;
	}

	.renkei_jisseki td:first-child {
		background: #eaeaea;
	}

	.purchace_imagebox {
		border-right: none;
		padding: 0 20px;
	}

	.clinic_box {
		width: 73%;
		padding: 5px;
		margin: 0 auto 10px;
	}

	.g_checklist ul {
		margin-left: 0.5rem;
		margin-top: 1rem;
	}

	.g_checklist ul li {
		padding-bottom: 5px;
		line-height: 2rem;
		text-indent: -2.4rem;
		padding-left: 2rem;
	}

	#option .option_box {
		align-items: unset;
		justify-content: space-between;
		display: block;
	}

	#option .col-3 {
		width: 95% !important;
		margin: auto;
		margin-bottom: 10px;
	}

	#option .col-3 .option_textbox {
		height: auto;
	}

	#option .col-3 .option_textbox h3 {
		display: flex;
		flex-direction: column;
		font-size: 18px !important;
		height: auto;
	}

	#option .col-3 p {
		padding: 0 5%;
		margin-top: 5px;
	}

	.renkei_jisseki td:first-child {
		background: #eaeaea;
	}

	table.spec tr {
		border: none;
	}

	table.spec th {
		background: #f2f2f2;
		width: 98%;
		display: block;
	}

	table.spec td {
		width: 97%;
		display: block;
		padding: 1rem 0 0.5rem 0;
		margin-bottom: 16px;
	}

	.green_border_box {
		grid-template-columns: repeat(1, 1fr);
		gap: 20px 0;
	}

	.kaichu {
		max-width: 250px;
	}

	.cashless_icon img {
		width: 80% !important;
	}

	.koukin_box > section > div:nth-of-type(1) {
		max-width: 600px;
		grid-template-columns: repeat(1, 1fr);
		margin: 0 auto;
	}

	.bcpos_box > div:nth-of-type(1) > div,
	.bcpos_box > div:nth-of-type(2) > div,
	.bcpos_box > div:nth-of-type(3) > div,
	.bcpos_box > div:nth-of-type(10) > div {
		grid-template-columns: repeat(1, 1fr);
	}

	.bcpos_box img {
		max-width: 400px;
		display: block;
		margin: 0 auto;
	}

	.regiset_box {
		max-width: 500px;
		grid-template-columns: repeat(1, 1fr);
		padding: 0 20px;
		margin: 0 auto 60px;
	}

	.mb-20-sp {
		margin-bottom: 20px !important;
	}

	/*----- slickスライダー -----*/

	.slick_box {
		max-width: 500px;
		margin: 0 auto 30px;
	}

	.slick_box > div > div > div {
		transform: scale(1);
	}

	/*----- /slickスライダ-----*/

	/* 240903 */
	.banner_box2 {
		justify-content: center;
		padding: 0 0 0 0;
	}
	
	.banner_box2 img:nth-child(1) {
		margin-bottom: 5px;
			margin-right: 0px;
		
	}
	/* 240903 */


.set-content-wrapper{
	flex-direction:column;
}
.set-header{
	width: 100%;
	font-size:1.3rem;
	padding: 1rem;
	min-height: auto;
}
.set-content-list{
padding: 1em ;
}
.jichitai-product-title{
	line-height:1.2;
	margin: 0 auto;
	width: 100%;
}

.bpRe-btn{
	font-size:12px;
	text-align:center;
	line-height:1.5;
	width:100%;
	padding: 10px ;
}

.planBox{
	gap:5rem;
}
.planBox .soft{
	width:100%;
  }
  .planBox h4{
	  font-size:1.8rem;
  }
  .planBox dl dd p span{
	  font-size:1.0em;
  }
  .planBox .softhow > div{
	font-size: 1.6rem;
}
.planBox .softhow > div > p{
	font-size: 1.2rem;
}
.planBox .softhow > div > .unyou{
	font-size: 1.4rem;
}
.planBox .cap{
	font-size: 1.2rem;
	line-height:1.5;
	margin-top: 1rem;
	margin-bottom: 1.5rem;
}

.planBox .softhow > div > p > span{
	font-size: 3.0rem;
}

.text_annotation {
	font-size: 1.0rem;
	line-height: 1.5;
	text-align:center !important;
}

.tenpovisor {
	grid-template-columns: repeat(1, 2fr);
	gap: 3rem;
}

.tenpovisor .flex{
	gap: 1rem;
	flex-direction: column;
}
.tenpovisor .subTxt{
	width:80%;
}
.tenpovisor .sample{
	padding: 2rem 0 0;
}


	.features-main-container {
	  padding: 40px 0;
	}
	
	.features-main-title {
	  font-size: 24px;
	}
	
	.feature-section {
	  padding: 30px 20px;
	  margin-bottom: 30px;
	}
	
	.feature-number {
	  width: 50px;
	  height: 50px;
	  font-size: 22px;
	}

  .feature-renkei {
	width: 100px;
	height: 50px;
	font-size: 14px;
  }

	.feature-header {
	  margin-left: 0rem;
	  margin-bottom: 20px;
	  margin-top:  3rem;
	}
	
	.feature-title {
	  font-size: 20px;
	}
	
	.feature-description,
	.feature-list li {
	  font-size: 15px;
	}


	.set-section {
	  padding: 30px 20px 0;
	  margin-bottom: 30px;
	}
	
	.set-number {
	  width: 50px;
	  height: 50px;
	  font-size: 22px;
	}


.infobox>div:first-child{
	width: 50%;
	margin: 0 2rem 0 0 !important;
}

.infobox>div>p{
padding: 0.2rem;
}

.feature-title2{
	font-size: 2.0rem;
}



.mg-5{
    margin: 5rem auto !important;
}
.mg-10{
    margin: 5rem auto !important;
}
.pb-10{
	padding-bottom:1rem;
}
.mt-50{
	margin-top: 3rem !important;
}

.contactBtn {
    font-size: 1.6rem;
}

.spOnly_res{
	display:block !important;
}

.pb50{
	padding-bottom: 2rem !important;
}

.setBox{
	padding: 2rem;
}
.planBox dl{
	width: 100%;
}

.planBox dl dd .flex{
	gap: 1rem;
	flex-direction: column;
}


.planBox dl dd .subTxt{
	width: 80%;
}


	.jichitai-product-grid {
	  justify-content:center;
	  margin: 0 auto 0;
	  gap: 0;
	}
	
	.jichitai-product-card {
	  flex: 0 0 100%;
	  margin-top:3rem;
	  margin-bottom: 2rem;
	  gap : 0;
	}
	
	.jichitai-lineup-heading {
	  font-size: 1.8rem;
	  line-height:1.4;
	}

.jichitai-product-sub{
	font-size: 1.8rem;
	line-height: 1.4;
	margin-bottom: 1rem;
	text-align:center;
}

.jichitai-product-card img{
	max-width: 100%;
	max-height: 200px;
	width: auto;
}
.planTxt{
	font-size: 1.6rem;
}

.pro-list li{
	font-size:15px;
}
.jichitai-lineup-container .hTit{
	font-size: 1.8rem;
	line-height: 1.4;
}

.rearegi-section{
	padding: 0;
}
.rearegi-section .flex{
	flex-direction: column;
	gap: 1rem;
}
.rearegi-section .subTxt{
	width: 100%;
}
.rearegi-section .senyou{
	margin: 1rem auto 0;
}



.fBox{
	flex-direction: row;
	align-items: stretch;
	gap: 0.5rem;
}
.fBox .fUl{
  gap: 5rem;
  grid-template-columns: repeat(1, 1fr);
}

.fBox .fUl li .fSet .fSub{
	font-size: 1.1rem;
	width: 100%;
}
.fBox .arrow{
	width: 60%;
	flex-direction: column;
	height:auto;
	margin: 40% 0;
}
.fBox .arrow:after{
	height: 101%;
	width: 30%;
	background: linear-gradient(180deg,rgba(244, 230, 179, 1) 0%, rgba(228, 188, 40, 1) 100%);
}
.fBox .arrow li:last-child::after{
	content:"\f0d7";
	font-family: Font Awesome\ 5 Free;
	font-style: normal;
	font-weight: 900;
	color:#E4BC28;
	font-size: 15.6vw;
	position:absolute;
	right: calc(50% - 5vw);
	bottom: calc(50% - 17vw );
}

.fBox .arrow li dl{
	width: 100px;
	padding: 0.5rem;
}
.fBox .arrow li dl dt{
	font-size:1.2rem;
}
.fBox .arrow li dl dd{
	font-size:1rem;
}

.syukeiFlex{
	flex-direction:column;
	padding: 0 2rem;
	margin: 0 auto 3rem;
}
.syukeiFlex img{
	width:100%;
}
.syukeiH{
	width:90%;
}

	.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;
	}

}

  @media (max-width: 480px) {
	.hero-inner {
	  padding: 20px 15px 30px;
	}
	
	.badge {
	  width: 80px;
	  height: 70px;
	  font-size: 14px;
	}
	
	.title {
	  font-size: 36px;
	}
	
	.sub {
	  font-size: 16px;
	}
	
	.features li {
	  font-size: 14px;
	}
	
	.staff-image {
	  width: 200px;
	}
	
	.medal {
	  width: 70px;
	}
	
	.set-label {
	  flex: 0 0 100px;
	  font-size: 14px;
	}
	
	.set-items li {
	  font-size: 12px;
	  padding: 6px 0;
	  	  height: 4rem;
	  display: flex;
	  align-items: center;
	  justify-content: center;
	}
	
	.price-num .num {
	  font-size: 46px;
	}
	
	.price-num .yen {
	  font-size: 32px;
	}
	
	.price-num .tax-note {
	  font-size: 12px;
	}




}
  /*  */
/*---印刷用---*/

@media print {
	form#mail_form {
		display: flex;
		flex-wrap: wrap;
	}

}
.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;
}
.infobox{display: flex;
	width: 100%;
	padding: 15px 10px;
}
.oshirase_box > div:nth-of-type(2) div:first-of-type {
	margin: 0 30px 0 0;
}