@charset "utf-8";
/*
Theme Name: 株式会社株式会社東興商事
Theme URI: https://www.tohko-shoji.com/
Description: 株式会社株式会社東興商事のテーマです
*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video,input,select,textarea {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	box-sizing: border-box;
	letter-spacing:1px;
    font-weight: 400;
	font-family: Oswald, 'Noto Sans JP', sans-serif;
	line-height:2;
}

header::after, footer::after, section::after, article::after, aside::after, div::after, dl::after, ul::after {
	content:none !important;
}

body {
	overflow:hidden;
	color:#111;
    font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
	box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6, p, dl, li, span, small, strong, b, a, dt, dd {
    font-size: 1em;
}

html {
	overflow-y: scroll;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	scroll-behavior:smooth;
}

section {
}

blockquote, q {
	quotes: none;
	box-sizing: border-box;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
	box-sizing: border-box;
}
 input, textarea, {
 margin: 0;
 padding: 0;
 box-sizing:border-box;
}
ul {
	list-style: none;
	box-sizing: border-box;
}
ol {
	box-sizing: border-box;
	margin-left:2rem;
}
table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	box-sizing: border-box;
}
table th,
table td,
.wp-block-table td,
.wp-block-table th {
	padding:1.5rem 2rem;
}

caption, th {
	text-align: left;
	box-sizing: border-box;
}
a:focus {
	outline: none;
}
header:after, footer:after, section:after, article:after, aside:after, div:after, dl:after, ul:after {
	content : "";
	display : block;
	height : 0;
	clear : both;
}
br {
	letter-spacing: 0;
}
img {
	width: auto;
	height:auto;
	max-width:100%;
	border: 0;
	vertical-align: bottom;
	box-sizing: border-box;
	vertical-align: top;
}
.clear {
	clear: both;
}


html{
    font-size: 62.5%;
}
body{
    font-size:1.6rem;/* 16px*/
    line-height: 1.6;
    animation: BgfadeIn 2s ease 0s 1 normal;
    -webkit-animation: BgfadeIn 2s ease 0s 1 normal;
	background: url(../../images/bg_ptn01.jpg) repeat;
}

@keyframes BgfadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes BgfadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}


@media (max-width: 768px){
table th, table td,
.wp-block-table td, .wp-block-table th {
    padding: 1rem;
	letter-spacing:0;
    font-size: 0.95em;
	vertical-align:middle;
}
}

/*文字色のスタイル*/
a:link, a:visited {
	text-decoration: none;
	overflow: hidden;
}

#header nav#nav a:link,#header nav#nav a:visited, 
#footer a:link,#footer a:visited {
	color:#333;
}

a:hover {
	text-decoration: none;
}

/*boxのスタイル*/
.box1200 {
	display:block;
    clear: both;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
}

.base {
}

@media (max-width:1280px) {
.base {
	padding-left:1.5rem;
	padding-right:1.5rem;
}
}

@media (max-width:768px) {
.base {
	padding:0 2rem;
}
}

/* 表示・非表示*/
.pc_none {
	display:none;
}

@media (max-width: 980px){
.pc_none {
	display:block;
}
.sp_none {
	display:none;
}
}

/*パン屑のスタイル*/
#breadcrumb {
	width:100%;
	padding:1.5rem;
	background:#FAFAFA;
}

#breadcrumb ul {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	list-style:none;
}

#breadcrumb ul li {
	margin-right:0.5rem;
	letter-spacing:0;
	font-size:1.4rem;
}

#breadcrumb ul li:nth-child(1):before {
    content: "\f015";
    font-family: FontAwesome;
    margin-right:0.5rem;
}

#breadcrumb ul li a {
	color:#333;
}

#breadcrumb ul li:after {
    content: "\f105";
    font-family: FontAwesome;
    margin-left:0.5rem;
}

#breadcrumb ul li:last-child:after {
	content:none;
}

@media (max-width: 768px){
#breadcrumb {
	padding:1rem 10px;
	font-size:0.55em;
	letter-spacing:0;
}

#breadcrumb ul li {
	margin-right:0.25rem;
	font-size:1rem;
}

#breadcrumb ul li:after {
    margin-left:0.25rem;
}
#breadcrumb ul li a {
}

}

/*改行消す*/
@media (max-width: 768px){
.br_none br {
	display:none;
}
}


/*hoverのスタイル*/ 
.fade {
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
	-ms-transition: 0s ease-in-out;
}

.fade:hover,
.fadein.fade:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
}

.fadein {
	opacity: 0;
	-webkit-transform: translate(0, 50px);
	transform: translate(0, 50px);
	transition: all 0.5s;
}

.fadein-left {
	opacity: 0;
	-webkit-transform: translate(-50px, 0);
	transform: translate(-50px, 0);
	transition: all 0.5s;
}

.fadein-right {
	opacity: 0;
	-webkit-transform: translate(50px, 0);
	transform: translate(50px, 0);
	transition: all 0.5s;
}

.fadein.scrollin,
.fadein-left.scrollin,
.fadein-right.scrollin {
    opacity: 1;
  -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}


@keyframes SlideUp {
0% {
    opacity: 0;
    transform: translateY(50px);
}
100% {
    opacity: 1;
    transform: translateY(0);
}
}


/*scaleのスタイル*/
.scale {
	overflow: hidden;
}
.scale img {
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
	-ms-transition: 0s ease-in-out;
}
.scale img:hover {
	webkit-transform: scale(1.08);
	-moz-transform: scale(1.08);
	-o-transform: scale(1.08);
	-ms-transform: scale(1.08);
	transform: scale(1.08);
}

/*装飾*/
.bottom10 {	margin-bottom:1rem;}
.bottom15 {	margin-bottom:1.5rem;}
.bottom20 {	margin-bottom:2rem;}
.bottom30 {	margin-bottom:3rem;}
.bottom40 {	margin-bottom:4rem;}
.bottom45 {	margin-bottom:4.5rem;}
.bottom50 {	margin-bottom:5rem;}
.bottom60 {	margin-bottom:6rem;}
.bottom75 {	margin-bottom:7.5rem;}
.bottom90 {	margin-bottom:9rem;}
@media (max-width: 768px){
.bottom10 {margin-bottom:0.5rem;}
.bottom15 {	margin-bottom:1rem;}
.bottom20 {	margin-bottom:1rem;}
.bottom30 {	margin-bottom:1.5rem;}
.bottom40 {	margin-bottom:1.5rem;}
.bottom45 {	margin-bottom:2rem;}
.bottom50 {	margin-bottom:2.5rem;}
.bottom60 {	margin-bottom:3rem;}
.bottom75 {	margin-bottom:3.5rem;}
.bottom90 {	margin-bottom:4.5rem;}
}

