@charset "UTF-8";
/*
	Template: swell
	Theme Name: ADSTEC 2022
	Theme URI: https://swell-theme.com/
	Description: 専用テーマ
	Version: 2024.507.5
	Author: Element System
	Author URI: https://www.element-system.co.jp/

	License: GNU General Public License
	License URI: http://www.gnu.org/licenses/gpl.html
*/

/*========================================

# Index

## Variables
## General Components
## Layout
## Navigation
## Header
## Contents
## Home
## Sidebar
## Widget
## Footer

========================================*/



/*------------------------------------------------------------

## Variables

------------------------------------------------------------*/
:root {
	/* 主要コンテンツカラー */
	--elm-color_main: var(--color_main, #053566);
	--elm-color_sub: #920563;
	/* フォントファミリー */
	--elm-font_serif: 'Noto Serif JP', serif;
	--elm-font_sans-serif: var(--swl-font_family);/*"游ゴシック体", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;*/
	--elm-font_default: var(--swl-font_family);
	/* フォントカラー */
	--elm-text-color_dark:    #000;
	--elm-text-color_light:   #fff;
	--elm-text-color_default: var(--color_text, #333);
}


/*------------------------------------------------------------

## General Components

------------------------------------------------------------*/

/* Link */

/* - テキストカラー個別指定を優先する */
:where(p.has-text-color:not(.has-link-color)) a {
	color: inherit !important;
}


/* Button */
.swell-block-button a,
.wp-block-button__link {
	border-radius: 0;
}
	/* Normalスタイル */
	.is-style-btn_normal a {
		transition: box-shadow .25s, opacity .25s;
	}
	.is-style-btn_normal a:hover {
		opacity: 0.92;
	}
	/* アウトラインスタイル白地対応（デフォルトは透明） */
	.is-style-btn_line.bg-white a {
		background-color: #fff;
	}
	.is-style-btn_line a:hover {
		background-color: inherit;
	}
	.is-style-btn_line.bg-white a:hover {
		border-color: inherit;
	}
/* Button - エリアカメラセレクターリンク */
.goto-areacameraselector [class*=is-style-btn_].-size-s a {
	font-size: 0.76em;
}
.goto-areacameraselector .is-style-btn_line a:hover {
	background-color: var(--the-btn-color,var(--color_main));
	opacity: 0.8;
}



/* Typography */
.ff-serif {
	font-family: var(--elm-font_serif) !important;
}
.ff-sanserif {
	font-family: var(--elm-font_sans-serif) !important;
}
.post_content .is-style-section_ttl {
	font-family: var(--elm-font_serif);
}
.post_content .is-style-section_ttl small {
	font-family: var(--elm-font_sans-serif);
}


/* List */
ul.is-style-index.is-style-index--bar li {
	margin: 0.4em 0;
	padding-left: 2.25em;
}
ul.is-style-index.is-style-index--bar li:before {
	background-color: currentColor;
	border-radius: 0;
	color: inherit;
	content: "";
	display: block;
	height: 1px;
	left: 2px;
	position: absolute;
	top: calc(0.75em - 2px);
	width: 1.6em;
}


/* 投稿リスト */

/* - 先頭1件を非表示 */
.p-postListWrap.hide-first-post .p-postList .p-postList__item:first-of-type {
	display: none !important;
}

.p-postListWrap._justify-content__center .p-postList.-type-card,
.p-postListWrap._justify-content__center .p-postList.-type-thumb {
	justify-content: center;
}




/* カード型コンテンツ elm-card-v */
.elm-card-v {
	background-color: #fff;
}
.elm-card-v .wp-block-image {
	margin: 0 !important;
}
.elm-card-v h3 {
	margin-bottom: 0.5em;
	padding: 0.5em 2px;
	font-size: 1em;
}
.elm-card-v h3::before {
	display: none !important;
}
.elm-card-v h3 a {
	color: #fff;
}
.elm-card-v h3 a:hover {
	text-decoration: underline;
}
.elm-card-v__body {
	padding: 0.5em 0.8em 1em;
	color: #fff;
	background-color: #421e4e;
}
.elm-card-v__body p {
	font-size: 0.9em;
}


/* ブログパーツ：widget_contact */
.p-blogParts>.blogParts-widget_contact-section {
}
.p-blogParts>.blogParts-widget_contact-section .wp-block-group {
}


/* ブログパーツ： */
.cta-testroomdalsa-button {}
.cta-testroomdalsa-button a {
	padding: 0.9em 0.9em;
}
.cta-testroomdalsa-button a span {
	font-size: 0.9em;
}

/* Contact Form 7 */

.wpcf7 .wpcf7-form .form-action {}
.wpcf7 .wpcf7-form input.wpcf7-form-control:not([type="submit"]),
.wpcf7 .wpcf7-form select.wpcf7-form-control,
.wpcf7 .wpcf7-form textarea.wpcf7-form-control {
	max-width: 100%;
}
.wpcf7-list-item {
	display: block;
}
.wpcf7 .wpcf7-form input.wpcf7-form-control[name="goods"] {
	font-weight: bold;
}

.wpcf7 .wpcf7-form .form-input--acceptance {
	margin: 2em 0;
	padding: 2em 1px;
	text-align: center;
}
.wpcf7 .wpcf7-form .form-input--acceptance input[type="checkbox"] {
	transform: scale(1.4);
}
.wpcf7 .wpcf7-form .form-input--acceptance .wpcf7-list-item label {
	display: flex;
	align-items: baseline;
}
.wpcf7 .wpcf7-form .form-input--acceptance .wpcf7-list-item label .wpcf7-list-item-label {
	padding-left: 0.5em;
}

.wpcf7 .wpcf7-form .wpcf7-submit {
	display: block;
	width: 50%;
	max-width: 480px;
	padding: 10px;
	margin-top: 30px !important;
	margin-left: auto;
	margin-right: auto;
	border: 1px solid var(--elm-color_main);
	border-radius: 0;
	color: #fff;
	background: var(--elm-color_main);
	transition: 0.3s;
}
.wpcf7 .wpcf7-submit:hover {
	color: var(--elm-color_main);;
	background: var(--elm-text-color_light);
}
.wpcf7 .wpcf7-submit:disabled {
	opacity: 0.6;
}

.wpcf7 .wpcf7-form span.at {
	color: #c00;
}
.wpcf7 form .wpcf7-response-output {
	padding: 1em;
	border-width: 4px;
}


/* 関連記事 */
.p-blogCard__caption {
	background-color: #fff;
}



/*------------------------------------------------------------

## Layout

------------------------------------------------------------*/
/* 汎用：Flexアイテムの order制御 */
@media (max-width: 599px) {
	.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column.mobile_col-order-top {
		order: -10;
	}
}

/* アーカイブ カード型／サムネ型記事リスト(PC) 4カラム対応 */
/*@media (min-width: 1020px) {
	.archive.-sidebar-off .-type-card.-pc-col3 .p-postList__item,
	.archive.-sidebar-off .-type-thumb.-pc-col3 .p-postList__item {
		width: 25%;
	}
}*/

.l-mainContent__inner>.post_content {
	margin-bottom: 12em;
}

.top #content {
	margin-bottom: 0;
}
.top .l-mainContent__inner>.post_content {
	margin-bottom: 0;
}



/*------------------------------------------------------------

## Navigation

------------------------------------------------------------*/
.c-gnav {
	max-width: var(--article_size, 900px);
	margin-right: auto;
	margin-left: auto;
}
.-parallel .l-header__gnav .c-gnav {
	justify-content: space-around;
}
.c-gnav>.menu-item {
	font-family: var(--elm-font_serif);
	text-transform: uppercase;
}

/* 固定ヘッダーナビ */
[data-scrolled=true] .l-fixHeader[data-ready] {
	box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.24);
}

