/*-----------------------------------
    Header
------------------------------------*/
header {
  background: url(../../img/job_explanation/hero-bg.png) no-repeat center;
  background-size: cover;
  overflow: hidden;
  position: relative;
  /*background-color: rgba(26, 10, 56, 0.53);*/
  background-color: rgb(26, 10, 56);
  color: #fff;
  z-index: 100;
}

header a {
  color: #fff;
}

header::after {
  content: "";
  width: 100%;
  height: 2px;
  background-color: rgba(0, 0, 0, 0)
  position: absolute;
  left: 0;
  bottom: -20px;
}

header .diag-bg {
  width: 100%;
  height: 100%;
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
          clip-path: polygon(0 0, 100% 100%, 100% 0);
  background-color: rgba(240, 0, 255, 0.1);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

header　.texture {
  width: 100%;
  height: 100%;
  background: url(../../img/job_explanation/hero-texture.png) no-repeat center;
  background-size: cover;
  opacity: 0.4;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.nav-link {
  font-family: "Rajdhani", sans-serif;
  text-transform: uppercase;
}

.navbar-brand h1 {
  margin: 0;
}

.navbar-brand img {
  width: 135px;
}

.navbar-collapse .search-form input[type="text"] {
  border: 1px solid #ced4da;
  color: #333;
  padding: 1.5625rem 0.625rem;
}

.navbar-collapse .search-form .btn {
  margin-top: 0;
  border-radius: 0;
  margin-left: -1px;
}

.navbar-collapse .nav-link {
  font-size: 1.6rem !important;/*obara*/
  transition: all 0.2s ease-in-out;
}

.navbar-collapse .nav-link:hover {
  color: #ee1515;
}

form input.btn-primary:hover,
form button.btn-primary:hover {
  background-color: #fff;
  color: #ee1515;
}


/*-----------------------------------
    CTA
------------------------------------*/
.cta-content {
  margin-top: 100px;
  padding: 30px 0 90px;
  color: #fff;
  background-color: #3353e2;
  position: relative;
  z-index: 1;
}

.cta-content::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(24, 9, 53, 0.77);
  position: absolute;
  top: -25px;
  left: -1px;
  z-index: -1;
  transition: all 0.2s ease-in-out;
}

.cta-content .subscribe-btn {
  align-self: flex-end;
  margin-top: 30px;
  margin-right: 30px;
}

.cta-content h2{
  font-size: 20px !important;
  position: relative;
  padding: 1.5rem 1rem;
}


/*-----------------------------------
    TOC
------------------------------------*/
.toc {
  margin: 2em;
  border: 2px solid #000;
  border-radius: 3px;
}

.toc div {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 10px 0;
  /*background-color: #5063c3*/;
  color: #292929;
  font-weight: 600;
  font-size: 1.1em;
}

.toc div::before {
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 5px;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22%23333%22%3E%3Cpath%20d%3D%22M3.8%2017.2h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.8-.8-.8zm0-15h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8V3c-.1-.4-.4-.8-.8-.8zm0%207.6h-3c-.5%200-.8.3-.8.7v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.7-.8-.7zM23.2%2018h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8zm0-15h-15c-.4%200-.7.3-.7.8v1.5c0%20.4.3.7.7.7h15c.5%200%20.8-.3.8-.8V3.8c0-.5-.3-.8-.8-.8zm0%207.5h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8z%22%2F%3E%3C%2Fsvg%3E');
  content: '';
}

.toc label::after {
  margin-left: 7px;
  font-weight: 500;
  font-size: .7em;
  color: #303030;
  content: "[開く]";
  cursor: pointer;
}

.toc:has(:checked) label::after {
  content: "[閉じる]";
}

.toc input {
  display: none;
}

.toc ol {
  list-style-type: disc;
  margin: 0;
  overflow: hidden;
}

.toc > ol {
  height: 0;
}

.toc:has(:checked) > ol {
  height: auto;
  padding: 1em 1em 1em 3em;
}

.toc ol ol {
  margin: 2px 0 8px 0;
}

.toc li {
  padding: 5px 0;
  font-weight: 600;
}

.toc ol ol li {
  font-weight: 300;
  font-size: 0.75em;
  list-style-type: none;
}

.toc a {
  color: #2c43a8;
  text-decoration: none;
}


/*-----------------------------------
    Contents featured
------------------------------------*/
.contents {
  padding: 100px 0 0 0;
  background-color: #fafafa;
}

.contents h1 {
  font-size: 28px !important;
  /*color: #3737c2;*/
  padding: 1.5rem 1.5rem calc(1.5rem + 10px);
  border: 2px solid #dc143c;
  position: relative;
  padding: 1rem 2rem calc(1rem + 10px);
  background: #ffffff;
  margin-bottom: 50px;
  font-weight: 700;
  text-transform: uppercase;
}
  
.contents h1:before {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  border-top: 2px solid #dc143c;
  background-image: -webkit-repeating-linear-gradient(135deg, #dc143c, #dc143c 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #dc143c, #dc143c 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  }

.contents h2 {
  font-size: 20px !important;
  position: relative;
  padding: 1.5rem 1rem;
  color: #494949;
  background: #ffcccc/*eeeeee*/;
  border-left: solid 5px #dc143c/*#ff3333*/;
  margin: 50px 0 10px 0;
}

.contents h3 {
  font-size: 1.1em !important;
  font-weight: bold;
  border-bottom: 3px solid #ffcccc;
  padding: 0.3em;
  margin: 2em 1.5em 0em 1.5em;
  position: relative;
}
.contents h3::after {
  content: '';
  background-color: #ff3333;
  width: 2em;
  height: 3px;
  position: absolute;
  bottom: -3px;
  left: 0;
  z-index: 1;
}

/*.contents h3 {
  font-size: 18px !important;
  background: linear-gradient(transparent 70%, #a7d6ff 70%);
  margin: 50px 20px 0 20px;
}*/

.contents h6 {
  letter-spacing: 4px;
  margin-bottom: 20px;
}

.contents p {
  font-size: 0.9em !important;
  margin: 2em;
}

.contents .title-primary {
  color: #ee1515;
}

.contents .media i {
  font-size: 24px;
  color: #ee1515;
}

.contents .media h5 {
  text-transform: uppercase;
  color: #26264b;
}

.contents .btn {
  margin-top: 80px;
}


.contents-img {
  position: relative;
  height: 530px;
  margin-top: 60px;
}

.contents-img img{
  width:auto !important;
  height:auto;
  border:0;
  vertical-align:bottom;
}

.contents-big {
  position: absolute;
  bottom: 0;
  right: 0;
}

.contents-small {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 25px 25px 0 0;
  background-color: #fff;
}

.contents .box {
  margin: 20px 2em;
  padding: 20px;
  background-color: #ffe6e6;
  position: relative;
}
.contents .box::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  border-width: 0 20px 20px 0;
  border-style: solid;
  border-color: #ffe6e6 #fff #ff8080;
  box-shadow: -1px 1px 1px rgba(0, 0, 0, 0.15)
}

.contents .box-txt {
  padding: 10px 20px;
}

.contents .box-txt ul {
  padding: 0;
  font: 14px/1.6 'arial narrow', sans-serif;
  width:auto;
  list-style: none;
}
.contents .box-txt li{
  position: relative;
  padding: 0.5em 1em 0.5em 2.3em;
  margin-bottom:5px;
  color: #ff3333;
  font-size: 15px;
  font-weight: bold;
  /*border-bottom: 1px dashed rgba(104, 167, 226, 0.5)*/;
}
.contents .box-txt li:after,
.contents .box-txt li:before{
  content: "";
  position: absolute;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.contents .box-txt li:before{
  top: 0.7em;
  left: 0.2em;
  width: 12px;
  height: 12px;
  border:2px solid #ff8080;
}
.contents .box-txt li:after{
  top: 0.9em;
  left: 0.7em;
  width: 14px;
  height: 14px;
  background: #dc143c;
  -webkit-transform: rotate(60deg);
  -moz-transform: rotate(60deg);
  -o-transform: rotate(60deg);
  -ms-transform: rotate(60deg);
  transform: rotate(60deg);
}



.contents .box_references {
  margin: 20px auto;
}

.contents .box_reference-ttl {
  background-color: #dc143c/*rgba(24, 9, 53, 0.77)*/;
  color: #fff;
  padding: 0.5em 20px;
  width: fit-content;
  border-radius: 10px 10px 0 0;
  margin: 0;
  font-size: 17px;
  font-weight: bold;
}
.contents .box_reference-txt {
  padding: 10px 20px;
  border: 2px solid #dc143c/*rgba(24, 9, 53, 0.77)*/;
}

.contents .box_reference-txt ul {
  padding: 0;
  font: 14px/1.6 'arial narrow', sans-serif;
  width:auto;
  list-style: none;
  border:none;
  margin: 0;
}
.contents .box_reference-txt ul li:before{
  font-family: FontAwesome;
  content: "\f054";
  position: absolute;
  left: 5px;
  font-size: 1.2em;
  -webkit-transition: all 0.8s ease-in-out;
  transition: all 0.8s ease-in-out;
  background-position: bottom;
}
.contents .box_reference-txt ul li:hover:before{
  -webkit-transform:rotateY(-360deg);
  transform:rotateY(-360deg);
  color: red;
}

.contents .box_reference-txt li{
  position: relative;
  padding: 0.5em 1em 0.5em 2.3em;
  margin-bottom:5px;
  color: #dc143c;
  font-size: 15px;
  font-weight: bold;
  /*border-bottom: 1px dashed rgba(104, 167, 226, 0.5);*/
}

.contents .marker_seo {
  color:#000;
  background:linear-gradient(transparent 50%, rgba(255, 220, 123) 50%);
  display: inline;
  background-repeat: no-repeat;
  background-size: 0% 100%;
  transition:background-size 2.5s;
}

/* マーカーが引かれる際に付与するクラス */
.contents .marker_seo.on {
  color:#000;
  background-size: 100% 100%;
}


/*-----------------------------------
    1 - Event Table
------------------------------------*/
.event-table {
  padding: 100px 0;
}

.single-pricing {
  padding: 65px 0 40px;
  margin-top: 23px;
  color: #fff;
  background: #26264b;
  border: 0px solid #fff;
  position: relative;
  overflow: hidden;
  z-index: 1;
  transition: all 0.2s ease-in-out;
}

.single-pricing span {
  font-size: 12px !important;
  text-transform: uppercase;
  padding: 6px 15px;
  border-radius: 15px;
  background-color: transparent;
  position: absolute;
  top: 28px;
  right: 6px;
  transition: all 0.2s ease-in-out;
}

.single-pricing h2 {
  margin-bottom: -5px;
}

.single-pricing .desc {
  color: #9d9d9d;
  padding: 30px;
  margin-bottom: 32px;
  border-bottom: 2px solid #2f2f2f;
  transition: all 0.2s ease-in-out;
}

.single-pricing .date {
  font-size: 2rem !important;
  margin-bottom: 8px;
}

.single-pricing p {
  color: #ddd;
}

.single-pricing p:last-of-type {
  margin-bottom: 25px;
}

.single-pricing svg {
  width: 170px;
  position: absolute;
  top: -45px;
  right: -60px;
  z-index: -1;
  transition: all 0.5s ease-in-out;
}

.single-pricing:hover {
  border: 4px solid #fff;
  box-shadow: 0px 10px 18px 0px rgba(0, 0, 0, 0.16);
  margin: 19px 0 -4px;
}

.single-pricing:hover span {
  background-color: #26264b;
}

.single-pricing:hover .desc {
  color: #fff;
  border-bottom: 2px solid rgba(245, 245, 245, 0.322);
}

.single-pricing:hover svg {
  width: 500%;
  top: -200%;
  right: -50%;
}

.single-pricing:hover .btn {
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.35);
}


/*-----------------------------------
    1 - Trust
------------------------------------*/
.trust {
  padding: 75px 0;
  background-color: #26264b;
  color: #ddd;
  position: relative;
}

.trust .title {
  margin-bottom: 46px;
}

.trust h1 {
  color: #fff;
}

.trust h5 {
  font-size: 24px;
  color: #fefefe;
  margin: 28px 0 12px;
}

.trust ul {
  color: #fff;
  -webkit-column-count: 2;
     -moz-column-count: 2;
          column-count: 2;
}

.trust li {
  margin-bottom: 15px;
}

.trust .gallery img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

.trust .gal-img {
  display: inline-block;
  position: relative;
  z-index: 1;
}

.trust .gal-img i {
  font-size: 72px;
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  opacity: 0;
  z-index: 2;
}

.trust .gal-img::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: all 0.2s ease-in-out;
}

.trust .gal-img:hover {
  cursor: pointer;
}

.trust .gal-img:hover i {
  opacity: 1;
}

.trust .gal-img:hover::after {
  opacity: 1;
}

.trust .gal-img3 {
  top: -50%;
  left: 50%;
}

/*-----------------------------------
    1 - Footer
------------------------------------*/
footer {
  background: url(../../img/job_explanation/footer-bg.png) center center/cover no-repeat #26264b;
}

/*-----------------------------------
    1 - Footer Widgets
------------------------------------*/
.footer-widgets {
  padding: 100px 0;
}

.footer-widgets .col-md-6 .single-widget:not(:first-child) .widget-tiltle {
  margin: 40px 0 30px;
}

.single-widget {
  color: #aaa;
}

.single-widget .widget-tiltle {
  font-size: 17px !important;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 45px;
}

.single-widget i {
  color: #ee1515;
}

.single-widget h6 {
  color: #fff;
}

.single-widget .media {
  margin-bottom: 20px;
}

.twitter-widget i,
.twitter-widget h6 {
  color: #777;
}

span {
  color: #fff;
}

.recent-post-widget .rcnt-img {
  width: 68px;
  height: 68px;
  border-radius: 4px;
  overflow: hidden;
}

.recent-post-widget .rcnt-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.recent-post-widget a {
  color: #fff;
}

.recent-post-widget p {
  font-size: 2em;
}

.recent-post-widget i {
  margin-right: 10px;
}

.recent-post-widget i:last-of-type {
  margin-left: 15px;
}

.tags-widget {
  margin: -10px -10px 0 0;
}

.tags-widget a {
  color: #aaa;
  display: inline-block;
  padding: 10px 12px;
  border-radius: 2px;
  background-color: #363636;
  font-size: 14px !important;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  margin: 10px 10px 0 0;
}

.tags-widget a:hover {
  text-decoration: none;
  color: #26264b;
  background-color: #ee1515;
}

.subscribe-widget form {
  margin-bottom: 10px;
}

.subscribe-widget input {
  font-size: 14px !important;
  padding: 0px 10px;
  background-color: #444;
  border: none;
  line-height: 0;
  position: relative;
  z-index: 1;
}

.subscribe-widget input:focus {
  outline: none;
  box-shadow: none;
}

.subscribe-widget button {
  background: #ee1515;
  border: none;
  padding: 9px 14px;
  border-top-right-radius: 10px;
  border-bottom-left-radius: 10px;
  margin-left: -10px;
  position: relative;
  z-index: 5;
}

.subscribe-widget button i {
  color: #fff;
}

.subscribe-widget .social-nav {
  margin-top: 32px;
}

.subscribe-widget .social-nav a {
  display: inline-block;
  text-align: center;
  width: 36px;
  height: 36px;
  line-height: 36px;
  background-color: #fff;
  color: #ddd;
  background-color: #444;
  border-top-right-radius: 10px;
  border-bottom-left-radius: 10px;
  margin-right: 10px;
}

.subscribe-widget .social-nav a i {
  color: #ddd;
}

.subscribe-widget .social-nav a:hover {
  background-color: #ee1515;
}

/*-----------------------------------
    1 - Foot Note
------------------------------------*/
.foot-note {
  padding: 35px 0;
  background-color: #dc143c;
  color: #fff/*#26264b*/;
}

.foot-note a {
  color: #fff;
}

.foot-note a:last-child {
  margin-left: 30px;
}

.foot-note a.fh5-link {
  margin-left: 0;
}