/*共通*/
#wrapper {
	background:url(../../images/logo_large.png) no-repeat left 3rem bottom 3rem;
	background-attachment:fixed;
	background-size:43%;
}

#header {
	width:100%;
	max-width:1480px;
	margin-left:auto;
	margin-right:auto;

	position:fixed;
	z-index:5;

	top:50%;
	transform:translateY(-50%);

	/* コンテナ中央合わせ */
	left:50%;
	transform:translate(-50%,-50%);
}

/* 左ブロック */
#header #header_inner {
	position:absolute;
	padding:2.5%;

	top: 56%;
	transform: translateY(-56%);
  
	left:0;                 /* ←ここが重要 */
	width:43.3%;
	max-width:640px;

	background: #FFF;
	border-radius:0.5rem;
	box-shadow:0 0 10px rgba(0,0,0,0.35);
}

#header #header_inner p {
	text-align:center;
	margin-bottom:2rem;
}

strong.site_copy {
	display:block;
	font-size:clamp(18px, 1.4vw, 22px);
	font-weight:700;
	margin-bottom:1rem;
	text-align:center;
	line-height:1.4;
	color:#96ae62;
}

@media (max-width: 768px) {
strong.site_copy {
	margin-bottom:2rem;
}
}


@media (min-width: 980px) {
.menu_box ul {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	margin-bottom:2.5rem;
}

.menu_box ul li {
	width:46%;
}

.menu_box ul li a {
	color:#111;
	display:block;
	padding:1.5rem;
	font-size:clamp(14px, 1.2vw, 18px);
	border-bottom:1px solid #111;
	font-weight:600;
	position:relative;
}

.menu_box ul li a:after {
	content:url(../../images/icon_arrow_bottom_bk.svg);
	position:absolute;
	right:1rem;
}

.menu_box ul li a:hover {
	color:#159ea9 !important;
}

.menu_box ul li a:hover:after {
	content:url(../../images/icon_arrow_bottom_blue.svg);
}

.menu_box ul li.current-menu-item a {
	color:#159ea9 !important;
}

.menu_box ul li.current-menu-item a:after {
	content:url(../../images/icon_arrow_bottom_blue.svg);
}
.menu_box ul li.menu-item-623 a {
	color:#111 !important;
}

.menu_box ul li.menu-item-623 a:hover {
	color:#159ea9 !important;
}

.menu_box ul li.menu-item-623 a:after {
	content:url(../../images/icon_arrow_bottom_bk.svg);
}

.menu_box ul li.menu-item-623 a:hover:after {
	content:url(../../images/icon_arrow_bottom_blue.svg) !important;
}

}

.sns_btn {
	position:absolute;
	right:60px;
	top:0;
	width:60px;
}

/* 全体 */
#news_box{
    display:flex;
    gap:15px;
    align-items:flex-start;
	margin-bottom:2.5rem;
	padding:1.5rem;
	background:#f5f5f5;
    flex-wrap:wrap; /* 小さい画面で折り返し対応 */
}

/* 見出し */
#news_box h2{
}

/* NEWS文字 */

#news_box h2 a {
    flex: 0 0 64px;
    aspect-ratio: 1/1;
    border: 1px solid #000;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    background: #FFF;
    min-width: 60px; /* 小さい画面でも潰れない */
    color: #111;
    transition: color 0.3s ease, border-color 0.3s ease; /* 色の変化を滑らかに */
}

#news_box h2 a:hover {
    color: #159ea9;       /* 文字色 */
    border-color: #159ea9; /* 線の色 */
}

#news_box h2 span{
    font-weight:700;
    letter-spacing:2px;
    text-align:center;
}

/* リスト */
#news_box ul {
    flex:1;
    list-style:none;
    margin:0;
    padding:0;
	max-height: 60px;
	overflow: auto;
}

/* li 横並び */
#news_box li {
    display:flex;
    gap:10px;
    flex-wrap:wrap; /* 日付・タイトル折り返し対応 */
    margin-bottom: 0.25rem;
    align-items:center;
}

/* 日付 */
#news_box .date{
    flex:0 0 auto;
	line-height:1.4;
    min-width:60px; /* 狭い画面でも潰れない */
}

/* small カテゴリーラベル */
#news_box small {
	line-height:1.4;
}

#news_box small a {
	line-height:1.4;
	font-size:0.7em;
	display:inline-block;
	padding:0.2rem 0.25rem 0.45rem 0.25rem;
	background:#159ea9;
	color:#FFF !important;
	border-radius:5px;
	letter-spacing:0;
	position: relative;
	top: 2px;
}

/* リンク */
#news_box li a {
    text-decoration:none;
	line-height:1.4;
	color:#111;
    word-break: break-word; /* 長いタイトルも折り返す */
}

#news_box li a:hover {
	color:#159ea9;
}

/* レスポンシブ */

@media (max-width:1280px){
li{
	gap:5px;
}
}

@media (max-width:768px){
#news_box {
	width:calc(100% - 3rem);
	margin-bottom:4.5rem;
	margin-left:auto;
	margin-right:auto;
}

#news_box ul {
	max-height:60px;
	overflow:auto;
}

#news_box li > a {
	position:relative;
	display:inline-block;
	margin-top:-0.75rem;
}

#news_box li {
	margin-bottom:1rem;
}

}

#bottom_info dl dd {
	line-height:1.6;
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	-webkit-justify-content: space-between;
	justify-content: space-between;
    align-items: flex-end;
}

#bottom_info .base_lp dl {
	padding-top:6rem;
	border-top:1px solid #DDD;
}

#bottom_info dl dt {
	margin-bottom:1rem;
}

#bottom_info dl dd .box_left {
	width:55.8%;
}

#bottom_info dl dd .box_left p {
	letter-spacing:1px;
}

#bottom_info dl dd .box_right {
	width:41.5%;
}

#bottom_info dl dd .box_right a {
	display:block;
	padding:1rem 2rem;
	border:1px solid #159ea9;
	color:#159ea9;
	border-radius:5px;
	text-align:center;
	position:relative;
	transition: transform .35s cubic-bezier(.34, 1.56, .64, 1);
}

