﻿@charset "utf-8";

.tag {
	display: inline-block;
	background: skyblue;
	padding: 5px;
	margin-bottom: 5px;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
}


.shop_box h3 {
	font-size: 30px;
	text-align: center;
	border-top: 1px solid #333;
	padding-top: 1rem;
}

.shop_box .shop_image {
	width: 280px;
	display: inline-block;
}

.shop_box .shop_service li {
	background: navy;
	display: inline-block;
	padding: 2px 10px;
	margin-top: 5px;
	color: white;
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
}

.shop_service a {
	color: white;
}

/* スライド */

#out {
	width: 280px;
	height: 280px;
	overflow: hidden;
}

#in {
	width: 560px;
}

#in div,
#in2 div,
#in3 div,
#in4 div {
	float: left;
	width: 280px;
	height: 280px;
	margin-right: 3px;
	font-size: 25px;
}

#corp_info {
	font-family: 'Roboto', 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
	font-size: 0.9rem;
	margin: 2em auto 2em;
	width: 750px;
}

@media only screen and (min-width: 769px) {
	#corp {
		width: 750px;
	}

	.brand_list {
		width: 750px;
		margin-top: 60px;
		text-align: left;
	}
}

@media only screen and (max-width: 768px) {
	#corp {
		margin-bottom: 15px;
	}

	#corp_info img {
		max-width: 100%;
	}

	.brand_list {
		margin-top: 30px;
		text-align: left;
	}
}

#corp {
	display: grid;
	grid-template-columns: 20% 1fr;
	line-height: 2;
	margin-top: 10px;
}

#corp dt {
	font-size: 0.8rem;
	padding: 0.5em 1em;
	background-color: #e6e6fa;
	border-bottom: 3px solid #fff;
	text-align: left;
}

#corp dd {
	padding: 0.5em 1em;
	background-color: #f0f8ff;
	border-bottom: 3px solid #fff;
	margin-left: 0;
	text-align: left;
}

@media only screen and (max-width: 768px) {
	#corp {
		display: block;
		width: 100%;
	}

	#corp dt {
		border-left: 3px solid #358cac;
		padding-left: 10px;
	}

	#corp dd {
		margin-bottom: 10px;
	}
}

#corp_history,
.csr-history {
	display: grid;
	grid-template-columns: 120px 1fr;
	width: 750px;
	margin-top: 1rem;
}

@media only screen and (max-width: 768px) {
	.table-scroll-sp {
		width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 10px;
	}

	#corp_history,
	.csr-history {
		display: block;
		width: 100%;
		margin-top: 0;
	}

	#corp_history dt,
	.csr-history dt {
		text-align: left;
		padding: 0.6rem 10px;
		background: #f1f1f1;
		border-left: 4px solid #358cac;
		margin-top: 1.5rem;
		border-bottom: none;
	}

	#corp_history dd,
	.csr-history dd {
		padding: 1rem 5px;
		border-bottom: 1px solid #eee;
		margin-bottom: 0.5rem;
	}
}

#corp_history dt,
.csr-history dt {
	padding: 0.5em 1em;
	text-align: center;
	background: #f0f8ff;
	border-bottom: 1px dashed #ccc;
	font-size: 0.85rem;
}

#corp_history dd,
.csr-history dd {
	padding: 0.5em 1em 0.5em 20px;
	border-bottom: 1px dashed #ccc;
	line-height: 2;
	margin-left: 0;
}

#corp_outline {
	margin-top: 30px;
}

#corp_outline h2 {
	border-top: 1px dashed #ccc;
	border-bottom: 1px dashed #ccc;
	/*font-weight: bold;*/
	font-size: 150%;
}

#corp_outline dl {
	margin: 20px 0px;
}

#corp_outline dt {
	font-weight: bold;
	margin-left: 2em;
}

#corp_outline dd {
	margin-left: 4em;
}

#corp_outline p {
	margin: 20px 0px;
}

#corp_outline h3 {
	font-weight: bold;
	margin-top: 1.5em;
}

@media only screen and (max-width: 768px) {
	#corp_outline {
		margin-top: 15px;
		padding: 0 5px;
	}

	#corp_outline h2 {
		font-size: 1.1rem;
		padding: 10px 0;
	}

	#corp_outline dt {
		margin-left: 0.5em;
		padding-left: 5px;
		border-left: 3px solid #358cac;
		margin-top: 1.5em;
	}

	#corp_outline dd {
		margin-left: 1.5em;
		font-size: 0.95rem;
	}
}

