/* 通用 */

html {
	font-size: 16px;
	scroll-behavior: smooth;
}
body {
	font-family: 'Noto Sans TC', sans-serif;
}
.font-jp {
	font-family: 'Noto Sans JP', sans-serif;
}
h1,h2,h3,h4,h5,h6,p,dd {
	Margin: 0;
	padding: 0;
}

h1 {
    font-size: 25px;
    line-height: 1.6;
}
h2 {
    font-size: 48px;
    font-weight: 700;
    line-height: 1.6;
}
h3 {
	font-size: 32px;
    line-height: 1.6;
}
a {
	text-decoration: none;
	display: block;
}
a:hover {
	opacity: 0.9;
}
a:link,a:visited {
    color: #c80b16;
}
span {
	display: inline-block;
}
img {
	max-width: 100%;
	height: auto;
}
.pc {
	display: block;
}
.sp {
	display: none;
}
.ec-support-icon {
	text-align: center;
}
.ec-support-icon img {
	height: 25px;
	margin-bottom: 1em;
}
.mb15 {
	margin-bottom: 1.5em;
}
.mb17 {
	margin-bottom: 1.7em;
}
.mb30 {
    margin-bottom: 3em;
}
.mb50 {
    margin-bottom: 5em;
}
.mt60 {
    margin-bottom: 6em;
}

/* section 通用 */
.sec-tit {
	margin-bottom: 40px;
}
.sec-tit h3 {
	text-align: center;
	font-size: 1.5rem;
	font-weight: 500;
}
.section .container {
	padding: 4% 5%;
}
.larger {
	font-size: 1.5em;
}
.bolder {
	font-weight: 600;
}
.contact .banner-5 .container {
    padding: 4% 5%;
}
.contact.fixeditem .banner-5 .container {
    padding: 20px 0;
}

/* HEADER */
.header {
	height: 60px;
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	z-index: 999;
	line-height: 1;
	background-color: #fff;
	box-shadow: 0 1px 10px rgba(0, 0, 0, 0.1);
}
.main-link {
	background-color: #fff;
}
.inner {
	margin: auto;
	padding: 0 30px;
	position: relative;
}
.inner::after {
	content: '';
	width: 0;
	clear: both;
	display: block;
}
.menu {
	float: right;
	text-align: center;
}
.menu li {
	display: inline-block;
	position: relative;
	transition: all .5s;
}
.menu a {
	color: #000;
	font-weight: 500;
	font-size: 1rem;
	padding: 15px 20px;
	display: block;
}
.menu li:hover {
	background-color: #c80b16;
}
.menu li:hover a {
	color: #fff;
}
.top {
	padding: 1% 0;
	position: relative;
	z-index: 3;
	background: #fff;
	box-shadow: 0 0 10px 5px rgba(0, 0, 0, 0.2);
	width: 100%;
}
.logo {
	padding-left: 2%;
}
.logo img {
	width: 50px;
}
.btw_logo img {
    width: 176px;
    padding-right: 15px;
}
.subtitle-sp {
	position: absolute;
	top: 25%;
	left: 17%;
	margin: auto;
}
.subtitle-pc {
	display: none;
}
.subtitle p {
	white-space: nowrap;
	font-size: .9rem;
	margin: 0 0 0 2%;
	padding: 0;
}

/* 開合選單 */
.menu {
	position: absolute;
	width: 100%;
	background: #ffffff;
	left: 0;
	padding: 0;
	top: calc( -100% - 205px);
	z-index: 2;
	transition: all .5s;
}
.menu li {
	display: block;
	border-bottom: 1px solid #dddddd;
}
.menu li:last-child {
	border: none;
}
.menu-wrap {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 0;
	width: 52px;
	height: 52px;
	cursor: pointer;
}
.menu-icon {
	position: absolute;
	width: 32px;
	height: 32px;
	right: 10px;
	top: 14px;
}
.menu-icon span {
	position: absolute;
	height: 4px;
	width: 32px;
	background: #000;
	opacity: .9;
	right: 0;
	transition: all .3s;
}
.menu-icon span:nth-child(1) {top: 0px;}
.menu-icon span:nth-child(2) {top: 10px;}
.menu-icon span:nth-child(3) {top: 20px;}
.menu.act {
	top: 100%;
	margin: 0;
}
.menu-wrap.act .menu-icon span:nth-child(1) {
	transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	top: 10px;
}
.menu-wrap.act .menu-icon span:nth-child(2) {
	opacity: 0;
}