#bottom_info dl dd .box_right a:hover {
	transform: translateY(-8px);
}

#bottom_info dl dd .box_right a:after {
	content:url(../../images/icon_arrow_circle_green.svg);
	position:absolute;
	right:2rem;
    top: 1.35rem;
	display:inline-block;
}

@media (max-width:768px){
#bottom_info .base_lp dl {
}

#bottom_info dl dd {
	display:block;
}

#bottom_info dl dd .box_left {
	width:100%;
	margin-bottom:1.5rem;
}

#bottom_info dl dd .box_right {
	width:100%;
}

#bottom_info dl dd .box_right a::after {
}

}

.contact_box {
	margin:0 auto;
	width:100%;
}

.contact_box ul {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	-webkit-justify-content: center; /* 横方向中央揃え（Safari用） */
	justify-content: center; /* 横方向中央揃え */
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.contact_box ul li:nth-child(1) {
	width:55.8%;
}

.contact_box ul li:nth-child(2) {
	width:41.5%;
}

#main .contact_box {
	padding-top:4.5rem;
	padding-bottom:9rem;
	width:100%;
}

/* mainコンテナ */
#main {  
	max-width:1480px;
	margin:0 auto;
	box-sizing:border-box;
}

/* 右ブロック */
#primary {
	width:54.1%;
	max-width:800px;

	margin-left:auto;      /* 右寄せ */
	position:relative;

	box-shadow:0 0 10px rgba(0,0,0,0.35);
	background:#fff;
}

.base_lp {
	padding:0 3rem;
}

#main_slide {
	position:relative;
}

#main_slide:before {
  content: "";
  display: block;
  background: rgba(0,0,0,0.5);
  width: 100%;
  height: 835px;
  position: absolute;
  top: 0;
  z-index:1;
}

#main_slide span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto;
    display: inline-block;
	width:96%;
	z-index:2;
}

#main_slide span img {
	max-width:inherit;
	width:100%;
	height:auto;
}

@media (max-width: 980px) {
#main_slide {
	margin-bottom:4.5rem;
}

#news_box {
	width:calc(100% - 3rem);
	margin-bottom:4.5rem;
	margin-left:auto;
	margin-right:auto;
}

}

@media (max-width: 768px) {
#main_slide {
	margin-bottom:4.5rem;
	height:720px;
}
}

@media (max-width: 480px) {
#main_slide {
	height:520px;
	margin-bottom:4.5rem;
}
}

#lp_contents02 h2,
#lp_contents03 h2,
#lp_contents04 h2,
#lp_contents05 h2,
#lp_contents06 h2 {
	text-align:center;
	font-size:clamp(24px, 3.6vw, 42px);
	font-weight:900 !important;
	margin-bottom:4.5rem;
	color:#159ea9;
	letter-spacing:3px;
}

#lp_contents02 h2 {
    display:flex;
    align-items:center;
    justify-content:center;
}

#lp_contents02 h2:before,
#lp_contents02 h2:after {
    content:"";
    flex:1;
    height:2px;
    background:#159ea9;
}

/* 文字と線の間隔 */
#lp_contents02 h2:before {
    margin-right:20px;
}

#lp_contents02 h2:after{
    margin-left:20px;
}

#lp_contents03 h2:after {
	content:"";
	display:block;
	width:45px;
	height:2px;
	background:#159ea9;
	margin:1rem auto 0 auto;
}

#footer {
	padding-top:6rem;
	padding-bottom:6rem;
	padding-left:2rem;
	padding-right:2rem;
	background:#159ea9;
}

#footer ul {
	width:60%;
	margin:0 auto 3rem;
}

#footer ul li a {
	color:#FFF !important;
	display:block;
	border-bottom:1px solid #FFF;
	padding:1.5rem 0;
	text-align:center;
	font-size: 14px;
}

#footer small {
	display:block;
	color:#FFF;
	text-align:center;
	font-size:14px;
}

@media (max-width: 1650px) {
#wrapper {
	padding-left:4.5rem;
	padding-right:4.5rem;
}

#header #header_inner {
	left:4.5rem !important;
	width: 40.3%;
}

.menu_box ul li {
	width:48%;
}
}

@media screen and (max-width:1280px){
#primary {
  width: 56.3%;
}

.base_lp {
  padding-left:1.5rem;
  padding-right:1.5rem;
}

#header #header_inner {
	width: 36%;
}

#header #header_inner p strong {
	letter-spacing:0.5rem;
	margin-bottom:0.5rem;
}

.menu_box ul li {
	width:100%;
}

.contact_box {
	width:100%;
}
}


/* 980px以下 */
@media screen and (max-width:980px){
#wrapper {
	padding-left: 0;
	padding-right: 0;
	padding-top: 0;
	padding-bottom:4.5rem;
}

#header {
	position:inherit;
	top:inherit;
	left:inherit;
	transform:none;
	height:60px;
}

#header #header_inner {
    width: 100%;
	margin:0 auto;
	left: inherit;
	position: inherit;
	padding: 1rem 1.5rem 1rem 1.5rem;
	top: inherit;
	transform: none;
	left: inherit;
	max-width: 100%;
	border-radius:0;
	height:60px;
}

#header #header_inner::before {
	background-size:cover;
	top: 0.5%;
}

#header #header_inner .contact_box {
	display:none;
}

#primary {
    width: 100%;
    margin: 0 auto;
}

.menu_box {
}

#lp_contents02 .base_lp,
#lp_contents03 .base_lp,
#lp_contents04 .base_lp,
#lp_contents05 .base_lp,
#lp_contents06 .base_lp {
	padding-top:6rem;
	padding-bottom:6rem;
}

#footer {
	padding-top:3rem;
	padding-bottom: 18%;
}

}



@media screen and (max-width:680px) {
#lp_contents02 h2,
#lp_contents03 h2,
#lp_contents04 h2,
#lp_contents05 h2,
#lp_contents06 h2 {
	margin-bottom:2rem;
}
}

@media screen and (max-width:980px){
#header #header_inner p img {
	max-width:150px;
}
}

@media screen and (max-width:768px){
#header #header_inner p {
	margin-bottom:0;
	text-align:left;
}

#lp_contents03 h2,
#lp_contents04 h2,
#lp_contents05 h2,
#lp_contents06 h2 {
	margin-bottom:3rem;
}

#main .contact_box  {
  padding-top: 3rem;
  padding-bottom: 6rem;
}
}

