/*
Theme Name: AGI
Author: AD5
Author URI: http://ad5.jp/
Version: 1.0
Text Domain: agi
*/

/* -------------------------
標準化
------------------------- */

@charset "utf-8";

@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {margin:0; padding:0; border:0; outline:0; font-size:100%; vertical-align:baseline; background:transparent;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display:block;}
ul, ol {list-style:none;}
sup {font-size: .6em}
blockquote, q {quotes:none;}
blockquote:before, blockquote:after, q:before, q:after {content:''; content:none;}
a {margin:0; padding:0; font-size:100%; vertical-align:baseline; background:transparent; outline:none;}
del {text-decoration:line-through;}
abbr[title], dfn[title] {border-bottom:1px dotted; cursor:help;}
table {border-collapse:collapse; border-spacing:0;}
input, select {vertical-align:middle;}
img {vertical-align:bottom; border:none; font-size:0; line-height:0;}
em {font-style:normal;}
body {-webkit-text-size-adjust:none; font-size:16px; font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Hiragino Sans", "Noto Sans CJK JP", "Original Yu Gothic", "Yu Gothic", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Sans Emoji";}
address {font-style:normal;}
input,select,textarea,button {font-size: 100%;}
*, *::before, *::after {box-sizing: border-box;}
.nowrap {white-space: nowrap;}

.fs-11 {font-size: 1.1em;}
.fs-12 {font-size: 1.2em;}
.fs-13 {font-size: 1.3em;}

/* -------------------------
汎用
------------------------- */

.bold {font-weight: bold;}

.m20 {margin: 20px !important;}
.m30 {margin: 30px !important;}
.m30 {margin: 30px !important;}

.mt10 {margin-top: 10px !important;}
.mt20 {margin-top: 20px !important;}
.mt30 {margin-top: 30px !important;}
.mt40 {margin-top: 40px !important;}
.mt50 {margin-top: 50px !important;}
.mt60 {margin-top: 60px !important;}
.mt80 {margin-top: 80px !important;}
.mt40-minus {margin-top: -40px !important;}

.mb10 {margin-bottom: 10px !important;}
.mb20 {margin-bottom: 20px !important;}
.mb30 {margin-bottom: 30px !important;}
.mb40 {margin-bottom: 40px !important;}
.mb50 {margin-bottom: 50px !important;}

.ml20 {margin-left: 20px !important;}
.ml30 {margin-left: 30px !important;}
.ml40 {margin-left: 40px !important;}

.mr10 {margin-right: 10px !important;}
.mr15 {margin-right: 15px !important;}
.mr20 {margin-right: 20px !important;}
.mr30 {margin-right: 30px !important;}
.mr40 {margin-right: 40px !important;}
.mr50 {margin-right: 50px !important;}

.mr10p {margin-right: 10% !important;}

.mlr5p {margin-left: 5%; margin-right: 5% !important;}
.mlr10p {margin-left: 10%; margin-right: 10% !important;}

.mlr20 {margin-left: 20px; margin-right: 20px !important;}
.mlr30 {margin-left: 30px; margin-right: 30px !important;}
.mlr40 {margin-left: 40px; margin-right: 40px !important;}

.pb10 {padding-bottom: 10px !important;}
.pb15 {padding-bottom: 15px !important;}
.pb20 {padding-bottom: 20px !important;}
.pb30 {padding-bottom: 30px !important;}
.pb40 {padding-bottom: 40px !important;}
.pb50 {padding-bottom: 50px !important;}

.w100p {width: 100% !important;}

.tal {text-align: left !important;}
.tac {text-align: center !important;}
.tar {text-align: right !important;}
.clearfix::after {
   content: "";
   display: block;
   clear: both;
}
.vam {vertical-align: middle;}