.nowrap {
	white-space: nowrap;

}

#sub_menu a {
	padding: 0 10px;
	border-right: 1px dotted #333;
}

#sub_menu a:first-child {
	padding-left: 0;
}

#sub_menu a:last-of-type {
	margin-left: 0.5em;
	border-right: 1px dotted transparent;
}

#sub_menu img {
	margin-right: 10px;
}

@media only screen and (max-width: 768px) {

	#sub_menu a,
	#sub_menu a:last-of-type {
		margin: 0 !important;
		padding: 0 !important;
	}

	#sub_menu img {
		display: none;
	}
}

#corp_history td,
#shop td,
#shop_cl td,
#rec td,
#ws td {
	border-bottom: 2px solid #fff;
	border-left: 2px solid #fff;
}

#corp dd address {
	font-style: normal;
}

#corp dd .store-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

#corp dd .store-list li {
	display: inline;
}

#corp dd .store-list li+li::before {
	content: "、";
}

@media only screen and (min-width: 769px) {
	#shop {
		width: 750px;
	}
}

#shop td {
	padding: 0.5em;
	background-color: #e6e6fa;
}

#shop td+td {
	background-color: #f0f8ff;
	width: 52%;
}

#csr {
	line-height: 220%;
	width: 750px;
	margin-bottom: 1em;
}

#csr h3 {
	font-size: 1rem;
	font-weight: bold;
	color: #555;
	margin: 1em 0;
	padding-left: 0.5em;
	border-left: 3px solid #358cac;
	line-height: 1.6;
}

@media only screen and (max-width: 768px) {
	#csr {
		width: 100%;
		line-height: 1.8;
		padding: 0 10px;
		box-sizing: border-box;
	}

	.csr-message img {
		float: none !important;
		display: block;
		width: 100%;
		max-width: 200px !important;
		margin: 0 auto 1.5rem !important;
	}
}

#shop_cl {
	/*width: 600px;*/
	width: 750px;
}

#shop_cl td {
	width: 50px;
	padding: 1em;
	background-color: #e6e6fa;
}

#shop_cl td+td {
	background-color: #f0f8ff;
}

.koushiki_twitter {
	font-size: 0.8rem;
	font-weight: bold;
	line-height: 0.1em;
	vertical-align: text-top;
}

.e_depart {
	font-size: 0.8rem;
	font-weight: bold;
}

.last_name {
	font-size: 0.9rem;
	font-weight: bold;
}

.item_name {
	font-size: 0.9rem;
	font-weight: bold;
}

.note {
	font-size: 0.8rem;
	font-weight: bold;
	margin-bottom: 10px;
}

#prof {
	margin: 0 auto;
}

#prof td {
	padding-left: 3em;
}

.center {
	width: 600px;
	margin: 0 auto;
	margin-bottom: 15px;
}

.fuss_movie {
	width: 100%;
	position: relative;
	padding-top: 56.25%;
}

.fuss_movie iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.shop_intro,
.shop_intro_s {
	padding: 1em;
	border: 1px solid #ccc;
	border-radius: 10px;
}

.shop_intro {
	height: 17em;
}

.shop_intro_s {
	height: 20em;
}

.ws-mission,
#ws_intro {
	margin-top: 2em;
	margin-bottom: 2em;
	line-height: 1.8;
}

.ws-subtitle,
.office-name {
	font-size: 1.1rem;
	font-weight: bold;
	color: #333;
	margin-bottom: 1rem;
	border-bottom: 2px solid #358cac;
	padding-bottom: 0.5rem;
	display: inline-block;
}

.ws-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin: 2rem 0;
}

.ws-buttons .btn2 {
	flex: 1 1 calc(33.333% - 1rem);
	min-width: 250px;
	margin: 0;
	box-sizing: border-box;
}

.office-block {
	margin-bottom: 3rem;
}

.ws-info {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 1rem;
	margin-bottom: 1.5rem;
	border-top: 1px dashed #ccc;
	padding-top: 1rem;
}

.ws-info dt {
	font-weight: bold;
	color: #555;
}

.ws-info dd {
	margin: 0;
	padding-bottom: 1rem;
	border-bottom: 1px dashed #ccc;
}