.menu-wrap.act .menu-icon span:nth-child(3) {
	transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-webkit-transform: rotate(-45deg);
	-o-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	top: 10px;
}
.main-link,.inner {
	padding: 0;
}
.menu .contactBtn {
	background-color: #555;
	background-color: #d80c18;
}
.menu .contactBtn a {
	color: #fff;
}

/* main */
.container {
	max-width: 1440px;
	margin: auto;
	height: 100%;
	position: relative;
}

/* banner image */
.banner {
	margin-top: 60px;
}
.banner-1 {
	background: url(../images/FV.jpg) center center no-repeat;
	height: 768px;
}
.banner-2 {
	background: url(../images/pa.jpg) center center no-repeat;
}
.banner-3 {
	background: url(../images/bg.jpg) no-repeat;
	background-position: 85% 50%;
}
.banner-4 {
	background: url(../images/bg2.png) no-repeat;
	background-size: cover;
}
.banner-5 {
	background: url(../images/bg3.png) no-repeat;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	-ms-background-size: cover;
	background-size: cover;
	width: 100%;
}
.banner-6 {
	background: url(../images/bg4.png) no-repeat;
	background-size: cover;
}
.banner-item {
	background-size: cover;
	position: relative;
	background-repeat: no-repeat;
}
.keypoint {
	color: #e7221a;
}
.banner-1 .keypoint {
	font-size: 2rem;
	color: #fff;
}
.banner-content {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	margin: auto;
	transform: translateY(-50%);
	display: flex;
	flex-direction: column;
	padding: 0 1%;
}
.banner-content-left {
	margin-bottom: 1.7em;
}
.banner-info .title, .banner-info .description {
	text-align: center;
	margin-bottom: 0.7em;
	color: #fff;
}
.banner-info .title {
    letter-spacing: 1px;
}
.banner-info .description p {
	font-weight: 100;
	line-height: 1.5;
}
.banner-info .title .sub {
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 1rem;
}
.banner-info .description h3 {
	line-height: 1.8;
	font-size: 1.5rem;
	font-weight: 500;
}
.banner-info p {
	font-size: 0.8rem;
}
.banner-info-item {
	display: flex;
	justify-content: center;
	margin: auto;
}
.banner-info-item .item {
	text-align: center;
	padding: 1% 2%;
	margin: 0 2%;
	border: 1px solid #fff;
	background-color: rgba(0, 0, 0, 0.5);
	color: #fff;
	font-size: .75rem;
}
.banner-info-exp {
	display: flex;
	justify-content: center;
	margin-top: 1em;
}
.banner-info-exp .item {
	width: 100px;
	height: 100px;
	margin: 0 1%;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #fff;
	border-radius: 50%;
	color: #d80c18;
	font-weight: 600;
	text-align: center;
}
.banner-device {
	width: 90%;
	margin: auto;
	margin-bottom: 1.7em;
}
.banner-btn a {
	text-align: center;
	display: block;
	color: #fff;
	padding: 3% 4%;
	width: 75%;
	margin: auto;
	background-color: #d80c18;
	border-radius: 50px;
	transition: .3s;
}
.banner-btn a:hover {
	opacity: 0.9;
}
.redcycleP {
	position: relative;
    font-weight: 600;
}
.redcycleP:after {
	content: "";
	display: block;
	position: absolute;
	height: 10px;
    top: 0;
    width: 100%;
    background-image: url(../images/redcycle.png);
    background-size: auto 100%;
    background-position: center;
    background-repeat: no-repeat;
}

/* paragraph */
.paragraph {
	color: #fff;
	text-align: center;
}
.paragraph p {
	line-height: 1.5;
}