@media screen and (max-width: 480px) {
}

.gmap {}
.gmap iframe { width:100%; }

@media (max-width: 768px) {
	.gmap {	padding:0; }
}

/*pagenav*/
.pagenav {
	text-align:center;
	margin-top:4.5rem;
}

.pagenav ul {
	clear: both;
	padding: 3rem 0;
	text-align: center;
}
a.page-numbers, .pagenav .current {
	background: #fff;
	border: solid 1px #ddd;
	padding: 5px 10px;
	margin: 5px 2px;
	text-decoration: none;
}
.pagenav .current {
	background: #222222;
	border: solid 1px #094829;
	color: #fff;
}

@media (max-width: 768px) {
.pagenav ul {
	clear: both;
	padding: 2rem 10px;
	font-size:1em;
}
}

/*ページトップ
***************************************/
.scroll-btn{
	position:fixed;
	right:1.5rem;
	bottom:-150px;
	transition:bottom .3s ease;
}

.scroll-btn.show{
	bottom:1.5rem;
}

div.scroll-btn a {
	background: rgba( 204, 204, 204, 0.5);
	width: 50px;
	height: 50px;
	display: block;
	text-align: center;
	transition: .2s ease-in-out;
	-moz-transition: .2s ease-in-out;
	-webkit-transition: .2s ease-in-out;
	-o-transition: .2s ease-in-out;
	-ms-transition: .2s ease-in-out;
}

div.scroll-btn a:hover {
	background: #111;
}

div.scroll-btn a i {
	font-size: 60px;
	line-height: .8;
	color: #fff;
	opacity: .8;
	transition: .2s ease-in-out;
	-moz-transition: .2s ease-in-out;
	-webkit-transition: .2s ease-in-out;
	-o-transition: .2s ease-in-out;
	-ms-transition: .2s ease-in-out
}

div.scroll-btn a:hover i {
	color: #FFF;
	opacity: 1;
}

@media (max-width: 768px) {
.scroll-btn.show{
	bottom:9rem;
}

}

/*スマホ用コンタクトボタン
***************************************/

@media screen and (min-width:768px){
#sp_contact {
	display:none;
}
}

@media (max-width:768px) {
#sp_contact {
    position: fixed !important;
    bottom: 0;
    right: 0;
	width: 100%;
	z-index:9999;
	border-top:1px solid rgba(255,255,255,0.6);
    background: #159ea9;
	padding:0.5rem;
}

#sp_contact ul {
	position:relative;
	display:flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	gap:0.5rem;
}

#sp_contact li {
	width:calc((100% - 1rem) / 3);
}

#sp_contact li a {
	display:block;
}

}

.flex_wrapper {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
}

.flex_wrapper:after {
	content:none;
}

.jc-spc_btw {
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.jc-center {
	-webkit-justify-content: center; /* 横方向中央揃え（Safari用） */
	justify-content: center; /* 横方向中央揃え */
}

.ai-center {
	-webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
	align-items: center; /* 縦方向中央揃え */
}

.fd-row_r {
	flex-direction:row-reverse; /*逆順*/
}

/* header */

@media (max-width: 1280px) {
}

@media (max-width: 1120px) {
}

@media (max-width: 768px) {
}

@media (max-width: 768px) {
}

@media (max-width: 640px) {
}

@media (max-width: 414px) {
}

/* nav */


@media (max-width: 1120px) {
}

@media (max-width: 768px) {
}

/* footer */

#lp_contents01 {
	margin-bottom:7.5rem;
	padding-bottom:7.5rem;
	background:url(../../images/index/lp_contents01_bg.jpg) no-repeat center center;
	background-size:cover;
}

#lp_contents01 h2 {
	margin-bottom:3rem;
}

.purchase-list {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 2%;
}

.purchase-list .purchase-item {
    width: 49%;
    display: flex; /* ← これが重要 */
}

/* リンクをカード化 */
.purchase-list .purchase-item a {
    display: flex;              /* ← 高さ揃えの核 */
    align-items: center;        /* ← 縦中央 */
    width: 100%;
    text-decoration: none;
    color: #FFF;
    background: rgba(0,110,110,0.9);
    transition: all 0.3s ease;
    padding: 0.75rem 1.5rem;
    font-size: clamp(14px, 1.2vw, 16px);
    letter-spacing: -0.5px;
    line-height: 1.2;
	
	align-items:flex-start;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}

.purchase-list .purchase-item:nth-child(2n) a {
	background: rgba(8,158,170,0.9);
}

/* アイコン */
.purchase-list .purchase-item a:before {  
    content: "\f061";
    font-family: FontAwesome;
    margin-right: 0.35rem;
    color: #FFF;
}


/*.purchase-list .purchase-item:nth-child(3n) a, 
.purchase-list .purchase-item:nth-child(3n + 1) a {
    background: rgba(8,158,170,0.8);
}*/

/* hover */
.purchase-item a:hover {
    color: #fff;
}

/* スマホ */
@media screen and (max-width: 768px) {
	#lp_contents01 {
		margin-bottom:0;
	}
    .purchase-list {
        gap: 2%;
    }

    .purchase-list .purchase-item {
        width: 49%;
    }
	
	.purchase-list .purchase-item a {
    	padding: 0.5rem 0.65rem;
	}

	.purchase-list .purchase-item:nth-child(3n) a, 
	.purchase-list .purchase-item:nth-child(3n + 1) a {
    	background: rgba(0,110,110,0.8);
	}
	
	.purchase-list .purchase-item:nth-child(2n) a {
    	background: rgba(8,158,170,0.8);
	}
}




#lp_contents03 {
	margin-bottom:6rem;
}

#lp_contents03 dl dt {
	margin-bottom:1rem;
	text-align:center;
}

#lp_contents03 dl dt img {
	width:100%;
	height:auto;
}

#lp_contents03 dl dd h3 {
	text-align:center;
	margin-bottom:0.5rem;
	font-size:clamp(20px, 1.6vw, 20px);
	color:#00aebd;
	font-weight:600;
}

@media (max-width: 768px) {
#lp_contents03 {
	margin-bottom:0;
}

#lp_contents03 .base_lp {
	padding-bottom:0;
}
}

@media (max-width: 480px) {
#lp_contents03 dl.w32 {
	width:100%;
	margin-bottom:3rem;
}

#lp_contents03 dl.w32:last-child {
	margin-bottom:0;
}
}