.inq {
	background-color: #33bdef;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	border-radius: 10px;
	border: 2px solid #057fd0;
	display: inline-block;
	cursor: pointer;
	color: #ffffff;
	font-family: Arial;
	font-size: 14px;
	padding: 8px 8px;
	text-decoration: none;
	text-shadow: 1px 2px 5px #5b6178;
	margin: 1px 0px;
}

.inq:hover {
	background-color: #019ad2;
}

.inq:active {
	position: relative;
	top: 1px;
}

.list {
	background-color: #ffec64;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	border-radius: 8px;
	border: 2px solid #ffaa22;
	display: inline-block;
	cursor: pointer;
	color: #333333;
	font-family: Arial;
	font-size: 14px;
	padding: 8px 8px;
	text-decoration: none;
	text-shadow: 1px 2px 5px #ffee66;
	margin: 1px 6px 0 1px;
}

.list:hover {
	background-color: #ffab23;
}

.list:active {
	position: relative;
	top: 1px;
}

.map {
	margin-top: 30px;
	margin-bottom: 30px;
}

.access_map {
	margin: 2rem 0;
	text-align: center;
}

.access_map img {
	max-width: 100%;
	height: auto;
}

.map iframe {
	width: 100% !important;
	height: 450px;
	border: 0;
}

@media only screen and (max-width: 768px) {
	.map iframe {
		height: 300px;
	}

	.location h3 {
		font-size: 1.1rem;
		border-left: 4px solid #358cac;
		padding-left: 10px;
		margin-bottom: 1rem;
	}

	.location address {
		background: #fdfdfd;
		padding: 1rem;
		border: 1px solid #eee;
		line-height: 1.6;
	}
}

/*リクルート*/

@media only screen and (min-width: 769px) {

	#rec,
	.rec {
		display: grid;
		grid-template-columns: 25% 1fr;
		width: 750px;
	}
}

@media only screen and (max-width: 768px) {
	#rec {
		margin-bottom: 20px;
	}
}

#rec dt,
.rec dt {
	padding: 0.5em;
	background-color: #e6e6fa;
	border-bottom: 2px solid #fff;
	font-size: 0.8rem;
}

#rec dd,
.rec dd {
	padding: 0.5em;
	background-color: #f0f8ff;
	border-bottom: 2px solid #fff;
	margin-left: 0;
}

@media only screen and (max-width: 768px) {

	#rec,
	.rec {
		display: block;
		width: 100%;
	}

	#rec dt,
	.rec dt {
		border-left: 3px solid #358cac;
		padding-left: 8px;
		margin-top: 15px;
	}

	#rec dd,
	.rec dd {
		margin-bottom: 5px;
	}
}

.recruit-status {
	color: #b22222;
	font-size: 1.2rem;
	margin: 1.5em 0;
}

.recruit-entry {
	margin-bottom: 2em;
}

.recruit-entry h4 {
	font-weight: bold;
	margin: 1em 0 0.3em;
}

.recruit-entry .schedule {
	display: grid;
	grid-template-columns: 5em 1fr;
	margin: 0.5em 0;
}

.recruit-entry .schedule dt {
	font-weight: bold;
	background: transparent;
	border: none;
}

@media only screen and (min-width: 769px) {
	.shop_box {
		width: 750px;
		padding-bottom: 10px;
	}

	.shop_box .shop_text {
		width: 450px;
		display: inline-block;
		vertical-align: top;
		margin-left: 10px;
		margin-top: 10px;
	}
}