/* Record */
.record {
	background-color: #e3e3e3;
}
.record .title {
	text-align: center;
}
.record .title h4 {
	font-weight: 500;
}
.record>.title h3 {
	font-weight: 400;
}
.record-intro {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	text-align: center;
	margin: 5% 0;
}
.record-intro .item {
	width: 48%;
	margin: 4% 1%;
}
.record-intro .title {
	margin-bottom: 10px;
}
.record-intro h5, .record-intro p {
	font-weight: 400;
	color: #5a5a5a;
	font-size: 0.7rem;
}
.record-intro .content {
	margin-top: 5%;
}

/* ec support pro */
.ec-support-pro .title h3 {
	color: #fff;
	text-align: center;
}
.ec-support-pro .txtBox {
	width: 85%;
	margin: auto;
	background-color: #fff;
	padding: 5%;
	line-height: 1.5;
}
.ec-support-pro .paraBox {
	margin-top: 10%;
	text-align: center;
}
.ec-support-pro .paraPoint {
	text-align: center;
	margin-top: 10%;
	margin-bottom: 10%;
}
.ec-support-pro .paraPoint p {
	font-size: 1.2rem;
}
.ec-support-pro .itembox {
	display: flex;
	flex-wrap: wrap;
}
.ec-support-pro .itembox .item {
	padding: 3% 2%;
	margin: 1%;
	text-align: center;
	background-image: linear-gradient(45deg, #e7221a 60%, #bd1a13);
	color: #fff;
	flex-grow: 1;
}
.ec-support-pro p {
	font-size: 0.9rem;
}

/* ec market scale */
.ec-market-scale .itembox {
	display: flex;
	flex-direction: column;
}
.ec-market-scale .itembox .item {
	margin: 5% 0;
}

/* ec-market-problem */
.ec-market-problem {
    background-color: #f0f0f0;
}

.ec-market-problem .title {
	text-align: center;
}
.ec-market-problem .itembox {
	display: flex;
	flex-direction: column;
	text-align: center;
	align-items: center;
}
.ec-market-problem .item {
	position: relative;
	background-color: #fff;
	margin: 50px 0 10px;
	padding: 50px 10px 10px 10px;
	height: 250px;
	max-width: 240px;
}
.ec-market-problem .item-num {
	border-radius: 50%;
	height: 60px;
	width: 60px;
	margin: -30px auto;
	color: #fff;
	background-color: #333333;
	text-align: center;
	line-height: 60px;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	font-size: 1.3rem;
}
.ec-market-problem .item-title {
	color: #e01f20;
	font-size: 1rem;
	margin-bottom: 1.5em;
}
.ec-market-problem .item-title h4 {
	font-weight: 700;
}
.ec-market-problem .item .item-txt {
	text-align: left;
}
.ec-market-problem .item .item-txt li {
	margin-bottom: 10px;
}
.ec-market-problem .txtbox .title {
	margin-top: 1.7em;
}
.ec-market-problem .txtbox .txt {
	padding: 10px;
	line-height: 1.5;
	text-align: center;
}

/* solution */
.solution .txtbox {
	text-align: center;
	padding: 5%;
}
.solution .txtbox .title {
	margin-bottom: 1.7em;
}
.solution .txtbox .title h3 {
	color: #e7221a;
	font-size: 1.4rem;
}
.solution .txtbox .txt {
	margin: 2em 0;
}
.solution .txtbox .txt h3 {
	font-weight: 700;
}

/* strength */
.strength .title {
	text-align: center;
}
.strength h4 {
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.4;
}
.strength .itembox {
	display: flex;
	flex-wrap: wrap;
}
.strength .item-num {
	border-radius: 50%;
	height: 60px;
	width: 60px;
	color: #fff;
	background-color: #e7221a;
	text-align: center;
	line-height: 60px;
	font-size: 1.3rem;
	margin: auto;
}
.strength .itembox .item {
	text-align: center;
	width: 46%;
	background-color: #fff8de;
	margin: 2%;
	padding: 4% 0;
	border-top: 5px solid #e7221a;
	color: #e7221a;
}
.strength .itembox .item-img img {
	height: 90px;
}
.strength .item-num, .strength .item-title, .strength .item-img {
	margin-bottom: 1em;
}

/* strength-point-box */
.strength-point-item:not(:nth-child(1)) {
	margin: 7% 0;
}
.strength-point-box .title {
	display: flex;
	justify-content: center;
	justify-content: center;
	align-items: center;
	margin-bottom: 1em;
}
.strength-point-box .title .point {
	font-family: 'Montserrat', sans-serif;
	border: 1px solid #000;
	padding: 1% 2%;
	margin-right: 2%;
	font-size: 1rem;
	text-transform: uppercase;
	font-weight: 700;
}
.strength-point-box .title .number {
	font-family: 'Montserrat', sans-serif;
	font-size: 3rem;
	margin-left: 2%;
	color: #e7221a;
	font-weight: 300;
}
.strength-point-box .subtitle {
	text-align: center;
	margin-bottom: 1.7em;
	color: #e7221a;
}
.strength-point-box .subtitle h3 {
	font-weight: 700;
}
.strength-point-box .itembox {
	display: flex;
	flex-direction: column;
    gap: 3%;
}
.strength-point-box .item .item-img {
    margin-bottom: 1.7em;
}
.strength-point-box .item-txt {
    border-left: 5px solid #e7221a;
    padding-left: 3%;
}
.strength-point-box .item-txt .txt p {
    font-size: 0.9rem;
    line-height: 1.5;
    letter-spacing: 1px;
}
.strength-point-box .item-btn a {
    text-align: center;
    color: #fff;
    border-radius: 30px;
    display: block;
    margin: 5%;
    padding: 3%;
    background-color: #e7221a;
}
.strength-point-box .mall dd {
    width: 30%;
    flex-grow: 1;
    text-align: center;
}
.strength-point-box .mall img {
    height: 40px;
}
.strength-point-box .mall-box {
    background-color: #fff8de;
    padding: 2% 5%;
}
.strength-point-box .mall-box p {
    text-align: center;
    color: #e7221a;
    font-weight: 600;
    font-size: 1rem;
}
.strength-point-box .mall {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

/* production */
.production span {
    background-color: #fff;
    position: relative;
    z-index: 2;
}
.production>.container>.title>h3 {
    text-align: center;
}

.production>.container>.title {
    position: relative;
    background-color: #fff;
    z-index: 2;
    display: block;
}

.production>.container>.title:before,
.production>.container>.title:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    width: 30%;
    height: 1px;
    margin: auto;
    background-color: #e7221a;
}

.production>.container>.title:before {
    left: 0;
}

.production>.container>.title:after {
    right: 0;
}

.production .itembox {
    display: flex;
    flex-wrap: wrap;
}

.production .itembox .item {
    text-align: center;
    width: 29.33333%;
    margin: 5% 2%;
}

.production .itembox .item .item-img {
    margin-bottom: 1em;
}

.production .itembox .item .title p {
    color: #e7221a;
    font-size: 0.7rem;
}


/* contact */

.contact .itembox {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

.contact .txt {
    margin: auto;
    text-align: center;
}

.contact .itembox .item p {
    color: #fff;
}

.contact .itembox .item {
    margin-bottom: 3%;
    width: 100%;
    text-align: center;
}

.contact .itembox .item a {
    width: 80%;
    margin: auto;
    color: #fff;
    display: block;
}

.contact .phone,
.contact .mail {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 1em;
}

.contact .phone img,
.contact .mail img {
    height: 20px;
    margin-right: 10px;
}

.contact .phone img {
    height: 30px;
}

.contact .phone h3 {
    font-size: 1.5rem;
}

.contact .mail {
    background-color: #e7221a;
    padding: 10px;
    border-radius: 30px;
    transition: .3s;
}

.contact .mail:hover {
    opacity: 0.9;
}


/* achivement */

.ec-support-pro-achivement .title {
    text-align: center;
    margin-bottom: 1.7em;
}

.ec-support-pro-achivement .title h3 {
    margin-bottom: 1.7em;
	font-weight: 500;
}

.ec-support-pro-achivement .itembox {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.ec-support-pro-achivement .item {
    position: relative;
    text-align: center;
    width: 45%;
    padding: 5% 1%;
    margin: 5% 1%;
    border: 1px solid #c9c9c9;
    border-radius: 0 0 0 30px;
}

.ec-support-pro-achivement .item-num {
    border-radius: 50%;
    height: 60px;
    width: 60px;
    margin: -30px auto;
    top: 0;
    left: 0;
    right: 0;
    color: #fff;
    background-color: #e7221a;
    text-align: center;
    line-height: 60px;
    position: absolute;
    font-size: 1.3rem;
}

.ec-support-pro-achivement .item-title {
    margin-top: 1.5em;
    margin-bottom: 1.2em;
}

.ec-support-pro-achivement .item-txt {
    margin-top: 1.5em;
}

.ec-support-pro-achivement .item-txt p {
    color: #e7221a;
    font-size: 0.9rem;
    font-weight: 400;
	line-height: 1.6;
}

.ec-support-pro-achivement .item:nth-child(2) .item-txt p {
    font-size: 0.8rem;
}


/* case */

.case-item {
    border: 1px solid #ccc;
    border-radius: 0 0 0 30px;
    padding: 2%;
    margin-bottom: 1.5em;
}

.case .title {
    display: flex;
    align-items: center;
    font-size: 0.9rem;
    padding-bottom: 10px;
    border-bottom: 2px solid #ccc;
    margin-bottom: 1.7em;
}

.case .title b,
.case .title h4 {
    margin-right: 10px;
    white-space: nowrap;
}

.case .title b {
    background-color: #333333;
    color: #fff;
    padding: 10px 20px;
}

.case .title h4 {
    color: #9d9d9d;
}

.case .title p {
    color: #e7221a;
	font-weight: 500;
}

.case-item .itembox {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.case-item .itembox .item {
    margin-bottom: 1.5em;
}

.case-txt {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #e9e9e9;
    padding: 5%;
    margin-bottom: 1.7em;
}

.case-txt .point {
    color: #fff;
    padding: 10px;
    font-weight: 500;
    background-color: #e7221a;
    margin-bottom: 1.2em;
}

.case-txt p {
    font-size: 0.9rem;
}


/* service-flow */

.service-flow .title {
    color: #fff;
    text-align: center;
    margin-bottom: 1.7em;
}

.service-flow .title h3 {
    margin-bottom: 1.7em;
}

.service-flow .itembox {
    display: flex;
    /* justify-content: center; */
    flex-direction: column;
    align-items: center;
}

.service-flow .item {
    position: relative;
    text-align: center;
    width: 55%;
    padding: 5% 1%;
    margin: 5% 1%;
    border: 1px solid #c9c9c9;
    height: 200px;
    margin-bottom: 1.7em;
}

.service-flow .item-num {
    height: 50px;
    width: 80px;
    margin: -30px auto;
    top: 0;
    left: 0;
    right: 0;
    color: #fff;
    background-color: #900e0e;
    text-align: center;
    line-height: 50px;
    position: absolute;
    font-size: 1.3rem;
	font-weight: 100;
}

.service-flow .item-title {
    color: #fff;
    margin-top: 1.5em;
    margin-bottom: 1.2em;
}
.service-flow .item-title h4 {
	font-weight: 500;
}

.service-flow .item-txt {
    margin-top: 1.5em;
}

.service-flow .item-txt p {
    color: #fff;
    font-size: 1rem;
    font-weight: 400;
}

.service-flow .item-btn {
    margin-top: 2.5em;
}

.service-flow .item-btn a {
    font-size: 0.9rem;
    text-align: center;
    color: #fff;
    border-radius: 30px;
    display: block;
    margin: 5%;
    padding: 5%;
    background-color: #e7221a;
}


/* voice */

.voice .item {
    width: 100%;
}

.voice .item dt {
    margin-bottom: 1.2em;
}

.voice .item dd {
    margin: 0 auto 1.1em;
}

.voice .company-name img {
    margin: auto;
    height: 35px;
}

.voice .company-site img {
    margin: auto;
    height: 120px;
}

.voice .item-txt dt {
    color: #e7221a;
}

.voice .item-txt dd p {
    font-size: 0.8rem;
    line-height: 1.5;
}


/* FAQ */

.faq .item {
    display: flex;
    padding: 3%;
    border: 1px solid #c9c9c9;
    margin-bottom: 1.2em;
}
.faq .item-title {
    margin-right: 1em;
}
.faq .item-title h3 {
    font-size: 1.5rem;
}
.faq .item-txt {
    display: flex;
    flex-direction: column;
}
.faq .item-txt .title {
    margin-bottom: 1.1em;
}


/* award */
.award {
    background-color: #F1C54B;
}
.award .title {
    text-align: center;
    width: 100%;
}
.award .title h2 {
    line-height: 2;
    font-size: 1.2rem;
	font-weight: 500;
}

/* map */
#branch {
    margin: 0;
    padding: 0;
}
.ttl_area5 {
    width: 100%;
    text-align: center;
    font-size: 20px;
    padding: 10% 2% 5% 2%;
    line-height: 1.2em;
}
.ttl_area5 h2 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.7em;
}
.ttl_area5 p {
    width: 100%;
    text-align: center;
    font-size: 0.8rem;
    font-weight: nomal;
    line-height: 1.3;
}
#branch .branch_box h3 {
    font-size: 20px;
    border-left: 5px solid #c80b16;
    padding: 0 0 0 2%;
    margin: 0 0 3% 0;
    box-sizing: border-box;
}
.map_box {
    text-align: center;
    margin: 0 0 3% 0;
    line-height: 1.8em;
    float: none;
    padding: 0 0 5% 0;
}
.map_box .red {
    font-size: 30px;
    background: url(../images/under_gre.jpg) bottom repeat-x;
}
.branch_inner_box {
    margin: 0 0 20px 0;
}
.branch_inner_box a {
    font-family: Montserrat;
    font-weight: 900;
}
.branch_inner_box table th {
    background: #f1efef;
    padding: 0 3%;
    border-bottom: 5px solid #fff;
    width: 17%;
}
.branch_inner_box table td {
    padding: 3%;
}
.map_box .red {
    font-size: 50px;
    background: url(../images/under_gre.jpg) bottom repeat-x;
}
#branch .branch_box {
    float: none;
    margin: 0 0 7% 0;
    width: 100%;
}


