:root{

	--def_color_bg:   #fffff5; /* 基本背景色 */
	--def_color_text: #212529; /* 基本文字色 */
	--def_color_border: #ffaa00; /* 基本Border色 */
	
	--color_y: #feea00;
	--color_w: #fff;
}


*{
	font-family: メイリオ, Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Noto Sans JP", sans-serif;
	overflow-wrap: break-word;

	color: var(--def_color_text);

	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	text-decoration: none;
	text-align: left;
	border: none;
	border-spacing: 0px;
	border-collapse: collapse;
	margin: 0px;
	padding: 0px;
	outline: none;
	line-height: 130%;
	letter-spacing: 0.1em;
	white-space: normal;
	list-style: none;

	font-size-adjust: 100%;
	-webkit-font-size-adjust: 100%;
	text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	
	overflow-wrap: anywhere;

	word-break: auto-phrase;
    box-sizing: border-box;

}
.serif {
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

html, body{
	background-color: var(--def_color_bg);
}
img{
	vertical-align:middle;
	width: 100%;
	height: auto;
}
a,a:link{
/*	color: ;*/
}
a:visited{
/*	color: ;*/
}
a[href]:hover{
	text-decoration: underline;
}
a[href]:has(img):hover {
    text-decoration: none;
}
a{
	cursor: pointer;
	color: var(--def_color_border);
}
label{
	cursor: pointer;
}

.w80{
	width: 80vw;
	margin: auto;
}
section.contact .email button{
    margin: 3vw auto;
}

.button{
    color: var(--color_w);
    background-color: var(--def_color_border);
    padding: 10px 30px;
    border-radius: 6px;
    display: inline-block;
	cursor: pointer;
}
a[href].button:hover{
    text-decoration: none;
}
h3.title{
    padding: 20px 0;
	color: var(--color_w);
	font-size: 2rem;
	text-align: center;
	background-color: var(--def_color_border);
}

.under_orenge{
    position: relative;
    border-bottom: 1px solid #ccc;
	font-size: 150%;
	padding-bottom: 10px;
}
.under_orenge:after{
	content: ".";
    line-height: 0;
    display: block;
    overflow: hidden;
    position: absolute;
    bottom: -1px;
    width: 30%;
    border-bottom: 5px solid #ffaa00;
}
.required-srt{
font-size: 8pt;
    padding: 5px;
    background: #fa918d;
    color: #fff;
    border-radius: 3px;
    margin-left: 10px;
    vertical-align: middle;
}

.hr{
	display: none;
}

/********************
 * default_about
********************/
section.about p.message1{
	text-align: center;
    font-size: 250%;
    line-height: 200%;
    margin: 3vw;
}
section.about p.message2{
	background: #f69483;
    color: var(--color_w);
    text-align: center;
    padding: 3vw;
    font-size: 200%;
}
section.about p.message2 i{
	font-size: 100%;
	color: var(--color_w);
}

section.about .support h4{
	text-align: center;
}
section.about .support img{
	width: 50%;
}
section.about .support p{
	    margin: 1vw 0
}
section.about .support .box{
	background: #f5f4d0;
	padding: 2vw;
}
section.about .support .box strong{
	    color: #f69483;
	    font-size: 150%;
    font-weight: 900;
}
section.about .support ol li{
    list-style: decimal inside;
	    background: #70ca30;
    color: var(--color_w);
    padding: 1vw;
    font-weight: 900;
    font-size: 120%;
    border-radius: 10px;
	margin: 1vw 0;
}
section.about .items{
	margin-top: 3vw;
	text-align: center;
}
section.about .items div{
	text-align: center;
}
section.about .items h4{
	background: #f6ab00;
    color: var(--color_w);
    text-align: center;
    padding: 3vw;
    font-size: 200%;
}
section.about .items h4 i{
	font-size: 100%;
	color: var(--color_w);
}
section.about .items p{
	margin: 2vw 0;
}
section.about .items figure{
	text-align: center;
}
section.about .items figure img{
	width: 44%;
	padding: 3%;
}



section.about .store{
	margin-top: 3vw;
	text-align: center;
	margin-bottom: 3vw;
}
section.about .store div{
	text-align: center;
}
section.about .store h4{
	background: #a0cc63;
    color: var(--color_w);
    text-align: center;
    padding: 3vw;
    font-size: 200%;
}
section.about .store h4 i{
	font-size: 100%;
	color: var(--color_w);
}
section.about .store img{
	width: 44%;
	    margin: 2vw 0;

}
section.about .store iframe{
	width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
}

/********************
 * default_news
********************/
section.news span.red{
	color: #cf2e2e;
}
section.news span.under_line{
	background: linear-gradient(transparent 60%, rgba(6, 147, 227, 0.7) 0);
}
section.news b{
	font-weight: 900;
}


section.news a.tag{
	background-color: #999;
	color: var(--color_w);
	padding: 6px 9px;
	display: inline-block;
	border-radius: 6px;
	margin: 3px;
}
section.news .article{
	display: inline-block;
    width: 70%;
	margin-top: 3vw;
}
section.news .article li{
	padding-bottom: 1vw;
    border-bottom: 1px solid #ccc;
    margin: 1vw 0;
}
section.news .article div.title{
	padding-top: 1vw;
}

section.news nav.tag{
	display: inline-block;
    width: 27%;
    vertical-align: top;
	margin-top: 3vw;
	margin-left: 3%;
}
section.news nav.tag li{
	margin: 1vw 0;
}


section.news nav.paging{
    margin-top: 2vw;
	margin-bottom: 2vw;
}

section.news nav.paging ul{
	text-align: center;
}
section.news nav.paging li{
	display: inline-block;
    border: 1px solid #ccc;
    padding: 10px 15px;
}
section.news nav.paging li.active{
	background-color: var(--def_color_border);
}
section.news nav.paging li.active span{
	color: var(--color_w);
}

section.news_topic .article .title{
	    font-size: 200%;
    margin: 1vw 0;
}
section.news_topic .article .body{
	line-height: 250%;
    font-size: 110%;
	margin-bottom: 3vw;
}
section.news_topic .article .body img{
	margin: 1vw 0;
}



/********************
 * default_ontact
********************/
section.contact article{
	padding: 3vw 0;
}
section.contact i.fas{
	color: var(--def_color_border);
	font-size: 150%;
	vertical-align: middle;
}
section.contact .tel a{
	font-size: 200%;
	display: inline-block;
	margin-bottom: 1vw;
}
section.contact .tel div{
	border: 1px solid #ccc;
	background-color: var(--color_w);
	padding: 2vw;
	margin-top: 1vw;
}
section.contact fieldset{
	text-align: center;
}
section.contact .email legend{
	width: 100%;
	margin-bottom: 1vw;
}
section.contact .email .form-group{
	border: 1px solid #ccc;
}
section.contact .email .form-group + .form-group{
	border-top:none;
}
section.contact .email .form-label{
	display: inline-block;
	padding: 1vw;
	width: 250px;
	vertical-align: top;
}
section.contact .email .form-input{
	    display: inline-block;
		padding: 1vw;
		width: 70%;
}
section.contact .email .form-input input[type="text"],
section.contact .email .form-input input[type="tel"],
section.contact .email .form-input input[type="email"],
section.contact .email .form-input textarea
{
	width: 100%;
	border: solid 1px #ccc;
    padding: 3px;
    border-radius: 3px;
}
section.contact .email button{
    margin: 3vw auto;
}

/********************
 * default_medicine
********************/

/* -----------------------------------
   3. 商品カード
----------------------------------- */
.medicine-item {
    /* まずはスマホ向けの表示（縦積み） */
    display: flex;
	flex-direction: row; /* PCでは横並び（ロウ） */
	gap: 40px;               /* PC画面では画像とテキストの隙間を広めにとる */
    margin-bottom: 40px;    /* 次の商品との隙間 */
    padding-bottom: 40px;
    margin-top: 40px;    /* 次の商品との隙間 */
    padding-top: 40px;
    border-bottom: 1px solid #e0e0e0; /* 区切り線 */	
        align-items: flex-start; /* 上端で揃える */
}

/* --- 画像エリア --- */
.medicine-image {
    margin: 0;       /* figure標準の余白をリセット */
        width: 320px;   /* PCでは画像エリアの幅を固定する */
    text-align: center;
        flex-shrink: 0; /* 画面が狭くなっても画像を潰さない（縮小させない）という絶対死守の命令 */
}

.medicine-image img {
    width: 100%;
    max-width: 320px; /* 画像が大きくなりすぎないように制限 */
    height: auto;     /* 先ほどのレッスン通り、比率を保つ！ */
}

/* --- テキストエリア --- */
.medicine-content {
    flex: 1; /* 余ったスペースをすべて使い切る指示 */
}

.medicine-content h4 {
    margin: 0 0 10px 0;
    font-size: 1.5rem;
    color: #333;
}

/* --- カテゴリバッジ --- */
.category-badge {
    display: inline-block;
    background-color: #fce4e4; /* 薄い赤（デザインに合わせて変更してください） */
    color: #d32f2f;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: bold;
    margin-bottom: 15px;
}

.medicine-content p {
    line-height: 1.8;
    color: #555;
    margin: 0;
}



/********************
 * default_access
********************/
section.access div.rows{
	padding: 3vw;
}
section.access img{
	width:60%;
}
section.access p{
	width: 37%;
	margin-left: 3%;
	vertical-align:middle;
	display: inline-block;
	line-height: 200%;
}


/********************
 * default_default section.main
********************/
section.main{
	background: var(--color_y);
	text-align: center;
}
section.main img{
	
}
/********************
 * default_default section.main_news
********************/
section.main_news{
	text-align: right;
}
section.main_news ul{
	margin-top: 20px;
    margin-bottom: 20px;
    border: 1px solid #ccc;
    padding: 11px 10px;
    background-color: var(--color_w);
    border-radius: 6px;
}

section.main_news span.title{
	margin-left: 20px;
}

#news span.date{
	background-color: #999;
/*    opacity: .6;*/
    color: var(--color_w);
    padding: 6px 12px;
    border-radius: 6px;
	display: inline-block;
	margin-bottom: 9px;
    margin-top: 9px;
}