@media only screen and (max-width: 768px) {
	#corp_info {
		font-family: 'Roboto', 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
		font-size: 0.95rem;
		margin: 0 auto;
		margin-top: 1em;
		width: 100%;
		padding: 0 10px;
		box-sizing: border-box;
	}

	#brand_list,
	#ganter {
		display: block;
		width: 100% !important;
	}

	#brand_list tr,
	#brand_list td,
	#brand_list th,
	#ganter tr,
	#ganter td,
	#ganter th {
		display: block;
		width: 100% !important;
		box-sizing: border-box;
		border: none !important;
	}

	#brand_list td,
	#ganter td {
		padding: 1.5rem 0;
		border-bottom: 1px dashed #ccc !important;
		text-align: center;
	}

	#brand_list td img,
	#ganter td img {
		max-width: 80%;
		height: auto;
		margin-bottom: 1rem;
	}

	.shop_box {
		padding-bottom: 10px;
		border-bottom: 1px solid #333;
	}

	.shop_box .shop_text {
		display: block;
		width: 100%;
		margin-left: 0;
		margin-top: 15px;
	}

	.shop_box .shop_image {
		display: block;
		margin: 0 auto;
		text-align: center;
	}

	.shop-banners {
		display: flex;
		flex-direction: column;
		gap: 10px;
		margin-top: 15px;
	}

	.shop-banners .banner-item img {
		max-width: 100%;
		height: auto;
	}

	.shop-social {
		margin-top: 15px;
		text-align: center;
	}

	.fsc-features-desc p {
		margin-bottom: 1em;
	}

	.section-download {
		text-align: center;
	}

	.ws-info {
		display: block;
		width: 100%;
	}

	.ws-info dt {
		border-left: 3px solid #358cac;
		padding-left: 10px;
		margin-top: 1.5rem;
	}

	.ws-info dd {
		margin-bottom: 0.5rem;
		border-bottom: 1px dashed #eee;
	}

	.ws-buttons .btn2 {
		flex: 1 1 100%;
	}

	.ws-subtitle {
		font-size: 1rem;
	}

	.client-gallery {
		grid-template-columns: 1fr;
		gap: 0.5rem;
	}

	.client-photo {
		margin: 1.5rem 0;
	}

	.client-description {
		margin: 1rem 0;
	}

	/* OMC Page SP optimization */
	.omc-page h1.page-title {
		font-size: 1.2rem;
		line-height: 1.4;
	}

	.omc-page .ja,
	.omc-page .en {
		display: block;
	}

	.omc-page .en {
		font-size: 0.9rem;
		margin-top: 5px;
	}

	.omc-page img {
		max-width: 100%;
		height: auto;
	}

	.omc-page .section-title {
		margin-top: 2rem;
	}

	.omc-page .u-mr-1 {
		margin-right: 0;
		margin-bottom: 5px;
	}

	.fuss-page .section-title {
		margin-top: 2rem;
	}

	.fuss-intro-content p {
		margin-bottom: 0.8rem;
	}

	.hospital-list dt {
		margin-top: 1rem !important;
	}

	.hospital-list dd {
		margin-left: 1rem !important;
	}

	.fuss_movie iframe {
		height: 200px;
	}

	/* Materials Page SP optimization */
	.materials-page .page-title {
		font-size: 1.2rem;
		line-height: 1.4;
	}

	.section-download {
		flex-direction: column;
		align-items: center;
		gap: 1.5rem;
		margin-top: 2rem;
	}

	.download-item img {
		max-width: 100%;
		height: auto;
	}

	.materials-intro p {
		margin-bottom: 0.8rem;
	}
}

.location {
	margin-left: 20px;
	margin-bottom: 20px;
	font-size: 0.9rem;
	font-weight: bold;
}

.map {
	width: 100%;
	position: relative;
	padding-top: 56.25%;
}

.map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.access_map {
	text-align: center;
	margin-bottom: 2rem;
}

.access_map img {
	max-width: 100%;
	height: auto;
}

@media only screen and (max-width: 768px) {
	.location {
		margin-left: 10px;
		margin-bottom: 15px;
		font-size: 0.85rem;
	}

	.location h3 {
		font-size: 1rem;
		border-left: 3px solid #358cac;
		padding-left: 8px;
		margin-bottom: 8px;
	}

	address {
		line-height: 1.6;
	}
}

.sub_navi_list {
	display: flex;
	justify-content: center;
	column-gap: 2rem;
	margin-top: 1rem;
	list-style: none;
	padding: 0;
}

.sub_navi_list li+li {
	padding-left: 2rem;
	border-left: 1px solid #ccc;
}

@media only screen and (max-width: 768px) {
	.sub_navi_list {
		flex-wrap: wrap;
		gap: 10px;
		margin-top: 15px;
	}

	.sub_navi_list li {
		width: calc(50% - 5px);
		box-sizing: border-box;
	}

	.sub_navi_list li+li {
		padding-left: 0;
		border-left: none;
	}

	.sub_navi_list li a {
		display: block;
		padding: 10px 5px !important;
		border: 1px solid #358cac !important;
		border-radius: 4px;
		text-align: center;
		color: #358cac;
		font-weight: bold;
		text-decoration: none;
		background: #fff;
	}

	#sub_menu a[aria-current="page"] {
		background: #358cac;
		color: #fff;
	}
}

/* English Page Styles */
.en-department {
	background: #fff;
	border: 1px solid #eaeaea;
	border-top: 4px solid #e6e6fa;
	border-radius: 6px;
	padding: 2.5rem 2rem;
	margin-bottom: 2.5rem;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
	margin-top: 1rem;
}