/* inquiry */


/* inquiry
============================================ */

.txtC {
    text-align: center;
}

.mb5 {
    margin-bottom: 5px;
}

.mb25 {
    margin-bottom: 25px;
}

.fmt_must {
    background: #ffeeee;
}

#form_box {
    margin: 0 auto 5%;
    padding: 4% 5% 5%;
    width: 100%;
    box-sizing: border-box;
    background-color: #fff;
}
#form_box p {
	line-height: 2;
}
#form_box table {
    margin: 0 auto;
    width: 100%;
    box-sizing: border-box;
}

#form_box table td input {
    border: 1px solid #ccc;
    padding: 1%;
    width: 100%;
    box-sizing: border-box;
}

#form_box table td textarea {
    border: 1px solid #ccc;
    height: 300px;
    padding: 10px;
    width: 100%;
    box-sizing: border-box;
}

.must_com {
    color: #fff;
    padding: 2px 10px;
    background-color: #c90914;
    border-radius: 5px;
    border: 1px solid #c90914;
    font-size: 12px;
}

#privacy {
    margin: 2% auto 3%;
    width: 94%;
}


/* #form_box #submit {
    background: #eee none repeat scroll 0 0;
    border: 1px solid #ccc;
    border-radius: 20px;
    color: #fff;
    cursor: pointer;
    font-weight: bold;
    margin: 10px auto;
    padding: 10px;
    text-align: center;
    text-shadow: 0 -1px 1px rgba(0, 0, 0, 0.5);
    width: 200px;
} */