/********************
 * default_default section.main_info
********************/
section.main_info{
}
section.main_info article.greetings{
	text-align: center;
	overflow: auto;
}
section.main_info article.greetings img{
	width: 50%;
	float: left;
}
section.main_info article.greetings p{
	padding: 30px;
	display: inline-block;
	width: 50%;	
}
section.main_info a.sokuteikai{
    background-color: #36c;
    padding: 2vw;
    text-align: center;
    display: block;
    margin-bottom: 2vw;
    margin-top: 2vw;
    border-radius: 30px;
    line-height: 100%;
    text-decoration: none;
}
section.main_info a.sokuteikai i.big{
    color: var(--color_w);
    font-size: 333%;
	vertical-align: text-bottom;
    font-weight: 900;
}
section.main_info a.sokuteikai i.small{
    color: var(--color_w);
    font-size: 150%;
    vertical-align: top;
    font-weight: 900;
}
section.main_info table.picup{
	border: solid 3px #009245;
	margin: 3vw 0;
	width: 100%;
}
section.main_info table.picup th{
	background-color: #009245;
	color: #fff;
	font-size: 200%;
	text-align: center;
	padding: 1vw;
	font-weight:900;
}
section.main_info table.picup td.img{
	padding: 2vw 6vw 2vw 2vw;
	width:40%;
	border: none;
}
section.main_info table.picup td.text{
	vertical-align: top;
	padding-top: 1vw;
	border: none;
	vertical-align: middle;
}
section.main_info table.picup td.text strong{
	font-size: 130%;
	font-weight:900;
}
section.main_info table.picup td.text b{
	color: #ED1C24;
    font-size: 100%;
	font-weight:900;
}
section.main_info table.picup td.text div{
	text-align: center;
	font-size: 120%;
	margin-top: 2vw;
}
section.main_info table.picup td.text a{
	border: solid 6px #8CC63F;
	padding: 2vw;
	margin: 2vw;
	text-align: center;
	font-weight: 900;
	border-radius: 9px;
	display: block;
	color: black;
	font-size: 124%;
}
section.main_info iframe.youtube{
	width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
}
section.main_info a.syohousen{
	display: inline-block;
	width: 100%;
	border: 3px solid #09c;
	padding: 6px;
	border-radius: 6px;
	transition: opacity 0.5s ease;

}
section.main_info a.syohousen:hover{
	opacity: 0.6;
}