/* Gナビアイコン化 */
/* - SP */
.c-spnav>.menu-item._iconize {
	background-size: 24px;
	background-repeat: no-repeat;
	background-position: 20px center;
	color: transparent;
}
.c-spnav>.menu-item._iconize._iconize__linkedin {
	background-image: url(assets/img/icon-linkedin.png);
}
.c-spnav>.menu-item._iconize._iconize__ec {
	background-size: 48px 24px;
	background-image: url(assets/img/icon-ec.png);
}
/* - PC */
.c-gnav>.menu-item._iconize {
	background-size: 24px;
	background-repeat: no-repeat;
	background-position: center;
}
.c-gnav>.menu-item._iconize._iconize__linkedin {
	background-image: url(assets/img/icon-linkedin.png);
}
.c-gnav>.menu-item._iconize._iconize__ec {
	background-size: contain;
	background-image: url(assets/img/icon-ec.png);
}
.c-gnav>.menu-item._iconize .ttl {
	opacity: 0;
}
.c-gnav>.menu-item._iconize._iconize__ec .ttl {
	min-width: 48px;
}

/* パンくずリスト */
#breadcrumb {
/*	display: none !important;*/
}
/* パンくずリスト：特定ノードを非表示化 */
#breadcrumb .p-breadcrumb__item .p-breadcrumb__text[href$="/c/"],
#breadcrumb .p-breadcrumb__item:has(.p-breadcrumb__text[href$="/c/"]) {
	display: none !important;
}