#inquiry .inner {
    padding: 5% 0;
    background: url(../images/triangle_red.png) top no-repeat;
    background-size: 10%
}

#form_box table th {
    text-align: left;
    width: 100%;
    display: block;
    padding: 0 0 3% 0;
	font-weight: 400;
}

#form_box table td {
    width: 100%;
    display: block;
    padding: 0 0 5% 0;
}

.must_com {
    padding: 1% 3%;
    font-size: 10px;
}

#privacy {
    margin: 2% auto 3%;
    width: 100%;
}

#privacy .priv_inner {
    background-color: #fff;
    border: 1px solid #dfdfdf;
    margin: 0 auto 30px;
    height: auto;
    padding: 5% 2%;
    overflow-y: visible;
    width: 96%;
}

#privacy .priv_inner a {
    display: block;
    max-width: 100%;
}

#form_box div#submit {
    background: #ab201d;
    border: 1px solid #ccc;
    border-radius: 10px;
    color: #fff;
    cursor: pointer;
    font-weight: bold;
    margin: 10px auto;
    padding: 5%;
    text-align: center;
    text-shadow: 0 -1px 1px rgba(0, 0, 0, 0.5);
    width: 100%;
    font-size: 1rem;
    box-sizing: border-box;
}


/* company */


/* company-sec */