.fz80 {font-size: 80%;}
.inline-b {display: inline-block;}
.color-gray {color: #555;}

.text-line-through {text-decoration: line-through;}

.overlink{position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 100%; height: 100%;}

.flex-direction-column {flex-direction: column;}

/* -------------------------
全体
------------------------- */

body {
  background-color: #EAEAEA;
}

#base {
  width: 1060px;
  margin: 0 auto;
  padding: 0;
  background-image: url(/common/img/bg.png);
  background-position: center;
  background-repeat: repeat-y;
}

/* -------------------------
ヘッダ
------------------------- */

.header{
  margin: 0 50px;
  position: relative;
  /* background-image: url(img/header_bg.png); */
  background-position: left top;
  background-repeat: no-repeat;
  position: relative;
}

.header-tagline{
  font-size: 70%;
  padding-top: 30px;
}

.header-logo{
  padding-bottom: 85px;
}


.header-nav > li{
  float: left;
  width: 152px;
  height: 50px;
  position: relative;
}

.header-nav　{
  display: none;
  background: #dedede;
  position: absolute;
  top: 48px;
  left: 0;
}

.header-nav-children {
  display: none;
  position: absolute;
  z-index: 99;
  left: 0;
  top: 48px;
  background: #EEE;
}

.header-nav-children a{
  color: #333;
  font-size: 13px;
  font-weight: bold;
  border: solid 1px #ccc;
  text-align: left;
  text-decoration: none;
  width: 172px;
  padding: 10px 7px;
  display: block;
}

.header-nav li.header-nav-cart {
  width: 45px;
}

.header-nav li.header-nav-cart a {
  display: block;
  position: relative;
  width: 45px;
  height: 45px;
  border-bottom: 1px solid #AAA;
  text-decoration: none;
  text-align: center;
  color: #666;
}

.header-nav-cart-text {
  display: block;
  text-align: left;
  height: 15px;
  font-size: 10px;
  color: #CCC;
  font-weight: bold;
}

.header-nav li.header-nav-cart i {
  line-height: 25px;
  font-size: 20px;
}

.header-nav-cart-mark {
  display: none;
  position: absolute;
  right: 0;
  top: 0;
  width: 16px;
  height: 16px;
  text-align: center;
  line-height: 16px;
  font-size: 14px;
  border-radius: 8px;
  background: #F60;
  color: #FFF;
}

.header-nav li.header-nav-cart.has-cart span {
  display: block;
}

/*
.header-nav li:hover .header-nav-children{
  display: block;
}
*/

.header-utility{
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
}

.header-utility-social{
  float: left;
  width: 350px;
  padding-top: 4px;
}

.header-utility-social-facebook{
  float: left;
  margin: 0 20px 20px 20px;
}

.header-utility-social-twitter{
  float: left;
  margin-bottom: 20px;
}

.header-utility-language {
    margin: 20px 0 0;
    clear: both;
    overflow: auto;
}
.header-utility-language a {float: right; text-decoration: none; color: #000; font-size: 14px;}

/*
.header-utility-language p{
  color: #444444;
  border: 1px solid #cdcdcd;
  background: #fff url(/common/img/arrow3.gif) no-repeat scroll right top;
  padding-left: 10px;
  height: 26px;
  line-height: 24px;
}

.header-utility-language-select{
  display: none;
}

.header-utility-language-select a{
  color: #444444;
  display: block;
  text-decoration: none ;
  padding-left: 10px;
  height: 26px;
  line-height: 24px;
}

.header-utility-language-select li{
  background: #ffffff;
  height: auto;
  border: 1px solid #cdcdcd;
}*/

.header-utility-inquiry{
  clear: both;
  /* width: 570px; */
  position: absolute;
  top: 45px;
  right: 0px;
}

.header-utility-inquiry > img {
    width: 140px;
}

.header-utility-inquiry-phone {
  display: block;
  float: left;
}
.header-utility-inquiry-button {
  display: block;
  float: left;
  margin-left: 3px;
}

.header-utility-search{
  font-size: 12px;
  line-height: 26px;
  box-sizing: border-box;
  text-align: center;
  margin-top: 10px;
  position: absolute;
  top: 80px;
  right: 0;
}

.header-utility-search-tab {
  background: #DDD;
  border-radius: 3px 3px 0 0;
  border-bottom: 2px solid #000;
  display: block;
  float: left;
  padding: 1px 5px;
  margin-right: 1px;
  width: 109px;
}

.header-utility-search-tab.__active {
  background: #000;
  color: #FFF;
}

.header-utility-search-form {
  display: none;
  width: 327px;
  margin: 0 1px;
  padding: 10px;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.4);
  clear: both;
}