/*------------------------------------------------------------

## Header

------------------------------------------------------------*/

@media (min-width: 600px) {
	.l-topTitleArea {
		min-height: 320px;
	}
}

/* タイトルヘッダー 背景画像 */
.u-obf-cover {
	object-position: 30%;
	/*object-position: 30% 60%;*/
}

.c-postTitle__ttl>small {
	display: block;
	font-size: .6em;
	font-weight: 500;
	padding-top: 0.25em;
	padding-bottom: 0.25em;
	opacity: 0.92;
}

.c-categoryList__link {
	pointer-events: none;
}


/*------------------------------------------------------------

## Contents

------------------------------------------------------------*/

/*
 ### 投稿 汎用
 */

/* single用スタイルとして存在するが固定ページ用に再定義 */
	.p-articleThumb {
		margin: 2em 0;
		text-align: center;
		width: 100%;
	}
	.p-articleThumb__img {

		border-radius: var(--swl-radius--8, 0);
		display: block;
		width: 100%;
	}

.p-articleThumb__img {
	max-width: 600px;
	margin-right: auto;
	margin-left: auto;
}

.p-relatedPosts .p-postList__times {
	display: none;
}


.adstec-productBasicinfo__tables {
	padding: 1em;
	border-top: 1px solid #ededed;
	border-bottom: 1px solid #ededed;
}
.adstec-productBasicinfo__tables>dl {}
.adstec-productBasicinfo__tables>dl dt,
.adstec-productBasicinfo__tables>dl dd {
	display: block;
}

.adstec-product-main-section {}
.adstec-product-main-section .wp-block-media-text__content strong {
	font-weight: bold;
	color: var(--elm-color_sub, #3f1e4c);
}

.adstec-product-spectable-section{}
.adstec-product-spectable-section .wp-block-table tbody tr td:first-of-type {
	color: #6f6f6f;
}


/*
 ### カスタム投稿：ニュース
 */

.single.single-news .c-postTitle__date {
	display: block;
}
.single.single-news .l-articleBottom__section.-related {
	display: none !important;
}


/*
 ### カスタム投稿：アプリケーション事例
 */
.single-appcases .p-articleThumb {
	display: none !important;
}


/*
 ### 固定ページ系
 */

/* コンテンツ下部の余白は基本的に無くす */
#body_wrap.page #content.l-content {
	margin-bottom: 0;
}
/* コンテンツ上部の余白をなくしたいページ用 */
.elm-postname-manufacturers #content,
.elm-postname-対象ページのスラッグ #content {
	padding-top: 0;
}



.c-pageExcerpt {
	font-size: 0.92em;
	text-transform: capitalize;
}

.swell-block-step.adstec-company-history-step .swell-block-step__number {
	width: 36px;
	height: 36px;
	background-color: var(--elm-color_sub) !important;
}
.swell-block-step.adstec-company-history-step:not(.is-style-big):not(.is-style-small)>.swell-block-step__item>.swell-block-step__title {
	min-height: 36px;
}


/*
 ### 固定ページ系 - カテゴリーインデックス系統用
 */