.company-sec {
    padding: 0 30px;
}

.company-sec a {
    color: #2a2a2a;
}

.company-sec ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.company-sec-ttl {
    font-family: 'Overpass', sans-serif;
    font-weight: 600;
    margin-bottom: 40px;
    text-align: center;
    font-size: 1.8rem;
    letter-spacing: 0.02em;
}

.company-sec-ttl span {
    padding-bottom: 10px;
    border-bottom: 2px solid #cc0000;
}

.company-sec-list {
    margin-bottom: 35px;
}

.company-sec-list li {
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px dashed #d2d2d2;
}

.company-sec-list li:last-child {
    margin-bottom: 0;
}

.company-sec-info {
    margin-bottom: 5px;
}

.company-date {
    display: inline-block;
    font-family: 'Overpass', sans-serif;
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: 0.02em;
    border-left: 4px solid #d2d2d2;
    padding-left: 5%;
}

.company-category a {
    font-family: 'Overpass', sans-serif;
    font-weight: 600;
    padding: 1px 5px;
    border: 1px solid #cc0000;
    font-size: 1.0rem;
    letter-spacing: 0.02em;
    line-height: 1.0;
    color: #cc0000;
}

.company-category a:hover {
    color: #cc0000;
}

.company-sec-list-ttl {
    display: inline-block;
    font-size: 1.3rem;
    line-height: 1.6;
}