.en-department h3 {
	font-size: 1.25rem;
	font-weight: bold;
	color: #333;
	margin-top: 0;
	margin-bottom: 1.5em;
	padding-bottom: 0.5em;
	border-bottom: 1px solid #eee;
	line-height: 1.4;
}

.en-department h4 {
	font-size: 1rem;
	font-weight: bold;
	color: #555;
	margin-top: 2em;
	margin-bottom: 0.5em;
}

.en-department section:first-child h4 {
	margin-top: 0;
}

.en-department ul {
	margin-left: 1.5em;
	margin-bottom: 1.5em;
	list-style-type: disc;
}

.en-department ul ul {
	margin-top: 0.5em;
	margin-bottom: 0;
	list-style-type: circle;
}

.en-department li {
	margin-bottom: 0.5em;
	line-height: 1.6;
}

.en-department p {
	line-height: 1.6;
	margin-bottom: 1em;
}

/* Shop List */
.shop-list {
	margin-bottom: 2em;
}

.shop-list dt {
	font-weight: bold;
	color: #333;
	margin-top: 1.5em;
	font-size: 0.95rem;
	border-left: 3px solid #358cac;
	padding-left: 0.5em;
}

.shop-list dt:first-child {
	margin-top: 0;
}

.shop-list dd {
	margin-left: 1em;
	margin-bottom: 0.5em;
	color: #666;
	font-size: 0.95rem;
}

/* Note Section */
.en-note {
	margin-top: 2.5em;
	padding: 1.5em;
	background: #f8f9fa;
	border-left: 4px solid #ccc;
	border-radius: 0 4px 4px 0;
}

.en-note p {
	margin: 0 0 0.5em 0;
	font-size: 0.9rem;
	color: #666;
}

.en-note p:last-child {
	margin-bottom: 0;
}

@media only screen and (max-width: 768px) {
	.en-department {
		padding: 1.5rem 1rem;
		margin-bottom: 1.5rem;
	}

	.en-department h3 {
		font-size: 1.1rem;
		margin-bottom: 1rem;
	}

	.en-department h4 {
		margin-top: 1.5em;
	}

	.en-note {
		padding: 1rem;
		margin-top: 1.5em;
	}
}

/* ---------------------------------
   page-shoes.php styles
--------------------------------- */
.brand-section {
	margin-top: 3rem;
	margin-bottom: 4rem;
}

.brand-section .section-title {
	font-size: 1.5rem;
	font-weight: bold;
	color: #333;
	margin-bottom: 2rem;
	border-bottom: 2px solid #358cac;
	padding-bottom: 0.5rem;
	line-height: 1.4;
}

.brand-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
	gap: 2rem;
}

.brand-card {
	border: 1px solid #eaeaea;
	border-radius: 8px;
	padding: 1.5rem;
	background: #fff;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.brand-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1);
}