#lp_contents04 {
	margin-bottom:6rem;
}

#lp_contents04 ul li:nth-child(1) a {
	display:block;
	background:url(../../images/index/index_flow_bg.jpg) no-repeat center center;
	background-size:cover;
	padding:9rem 2rem;
	text-align:center;
	color:#FFF;
	font-size:clamp(24px, 2.8vw, 42px);
	font-weight:700;	
}

#lp_contents04 ul li:nth-child(2) a {
	display:block;
	background:url(../../images/index/index_recruit_bg.jpg) no-repeat center center;
	background-size:cover;
	padding:9rem 2rem;
	text-align:center;
	color:#FFF;
	font-size:clamp(24px, 2.8vw, 42px);
	font-weight:700;
}

#lp_contents04 ul li a span {
	display:block;
	padding:1rem 0;
	border-top:1px solid #FFF;
	border-bottom:1px solid #FFF;
	font-weight:700;
}

@media (max-width: 768px) {
#lp_contents04 {
	margin-bottom:0;
}

#lp_contents04 .base_lp {
	padding-bottom:0;
}
}

@media (max-width: 480px) {
#lp_contents04 ul li.w49 {
	width:100%;
	margin-bottom:2rem;
}

#lp_contents04 ul li.w49:last-child {
	margin-bottom:0;
}

#lp_contents04 ul li:nth-child(1) a,
#lp_contents04 ul li:nth-child(2) a {
	padding:6rem 2rem;
}
}

#lp_contents05 {
	margin-bottom:6rem;
}

@media (max-width: 768px) {
#lp_contents05 {
  margin-bottom: 0;
}
}

#flow01 .box01 h2 {
	margin-top:0 !important;
}

#flow01 .box01:nth-child(1) {
	margin-bottom:6rem;
}

#flow01 ol {
	list-style:none;
	margin-left:0;
}

/*company*/
#company #primary iframe {
	margin-top:0 !important;
	max-width:100% !important;
}

#company #primary table td {
	vertical-align:middle;
}

#company #primary td:nth-child(1) {
	width:22%;
}

/*privacy*/
#privacy #primary .entry-content p {
	background:#F5F5F5;
	padding:3rem;
	margin-bottom:4.5rem;
}

#privacy #main ul {
	list-style:none !important;
}

#privacy #primary .entry-content dl {
}

#privacy #primary .entry-content dl dt {
	margin-bottom:1rem;
	border-left:3px solid #159ea9;
	padding-left:1rem;
	line-height:1.4;
	font-size:1.1em;
}

#privacy #primary .entry-content dl dd {
	margin-bottom:4.5rem;
	padding-left:1.3rem;
	line-height:1.8;
}

#privacy #primary .entry-content dl dd:last-child {
	margin-bottom:0;
}

#privacy #primary .entry-content dl dd table {
	width:100%;
	margin:2rem auto 0 auto;
}

#privacy #primary .entry-content dl dd table td {
	padding:1.5rem 2rem;
	border:1px solid #DDD;
	vertical-align:middle;
}

#privacy #primary .entry-content dl dd table td:first-child {
	width:30%;
	padding:1.5rem 2rem;
	border:1px solid #DDD;
	background:#FAFAFA;
}

#privacy #primary .entry-content dl dd table a {
	color:#159ea9;
}

@media (max-width: 768px){
#privacy #primary .entry-content {
}

#privacy #primary .entry-content p {
	padding:1.5rem;
}

#privacy #primary .entry-content dl {
	margin:0;
}


#privacy #primary .entry-content dl dt {
	font-size:1em;
}

#privacy #primary .entry-content dl dd {
	margin-bottom:3rem;
	font-size:1em;
}

#privacy #primary .entry-content dl dd:last-child {
	padding-left:0;
}

#privacy #primary .entry-content dl dd table td:nth-child(1),
#privacy #primary .entry-content dl dd table td {
	padding:10px;
}
}

/*sitemp*/
#sitemap #main .entry-content ul {
	list-style:none !important;
	padding-left:0;
	margin-left:0;
}

#sitemap #main .entry-content ul li {
	margin-bottom:2rem;
}

#sitemap #main .entry-content ul li:last-child {
	margin-bottom:0;
}

#sitemap #main .entry-content ul li a {
	display:block;
	background:#F5F5F5;
	padding:1.5rem 2rem;
	text-decoration:none;
	color:#333;
	border-radius:5px;
}

#sitemap #main .entry-content ul li a:before {
    content: "\f152";
    font-family: FontAwesome;
    margin-right:0.5rem;
	color:#159ea9;
}

#sitemap #main .entry-content ul li.menu-item-has-children > a {
    pointer-events: none;
}

#sitemap #main .entry-content ul li ul {
	margin:1.5rem 0 0 4.5rem;
}

#sitemap #main .entry-content ul li ul li {
	margin-bottom:1rem;
}

#sitemap #main .entry-content ul li ul li a {
	background:none;
	padding:0;
}

#sitemap #main .entry-content ul li ul li a:before {
    content: "\f105";
    font-family: FontAwesome;
    margin-right:0.5rem;
	color:#159ea9;
}

@media (max-width: 768px){
#sitemap #main .entry-content ul  {
	margin-right:0;
}

#sitemap #main .entry-content ul li {
	margin-bottom:1rem;
}

#sitemap #main .entry-content ul li a {
	margin-bottom:0.5rem;
}
}


/*チェイン表示
***************************************/
.chain01,
.chain02,
.chain03,
.chain04,
.chain05 {
  opacity : 0;
  transition : all 1s;
}
  
.chain01.fadein-chain,
.chain02.fadein-chain,
.chain03.fadein-chain,
.chain04.fadein-chain,
.chain05.fadein-chain {
  opacity : 1;
}


.shine {
  position:relative;
  overflow:hidden
}
.shine a:before {
  position:absolute;
  content:"";
  width:50%;
  height:100%;
  top:0;
  left:-100%;
  background:linear-gradient(to right,rgba(255,255,255,0) 0%,rgba(255,255,255,.3) 100%);
  transform:skewX(-45deg)
}
.shine a:hover:before {
  animation:shine .7s
}
@keyframes shine {
  100% {
    left:125%
  }
}


/*contact*/
table.contact {
	margin:-2rem auto 3rem auto;
}

table.contact th,
table.contact td:nth-child(1) {
	width:35%;
	border:1px solid #DDD;
	font-weight:400;
	vertical-align:middle;
	background:#F5F5F5;
}