.elm-topname-c {}
.elm-topname-c #content {
	padding-top: 0;
}

.adstec-categoryindex-section {}

.elm-topname-c .post_content .swell-block-fullWide:not(.adstec-categoryindex-section) .is-style-section_ttl {
	color: #421e4e;
	font-family: var(--elm-font_sans-serif, sans-serif);
}
.elm-topname-c .post_content .swell-block-fullWide:not(.adstec-categoryindex-section) .is-style-section_ttl::after {
	content: "";
	position: absolute;
	bottom: 3px;
	left: 0;
	right: 0;
	margin: 0 auto;
	width: 64px;
	height: 8px;
	background-color: #421e4e;
}


.elm-topname-c .p-postList.-type-list .p-postList__thumb {
	box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 12%);
}
@media (min-width: 600px) {
	.elm-topname-c .p-postList.-type-list2 .p-postList__link,
	.elm-topname-c .p-postList.-type-list .p-postList__link {
		align-items: stretch;
	}
	.elm-topname-c .p-postList.-type-list .p-postList__title {
		margin-bottom: 32px;
		font-size: 1.8rem;
		font-weight: bold;
	}
	.elm-topname-c .p-postList.-type-list .p-postList__title::after {
		content: "";
		display: block;
		position: absolute;
		bottom: -25px;
		left: 0;
		width: 60px;
		height: 25px;
		border: none;
		border-left: solid 25px var(--elm-color_main, #053566);
		border-right: solid 25px var(--elm-color_sub, #920563);
	}
}





/*
 ### アーカイブ
 */

.archive.tag .c-pageTitle__subTitle,
.archive.tax-product_maker .c-pageTitle__subTitle,
.archive.tax-news_category .c-pageTitle__subTitle {
	display: none;
}

/*
 ### アーカイブ：ニュース系
 */

.archive.post-type-archive-news {}
.archive.tax-news_category      {}

.archive.post-type-archive-news .-type-card .p-postList__item,
.archive.tax-news_category      .-type-card .p-postList__item {
	width: 100%;
}
.archive.post-type-archive-news .-type-card .p-postList__thumb,
.archive.tax-news_category      .-type-card .p-postList__thumb {
	display: none !important;
}




/*------------------------------------------------------------

## Home

------------------------------------------------------------*/

/* メインビジュアル */

	/* Slider & NEWS */
	.p-mainVisual.-height-full {
		height: auto;
	}
	.p-mainVisual__textLayer {
		position: static;
		left: 0;
		transform: none;
	}
	.p-mainVisual__slider__news.wp-block-columns:not(.is-not-stacked-on-mobile) .wp-block-column+.wp-block-column {
		/*margin-top: 0;*/
	}
	@media (min-width: 782px) {
		.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column:not(:first-child) {
			/*margin-left: 0;*/
		}
	}
	.p-mainVisual__slider__news.wp-block-column.has-background {
		padding-bottom: 18px;
	}
	.p-mainVisual__slider__news .is-style-section_ttl {
		display: flex;
		align-items: baseline;
		justify-content: space-between;
	}
	.p-mainVisual__slider__news .is-style-section_ttl small {
		font-weight: bold;
		font-size: 0.75em;
		font-family: var(--elm-font_serif, serif);
		opacity: 1;
	}
	.p-mainVisual__slider__news .is-style-section_ttl small a {
		padding: 6px 16px;
		border-width: 1px;
		border-style: solid;
		border-radius: 50px;
		color: #fff;
		background-color: var(--elm-color_sub);
		border-color: var(--elm-color_sub);
		transition: all 0.4s;
	}
	.p-mainVisual__slider__news .is-style-section_ttl small a:hover {
		color: var(--elm-color_sub);
		background-color: #fff;
		border-color: var(--elm-color_sub);
	}
	.p-mainVisual__slider__news .p-postList.-type-simple {
		border: none;
	}
	.p-mainVisual__slider__news .-type-simple .p-postList__meta {
		margin: 0 0 2px;
	}
	.p-mainVisual__slider__news .-type-simple .p-postList__link {
		padding: 0.4em 0.25em;
		border: none;
	}
	.p-mainVisual__slider__news .-type-simple .p-postList__title {
		/*font-size: 0.9em;*/
	}
	.p-mainVisual__slider__news .is-style-more_btn {
		text-align: right;
	}
	.p-mainVisual__slider__news .is-style-more_btn a {
		min-width: 160px;
		padding-top: 4px;
		padding-bottom: 4px;
		font-size: 12px;
		text-align: center;
	}
	.p-mainVisual__slider__news .p-postList.-type-simple+.is-style-more_btn {
		margin-top: 0.5em;
	}

	/* TwinVisual */
	.p-mainVisual__twin .wp-block-cover,
	.p-mainVisual__twin .wp-block-cover-image {
		/*
		height: calc(
			(
				var(--swl-mv-height, 100vh)
				- var(--swl-headerH, 0px)
				- var(--swl-adminbarH, 0px)
				- var(--wp-column-mt)
			) / 2
		);
		*/
		height: calc(66.66vw * 0.4 * 1.5);
		min-height: 300px;
		max-height: 600px;
	}
	@media (min-width: 600px) and (max-width: 781px) {
		.p-mainVisual__twin.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
			flex-basis: 100% !important;
		}
		.p-mainVisual__twin.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column+.wp-block-column {
			margin-top: var(--wp-column-mt);
		}
		.p-mainVisual__twin.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column:nth-child(2n) {
			margin-left: 0;
		}
	}
	@media (min-width: 782px) {
		.p-mainVisual.-height-full .p-mainVisual__twin .wp-block-cover,
		.p-mainVisual.-height-full .p-mainVisual__twin .wp-block-cover-image {
			/*height: calc(var(--swl-mv-height, 100vh) - var(--swl-headerH, 0px) - var(--swl-adminbarH, 0px));*/
			max-height: 700px;
		}
	}
	.p-mainVisual__twin .wp-block-cover .swell-block-button a {
		font-weight: bold;
		font-family: var(--elm-font_serif) !important;
	}
	.p-mainVisual__twin .wp-block-cover.cover-imaging .swell-block-button a:hover {
		color: var(--elm-color_main) !important;
	}
	.p-mainVisual__twin .wp-block-cover.cover-bio     .swell-block-button a:hover {
		color: var(--elm-color_sub) !important;
	}

	/* - overlay & hover */
	.p-mainVisual__twin .wp-block-cover .wp-block-cover__background,
	.p-mainVisual__twin .wp-block-cover .wp-block-cover__gradient-background {
		transition: opacity 0.4s;
	}
	.p-mainVisual__twin .wp-block-cover.cover-imaging .has-background-dim{
		border: 1px solid var(--elm-color_main, #000);
	}
	.p-mainVisual__twin .wp-block-cover.cover-imaging .has-background-dim:not([class*=-background-color]) {
		background-color: #010f1d;
	}
	.p-mainVisual__twin .wp-block-cover.cover-bio .has-background-dim {
		border: 1px solid var(--elm-color_sub, #000);
	}
	.p-mainVisual__twin .wp-block-cover.cover-bio .has-background-dim:not([class*=-background-color]) {
		background-color: #27011b;
	}
	.p-mainVisual__twin .wp-block-cover:hover .wp-block-cover__background,
	.p-mainVisual__twin .wp-block-cover:hover .wp-block-cover__gradient-background {
		opacity: 0.12;
	}

	/* Search bar */
	.p-mainVisual__search .wp-block-search__inside-wrapper {
		max-width: 800px;
		margin-left: auto;
		margin-right: auto;
	}
	.p-mainVisual__search .wp-block-search .wp-block-search__input {
		background-color: #f7f7f7;
	}
	.p-mainVisual__search button.wp-block-search__button {
		padding-left: 1.2em;
		padding-right: 1.2em;
		background-color: var(--color_main, #053566);
		color: #fff;
	}




/* Section: PICKUP */
.pickupProducts-section {
	background-color: transparent;
	background-image: url(assets/img/bg-line-01.png);
	background-repeat: no-repeat;
	background-position: top right;
	background-size: 28% 20%;
}
@media (min-width: 1020px) {
	.pickupProducts-section {
		background-size: auto
	}
	.-sidebar-off .pickupProducts-section .-type-card.-pc-col2 .p-postList__item,
	.-sidebar-off .pickupProducts-section .-type-thumb.-pc-col2 .p-postList__item {
		width: 25%
	}
}

/* Section: CASES */
.cases-section {
	background-color: #fff;
	background-image: url(assets/img/bg-line-02.png), url(assets/img/bg-dotted.png);
	background-repeat: no-repeat, repeat;
	background-position: 0 0, 0 0;
	background-size: 28% 20%, auto;
}
@media (min-width: 1020px) {
	.cases-section {
		background-size: auto;
	}
	.-sidebar-off .cases-section .-type-card.-pc-col2 .p-postList__item,
	.-sidebar-off .cases-section .-type-thumb.-pc-col2 .p-postList__item {
		width: 25%
	}
}


/* Section: Featured */
.home-featured-section {
	background-color: transparent;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}
	/* 画像非表示＆レイアウト調整用 */
	.home-featured-section .wp-block-media-text__media {
			display: none !important;
	}
	@media (max-width: 600px) {
		.home-featured-section .is-style-broken.is-stacked-on-mobile .wp-block-media-text__content {
			margin-top: 1px !important;
		}
	}
.home-featured-section .is-style-btn_line a:hover {
	border-color: #fff;
}
/* Section: Featured - NAIT */
.home-featured-section_nait {
	background-image: url(assets/img/bg-featured-nait.jpg?202211a);
}
.home-featured-section_nait .wp-block-media-text .wp-block-media-text__content>.has-background {
	color: var(--elm-text-color_light) !important;
	background-color: var(--elm-color_sub) !important;
	opacity: 0.975;
}
/* Section: Featured - SecureCam */
.home-featured-section_securecam {
	background-image: url(assets/img/bg-featured-securecam.jpg?202211a);
}
.home-featured-section_securecam .wp-block-media-text .wp-block-media-text__content>.has-background {
	color: var(--elm-text-color_light) !important;
	background-color: var(--elm-color_main) !important;
	opacity: 0.975;
}
/* Section: Featured - Testroom */
.home-featured-section_testroom {
	background-image: url(assets/img/bg-featured-testroom.jpg?20220930);
}
.home-featured-section_testroom .wp-block-media-text .wp-block-media-text__content>.has-background {
	color: var(--elm-text-color_light) !important;
	background-color: var(--elm-color_sub) !important;
	opacity: 0.975;
}


/* Section: Manufacture */
.maker-section-navi {}




/*------------------------------------------------------------

## Widget

------------------------------------------------------------*/
.w-frontBottom {
	margin-top: 0;
}

.w-frontBottom .is-style-section_ttl,
.w-pageBottom .is-style-section_ttl,
.w-beforeFooter .is-style-section_ttl,
.w-footer .is-style-section_ttl {
	background: none;
	border: none;
	border-radius: 0;
	color: inherit;
	letter-spacing: .2px;
	padding: 0;
	position: relative;
	text-align: center;
	font-family: var(--elm-font_serif);
}
.w-frontBottom .is-style-section_ttl small,
.w-pageBottom .is-style-section_ttl small,
.w-beforeFooter .is-style-section_ttl small,
.w-footer .is-style-section_ttl small {
	display: block;
	padding-top: 0.25em;
	font-size: .6em;
	font-family: var(--elm-font_sans-serif);
	opacity: 0.8;
}



/*------------------------------------------------------------

## Footer

------------------------------------------------------------*/

.w-beforeFooter {
	margin-top: 0;
	margin-bottom: 0;
}

.gl-footer-company,
.gl-footer-company .wp-block-image {
	text-align: center;
}
@media (min-width: 960px) {
	.gl-footer-company,
	.gl-footer-company .wp-block-image {
		text-align: left;
	}
}






/*------------------------------------------------------------

## WP-SWELL スタイル補完

------------------------------------------------------------*/
.post_content td, .post_content th {
	border-right: 0px solid #ededed;
	border-bottom: 0px solid #ededed;
}

/*------------------------------------------------------------

## WP-SWELL ブロックスタイル

------------------------------------------------------------*/

/* 登録画面 */
.swpm-registration-widget-form {
    background-color: #f2f2f2;
    padding: 20px;
    border-radius: 8px;
    max-width: 400px;
    margin: auto;
}

.swpm-registration-submit {
    font-family: "Roboto", sans-serif;
    text-transform: uppercase;
    background-color: #0073aa;
    width: 100%;
    border: 0;
    padding: 15px;
    color: #FFFFFF;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    border-radius: 4px;
}

.swpm-registration-widget-form table {
    border-collapse: collapse;
    width: auto;
}

.swpm-registration-widget-form td,
.swpm-registration-widget-form tr {
    border: none;
    display: flex;
}

.swpm-registration-widget-form tr td {
    flex: 1;
    padding: 0;
}

/* 入力フィールドとボタンのスタイルを共通クラスで管理 */
.input-field, .swpm-text-field {
    font-family: "Roboto", sans-serif;
    outline: 0;
    background: #f2f2f2;
    width: 100%;
    border: 1px solid #ccc;
    margin: 0 0 15px;
    padding: 15px;
    font-size: 14px;
    border-radius: 4px;
}

/* 特定のラベルを非表示にするスタイル */
.swpm-registration-widget-form .swpm-registration-username-row td:first-child,
.swpm-registration-widget-form .swpm-registration-email-row td:first-child,
.swpm-registration-widget-form .swpm-registration-password-row td:first-child,
.swpm-registration-widget-form .swpm-registration-password-retype-row td:first-child,
.swpm-registration-widget-form .swpm-registration-firstname-row td:first-child,
.swpm-registration-widget-form .swpm-registration-lastname-row td:first-child,
.swpm-registration-widget-form .swpm-registration-membership-level-row {
    display: none;
}

/* ログイン画面 */
.swpm-login-widget-form {
    background-color: #f2f2f2;
    padding: 20px;
    border-radius: 8px;
    max-width: 400px;
    margin: auto;
}

.swpm-login-form-submit {
    background-color: #0073aa;
    color: white;
    padding: 10px 15px;
    border: none;
    border-radius: 4px;
    width: 100%;
    cursor: pointer;
}

.swpm-login-form-submit:hover {
    background-color: #005a87;
}

.swpm-forgot-pass-link a,
.swpm-join-us-link a {
    color: #0073aa;
    text-decoration: underline;
}

.swpm-forgot-pass-link a:hover,
.swpm-join-us-link a:hover {
    color: #005a87;
}

/* join のリンクを変更して表示にする */
/* 既存のテキストを隠す */
.swpm-login-form-register-link {
    visibility: hidden; /* リンクのテキストを隠す */
    position: relative; /* 疑似要素の位置決めの基準点とする */
}

.swpm-login-form-register-link::after {
    content: '会員登録はこちら'; /* 新しいテキスト */
    visibility: visible; /* 疑似要素を表示する */
    position: absolute; /* 親要素に対して絶対位置 */
    top: 0; /* 親要素の上端に配置 */
    left: 0; /* 親要素の左端に配置 */
    white-space: nowrap; /* テキストを折り返さない */
}

/* パスワードリセット画面 */
.swpm-pw-reset-widget-form {
    background-color: #f2f2f2;
    padding: 20px;
    border-radius: 8px;
    max-width: 500px;
    margin: auto;
}

.swpm_label {
    display: block;
    margin-bottom: 5px;
}

.swpm-pw-reset-submit {
    background-color: #0073aa;
    color: white;
    padding: 10px 15px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    width: 100%;
}

.swpm-pw-reset-submit:hover {
    background-color: #005a87;
}

/* 会社情報のラベルを太文字にする */
tr > td[colspan="2"] > label[for="company_info"] {
    font-weight: bold;
	font-size: larger;
	padding: 3px 0;	
}


#swpm-registration-form > table > tbody > tr {
	margin-bottom: 6px;
}

/* ログインページhrタグ装飾 */
/* リセットCSS */
/* 実線 */
.hr1-login {
  border: 0;                  /* 既存のボーダーを消去 */
  height: 5px;                /* 線の太さ */
}

.swpm-forgot-pass-link {
	margin: 1em 0;
}

.swpm-join-us-link {
	margin: 1em 0;
}