.brand-logo {
	display: block;
	text-align: center;
	margin-bottom: 1.5rem;
	height: 120px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.brand-logo img {
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
}

.brand-content {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.brand-content .brand-name {
	font-size: 1.25rem;
	margin-bottom: 1rem;
	font-weight: bold;
	color: #333;
}

.brand-content p {
	font-size: 0.95rem;
	line-height: 1.6;
	color: #555;
	margin-bottom: 1.5rem;
	flex-grow: 1;
}

.brand-links {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.brand-links .btn-link {
	display: inline-block;
	font-weight: bold;
	color: #358cac;
	text-decoration: none;
	padding: 0.5rem 0;
	border-bottom: 1px dashed transparent;
	transition: all 0.3s;
}

.brand-links .btn-link:hover {
	color: #003366;
	border-bottom: 1px dashed #003366;
}

.brand-links .btn-link i {
	margin-left: 0.25rem;
	font-size: 0.8em;
}

@media only screen and (max-width: 768px) {
	.brand-section {
		margin-top: 2rem;
		margin-bottom: 3rem;
	}

	.brand-section .section-title {
		font-size: 1.2rem;
		margin-bottom: 1.5rem;
	}

	.brand-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.brand-card {
		padding: 1.2rem;
	}

	.brand-logo {
		height: 100px;
		margin-bottom: 1rem;
	}

	.brand-content .brand-name {
		font-size: 1.1rem;
	}

	.catalog-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
}

.catalog-section {
	margin-top: 4rem;
}

.catalog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.catalog-item a {
	display: block;
	transition: opacity 0.3s;
}

.catalog-item a:hover {
	opacity: 0.7;
}

.catalog-item img {
	width: 100%;
	height: auto;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

/* ---------------------------------
   page-shoes-client_list styles
--------------------------------- */
.client-region {
	margin-bottom: 3rem;
}

.region-title {
	font-size: 1.3rem;
	font-weight: bold;
	background: #e6e6fa;
	padding: 0.6rem 1rem;
	border-radius: 4px;
	margin-bottom: 1.5rem;
}

.client-prefecture {
	margin-bottom: 2rem;
}

.prefecture-title {
	font-size: 1.1rem;
	font-weight: bold;
	color: #333;
	background: #f0f8ff;
	padding: 0.5rem 1rem;
	border-left: 4px solid #e6e6fa;
	margin-bottom: 1rem;
}

.client-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 1rem;
	margin-bottom: 1rem;
}

.client-item {
	border: 1px solid #e8e8e8;
	border-radius: 6px;
	padding: 1rem 1.2rem;
	background: #fff;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.client-item:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.client-name {
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 0.75rem;
	color: #333;
	border-bottom: 1px dashed #ddd;
	padding-bottom: 0.5rem;
}

.client-name a {
	color: navy;
	text-decoration: none;
	transition: color 0.2s;
}

.client-name a:hover {
	color: darkorange;
	text-decoration: underline;
}

.client-details {
	display: grid;
	grid-template-columns: 50px 1fr;
	gap: 0.3rem 0.75rem;
	font-size: 0.9rem;
	line-height: 1.5;
}

.client-details dt {
	font-weight: bold;
	color: #888;
}

.client-details dd {
	margin: 0;
	color: #555;
}

.client-details dd a {
	color: #555;
	text-decoration: none;
}

.client-details dd a:hover {
	color: #73b64c;
}

@media only screen and (max-width: 768px) {
	.client-grid {
		grid-template-columns: 1fr;
	}
}

/* ---------------------------------
   page-client styles
--------------------------------- */
.client-profile {
	line-height: 1.8;
}

.client-photo {
	margin: 2rem 0;
	text-align: center;
}

.client-photo img {
	max-width: 100%;
	height: auto;
	border-radius: 6px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.client-photo figcaption {
	font-size: 0.9rem;
	color: #777;
	margin-top: 0.5rem;
}

.client-description {
	margin: 1.5rem 0;
}

.client-description p {
	margin-bottom: 1rem;
}

.client-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1rem;
	margin: 2rem 0;
}

.client-gallery img {
	width: 100%;
	height: auto;
	border-radius: 6px;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
	transition: transform 0.3s ease;
}

.client-gallery img:hover {
	transform: scale(1.03);
}

.client-notice {
	background: #fff8e1;
	border: 1px solid #ffe082;
	border-radius: 8px;
	padding: 2rem;
	margin-bottom: 2rem;
}

.client-notice h3 {
	font-size: 1.1rem;
	font-weight: bold;
	color: #e65100;
	margin-bottom: 1rem;
}

.client-notice p {
	margin-bottom: 0.75rem;
}

.client-notice a {
	color: navy;
	font-weight: bold;
}

.shop-info {
	margin: 2rem 0;
}

.shop-map {
	margin: 2rem 0;
}

.shop-map .map {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}

.shop-map .map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* ---------------------------------
   page-fsc-chooseyourshose.php styles
--------------------------------- */
.omc-price-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin: 2rem 0;
	background-color: #fff;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
	border-radius: 8px;
	overflow: hidden;
}

.omc-price-table th,
.omc-price-table td {
	padding: 1.2rem 1.5rem;
	text-align: left;
	border-bottom: 1px solid #eee;
}

.omc-price-table th {
	background-color: #f8f9fa;
	font-weight: bold;
	color: #333;
	width: 25%;
	border-right: 1px solid #eee;
}

.omc-price-table tr:last-child th,
.omc-price-table tr:last-child td {
	border-bottom: none;
}

.omc-price-table tr:hover td {
	background-color: #fafbfc;
}

@media only screen and (max-width: 768px) {

	.omc-price-table th,
	.omc-price-table td {
		display: block;
		width: 100%;
	}

	.omc-price-table th {
		border-right: none;
		border-bottom: 2px solid #358cac;
		background-color: #e6e6fa;
	}

	.omc-price-table td {
		border-bottom: 1px dashed #eee;
		padding-left: 2rem;
	}
}

.omc-contact-section {
	margin-top: 1rem;
}

.flow-image img {
	width: 100%;
}

.shop-info-card {
	margin-top: 1rem;
}

.shop-info-card .shop-link {
	display: inline-block;
	text-decoration: none;
	margin-bottom: 1.5rem;
	transition: opacity 0.3s;
}

.shop-info-card .shop-link:hover {
	opacity: 0.8;
}

.shop-info-card .shop-name {
	font-size: 1.25rem;
	font-weight: bold;
	color: #333;
	border-bottom: 2px solid #358cac;
	padding-bottom: 0.3rem;
	line-height: 1.5;
}

.shop-details dl,
.shop-info {
	width: 100%;
}

.shop-details dl dt,
.shop-info dt,
.shop-details dl dd,
.shop-info dd {
	padding: 1rem 1.2rem;
	border-bottom: 1px solid #eee;
	margin: 0;
	display: flex;
	align-items: center;
}

.shop-details dl dt,
.shop-info dt {
	background-color: #f8f9fa;
	font-weight: bold;
	color: #333;
	border-right: 1px solid #eee;
}

.shop-details dl dd,
.shop-info dd {
	background-color: #fff;
}

.shop-details dl dd a,
.shop-info dd a {
	color: #057fd0;
	text-decoration: underline;
}

.shop-details dl dd a:hover,
.shop-info dd a:hover {
	color: darkorange;
}

@media only screen and (max-width: 768px) {
	.shop-info-card {
		padding: 1rem 0;
	}

	.shop-details dl,
	.shop-info {
		display: block;
	}

	.shop-details dl dt,
	.shop-info dt,
	.shop-details dl dd,
	.shop-info dd {
		padding: 0.8rem 1rem;
		font-size: 0.9rem;
	}

	.shop-details dl dt,
	.shop-info dt {
		border-left: 3px solid #358cac;
		margin-top: 1rem;
		border-right: none;
	}

	.shop-details dl dd,
	.shop-info dd {
		margin-bottom: 0.5rem;
		border-bottom: 1px dashed #eee;
	}
}

/* Care Steps List Styles (Fuss Pages) */
.care-steps-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.care-step-item {
	display: flex;
	align-items: center;
	padding: 1.5rem 0;
	border-bottom: 1px solid #ccc;
	gap: 2rem;
}

.care-step-item .step-image {
	flex: 0 0 30%;
	margin: 0;
	text-align: center;
}

.care-step-item .step-image img {
	max-width: 100%;
	height: auto;
}

.care-step-item .step-content {
	flex: 1;
}

.care-step-item .step-title {
	font-weight: bold;
	margin-bottom: 0.5rem;
	color: #333;
}

.care-step-item .step-content h4 {
	font-weight: bold;
	margin-bottom: 0.5rem;
	color: #333;
}

@media only screen and (max-width: 768px) {
	.care-step-item {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}

	.care-step-item .step-image {
		flex: 0 0 100%;
		width: 100%;
	}
}

/* Materials Pages Styles */
.materials-brand-section,
.materials-intro {
	margin-top: 2rem;
}

.brand-list,
.product-grid {
	display: grid;
	gap: 2rem;
	list-style: none;
	padding: 0;
}

.brand-list,
.product-grid {
	grid-template-columns: repeat(3, 1fr);
}

@media only screen and (max-width: 960px) {

	.brand-list,
	.product-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media only screen and (max-width: 600px) {

	.brand-list,
	.product-grid {
		grid-template-columns: 1fr;
	}
}

.brand-item,
.product-item {
	background: #fff;
	padding: 1.5rem;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
}

.brand-item {
	text-align: center;
}

.brand-item figure {
	margin-bottom: 1rem;
}

.brand-item img,
.product-item img {
	max-width: 100%;
	height: auto;
	border-radius: 4px;
}

.product-item img {
	margin-bottom: 1rem;
}

.brand-name {
	font-size: 1.1rem;
	font-weight: bold;
	margin-bottom: 1rem;
	color: #333;
	border-bottom: 2px solid #358cac;
	padding-bottom: 0.5rem;
	display: inline-block;
}

.product-name {
	font-weight: bold;
	margin-bottom: 0.5rem;
	color: #333;
}

.product-item a .product-name {
	color: #057fd0;
}

.brand-item p {
	text-align: left;
	margin-bottom: 1rem;
	color: #555;
	line-height: 1.5;
}

.brand-item>div,
.product-details {
	margin-top: auto;
}

.button-outline {
	display: inline-block;
	padding: 0.8rem 1.5rem;
	background: transparent;
	border: 2px solid #358cac;
	color: #358cac;
	text-decoration: none;
	border-radius: 5px;
	font-weight: bold;
	transition: all 0.3s;
	width: 100%;
	box-sizing: border-box;
	text-align: center;
}

.button-outline:hover {
	background-color: #358cac !important;
	color: #fff !important;
}

.section-download {
	display: flex;
	gap: 2rem;
	justify-content: center;
	margin-top: 4rem;
	flex-wrap: wrap;
	margin-bottom: 3rem;
}

.download-item a {
	display: block;
	transition: opacity 0.3s;
}

.download-item a:hover {
	opacity: 0.8;
}

.download-item img {
	max-width: 100%;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	width: 250px;
}

.product-item a {
	text-decoration: none;
	color: inherit;
	display: block;
	text-align: center;
}

.product-item>div:first-child {
	text-align: center;
}

.product-code {
	font-size: 0.9rem;
	color: #777;
	margin-bottom: 0.5rem;
}

.product-desc {
	font-size: 0.95rem;
	line-height: 1.5;
}

.materials-note {
	background: #fdfdfd;
	padding: 1rem;
	border-left: 4px solid #358cac;
	margin-top: 2rem;
	margin-bottom: 2rem;
}

.materials-note p {
	margin-bottom: 0.5rem;
}

.materials-note p:last-child {
	margin-bottom: 0;
}

.materials-note a {
	font-weight: bold;
	color: #057fd0;
	text-decoration: underline;
}

/* Inquiry Page Styles */
.inquiry-form-section {
	margin-top: 2rem;
	margin-bottom: 4rem;
}

.form-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 2rem;
}

.form-table th,
.form-table td {
	padding: 1rem;
	border-bottom: 1px solid #ddd;
	text-align: left;
}

.form-table th {
	background: #f9f9f9;
	width: 30%;
	vertical-align: top;
}

.form-input,
.form-select,
.form-textarea {
	width: 100%;
	max-width: 450px;
	padding: 0.6rem;
	border: 1px solid #ccc;
	border-radius: 4px;
	box-sizing: border-box;
}

.form-input-short {
	width: 100%;
	max-width: 200px;
	padding: 0.6rem;
	border: 1px solid #ccc;
	border-radius: 4px;
	box-sizing: border-box;
}

.form-textarea {
	max-width: 100%;
}

.form-checkbox-label {
	display: block;
	margin-bottom: 0.8rem;
}

.form-submit {
	text-align: center;
	margin: 3rem 0;
}

.form-submit .button {
	padding: 1rem 4rem;
	font-size: 1.1rem;
	cursor: pointer;
	background: #358cac;
	color: #fff;
	border: none;
	border-radius: 4px;
	transition: background-color 0.3s;
}

.form-submit .button:hover {
	background-color: #2a708a;
}

@media only screen and (max-width: 768px) {

	.form-table th,
	.form-table td {
		display: block;
		width: 100%;
		box-sizing: border-box;
		border-bottom: none;
	}

	.form-table th {
		background: #f1f1f1;
		padding: 0.8rem 1rem;
		border-left: 4px solid #358cac;
	}

	.form-table td {
		padding: 1rem;
		border-bottom: 1px solid #eee;
		margin-bottom: 1rem;
	}

	.form-input,
	.form-select,
	.form-input-short {
		max-width: 100%;
	}

	.form-submit .button {
		width: 100%;
		padding: 1rem;
	}

	/* Privacy Policy SP */
	#corp_outline h3 {
		font-size: 1.1rem;
		margin-top: 1.5rem;
		padding-bottom: 0.3rem;
		border-bottom: 2px solid #358cac;
	}

	/* Recruit Page SP */
	#rec dt {
		width: 100%;
		float: none;
		background: #f1f1f1;
		padding: 0.8rem;
		margin-top: 1rem;
		border-left: 4px solid #358cac;
		box-sizing: border-box;
	}

	#rec dd {
		width: 100%;
		margin-left: 0;
		padding: 1rem 0.5rem;
		border-bottom: 1px solid #eee;
	}

	.recruit-status {
		padding: 1rem;
		background: #fff9e6;
		border: 1px solid #ffeeba;
		text-align: center;
	}
}