.company-link-text {
    text-align: right;
}

.pagetop {
    right: 5%;
    z-index: 10000;
    width: 10%;
}

.branch-sec-ttl {
    margin-bottom: 55px;
    text-align: center;
}

.branch-sec-ttl .eng {
    font-family: 'Overpass', sans-serif;
    font-weight: 600;
    color: #cc0000;
    font-size: 1.2rem;
    letter-spacing: 0.05em;
}

.branch-sec-ttl .jpn {
    display: block;
    font-size: 2rem;
    line-height: 1.6;
}


/* works */

.works .item img {
    height: 20px;
}

.works .itembox {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.works .itembox .item {
    margin: 20px 10px;
}


/* footer */

.service {
    background-color: #dcdcdc;
	padding-bottom: 3%;
}

.service ul.list-item {
    list-style-image: url(../images/square-red.png);
    padding-left: 10%;
    line-height: 1.4;
}

.service ul.list-item li.note {
    list-style-type: none;
    list-style-image: url(../images/note_icon.svg);
}

.service ul.list-item li.note:hover {
    opacity: 0.8;
}

.service ul.list-item li.note img {
    list-style: none;
    height: 15px;
    padding-left: -2em;
    margin-top: 0;
}

.service a {
    color: #333333;
}

.service a:hover {
    color: #d70c19;
}

.service img {
    height: 30px;
}

dl.list-item {
    text-align: center;
}

dl.list-item dt {
    font-size: 0.9rem;
}

.copyright {
    text-align: center;
    background-color: #333333;
    color: #fff;
    font-weight: 300;
}

.service .service-list {
    background-color: #fff;
}

.service-list-item {
    list-style: url(../images/circle.png);
}

.service-list {
    padding: 2% 0;
    border-radius: 0 0 0 40px;
    margin-bottom: 10%;
    box-sizing: border-box;
}

.service .service-list dd {
    border: 0;
    text-align: center;
    line-height: 1.5;
    color: #d70c19;
    font-size: 1.1rem;
    font-weight: 500;
    margin: auto;
    box-sizing: border-box;
}

.service-list-inner {
    width: 100%;
    padding: 2%;
    box-sizing: border-box;
}

/* thanks page */
#thanks {
    padding: 6vh 0;
}
#thanks p {
    line-height: 2;
}