section.main_info table.info{
	width: 100%;
	border: solid 3px #FF9900;
	margin-top: 3vw;
}
section.main_info table.info th{
	background-color: #FF9900;
	color: #fff;
	font-size: 200%;
	text-align: center;
	padding: 1vw;
}
section.main_info table.info td{
	text-align: center;
}
section.main_info table.info td strong{
	font-size: 130%;
	text-align: center;
	line-height: 270%;
	font-weight: 900;
}
section.main_info table.kit{
	width: 100%;
	border: solid 3px #1F2A67;
	margin-top: 3vw;
}
section.main_info table.kit th{
	background-color: #1F2A67;
	color: #fff;
	font-size: 200%;
	text-align: center;
	padding: 1vw;
}
section.main_info table.kit td{
	text-align: center;
	font-size: 150%;
	line-height: 200%;
}
section.main_info table.covid{
	width: 100%;
	border: solid 3px #FF0000;
	margin-top: 3vw;
}
section.main_info table.covid th{
	background-color: #FF0000;
	color: #fff;
	font-size: 200%;
	text-align: center;
	padding: 1vw;
}
section.main_info table.covid td{
	text-align: center;
	font-size: 150%;
	line-height: 200%;
}
section.main_info table.covid td a{
	font-size: 230%;
	text-align: center;
	display: inline-block;
	font-weight: 900;
}