table.contact td {
	border:1px solid #DDD;
	line-height:1.8;
	background:#FFF;
	vertical-align:middle;
}

table.contact td input,
table.contact td textarea {
	font-size:1.6rem;
    font-weight: 200;
}

table.contact td input[type="text"] ,
table.contact td input[type="email"],
table.contact td input[type="tel"],
table.contact td input[type="date"] {
	height:40px;
	padding:0.25rem;
	width:80%;
	border:1px solid #DDD;
    box-sizing: border-box;
}

table.contact td select {
	padding:0.25rem;
	border:1px solid #DDD;
    box-sizing: border-box;
	font-size:1.6rem;
}

table.contact td input[type="date"] {
	border:1px solid #CCC;
	height:35px;
	padding:0.5rem;
	width:20%;
}

table.contact td input[type="text"]:focus,
table.contact td input[type="email"]:focus,
table.contact td input[type="tel"]:focus,
table.contact td input[type="date"]:focus,
table.contact td textarea:focus {
	outline: 0;
	-moz-box-shadow: inset 0 0 4px rgba(0,0,0,0.2);
	-webkit-box-shadow: inset 0 0 4px rgba(0, 0, 0, 0.2);
	box-shadow: inner 0 0 4px rgba(0, 0, 0, 0.2);
}

::placeholder {
  color: #DDD;
}

table.contact td span.sp_btm10 {
	display:block;
	margin-bottom:0.5rem;
}

table.contact td span small {
	display:inline-block;
	padding:0.25rem 0.5rem;
	background:#135fa7;
	color:#FFF;
	font-size:0.8em;
	position:relative;
	top:-3px;
}

table.contact td p {
	margin-bottom:0;
}

table.contact td textarea {
	width:100%;
	border:1px solid #DDD;
	padding:0.5rem;
}

table.contact th span.required {
	background:#FF0000;
	color:#FFF;
	font-size:0.8em;
	padding:0.15rem 0.5rem;
	display:inline-block;
	margin-left:0.5rem;
}

p.submit {
	text-align:center !important;
	margin-bottom:1.5rem !important;
}

p.submit input {
	font-size:2rem;
	padding:0.75rem 1.5rem;
	margin:0 1rem;
	border:1px solid #CCC;
}

div.wpcf7-validation-errors, div.wpcf7-acceptance-missing, div.wpcf7-response-output {
	border:2px solid #FF0000 !important;
	padding:1rem !important;
	text-align:center;
	background:#FFFFFF;
	color:#FF0000;
	margin:0 auto !important;
	font-size:1.4rem !important;
	width:80% !important;
}

span.wpcf7-list-item {
	margin:0 0.75rem 0 0 !important;
}

span.wpcf7-not-valid-tip {
	font-size:1.4rem;
	margin-top: 0.5rem;
}

table.contact td strong {
	font-size:1.2em;
	margin-bottom:0.5rem;
	display:block;
}

table.contact td #privacy_box {
	font-size:0.8em;
	max-height:180px;
	overflow:auto;
	background:#FFF;
	padding:1rem;
}

table.contact td #privacy_box p {
	margin-bottom:0.5rem;
}

table.contact td.birth input[type="text"] {
	width:10%;
}

@media (max-width: 768px){
.entry-content p.has-background {
	padding: 10px;
}

table.contact {
	margin:0 0 3rem 0;
	width: 100%;
	table-layout: fixed;
	word-break: break-all;
	word-wrap: break-all;
}

table.contact th,
table.contact td:nth-child(1) {
	width:100%;
	background:#FAFAFA;
}

table.contact th,
table.contact td {
}

table.contact td:nth-child(1) {
	width:100%;
	border-bottom:none;
}

#omitsumori .content_wrapper p span {
	font-size:1em !important;
}

table.contact td input,
table.contact td textarea {
	font-size:1.5rem !important;
}

table.contact td input[type="text"] ,
table.contact td input[type="email"],
table.contact td input[type="tel"] {
	width:100%;
}

table.contact td input[type="date"] {
	width:100%;
}

table.contact td.birth input[type="text"] {
	width:20%;
}

table.contact td span small {
	font-size:1em;
}

input[type=text],
textarea {
}

span.wpcf7-list-item {
	display:block;
	margin-bottom:0.5rem !important;
}

.wpcf7 table {
    border-bottom: 1px solid #EEE;
}

.wpcf7 table th,
.wpcf7 table td {
	width:100%;
	display:block;
	border-bottom:none;
}

p.submit input {
	font-size:1.2em;
	padding:0.5rem 1rem;
}
}

#prev_next {
	margin-bottom:6rem;
}

#prev_next ul {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	border-top:1px solid #E0E0E0;
	border-bottom:1px solid #E0E0E0;
}

#prev_next ul li {
	width:50%;
}

#prev_next ul li #prev_title,
#prev_next ul li #next_title {
	width:100%;
}

#prev_next ul li #prev_title a:hover,
#prev_next ul li #next_title a:hover {
	text-decoration:underline;
}

#prev_next ul li #prev_title a {
	padding:1rem 2rem;
	background:#F7F7F7;
	display:block;
	font-size:1.5rem;
	font-weight:bold;
	color:#333;
}

#prev_next ul li #prev_title a:before {
    content: "\f0a8";
    font-family: FontAwesome;
    margin-right:0.5rem;
}

#prev_next ul li #next_title a {
	padding:1rem 2rem;
	background:#F7F7F7;
	text-align:right;
	display:block;
	font-size:1.5rem;
	font-weight:bold;
	color:#333;
}

#prev_next ul li #next_title a:after {
    content: "\f0a9";
    font-family: FontAwesome;
    margin-left:0.5rem;
}

#prev_next ul li {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

#prev_next ul li.bktop{
	-webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
	align-items:center; /* 縦方向中央揃え */
}

#prev_next ul li figure {
	width:35%;
	padding:2rem;
}

#prev_next ul li p {
	width:100%;
	padding:2rem;
	font-weight:bold;
	font-size:1.5rem;
	line-height:1.3;
}

#prev_next ul li p a {
	color:#333;
}

#prev_next ul li:nth-child(2) p {
	text-align:right;
}

#prev_next ul li p a:hover {
	text-decoration:underline;
}

#prev_next ul li:nth-child(1) {
	border-right:1px solid #E0E0E0;
}

.bktop {
}