.header-utility-search-form.__active {
  display: block;
  position: relative;
}

.header-utility-search-form button{
  position: absolute;
  top: 16px;
  right: 25px;
  border: none;
}

.header-utility-search-form input{
  width: 100%;
  height: 35px;
  font-size: 5px;
}

/* -------------------------
コンテナ
------------------------- */
.container {
  width: 960px;
  margin: 20px auto;
}

.primary {
  float: left;
  width: 780px;
}

.primary-inquiry{
  position: relative;
  margin-top: 20px;
}

.primary-inquiry-download{
  position: absolute;
  top: 317px;
  left: 35px;
}

.primary-inquiry-contact{
  position: absolute;
  top: 317px;
  left: 285px;
}

.primary-inquiry-estimates{
  position: absolute;
  top: 317px;
  right: 35px;
}

.primary-inquiry-product{
  position: absolute;
  bottom: 165px;
  left: 200px;
  font-size: 13px;
  line-height: 20.8px;
}

.primary-inquiry-red{
  color: #ff0000;
}

.primary-inquiry-nearest{
  position: absolute;
  bottom: 33px;
  left: 88px;
  font-size: 14px;
  line-height: 22.4px;
}

.page-title {
  margin-bottom: 10px;
}

.page-title-default {
  padding: 30px;
  line-height: 30px;
  background: #000;
  font-size: 24px;
  font-family: serif;
  font-weight: normal;
  color: #FFF;
  border: 5px solid #333;
  box-shadow: 0 0 5px 1px rgba(255,255,255,0.2) inset;
  background: linear-gradient(6deg, #444, #000 20%, #222 50%, #333 51%, #888);
}

.section-title-default {
  padding: 5px 0 5px 10px;
  border-bottom: #000 solid 2px;
  font-weight: normal;
  font-size: 18px;
  position: relative;
  line-height: 25px;
  margin-bottom: 20px;
}

.section-title-default + .breadcrumb {margin-top: -20px;}

.section-title-default::before {
  content: "";
  display: block;
  width: 5px;
  height: calc(100% - 10px);
  background: #008;
  position: absolute;
  top: 5px;
  left: 0;
}

.section-title-default small {
  display: block;
  font-size: 14px;
  line-height: 20px;
  color: #333;
}


.section-default-download{
  margin: 20px 0 40px 20px ;
}

.section-default-download-logo{
  float: left;
  margin-right: 10px;
  line-height:20.8px
}

.section-default-download-pamphlet{
  width: 760px;
  line-height:20.8px;
  font-size: 13px;
}


.section-default-download-pamphlet::after{
  content: "";
  clear: both;
}

.breadcrumb-wrapper {
  background: #00254E; /* #29415A */
  padding-left: 20px;
}

/* breadcrumb-wrapperのタグが親要素にあれば文字ショック変更 */
.breadcrumb-wrapper > .breadcrumb {color: #fff; font-size: 14px;}
.breadcrumb-wrapper > .breadcrumb a {color: #fff; font-size: 14px;}

.breadcrumb {
  text-align: left;
  font-size: 13px;
  padding: 3px 20px 7px 0px;
}

.breadcrumb li:before{
  content:"\0bb";
  padding: 0 10px;
  font-size: 18px;
}


.breadcrumb li:first-child::before{
  display: none;
}

.breadcrumb li{
  display: inline-block;
}

.PageTop {
  clear: both;
  text-align: right;
  font-size: 80%;
}

.nav-links {margin-top: 2rem;}
.pager-default {text-align: center;}
.pager-default h2 {display: none;}
.pager-default .page-numbers {display: inline-block; width: 30px; border: 1px solid #000; line-height: 30px; text-align: center; text-decoration: none; color: #000;}
.pager-default .page-numbers.current {background: #000; color: #FFF;}
.pager-default .page-numbers.prev,
.pager-default .page-numbers.next {width: 50px;}
.pager-default .page-numbers.dots {border: none;}

/* -------------------------
サイドバー
------------------------- */

.sidebar {
  float: right;
  width: 150px;
}

.sidebar-banners li{
  margin-bottom: 10px;
}

.sidebar-banners img{
    width: 100%;
    border: 1px solid #999;
    box-sizing: border-box;
}

.sidebar-nav-title{
  margin-bottom: 5px;
  background: #B6CEEF;
  line-height: 20px;
  padding: 10px;
  font-weight: normal;
  font-size: 13px;
}

.sidebar-nav-list li{
  font-size: 10px;
  padding: 2px 5px;
}

.sidebar-nav-list {
  margin-bottom: 10px;
}


.PageTop a {
  text-align: right;
  padding: 0 0 0 20px;
  background-image: url(/common/img/icon/pagetop.png);
  background-position: left 50%;
  background-repeat: no-repeat;
}

/* -------------------------
フッター
------------------------- */

.footer{
  margin: 20px 7px 0;
  border-top: 2px solid #CCCCCC;
}

.footer-banners{
  /* width: 1046px; */
  /* height: 200px; */
  padding: 20px 0;
}

.footer-banners ul {
    display: flex; flex-wrap: wrap; gap: .6rem 1%; justify-content: center; max-width: 1300px; margin: 0 auto; padding: 0 2%;
}
.footer-banners li{
    width: 18.8%; text-align: center; border: 1px solid #ddd;
}
.footer-banners li a {
    display: block;
}
.footer-banners li img {
    width: 100%;
}

.footer-nav{
  background-color: #242020;
  color: #fff;
  text-align: left;
  padding: 40px 70px;
}

.footer-nav-title{
  margin-bottom: 10px;
}

.footer-nav-list li::before {
  content: "\f0da";
  margin-right: 5px;
  display: inline-block;
  font: normal normal normal 14px/1 FontAwesome;
  font-size: inherit;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.footer-nav-list li a{
 text-decoration: none;
 color: #fff;
 font-size: 13px
 ;
}

.footer-nav-list .space {margin-top: 1rem;}

.footer-nav-column{
  float: left;
  width: 300px;
  margin-bottom: 50px;
}

.footer-nav-search{
  clear: both;
  position: relative;
  width: 500px;
  padding-bottom: 40px;
}

.footer-nav-search select{
  font-size: 13px;
  height: 35px;
  line-height: 36px;
  width: 240px;
  float: left;
  margin-right: 5px;
}

.footer-nav-search input{
  border-radius: 5px;
  font-size: 13px;
  height: 35px;
  line-height: 36px;
  width: 240px;
  float: left;
}

.footer-nav-search button{
  position: absolute;
  top: 8px;
  right: 22px;
  border: none;
}

.footer-copyright{
  background: #EFF1F1;
  padding: 20px;
  text-align: center;
}

/* 旭製作所の事業 */
/* .bk_gray{background: #ebebeb;} */
.group-list-mgb0 {margin-bottom: -40px;}
.footer-pursuing_h6 {font-size: 28px; text-align: center; margin-bottom: 20px;}
.footer-pursuing-wrapper { width: 90%; max-width: 1500px; margin-left: auto !important; margin-right: auto !important;}
.footer-pursuing_items {display: flex; display: -webkit-flex; flex-wrap: wrap; -webkit-flex-wrap: wrap; justify-content: space-between; -webkit-justify-content: space-between;}
.footer-pursuing_items a { flex-basis: 24%; -webkit-flex-basis: 24%; max-width: 24%; border: solid 1px #ccc;}
.footer-pursuing_items img {width: 100%;}
.footer-home-copyright {text-align: center;}

.footer-wrapper {padding: 40px 0;}

/* -------------------------
管理画面から入力する本文
------------------------- */
.editor-content h2 {font-size: 20px; margin-bottom: 15px; margin-top: 45px;}
.editor-content h3 {font-size: 18px; margin-bottom: 15px; margin-top: 30px;}
.editor-content h4 {font-size: 16px; margin-bottom: 15px; margin-top: 15px;}
.editor-content h2:first-child,
.editor-content h3:first-child,
.editor-content h4:first-child {margin-top: 0;}
.editor-content h2 + h3,
.editor-content h2 + h4,
.editor-content h3 + h4 {margin-top: 0;}
.editor-content p {font-size: 15px; margin-bottom: 15px;}
.editor-content ul {margin-bottom: 15px; padding-left: 21px; list-style-type: disc;}
.editor-content ol {margin-bottom: 15px;  padding-left: 21px; list-style-type: decimal;}
.editor-content li {margin-bottom: 10px;}
.editor-content img {max-width: 100%; height: auto;}
.editor-content img.aligncenter {display: block; margin: auto; max-width: 100%; height: auto;}
.editor-content img.alignright {float: right; margin-left: 10px; max-width: 48%; height: auto;}
.editor-content img.alignleft {float: left; margin-right: 10px; max-width: 48%; height: auto;}
.editor-content hr {clear: both; border: none;}
.editor-content *:last-child {margin-bottom: 0;}

.editor-table-default {width: 100%; margin-bottom: 15px;}
.editor-table-default th,
.editor-table-default td {padding: 5px 10px; border: 1px solid #AAA; line-height: 1.2; vertical-align: middle;}
.editor-table-default tbody th, .editor-table-default thead th {min-width: 150px; background: #EEE; text-align: center;}
.editor-table-default thead th,
.editor-table-default tfoot th {background: #DDD;}
.th-width-small tbody th {width: 150px;}
.th-width-medium tbody th {width: 250px;}
.th-width-large tbody th {width: 350px;}
.editor-table-blue {width: 100%; margin-bottom: 15px;}
.editor-table-blue th,
.editor-table-blue td {padding: 5px 10px; border: 1px solid #88B; vertical-align: middle;}
.editor-table-blue tbody th {min-width: 150px; background: #EEF;}
.editor-table-blue thead th {background: #226; color: #FFF;}
.editor-table-blue tfoot th {background: #DDF;}
.editor-table-baloon {width: 100%; margin-bottom: 5px;}
.editor-table-baloon tr {margin-bottom: 15px;}
.editor-table-baloon th, .editor-table-baloon td {padding: 10px 20px; border-bottom: 10px solid #FFF; vertical-align: middle;}
.editor-table-baloon th, .editor-table-baloon td:first-child {position: relative; width: 200px; text-align: center; background: #226; color: #FFF;}
.editor-table-baloon th::after, .editor-table-baloon td:first-child::after {content: ""; position: absolute; right: -20px; top: 50%; display: block; width: 20px; height: 20px; margin-top: -10px; border: 10px solid transparent; border-left-color: #226;}
.editor-table-case {width: 75%; margin: 0 auto;}
.editor-table-case td {line-height: 2em; vertical-align: middle; padding: 5px;}
.editor-table-case td:last-child {text-align: right;}
.td-6-4 td:first-child {width: 60%;}
.td-7-3 td:first-child {width: 70%;}
.td-img-100 td img { width: 100px; }
.td-bdb td {border-bottom: 1px solid #89b;}

.editor-box-default {margin-bottom: 15px; padding: 15px 25px; border: 1px solid #CCC;}
.editor-box-shade {margin-bottom: 15px; padding: 15px 25px; background: #EEE;}

.editor-button-wrap {margin-bottom: 15px; text-align: center;}
.editor-button {display: inline-block; min-width: 300px; padding: 5px 15px; text-align: center; line-height: 30px; text-decoration: none; border-radius: 5px;}
.editor-button-blue {border: 2px solid #008; background: linear-gradient(#00C, #008 50%); color: #FFF;}
.editor-button-red {border: 2px solid #800; background: linear-gradient(#C00, #800 50%); color: #FFF;}
.editor-button-green {border: 2px solid #060; background: linear-gradient(#0A0, #060 50%); color: #FFF;}
.editor-icon {margin: 0 5px;}
.editor-icon:first-child {margin-left: 0;}

.editor-blocks {display: flex; margin-bottom: 15px; flex-wrap: wrap; justify-content: space-between; align-items: flex-start;}
.editor-block {margin-bottom: 15px; flex-grow: 0; flex-shrink: 0;}
.editor-block--1-2 {flex-basis: 48%;}
.editor-block--1-3 {flex-basis: 31%;}
.editor-block--2-3 {flex-basis: 65%;}

.editor-title-background-black {color: #fff !important; font-weight: normal; background-color: #000 !important; padding: 15px;}
.editor-note-default, .editor-note-default p {font-size: .9rem !important;}

/* 採用情報 recruit */

.editor-recruit--wrapper {margin: 0 4rem;}
/*
.editor-recruit--title {background-color: #555; color: #fff;}
*/
/* タイトルバック横線スタイル */
/* .editor-recruit--title {
    margin-bottom: 1.5rem !important;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.5rem !important;
	text-align: center;
    font-weight: normal;
}
.editor-recruit--title::before,
.editor-recruit--title::after {
	content: '';
	width: 70px;
	height: 3px;
	background-color: #000011;
}
.editor-recruit--title::before {
	margin-right: 20px;
}
.editor-recruit--title::after {
	margin-left: 20px;
} */

/* 下線スタイル */
.editor-recruit--title {
    border-bottom: 1px solid #555;
	font-size: 1.2rem !important;
    color: #333;
    padding: .5rem 1rem .3rem 0;
    margin-top: 2.5rem !important;
    position: relative;
}
.editor-recruit--title span {
	font-size: 1rem !important;
    color: #666;
    margin-left: .5rem;
}
/* .editor-recruit--title:before {
    display: inline-block;
    content: "";
    margin: .3rem .3rem .3rem 0;
    width: 1.2rem;
    height: 1.2rem;
    vertical-align: top;
    border-radius: 50%;
    background-color: #333;
} */
/* 斜線下線スタイル */
/*
.editor-recruit--title:after {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 10px;
    content: '';
    background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
    background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
    background-size: 7px 7px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
*/

.editor-recruit--box {display: flex; justify-content: space-between;}
.editor-recruit--box--image {width: 30%; position: relative; /*padding-top: 20%; margin-bottom: -20%;*/}
.editor-recruit--box--image img {width: 100%; /*height: 100%; position: absolute; top: 0;*/ object-fit: cover;}
.editor-recruit--box--text {width: 67%;}
.editor-recruit--instruction {margin-bottom: 1rem;}
.editor-recruit--option-box {padding-top: .5rem; border-top: 1px solid #bbb;}
.editor-recruit--location, .editor-recruit--experience { margin-bottom: .4rem; font-size: .85rem; display: flex;}
.editor-recruit--location span, .editor-recruit--experience span{
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #666;
    border-radius: 5px;
    color: #fff;
    padding: .15rem;
    margin-right: .5rem;
    min-width: 10%;
    text-align: center;
    font-size: .75rem;
}
.editor-recruit--location {}
.editor-recruit--experience {}

@media screen and (max-width: 980px) {
    .editor-recruit--wrapper {margin: 0;}
    .editor-recruit--title {border-bottom: 10px solid #333;}
}

@media screen and (max-width: 680px) {
    .editor-recruit--box {display: block;}
    .editor-recruit--box--text, .editor-recruit--box--image {width: 100%; padding-top: 0; margin-bottom: 0;}
    .editor-recruit--box--image img {position: relative;}
    .editor-recruit--instruction {width: 100%; margin-top: 1rem;}
    .editor-recruit--location span, .editor-recruit--experience span{min-width: 25%;}
}

/* 下記はeditor-style.css, page-flexible.css, product.cssも変更要 */
.wysiwyg-h4 {color: #2b3f78; font-size: 1.2rem; font-weight: 600; margin-top: 1.5em; margin-bottom: 0.5em;}
.wysiwyg-uppercase {font-size: 1.4rem;}
.wysiwyg-primary {color: #df3400; font-weight: 500; }
.wysiwyg-small {font-size: .9rem; }

.form-lead {margin: 20px;}
.form-table {margin-bottom: 20px;}
.form-table-full {width: 98%;}
.form-table th {width: 25%; padding: 15px 5px; text-align: left; line-height: 20px; vertical-align: top; color: #008;}
.form-table td {width: 75%; padding: 5px;}
.form-table-full td, .form-table_inner {width: 100%;}
.form-table td p {margin-bottom: 10px;}
.form-table td p:last-child {margin-bottom: 0;}
.form-error {padding: 5px 10px; line-height: 30px; color: #F00; font-weight: bold; background: #FEE;}
.form-output {padding: 5px 0; line-height: 30px;}

input.form-input-small {width: 30%; max-width: 150px; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
select.form-input-small {max-width: 100%; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
input.form-input-regular {width: 100%; max-width: 300px; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
select.form-input-regular {width: 100%; max-width: 300px; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
textarea.form-input-regular {width: 100%; height: 80px; padding: 4px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
input.form-input-medium {width: 100%; max-width: 500px; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
select.form-input-medium {width: 100%; max-width: 500px; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
textarea.form-input-medium {width: 100%; height: 120px; padding: 4px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
input.form-input-large {width: 100%; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
select.form-input-large {width: 100%; height: 40px; padding: 4px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
textarea.form-input-large {width: 100%; height: 160px; padding: 4px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px;}
label.form-input-regular {display: inline-block; margin-right: 5px; height: 40px; margin-bottom: 10px; padding: 4px 10px; line-height: 30px; font-size: 16px; border: 1px solid #AAA; border-radius: 5px; }
label.form-input-regular input {vertical-align: baseline;}

.form-label-fat {display: inline-block; padding: 4px 10px; line-height: 30px; border: 1px solid #AAA; border-radius: 5px;}

.form-icon-required::before {content: "*"; color: #800;}
.form-label-required {color: #800; font-size: 0.8em;}
.form-label-optional {color: #88A; font-size: 0.8em;}

.form-button-wrap {margin-bottom: 20px;}
.form-button-wrap::after {content: ""; display: block; clear: both;}
.form-buttom-medium, .form-buttom-large {width: 200px; display: inline-block; padding: 10px; text-align: center; line-height: 30px; font-size: 16px; border-radius: 5px; text-decoration: none;}
.form-buttom-large {width: 300px;}
.form-button-single {display: block; margin: auto;}
.form-button-left {float: left;}
.form-button-right {float: right;}
.form-button-submit {border: 2px solid #800; background: linear-gradient(#C00, #800 50%); color: #FFF;}
.form-button-submit-flat {background-color: #888; color: #ffffff; margin: 0 auto; padding: 12px; border: none; border-radius: 30px; position: relative;}
.form-button-submit-flat:hover {background-color: #696969; box-shadow: 0px 2px 2px 1px #fff; cursor: pointer;}
.form-button-plain {border: 2px solid #CCC; background: linear-gradient(#FFF, #EEE 50%); color: #000;}

/*
 * ショッピングカート
 */
.shopping-lead {background: #ffe2c0; padding: 20px 30px;}
.shopping-lead a {color: #D70;}

.shopping-table-cart {width: 100%; margin-bottom: 20px;}
.shopping-table-cart th,
.shopping-table-cart td {padding: 5px 10px; border: 1px solid #000; vertical-align: middle;}
.shopping-table-cart thead th {text-align: center; background: #EEE;}
.shopping-table-cart tfoot th {text-align: right; background: #EEE;}
.shopping-table-cart-image {width: 20%; text-align: center;}
.shopping-table-cart-image img {width: auto; height: auto; max-width: 100%; max-height: 200px;}
.shopping-table-cart-product {width: 44%;}
.shopping-table-cart-product-code {font-weight: bold;}
.shopping-table-cart-product-title {font-weight: bold;}
.shopping-table-cart-product-spec {color: #888;}
.shopping-table-cart-price {width: 12%; text-align: right; white-space: nowrap;}
.shopping-table-cart-quantity {width: 12%; text-align: center; white-space: nowrap;}
.shopping-table-cart-quantity input {width: 70px; height: 30px; padding: 3px; text-align: right; line-height: 22px; border: 1px solid #AAA; border-radius: 5px;}
.shopping-table-cart-quantity button {width: 50px; height: 30px; padding: 3px; text-align: center; line-height: 22px; border: 1px solid #AAA; border-radius: 5px; background: #CCC;}
.shopping-table-cart-subtotal {width: 12%; text-align: right; white-space: nowrap;}

.shopping-table-order {width: 100%; margin-bottom: 20px;}
.shopping-table-order th {width: 20%; min-width: 150px; padding: 5px 10px; background: #EEE; border: 1px solid #FFF; vertical-align: middle;}
.shopping-table-order td {padding: 5px 10px; border: 1px solid #FFF;}

.shopping-message-success {margin: 15px 0; padding: 10px 20px; border: 1px solid #0A0; background: #EFE; color: #0A0;}
.shopping-message-error {margin: 15px 0; padding: 10px 20px; border: 1px solid #C00; background: #FEE; color: #C00;}

.shopping-button {display: flex; flex-wrap: wrap; justify-content: space-between; margin-bottom: 20px;}
.shopping-button-back {width: 200px; height: 40px; text-align: center; line-height: 38px; border: 1px solid #000; background: #FFF; color: #000; text-decoration: none;}
.shopping-button-proceed {width: 200px; height: 40px; text-align: center; line-height: 38px; border: 1px solid #000; background: #000; color: #FFF; text-decoration: none; cursor: pointer;}

/* 見積書モーダル  */
.modal-window {display: none; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 300px; height: 300px; background-color: #FFF; border-radius: 5px; z-index: 11; padding: 2rem;}
.__open {margin-right: 10px;}
.__close {position: absolute; top: -1px; right: -1px;}
.overlay {display: none; position: fixed; top: 0; left: 0; background-color: rgba(0, 0, 0, 0.5); width: 100%; height: 100%; z-index: 10;}
.form {text-align: center;}
.input {margin: 40px auto; width:230px; height: 40px;}

.float-cart {position: fixed; left: 0; bottom: 0; z-index: 99999; width: 100%; height: 50px; padding: 10px 20px; background: rgba(0,0,0,0.5);}
.float-cart span {float: left; line-height: 30px; font-size: 16px; color: #FFF;}
.float-cart a {float: right; padding: 0 20px; border: 1px solid #F60; line-height: 28px; font-size: 16px; color: #FFF; background: linear-gradient(to bottom, #F80, #F60); border-radius: 5px; text-decoration: none;}

.form-button-plain-flat {border: 2px solid #CCC; color: #000; border-radius: 30px;}
.form-button-plain-flat:hover { background: #eee; }

/*20200807-RE-LAX▼*/
/*レスポンシブ検索サイズ*/
.footer-home-search select {
  max-width: 25%;
}
.footer-home-search input {
  max-width: 55%;
}
.footer-home-search button {
  max-width: 15%;
}