section.main_info div.taisei{
	border: 5px solid #c3c2c2;
	padding: 2vw 2vw;
	background-color: #fff;
	margin-top: 3vw;
}
section.main_info div.taisei strong{
	font-weight: 900;
	font-size: 25px;
	text-decoration: underline;
	text-decoration-color: #f5a517;
	text-decoration-thickness: 3px;
	text-align: center;
	display: block;
}
section.main_info div.taisei li{
	list-style-type: disc;
	margin: 20px 0 0 20px;
}
section.main_info div.president{
	margin-top: 3vw;
	display: inline-block;

}

section.main_info h3{
	background: linear-gradient(transparent 60%,rgba(255, 255, 0, 0.7) 0);
	font-size: 250%;
	margin-bottom: 1vw;
	display: inline-block;
}
section.main_info .president figure{
	width: 50%;
	display: inline-block;
}
section.main_info .president figure img{
}
section.main_info .president figure figcaption{
	font-size: 150%;
	text-align: center;
}
section.main_info .president p{
	width: 50%;
	display: inline-block;
	padding: 2vw;
	vertical-align: top;
}


section.main_info .dx{
	margin-top: 3vw;
}
section.main_info .dx figure{
	width: 50%;
	display: inline-block;
}
section.main_info .dx figure img{
}
section.main_info .dx ul{
	width: 50%;
	display: inline-block;
	padding: 2vw;
	vertical-align: top;
}
section.main_info .dx ul li{
	list-style-type: disc;
	margin: 20px 0 0 20px;
}

section.main_info .denshi{
}
section.main_info .denshi img{
	width: 44%;
	display: inline-block;
	margin: 3%;
}



section.main_info div.youtube{
	margin-top: 3vw;
	margin-bottom: 3vw;
	background-color: #ffe9ef;
	padding: 3vw;
}
section.main_info div.youtube img{
	width: 50%;
	vertical-align: top;
}
section.main_info div.youtube div.ch{
	width: 50%;
	display: inline-block;
	vertical-align: top;
	text-align: center;
	margin-top: 1vw;
}
section.main_info div.youtube div.ch strong{
	font-size: 150%;
	display: inline-block;
}
section.main_info div.youtube div.ch p{
	text-align: center;
	margin: 1vw;
}
section.main_info div.youtube div.ch a{
	display: inline-block;
	background-color: #fcb900;
	color: #fff;
	padding: 40px;
    font-size: 200%;
	font-weight: 900;
}

/********************
 * default_default section.main_about
********************/
section.main_about{
	padding: 3vw;
	text-align: center;
	background: #feea00;
}
section.main_about a{
	display: inline-block;
	margin: 0 10px;
	transition: opacity 0.5s ease;
}
section.main_about a:hover{
	opacity: 0.6;
}