.bktop a {
	display:block;
	text-align:center;
	width:100%;
	font-size:1.5rem;
	font-weight:bold;
	color:#333;
}

.bktop a:before {
    content: "\f015";
    font-family: FontAwesome;
    margin-right:0.5rem;
}

@media (max-width: 768px){
#prev_next {
	margin-bottom:3rem;
}

#prev_next ul {
	padding:0;
	border-bottom:1px solid #E0E0E0;
}

#prev_next ul li {
	-webkit-align-items: flex-start; /* 縦方向中央揃え（Safari用） */
	align-items:flex-start; /* 縦方向中央揃え */
}


#prev_next ul li #prev_title a,
#prev_next ul li #next_title a {
	padding:1rem 10px;
	font-size:1.2rem;
}

#prev_next ul li figure {
	display:none;
}

#prev_next ul li p {
	width:100%;
	padding:10px;
}

#prev_next ul li p a {
	font-size:1.2rem;
}

.bktop a {
	font-size:1.2rem;
}

}

.sns-container {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.sns-container > div {
	width:25%;
	text-align:center;
}

.sns-container > div > a {
	display:block;
	padding:1.5rem 1rem;
	font-size:1.4rem;
	font-weight:bold;
}

.sns-container > div:nth-child(1) a {
	background:#3b5998;
	color:#FFF;
}

.sns-container > div:nth-child(2) a {
	background:#55acee;
	color:#FFF;
}

.sns-container > div:nth-child(3) a {
	background:#00b900;
	color:#FFF;
}

.sns-container > div:nth-child(4) a {
	background:#008fde;
	color:#FFF;
}

.sns-container > div:nth-child(4) a b {
}

@media (max-width: 768px){
.sns-container > div > a {
	padding:1rem 0.5rem;
	font-size:0.8em;
	letter-spacing:0;
}
}

/*装飾*/
.head-border {
    display: flex;
    align-items: center;
}
 
.head-border:before,
.head-border:after {
    content: "";
    height: 3px;
    flex-grow: 1;
    background-color: #fea65e;
}
 
.head-border:before {
    margin-right: 3rem;
}
 
.head-border:after {
    margin-left: 3rem;
}




/*よくある質問*/

.qa-list {
}

dl.faq {
	width:100%;
	margin:0 auto !important;
	padding:1.5rem 1.5rem 2rem 1.5rem;
	border-bottom:1px dashed #DDD;
	background:#FAFAFA;
}

dl.faq:last-child,
dl.faq:first-child {
}

dl.faq dt {
	font-weight:700;
    padding-left: 5.5rem;
    text-indent: -5.5rem;
}

dl.faq dt span {
	position:relative;
    top: -6px;
}

dl.faq dt:before {
    content: "Q";
    margin-right:1.5rem;
	font-size:3em;
	color:#159ea9;
    line-height: 1;
	font-family:Arial, Helvetica, sans-serif;
	font-weight:bold;
	position: relative;
	bottom: -8px;
}

dl.faq dd {
	margin-top:3rem;
	padding-left:5.5rem;
	position:relative;
}

dl.faq dd p {
	margin-bottom:0 !important;
}

dl.faq dd:before {
	position:absolute;
    top: -5px;
	left:0.15rem;
    content: "A";
    margin-right:0.5rem;
	font-size:3em;
	color:#ff4800;
	font-family:Arial, Helvetica, sans-serif;
    line-height: 1;
	font-weight:bold;
}

.qa-list dl {
    position: relative;
    padding: 10px 80px 28px 30px;
    cursor: pointer;
    border-bottom: 1px solid #DDD;
}
.qa-list dl:first-child {
    border-top: 1px solid #DDD;
}
.qa-list dl::before {
    position: absolute;
    top: 35%;
    right: 35px;
    display: block;
    width: 15px;
    height: 15px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 3px solid #159ea9;
    border-right: 3px solid #159ea9;
}
.qa-list .open::before {
    transform: rotate(-45deg);
}

@media screen and (max-width: 768px) {
.qa-list {
	padding-top:1rem;
}

dl.faq dt {
	font-size:1em;
    padding-left: 3.1rem;
    text-indent: -3.1rem;
}

dl.faq dd {
	margin-top:3rem;
	padding-left:3.1rem;
}

.qa-list dl {
	padding: 1.5rem 40px 1.5rem 2rem;
}
}

@media screen and (max-width: 480px) {
.qa-list dl:before {
    right: 20px;
	width: 10px;
	height: 10px;
}

dl.faq dt:before {
	font-size:1.8em;
	margin-right: 1rem;
	bottom: -2px;
}

dl.faq dt span {
	font-size:0.9em;
	letter-spacing:0;
	top: -3px;
}

dl.faq dd::before {
	font-size:1.8em;
}

}


/* カテゴリーリスト */
.entry-content ul.category-list{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    list-style:none;
    padding:0;
    margin:0 0 3rem;
}

.tax-purchase_category .entry-content ul.category-list {
	margin-bottom:0;
	margin-top:6rem;
}


/* 各項目 */
.entry-content ul.category-list li {
    margin:0;
}

/* リンク */
.entry-content ul.category-list a{
    display:block;
    padding:0.5rem 1.5rem;
    background:#f3f3f3;
    border-radius:4px;
    text-decoration:none;
	font-size:clamp(14px, 1.1vw, 15px);
    color:#333;
    transition:0.2s;
	text-decoration:none;
}

.entry-content ul.category-list li.current a,
.entry-content ul.category-list li.current-cat a {
	background:#159ea9;
	color:#FFF;
}


/* hover */
.entry-content ul.category-list a:hover{
    background:#333;
    color:#fff;
}

/* タブレット */
@media (max-width:768px){
.entry-content ul.category-list{
    margin:0 0 3rem;
}
}

/* スマホ */
@media (max-width:480px){
    .category-list{
        gap:6px;
    }

    .category-list a{
    }
}

/* 一覧全体 */
.article_wrapper_four{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:2rem;
}

/* 各カード */
.article-item-four{
    background:#fff;
	position:relative;
}

/* 画像 */
/* 画像枠 */
.article-item-four .img-wrap{
    aspect-ratio:1 / 1; /* 正方形 */
    overflow:hidden;
	border-radius:0.5rem 0.5rem 0 0;
}

.article-item-four .img-wrap img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

/* テキスト */
.article-item-four .text{
}

/* タイトル */
.article-item-four h3 {
    font-size:18px;
	background:#000;
	color:#FFF;
	padding:0.75rem 1rem 1rem 1rem;
	text-align:center;
	line-height:1.4;
}

.article-item-four h3 a {
	text-decoration:none;
	color:#FFF;
	font-size:clamp(15px, 1.2vw, 16px);
	letter-spacing:0;
	line-height:1.4;
}

/* 価格 */
.article-item-four .price {
	text-align:center;
	margin-bottom:0 !important;
	background:#F7F7F7;
	border-radius:0 0 0.5rem 0.5rem;
}

.article-item-four .price strong {
	font-size:clamp(18px, 2.4vw, 30px);
	color:#FF0000;
}

.article-item-four .price small {
	font-weight:500;
	font-size:0.9em;
	letter-spacing:0;
}

.article-item-four .price em {
	font-style:normal;
	font-weight:600;
	margin-left:-0.75rem;
	font-size:0.9em;
	letter-spacing:0;
}

.article-item-four .item_price_up {
	position:absolute;
	right:1rem;
	top:1rem;
	width:60px;
	height:60px;
	
}

/* タブレット */
@media (max-width:1024px){
    .article_wrapper_four{
        grid-template-columns:repeat(2,1fr);
    }
}

/* スマホ */
@media (max-width:600px){
.article-item-four h3 {
    font-size:16px;
	padding:0.5rem 0.5rem 0.75rem 0.5rem;
}

.article-item-four h3 a {
	letter-spacing: -1px;
}


}


.article-item-detail {
	display:flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap:         wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.article-item-detail:after {
	content:none;
}

.article-item-detail .img-wrap {
	width:40%;
	position:relative;
}

.article-item-detail .img-wrap img {
	width:100%;
	height:auto;
}

.article-item-detail .img-wrap span.item_price_up {
	position:absolute;
	right:1rem;
	top:1rem;
}

.article-item-detail .text {
	width:56%;
}

.entry-content .article-item-detail h3 {
	border-left:none;
	padding:0.5rem 0.5rem;
	font-weight:500;
	margin:0 0 2rem 0;
	background:#000;
	color:#FFF;
	text-align:center;
	font-size:clamp(18px, 1.6vw, 20px);
}

.entry-content .article-item-detail h3:before {
	content:none !important;
}

.article-item-detail time {
	text-align:center;
	display:block;
}

.article-item-detail time small {
	display:inline-block;
	background:#EEE;
	padding:0.5rem 1rem;
}

.article-item-detail p.price {
	text-align:center;
	margin-bottom:0;
	line-height:1.4;
}

.article-item-detail p.price strong {
	font-size:3.6em;
	font-weight:bold;
	color:#FF0000;
	background:none;
	font-family:Arial, Helvetica, sans-serif;
	letter-spacing:-3px;
	line-height:1.6;
}

.article-item-detail p.price small {
	font-size:1.6em;
	font-weight:bold;
	margin-left:0.5rem;
}

.article-item-detail p.price em {
	font-style:normal;
	font-weight:bold;
	font-size:1.2em;
	margin-left:-0.75rem;
}


.article-item-detail p.caution {
	padding:1rem;
	background:#F5F5F5;
	margin-top:1.5rem;
	text-align:center;
	font-size:0.9em;
}

@media (max-width: 768px){
.article-item-detail .img-wrap {
	width:80%;
	margin:0 auto 1.5rem auto;
}

.article-item-detail .text {
	width:100%;
}

.article-item-detail p.price strong {
	font-size:3.6em;
}

.article-item-detail p.price small {
	font-size:1.2em;
}

.article-item-detail p.price em {
	font-size:1em;
}

#page_contact_box {
	margin-bottom:4.5rem;
}

#page_contact_box h3 {
	font-size:0.8em;
	padding:0.5rem 1rem;
	letter-spacing:0;
}

#page_contact_box ul {
	padding:1rem;
}