/********************
 * default_default section.main_item
********************/
section.main_item{
	padding: 3vw;
}
section.main_item h3{
	padding-bottom: 8px;
}

section.main_item a{
	display: inline-block;
	margin: 1%;
	width: 23%;
	transition: opacity 0.5s ease;
	vertical-align: top;
}
section.main_item a:hover{
	opacity: 0.6;
}
section.main_item a figcaption{
	text-align: center;
	margin-top: 15px;
}


/********************
 * default_default section.main_link
********************/
section.main_link{
	padding: 1vw;
	text-align: center;
	border-top: 3px solid #808080;
}
section.main_link a{
	display: inline-block;
	width: 23%;
	margin: 1%;
	transition: opacity 0.5s ease;
}
section.main_link a:hover{
	opacity: 0.6;
}

/********************
 * header
********************/
header{
    border-bottom: var(--def_color_border) 12px solid;
	box-shadow: 0 3px 3px rgba(0, 0, 0, .1);
	position: relative;
}
header, header *{
	background-color: var(--color_w);
}

header h1{
	width: 12vw;
	margin: 1vw;
	display: inline-block;
	vertical-align:middle;
}
header a.logo{
	display: inline-block;
	transition: opacity 0.5s ease;
}
header a.logo:hover{
	opacity: 0.6;
}

header div.right{
    width: 70%;
    display: inline-block;
    margin-left: 1vw;
	vertical-align:middle;
}
header div.right address{
	padding-bottom: 6px;
}
header div.right a{
	font-size: 150%;
}
header div.right a i{
	color: var(--def_color_border);
	font-size: 110%;
}

header h2{
    padding-bottom: 18px;
}

header nav{
border-top: #eee 1px solid;
    padding: 6px 0;
}

header ul li{
	display: inline-block;
	width: 20%;
	text-align: center;
	border-right: 1px #ccc solid;
	position: relative;
}

header ul li::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px; /* 線の位置を調整します */
  width: 0; /* 最初は線の長さをゼロにします */
  height: 1px; /* 線の太さ */
  background-color: #f90; /* 線の色 */
  transition: width 0.6s ease; /* 左から右に伸びる時間を設定します */
}

header ul li:hover::after {
  width: 100%; /* マウスを乗せると線が全体に広がります */
}

header ul li:first-child{
	border-left: 1px #ccc solid;
}

header ul li a{
	display: inline-block;
	padding: 21px 0;
	text-align: center;
	width: 100%;
    font-weight: 900;
	color: var(--def_color_text);
}

header ul li a[href]:hover{
    text-decoration: none;
}



/********************
 * footer
********************/

footer{
	background-color: #f9f9f9;
	border-top: var(--def_color_border) 3px solid;
	padding: 1vw 0;
	text-align: center;
}
footer div.col{
	display: inline-block;
	width: 29%;
	text-align: center;
	vertical-align: top;
	padding: 2%;
}
footer address{
	line-height: 200%;
    margin: 2vw 0;
}
footer table{
	width: 100%;
}

footer table th, footer table td{
	border: 1px solid #ccc;
	text-align: center;
	    padding: 1vw 0;
}
footer table th{
	background-color: #fff7c1;

}

footer table caption{
	font-size: 150%;
	font-weight: 900;
	margin-bottom: 1vw;
}
footer table caption i{
    font-size: 200%;
    vertical-align: sub;
    color: var(--def_color_border);
}
footer table tbody{
    border: 1px solid #ccc;
    border-bottom: 3px solid var(--def_color_border);
    border-top: 3px solid var(--def_color_border);
}

footer p{
	margin-top: 2vw;
}

footer ul{
}
footer ul li{
	padding: 1vw 0;
	border-bottom: 1px solid #ccc;
}
footer ul li span{
	color:#d44950;
	padding-right: 1vw;
}

footer small{
	display: block;
	margin-top: 2vw;
	text-align: center;
	border-top: #ccc 1px solid;
	padding: 2vw 0 1vw 0;
}

footer iframe{
	width:100%;
	aspect-ratio: 1/1;
	height: auto;
}

/********************
 * fix
********************/
div.fix{
	position: fixed;
	width: 100%;
	z-index: 10;

	right: 0;
	bottom: 0;
	width: 10%;
	margin: 1%;
}