#page_contact_box ul li {
	width:100%;
	margin-bottom:1rem;
}

}


/* 記事一覧3列 */
.article_list {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(2, 1fr);
  margin-bottom: 9rem;
}

@media (max-width: 980px) {
  .article_list {
    margin-bottom: 4.5rem;
  }
}

@media (max-width: 600px) {
  .article_list {
    /*grid-template-columns: 1fr;*/
  }
}



/* 各アイテム */
.list_item {
  display: flex;
  flex-direction: column;
}

/* 画像 */
.list_item div.img-box {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  margin-bottom: 0.5rem;
  background: #FAFAFA;
  /* 画像下余白増加 */
}

.list_item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* カテゴリータグ */
.category_tag {
  display: inline-block;
  font-size: 15px;
  /* 少し大きめ */
  color: #fff;
  padding: 0.3rem 0.6rem;
  margin-bottom: 0.8rem;
  /* タイトルとの間隔 */
  line-height: 1.4;
}

/* タイトル */
.list_item h3 {
  font-size: clamp(14px, 1.2vw, 16px);
  margin:0;
  /* 上下余白広め */
  line-height: 1.5;
}

/* 日付 */
.list_item time {
  font-size: 14px;
  /* 少し大きめに変更 */
  color: #666;
  line-height: 1.4;
}

.list_item time em {
  font-style: normal;
  font-family: Arial, Helvetica, sans-serif;
}

.list_item .article-date small a {
  line-height: 1.4;
  font-size: 0.7em;
  display: inline-block;
  padding: 0.2rem 0.25rem 0.45rem 0.25rem;
  background: #159ea9;
  color: #FFF !important;
  border-radius: 5px;
  letter-spacing: 0;
  position: relative;
  text-decoration:none;
  top: 5px;
}

/* リンク下線なし */
.list_item a {
  text-decoration: none;
}

/* デフォルト 3列 */
.article_list .list_item:nth-child(n+3) {
  margin-top: 3rem;
}

/* 2列（幅900px以下）の場合 3番目以降に余白 */
@media (max-width: 900px) {
}

/* 1列（幅600px以下）の場合 2番目以降に余白 */
@media (max-width: 600px) {
  .article_list .list_item:nth-child(n+2) {
    margin-top: 0;
  }
  .list_item h3 a {
	  line-height:1.6;
  }
}


@media (max-width: 980px) {
.line_box img {
	display:none;
}

.line_box .wp-block-media-text__content {
	padding:0 !important;
}

}




.grecaptcha-badge {
  bottom: 84px !important;
}


@media (max-width: 980px) {
.grecaptcha-badge {
  bottom: 160px !important;
}
}



















