@charset "UTF-8";
/* Scss Document */
@import "normalize.css";
/* Scss Document */
/*=======================================================
    reset
========================================================*/
/* http://meyerweb.com/eric/tools/css/reset/ 
v2.0 | 20110126
License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

* {
  margin: 0;
  padding: 0;
}

/*=======================================================
    font
========================================================*/
.yu-mincho {
  font-family: "Yu Mincho", "YuMincho";
}

.font_en {
  font-family: Copperplate, Copperplate Gothic Light, fantasy;
}

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

    ブレークポイント
========================================================*/
/*-------------- calc mixin ここから ----------------*/
/*-------------- calc mixin ここまで ----------------*/
/*
 * Mixin for placeholder
 * @include placeholderColor(#00ff00);
 */
/*=======================================================

    common

========================================================*/
html {
  font-size: 63.5%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  html {
    font-size: 56.5%;
  }
}

body {
  font-size: 1.5rem;
  height: 100%;
  -webkit-text-size-adjust: 100%;
  color: #0c1c4d;
  font-family: "Noto Sans JP", sans-serif;
  background: url(../img/common/bg_body.png) center top;
}
a {
  transition: all 0.3s ease 0s;
  color: #0c1c4d;
  text-decoration: none;
}
a:hover {
  color: #0c1c4d;
  text-decoration: underline;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

@media screen and (max-width: 1209px) {
  .pc02 {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

@media screen and (min-width: 1210px) {
  .sp02 {
    display: none !important;
  }
}

@media screen and (max-width: 767px) {
  .tab {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .tab {
    display: none;
  }
}
@media screen and (min-width: 606px) and (max-width: 767px) {
  .tab {
    display: block !important;
  }
}

.clearfix {
  *zoom: 1;
}
.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.no_link {
  opacity: 0.3;
  pointer-events: none;
}

.mincho {
  font-family: "Zen Old Mincho", serif;
}

a img {
  transition: all 0.3s ease 0s;
}
a img:hover {
  opacity: 0.8;
}

@media screen and (max-width: 767px) {
  img {
    max-width: 100%;
  }
}
.link {
  color: #000;
  text-decoration: none;
}

.mrgT5 {
  margin-top: 5px;
}

.mrgT10 {
  margin-top: 10px;
}

.mrgT15 {
  margin-top: 15px;
}

.mrgT20 {
  margin-top: 20px;
}

.mrgT25 {
  margin-top: 25px;
}

.mrgT30 {
  margin-top: 30px;
}

.mrgT40 {
  margin-top: 40px;
}

.mrgT50 {
  margin-top: 50px;
}

.mrgT60 {
  margin-top: 60px;
}

.mrgT70 {
  margin-top: 70px;
}

.mrgB5 {
  margin-bottom: 5px;
}

.mrgB10 {
  margin-bottom: 10px;
}

.mrgB15 {
  margin-bottom: 15px;
}

.mrgB20 {
  margin-bottom: 20px;
}

.mrgB25 {
  margin-bottom: 25px;
}

.mrgB30 {
  margin-bottom: 30px;
}

.mrgB40 {
  margin-bottom: 40px;
}

.mrgB50 {
  margin-bottom: 50px;
}

.mrgB60 {
  margin-bottom: 60px;
}

.mrgB70 {
  margin-bottom: 70px;
}

.floatL {
  float: left;
}

.floatR {
  float: right;
}

.fontBold {
  font-weight: bold;
}

.text-center {
  text-align: center;
}

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

.text-left {
  text-align: left;
}

.f12 {
  font-size: 1.2rem !important;
}

.f14 {
  font-size: 1.4rem;
}

.f16 {
  font-size: 1.6rem;
}

.f18 {
  font-size: 1.8rem;
}

.red {
  color: #e50044;
}

.marker {
  background: linear-gradient(transparent 60%, #ffe800 60%);
  font-weight: bold;
}

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

    header

========================================================*/
@media screen and (max-width: 767px) {
  #container {
    overflow: hidden;
  }
}
#container header {
  position: fixed;
  width: 100%;
  padding: 0;
  box-sizing: border-box;
  z-index: 9999;
}
@media screen and (max-width: 767px) {
  #container header {
    padding: 0;
  }
}
#container header.is-fixed {
  position: fixed;
  background: rgba(0, 0, 0, 0.8);
  animation: nyuru 0.5s;
}
#container header.is-fixed.bl {
  background: rgba(255, 255, 255, 0.8);
}
@keyframes nyuru {
  0% {
    margin-top: -158px;
  }
  100% {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  @keyframes nyuru {
    0% {
      margin-top: -78px;
    }
    100% {
      margin-top: 0;
    }
  }
}
#container header.bl .head_inner .nav_wrap .telnum {
  color: #0c1c4d;
}
#container header.bl .head_inner .nav_wrap nav .gnav li {
  border-right: 1px solid #0c1c4d;
}
#container header.bl .head_inner .nav_wrap nav .gnav li a {
  color: #0c1c4d;
}
#container header .head_inner {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  padding: 15px;
}
@media screen and (max-width: 1209px) {
  #container header .head_inner {
    padding: 13px;
    position: relative;
    z-index: 1000;
  }
}
#container header .head_inner .nav_wrap .telnum {
  color: #fff;
  font-size: 2rem;
  font-weight: 600;
  text-align: right;
}
#container header .head_inner .nav_wrap .telnum span {
  font-size: 1.6rem;
}
#container header .head_inner .nav_wrap nav {
  display: flex;
  flex-wrap: wrap;
  padding: 15px 0;
}
@media screen and (max-width: 1209px) {
  #container header .head_inner .nav_wrap nav {
    width: 65%;
    line-height: 1.6;
  }
}
@media screen and (max-width: 1101px) {
  #container header .head_inner .nav_wrap nav {
    width: 50%;
    line-height: 1.6;
  }
}
@media screen and (max-width: 767px) {
  #container header .head_inner .nav_wrap nav {
    padding: 10px;
  }
}
#container header .head_inner .nav_wrap nav .gnav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-right: 30px;
}
#container header .head_inner .nav_wrap nav .gnav li {
  margin-right: 20px;
  padding-right: 20px;
  border-right: 1px solid #fff;
  text-align: center;
  position: relative;
}
#container header .head_inner .nav_wrap nav .gnav li:last-child {
  margin-right: 0;
}
#container header .head_inner .nav_wrap nav .gnav li > ul {
  background: rgba(0, 0, 0, 0.6);
  line-height: 2;
  position: absolute;
  width: 250%;
  box-sizing: border-box;
  top: 110%;
  left: -20px;
  opacity: 0;
  display: block;
  transition: all 0.3s ease 0s;
}
#container header .head_inner .nav_wrap nav .gnav li > ul li {
  border: 0;
  margin: 0;
  padding: 0;
}
#container header .head_inner .nav_wrap nav .gnav li > ul li:last-child {
  margin: 0;
}
#container header .head_inner .nav_wrap nav .gnav li > ul li a {
  font-size: 1.3rem;
  color: #fff !important;
  padding: 10px;
  border-bottom: 1px solid #000000;
}
#container header .head_inner .nav_wrap nav .gnav li:hover > ul {
  opacity: 1;
}
#container header .head_inner .nav_wrap nav .gnav li a {
  display: block;
  text-decoration: none;
  color: #fff;
}
#container .menu-trigger,
#container .menu-trigger span {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
  cursor: pointer;
  color: #fff;
}
#container .menu-trigger {
  width: 50px;
  height: 50px;
  float: right;
  position: fixed;
  top: 1%;
  right: 1%;
  z-index: 9999;
  border-radius: 5px;
  background: #0c1c4d;
  transform: scale(0.8);
}
#container .menu-trigger span {
  width: 30px;
  height: 3px;
  margin: auto auto auto 10px;
  position: absolute;
  background-color: #fff;
}
#container .menu-trigger span:nth-of-type(1) {
  top: 15px;
}
#container .menu-trigger span:nth-of-type(2) {
  top: 0;
  bottom: 0;
}
#container .menu-trigger span:nth-of-type(3) {
  bottom: 15px;
}
#container .menu-trigger {
  padding-right: 20px;
}
#container .menu-trigger.active span {
  background-color: #fff;
}
#container .menu-trigger.active span:nth-of-type(1) {
  transform: translateY(10px) rotate(-45deg);
}
#container .menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
#container .menu-trigger.active span:nth-of-type(3) {
  transform: translateY(-7px) rotate(45deg);
}
#container #overlay {
  width: 100%;
  height: 100vh;
  margin: auto;
  padding-top: 10%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  background-color: #fff;
  display: none;
  text-align: center;
}
#container #overlay .telnum {
  font-size: 2rem;
  font-weight: 600;
  font-family: "Zen Old Mincho", serif;
  margin-top: 20px;
}
#container #overlay .telnum span {
  font-size: 1.6rem;
}
#container #overlay ul {
  width: 100%;
  margin: 10px 0;
}
#container #overlay ul li {
  margin: 25px 15px;
  text-align: center;
  line-height: 1.6;
  border: 0;
}
#container #overlay ul li a {
  text-decoration: none;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  color: #333;
}
#container footer {
  padding: 50px 0 20px;
  background: #ecedf1;
  color: #0c1c4d;
}
#container footer .inner {
  max-width: 1000px;
  padding: 0 0 30px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #container footer .inner {
    padding: 20px 10px;
  }
}
#container footer .inner .logo {
  text-align: center;
  margin-bottom: 20px;
}
#container footer .inner .address {
  font-size: 1.4rem;
  text-align: center;
  margin-bottom: 1em;
}
#container footer .inner .telnum {
  text-align: center;
  color: #0c1c4d;
  font-size: 2rem;
  font-weight: 600;
}
#container footer .inner .telnum span {
  font-size: 1.6rem;
}
#container footer .inner nav {
  margin: 40px 0 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  #container footer .inner nav {
    display: block;
    margin: 20px 0;
    text-align: center;
  }
}
#container footer .inner nav .gnav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-right: 30px;
}
@media screen and (max-width: 767px) {
  #container footer .inner nav .gnav {
    display: block;
    margin-right: 0;
    margin-bottom: 30px;
  }
}
#container footer .inner nav .gnav li {
  margin-right: 20px;
  padding-right: 20px;
  border-right: 1px solid #0c1c4d;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #container footer .inner nav .gnav li {
    border-right: 0;
    border-bottom: 1px solid #0c1c4d;
    margin: 0 0 10px 0;
    padding: 0 0 10px 0;
  }
}
#container footer .inner nav .gnav li:last-child {
  margin-right: 0;
  border-right: 0;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #container footer .inner nav .gnav li:last-child {
    padding: 0 0 10px 0;
  }
}
#container footer .inner nav .gnav li a {
  display: block;
  text-decoration: none;
  color: #0c1c4d;
}
#container footer address {
  text-align: center;
  font-size: 1.2rem;
}

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

    共通レイアウト

========================================================*/
#container img {
  max-width: 100%;
  height: auto;
}
#container .flex {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  #container .flex .box01 {
    order: 1;
  }
}
@media screen and (max-width: 767px) {
  #container .flex .box02 {
    order: 2;
  }
}
#container .flex img {
  max-width: 100%;
}
#container #content .pagenavi {
  text-align: center;
  margin: 50px 0 0;
}
@media screen and (max-width: 1101px) {
  #container #content .inner {
    width: 100%;
    padding: 0 15px;
    box-sizing: border-box;
  }
}
#container #content section p {
  line-height: 2.3;
}
#container #content section .inner {
  padding: 50px 0;
}
@media screen and (max-width: 1101px) {
  #container #content section .inner {
    padding: 15px 0;
    box-sizing: border-box;
  }
}
#container #content section .more01 {
  line-height: 1;
}
#container #content section .more01 a {
  font-family: "Inter", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 280px;
  padding: 15px;
  box-sizing: border-box;
  border-radius: 20px;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 2px 2px 4px #8e8e8e;
  color: #e50044;
  background: #fff;
}
#container #content section .more01 a::after {
  content: url(../img/common/ico_arrow.svg);
  margin-left: 30px;
}
#container #content section .more01 a:hover {
  opacity: 0.8;
}
#container #content section .more02 {
  line-height: 1;
}
#container #content section .more02 a {
  font-family: "Inter", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 280px;
  padding: 15px;
  box-sizing: border-box;
  border-radius: 20px;
  text-align: center;
  font-size: 1.6rem;
  text-decoration: none;
  box-shadow: 2px 2px 4px #8e8e8e;
  color: #fff;
  background: #33332a;
}
#container #content section .more02 a::after {
  content: url(../img/common/ico_arrow02.svg);
  margin-left: 30px;
}
#container #content section .more02 a:hover {
  opacity: 0.8;
}
#container #content section .more04 a {
  display: block;
  text-decoration: none;
  padding: 25px;
  font-size: 1.6rem;
  text-align: center;
  width: 280px;
  background: #fff;
  color: #b52e82;
  border: 1px solid #b52e82;
  font-family: "Proza Libre", sans-serif;
  position: relative;
  margin-top: 20px;
}
#container #content section .more04 a::after {
  position: absolute;
  top: 40px;
  right: 25px;
  content: "";
  width: 18px;
  height: 3px;
  border-bottom: solid 2px;
  border-right: solid 2px;
  transform: skew(45deg);
}
#container #content section .more04 a:hover {
  opacity: 0.8;
}
#container #content section .more04 a span {
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  #container #content section .more04 a {
    max-width: 100%;
    box-sizing: border-box;
  }
}
#container #content section .more03 a {
  display: block;
  text-decoration: none;
  padding: 15px 20px;
  font-size: 2rem;
  text-align: center;
  max-width: 450px;
  background: #7b673f;
  font-weight: bold;
  border-radius: 25px;
  margin: 40px auto 0;
  color: #fff;
}
#container #content section .more03 a:hover {
  background: #4f4023;
  color: #fff;
}
#container .toTop {
  position: fixed;
  right: 2%;
  bottom: 9%;
  z-index: 1000;
}
@media screen and (max-width: 767px) {
  #container .toTop {
    bottom: 2%;
  }
}
#container .wp-pagenavi a, #container .wp-pagenavi span {
  text-decoration: none;
  border: 0;
  margin: 2px 10px;
  color: #707070;
  font-size: 1.6rem;
  border-radius: 50%;
  width: 40px;
  height: 43px;
  line-height: 43px;
  display: inline-block;
  background: #fff;
  border: 1px solid #444;
}
#container .wp-pagenavi a:hover, #container .wp-pagenavi span.current {
  border-color: #b52e82;
  background: #b52e82;
  color: #fff;
}
#container .wp-pagenavi a.nextpostslink {
  border-radius: 20px;
  font-size: 1.3rem;
  width: auto;
  height: auto;
  padding: 10px 10px;
  line-height: 1.6;
}
#container .wp-pagenavi a.previouspostslink {
  border-radius: 20px;
  font-size: 1.3rem;
  width: auto;
  height: auto;
  padding: 10px 10px;
  line-height: 1.6;
}
#container .slick-arrow:before {
  content: "" !important;
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  left: 0;
}
#container .slick-next:before {
  background: url(../img/common/ico_next.svg) !important;
  background-size: contain !important;
}
#container .slick-prev:before {
  background: url(../img/common/ico_prev.svg) !important;
  background-size: contain !important;
}

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

    TOPコンテンツ

========================================================*/
#top #container {
  overflow: hidden;
}
#top #container section .ttl {
  max-width: 1000px;
  display: flex;
  margin: 0 auto;
}
#top #container section .ttl::before {
  content: "";
  height: 1px;
  display: flex;
  background: #0c1c4d;
  margin: 50px 20px 0 0;
  margin-left: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
}
#top #container section h2.style01 {
  font-size: 5.6rem;
  line-height: 1.6;
  margin-bottom: 1em;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767px) {
  #top #container section h2.style01 {
    font-size: 4.4rem;
  }
}
#top #container section h2.style01 span {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  display: block;
}
@media screen and (max-width: 767px) {
  #top #container section h2.style01 span {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #top #container section .inner {
    padding: 50px 15px;
  }
}
#top #container .sec001 {
  position: relative;
}
#top #container .sec001::after {
  content: "";
  background: #ecedf1;
  height: 70%;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
}
#top #container .sec001 .slick-arrow:before {
  content: "" !important;
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  left: 0;
}
#top #container .sec001 .slick-prev, #top #container .sec001 .slick-next {
  width: 28px;
  height: 44px;
}
#top #container .sec001 .slick-next:before {
  background: url(../img/top/btn_next.png) !important;
  background-size: contain !important;
}
#top #container .sec001 .slick-prev:before {
  background: url(../img/top/btn_prev.png) !important;
  background-size: contain !important;
}
#top #container .sec001 h2.style01 {
  line-height: 1;
}
#top #container .sec001 h2.style01 span {
  display: inline-block;
}
#top #container .sec001 h2.style01 span.more {
  margin-left: 20px;
}
#top #container .sec001 .flex {
  justify-content: space-between;
  padding: 0 70px 70px;
}
@media screen and (max-width: 767px) {
  #top #container .sec001 .flex {
    padding: 0 15px 70px;
  }
}
#top #container .sec001 .flex .slick-slide {
  margin: 0 10px;
}
#top #container .sec001 .flex li {
  box-shadow: 0 0 8px #ebebeb;
  background: #fff;
  width: calc(33.333333% - 10px);
}
@media screen and (max-width: 767px) {
  #top #container .sec001 .flex li {
    width: 100%;
    margin-bottom: 20px;
  }
}
#top #container .sec001 .flex li .box_inner {
  background: #fff;
  padding: 15px;
  text-align: center;
}
#top #container .sec001 .flex li .box_inner h3 {
  font-family: "Zen Old Mincho", serif;
  color: #0c1c4d;
  font-size: 2.2rem;
  margin-bottom: 0.5em;
  line-height: 1.2;
  font-weight: 500;
}
#top #container .sec001 .flex li .box_inner h4 {
  font-size: 1.8rem;
  margin-bottom: 1em;
}
#top #container .sec001 .flex li .box_inner .txt {
  font-size: 1.4rem;
  direction: ltr;
}
#top #container .sec001 .flex li .box_inner .more > a {
  font-size: 1.4rem;
  text-decoration: none;
  margin-top: 20px;
}
#top #container .sec001 .flex li .box_inner .more > a::after {
  content: url(../img/common/ico_arrow01.svg);
  margin-left: 10px;
}
#top #container .sec002 .inner .flex {
  justify-content: space-between;
  padding: 0 70px 70px;
}
@media screen and (max-width: 767px) {
  #top #container .sec002 .inner .flex {
    padding: 0 0 40px;
  }
}
#top #container .sec002 .inner .flex li {
  width: calc(25% - 10px);
}
@media screen and (max-width: 767px) {
  #top #container .sec002 .inner .flex li {
    width: 100%;
    margin-bottom: 20px;
  }
}
#top #container .sec002 .inner .flex li h3 {
  font-size: 2rem;
  text-align: center;
  color: #0c1c4d;
  font-weight: 500;
  margin-top: 0.5em;
  font-family: "Zen Old Mincho", serif;
}
#top #container .sec003 {
  background: #DCEBF5;
  padding: 60px 0;
}
#top #container .sec003 .ttl::before {
  background: #0C1C4D;
}
#top #container .sec003 h2 {
  color: #0C1C4D;
}
#top #container .sec003 ul {
  max-width: 1000px;
  margin: 0 auto;
}
#top #container .sec003 ul li {
  color: #0C1C4D;
  font-size: 1.8rem;
  display: flex;
  padding: 15px 0;
  border-bottom: 1px solid #0C1C4D;
  line-height: 1.6;
}
#top #container .sec003 ul li:first-child {
  border-top: 1px solid #0C1C4D;
}
#top #container .sec003 ul li .date {
  margin-right: 30px;
}
#top #container .sec003 ul li .post a {
  color: #0C1C4D;
  font-size: 2rem;
}
#top #container .sec003 ul li .post .cat {
  display: block;
}
#top #container .sec003 ul li .post .cat a {
  color: #0C1C4D;
  font-size: 1.8rem;
}
#top #container .sec003 ul li .post .new {
  background: #ee2a7b;
  padding: 1px 3px;
  color: #fff;
  font-size: 1.2rem;
  margin-right: 10px;
}
#top #container .sec003 .more {
  text-align: center;
  margin-top: 50px;
}
#top #container .sec004 .inner .flex {
  padding: 0 70px 70px;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #top #container .sec004 .inner .flex {
    padding: 40px 0 40px;
  }
}
#top #container .sec004 .inner .flex li {
  width: calc(33.333333% - 5px);
}
@media screen and (max-width: 767px) {
  #top #container .sec004 .inner .flex li {
    width: 100%;
    margin-bottom: 10px;
  }
}
#top #container .sec005 .inner {
  max-width: 1000px;
  margin: 0 auto;
}
#top #container .sec005 .inner h2.style01 {
  line-height: 1;
}
#top #container .sec005 .inner h2.style01 span {
  display: inline-block;
}
#top #container .sec005 .inner h2.style01 span.more {
  margin-left: 20px;
}
#top #container .sec005 .inner .flex {
  justify-content: space-between;
}
#top #container .sec005 .inner .flex li {
  width: calc(33.333333% - 5px);
}
@media screen and (max-width: 767px) {
  #top #container .sec005 .inner .flex li {
    width: 100%;
    margin-bottom: 10px;
  }
}
#top #container .contact_area {
  background: url(../img/top/bg_contactarea.png) no-repeat center center/cover;
  margin-bottom: 60px;
}
#top #container .contact_area .inner {
  padding: 60px 0;
  color: #0c1c4d;
}
#top #container .contact_area .inner .ttl::before {
  background: #0c1c4d;
}
@media screen and (max-width: 767px) {
  #top #container .contact_area .inner {
    padding: 60px 15px;
  }
}
#top #container .contact_area .inner .flex {
  justify-content: space-between;
  max-width: 1000px;
  margin: 0 auto;
}
#top #container .contact_area .inner .flex .box {
  color: #0c1c4d;
}
#top #container .contact_area .inner .flex .box .txt {
  color: #0c1c4d;
  margin-bottom: 40px;
}

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

    下階層

========================================================*/
#local #container {
  overflow: hidden;
}
#local #container .title {
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  #local #container .title {
    margin-bottom: 50px;
  }
}
#local #container .ttl {
  max-width: 1000px;
  display: flex;
  margin: 0 auto;
}
#local #container .ttl::before {
  content: "";
  height: 1px;
  display: flex;
  background: #0c1c4d;
  margin: 50px 20px 0 0;
  margin-left: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
}
#local #container h1.style01 {
  font-size: 5.6rem;
  line-height: 1.6;
  margin-bottom: 1em;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
  text-transform: uppercase;
}
@media screen and (max-width: 767px) {
  #local #container h1.style01 {
    font-size: 4.4rem;
  }
}
#local #container h1.style01 span {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  display: block;
}
@media screen and (max-width: 767px) {
  #local #container h1.style01 span {
    font-size: 2rem;
  }
}
#local #container .contact_area {
  background: url(../img/top/bg_contactarea.png) no-repeat center center/cover;
  margin-bottom: 60px;
}
#local #container .contact_area .inner {
  padding: 60px 0;
}
@media screen and (max-width: 767px) {
  #local #container .contact_area .inner {
    padding: 60px 15px;
  }
}
#local #container .contact_area .inner .flex {
  justify-content: space-between;
  max-width: 1000px;
  margin: 0 auto;
}
#local #container .contact_area .inner .flex .box .txt {
  margin-bottom: 40px;
}
#local #container section .ttl {
  max-width: 1000px;
  display: flex;
  margin: 0 auto;
}
#local #container section .ttl::before {
  content: "";
  height: 1px;
  display: flex;
  background: #0c1c4d;
  margin: 50px 20px 0 0;
  margin-left: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
}
#local #container section h2.style01 {
  font-size: 5.6rem;
  line-height: 1.6;
  margin-bottom: 0.5em;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
  text-transform: uppercase;
}
@media screen and (max-width: 767px) {
  #local #container section h2.style01 {
    font-size: 4.4rem;
  }
}
#local #container section h2.style01 span {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  display: block;
}
@media screen and (max-width: 767px) {
  #local #container section h2.style01 span {
    font-size: 2rem;
  }
}
#local #container section h2.style02 {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  color: #0c1c4d;
  font-size: 2.4rem;
  border-left: 1px solid #0c1c4d;
  padding-left: 1em;
  margin-bottom: 1em;
}
#local #container section h2.style03 {
  font-size: 4.8rem;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  margin-bottom: 1.5em;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #local #container section h2.style03 {
    font-size: 3.4rem;
  }
}
#local #container section h2.style04 {
  font-size: 4.8rem;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  margin-bottom: 1em;
  padding-bottom: 0.5em;
  line-height: 1.4;
  border-bottom: 1px solid #0c1c4d;
}
#local #container section h2.style04 span {
  font-size: 2.8rem;
  display: block;
}
@media screen and (max-width: 767px) {
  #local #container section h2.style04 span {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #local #container section h2.style04 {
    font-size: 3.4rem;
  }
}
#local #container section h3.style01 {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  color: #0c1c4d;
  font-size: 2.4rem;
  border-left: 1px solid #0c1c4d;
  padding-left: 1em;
  margin-bottom: 1em;
}
#local #container section h3.style02 {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  color: #0c1c4d;
  font-size: 2.4rem;
  margin-bottom: 1em;
}
#local #container section h3.style02::before {
  content: "■";
  margin-right: 10px;
}
#local #container section h3.style03 {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  color: #0c1c4d;
  font-size: 2.8rem;
  margin-bottom: 1em;
}
#local #container section .inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 60px 0;
}
@media screen and (max-width: 767px) {
  #local #container section .inner {
    padding: 40px 15px;
  }
}

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

    ピックアップ

========================================================*/
#local .pickup .title {
  height: 500px;
  background: url(../img/product/pickup/bg_title.png) no-repeat center top/cover;
}
#local .pickup .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .pickup .title .ttl::before {
  background: #fff !important;
}
#local .pickup .sec001 .inner .flex {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #local .pickup .sec001 .inner .flex {
    display: block;
  }
}
#local .pickup .sec001 .inner .flex h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.6;
}
#local .pickup .sec001 .inner .flex h3 span {
  color: #1a2f9e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  display: block;
}
#local .pickup .sec001 .inner figure {
  margin: 40px 0;
  text-align: center;
}
#local .pickup .sec001 .inner .point {
  margin: 50px 0;
}
#local .pickup .sec001 .inner .point dt {
  background: #0c1c4d;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  padding: 5px 20px;
  margin-bottom: 1em;
  display: inline-block;
}
#local .pickup .sec001 .inner .point dd h4 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
}
#local .pickup .sec001 .inner .point dd .txt {
  margin-bottom: 50px;
}
#local .pickup .sec001 .inner .list_wrap {
  background: #ecedf1;
  padding: 50px;
}
@media screen and (max-width: 767px) {
  #local .pickup .sec001 .inner .list_wrap {
    padding: 20px;
  }
}
#local .pickup .sec001 .inner .list_wrap h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 2em;
  padding-left: 1em;
  border-left: 1px solid #0c1c4d;
}
#local .pickup .sec001 .inner .list_wrap .txt {
  margin-bottom: 30px;
}
#local .pickup .sec001 .inner .list_wrap .photos {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#local .pickup .sec001 .inner .list_wrap .photos .box {
  width: calc(50% - 30px);
}
@media screen and (max-width: 767px) {
  #local .pickup .sec001 .inner .list_wrap .photos .box {
    width: 100%;
    margin-bottom: 30px;
  }
}
#local .pickup .sec001 .inner .list_wrap .photos .box h4 {
  color: #0c1c4d;
  font-weight: 600;
  margin-bottom: 1em;
}
#local .pickup .sec001 .inner .list_wrap .photos .box .txt {
  margin-bottom: 1em;
}

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

    その他製品

========================================================*/
#local .other .title, #local .other01 .title, #local .other02 .title, #local .other03 .title, #local .other04 .title {
  height: 500px;
  background: url(../img/product/other/bg_title.png) no-repeat center top/cover;
}
#local .other .title .ttl, #local .other01 .title .ttl, #local .other02 .title .ttl, #local .other03 .title .ttl, #local .other04 .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .other .title .ttl::before, #local .other01 .title .ttl::before, #local .other02 .title .ttl::before, #local .other03 .title .ttl::before, #local .other04 .title .ttl::before {
  background: #fff !important;
}
#local .other .sec001 .inner .flex, #local .other01 .sec001 .inner .flex, #local .other02 .sec001 .inner .flex, #local .other03 .sec001 .inner .flex, #local .other04 .sec001 .inner .flex {
  justify-content: space-between;
}
#local .other .sec001 .inner .flex li, #local .other01 .sec001 .inner .flex li, #local .other02 .sec001 .inner .flex li, #local .other03 .sec001 .inner .flex li, #local .other04 .sec001 .inner .flex li {
  width: calc(50% - 10px);
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  #local .other .sec001 .inner .flex li, #local .other01 .sec001 .inner .flex li, #local .other02 .sec001 .inner .flex li, #local .other03 .sec001 .inner .flex li, #local .other04 .sec001 .inner .flex li {
    width: 100%;
  }
}
#local .other .sec001 .inner .flex figure, #local .other01 .sec001 .inner .flex figure, #local .other02 .sec001 .inner .flex figure, #local .other03 .sec001 .inner .flex figure, #local .other04 .sec001 .inner .flex figure {
  margin: 30px 0;
}
#local .other .sec001 .inner .list_wrap, #local .other01 .sec001 .inner .list_wrap, #local .other02 .sec001 .inner .list_wrap, #local .other03 .sec001 .inner .list_wrap, #local .other04 .sec001 .inner .list_wrap {
  background: #ecedf1;
  padding: 50px;
}
@media screen and (max-width: 767px) {
  #local .other .sec001 .inner .list_wrap, #local .other01 .sec001 .inner .list_wrap, #local .other02 .sec001 .inner .list_wrap, #local .other03 .sec001 .inner .list_wrap, #local .other04 .sec001 .inner .list_wrap {
    padding: 20px;
  }
}
#local .other .sec001 .inner .list_wrap h3, #local .other01 .sec001 .inner .list_wrap h3, #local .other02 .sec001 .inner .list_wrap h3, #local .other03 .sec001 .inner .list_wrap h3, #local .other04 .sec001 .inner .list_wrap h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
  padding-left: 1em;
  border-left: 1px solid #0c1c4d;
}
#local .other .sec001 .inner .list_wrap .txt, #local .other01 .sec001 .inner .list_wrap .txt, #local .other02 .sec001 .inner .list_wrap .txt, #local .other03 .sec001 .inner .list_wrap .txt, #local .other04 .sec001 .inner .list_wrap .txt {
  margin-bottom: 30px;
  padding-left: 2em;
}

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

    鉛フリーはんだ

========================================================*/
#local .lead-free .title {
  height: 500px;
  background: url(../img/product/other/bg_title.png) no-repeat center top/cover;
}
#local .lead-free .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .lead-free .title .ttl::before {
  background: #fff !important;
}
#local .lead-free .sec001 .inner .flex {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #local .lead-free .sec001 .inner .flex {
    display: block;
  }
}
#local .lead-free .sec001 .inner .flex h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.6;
}
#local .lead-free .sec001 .inner .flex h3 span {
  color: #1a2f9e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  display: block;
}
#local .lead-free .sec001 .inner figure {
  margin: 40px 0;
  text-align: center;
}
#local .lead-free .sec001 .inner .point {
  margin: 50px 0;
}
#local .lead-free .sec001 .inner .point dt {
  background: #0c1c4d;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  padding: 5px 20px;
  margin-bottom: 1em;
  display: inline-block;
}
#local .lead-free .sec001 .inner .point dd h4 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
}
#local .lead-free .sec001 .inner .point dd .txt {
  margin-bottom: 50px;
}
#local .lead-free .sec001 .inner .list_wrap {
  background: #ecedf1;
  padding: 50px;
}
@media screen and (max-width: 767px) {
  #local .lead-free .sec001 .inner .list_wrap {
    padding: 20px;
  }
}
#local .lead-free .sec001 .inner .list_wrap h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 2em;
  padding-left: 1em;
  border-left: 1px solid #0c1c4d;
}
#local .lead-free .sec001 .inner .list_wrap .txt {
  margin-bottom: 30px;
}
#local .lead-free .sec001 .inner .list_wrap .photos {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#local .lead-free .sec001 .inner .list_wrap .photos .box {
  width: calc(50% - 30px);
}
@media screen and (max-width: 767px) {
  #local .lead-free .sec001 .inner .list_wrap .photos .box {
    width: 100%;
    margin-bottom: 30px;
  }
}
#local .lead-free .sec001 .inner .list_wrap .photos .box h4 {
  color: #0c1c4d;
  font-weight: 600;
  margin-bottom: 1em;
}
#local .lead-free .sec001 .inner .list_wrap .photos .box .txt {
  margin-bottom: 1em;
}

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

    有鉛はんだ

========================================================*/
#local .leaded .title {
  height: 500px;
  background: url(../img/product/other/bg_title.png) no-repeat center top/cover;
}
#local .leaded .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .leaded .title .ttl::before {
  background: #fff !important;
}
#local .leaded .sec001 .inner .flex {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #local .leaded .sec001 .inner .flex {
    display: block;
  }
}
#local .leaded .sec001 .inner .flex h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.6;
}
#local .leaded .sec001 .inner .flex h3 span {
  color: #1a2f9e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  display: block;
}
#local .leaded .sec001 .inner .point {
  margin: 50px 0;
}
#local .leaded .sec001 .inner .point dt {
  background: #0c1c4d;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  padding: 5px 10px;
  margin-bottom: 1em;
  display: inline-block;
}
#local .leaded .sec001 .inner .point dd h4 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
}
#local .leaded .sec001 .inner .point dd .txt {
  margin-bottom: 50px;
}
#local .leaded .sec001 .inner .list_wrap {
  background: #ecedf1;
  padding: 50px;
}
@media screen and (max-width: 767px) {
  #local .leaded .sec001 .inner .list_wrap {
    padding: 20px;
  }
}
#local .leaded .sec001 .inner .list_wrap h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 2em;
  padding-left: 1em;
  border-left: 1px solid #0c1c4d;
}
#local .leaded .sec001 .inner .list_wrap .txt {
  margin-bottom: 30px;
  padding-left: 2em;
}
#local .leaded .sec001 .inner .list_wrap .photos {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#local .leaded .sec001 .inner .list_wrap .photos .box {
  width: calc(50% - 30px);
}
@media screen and (max-width: 767px) {
  #local .leaded .sec001 .inner .list_wrap .photos .box {
    width: 100%;
    margin-bottom: 30px;
  }
}
#local .leaded .sec001 .inner .list_wrap .photos .box h4 {
  color: #0c1c4d;
  font-weight: 600;
  margin-bottom: 1em;
}

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

    鉛フリーソルダーペースト

========================================================*/
#local .solder-paste .title {
  height: 500px;
  background: url(../img/product/other/bg_title.png) no-repeat center top/cover;
}
#local .solder-paste .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .solder-paste .title .ttl::before {
  background: #fff !important;
}
#local .solder-paste .sec001 .inner .flex {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #local .solder-paste .sec001 .inner .flex {
    display: block;
  }
}
#local .solder-paste .sec001 .inner .flex h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.6;
}
#local .solder-paste .sec001 .inner .flex h3 span {
  color: #1a2f9e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  display: block;
}
#local .solder-paste .sec001 .inner figure {
  margin: 40px 0;
  text-align: center;
}
#local .solder-paste .sec001 .inner .point {
  margin: 50px 0;
}
#local .solder-paste .sec001 .inner .point dt {
  background: #0c1c4d;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  padding: 5px 20px;
  margin-bottom: 1em;
  display: inline-block;
}
#local .solder-paste .sec001 .inner .point dd h4 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
}
#local .solder-paste .sec001 .inner .point dd .txt {
  margin-bottom: 50px;
}
#local .solder-paste .sec001 .inner .list_wrap {
  background: #ecedf1;
  padding: 50px;
}
@media screen and (max-width: 767px) {
  #local .solder-paste .sec001 .inner .list_wrap {
    padding: 20px;
  }
}
#local .solder-paste .sec001 .inner .list_wrap h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 2em;
  padding-left: 1em;
  border-left: 1px solid #0c1c4d;
}
#local .solder-paste .sec001 .inner .list_wrap .txt {
  margin-bottom: 30px;
}
#local .solder-paste .sec001 .inner .list_wrap .photos {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#local .solder-paste .sec001 .inner .list_wrap .photos .box {
  width: calc(50% - 40px);
}
@media screen and (max-width: 767px) {
  #local .solder-paste .sec001 .inner .list_wrap .photos .box {
    width: 100%;
    margin-bottom: 30px;
  }
}
#local .solder-paste .sec001 .inner .list_wrap .photos .box h4 {
  color: #0c1c4d;
  font-weight: 600;
  margin-bottom: 1em;
}
#local .solder-paste .sec001 .inner .list_wrap .photos .box figure {
  margin: 0;
}
#local .solder-paste .sec001 .inner .list_wrap .photos .box .txt {
  margin-bottom: 1em;
}
#local .solder-paste .sec001 .inner .list_wrap .photos02 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#local .solder-paste .sec001 .inner .list_wrap .photos02 .box {
  width: calc(33.33333% - 30px);
}
@media screen and (max-width: 767px) {
  #local .solder-paste .sec001 .inner .list_wrap .photos02 .box {
    width: 100%;
    margin-bottom: 30px;
  }
}
#local .solder-paste .sec001 .inner .list_wrap .photos02 .box h4 {
  color: #0c1c4d;
  font-weight: 600;
  margin-bottom: 1em;
}
#local .solder-paste .sec001 .inner .list_wrap .photos02 .box figure {
  margin: 0;
}
#local .solder-paste .sec001 .inner .list_wrap .photos02 .box .txt {
  margin-bottom: 1em;
}

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

    棒はんだ（合金一覧表）

========================================================*/
#local .bar-solder .title {
  height: 500px;
  background: url(../img/product/other/bg_title.png) no-repeat center top/cover;
}
#local .bar-solder .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .bar-solder .title .ttl::before {
  background: #fff !important;
}
#local .bar-solder .sec001 .inner .flex {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #local .bar-solder .sec001 .inner .flex {
    display: block;
  }
}
#local .bar-solder .sec001 .inner .flex h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.6;
}
#local .bar-solder .sec001 .inner .flex h3 span {
  color: #1a2f9e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  display: block;
}
#local .bar-solder .sec001 .inner figure {
  text-align: center;
  margin-bottom: 50px;
}
#local .bar-solder .sec001 .inner .point {
  margin: 50px 0;
}
#local .bar-solder .sec001 .inner .point dt {
  background: #0c1c4d;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  padding: 5px 10px;
  margin-bottom: 1em;
  display: inline-block;
}
#local .bar-solder .sec001 .inner .point dd h4 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
}
#local .bar-solder .sec001 .inner .point dd .txt {
  margin-bottom: 50px;
}
#local .bar-solder .sec001 .inner .list_wrap {
  background: #ecedf1;
  padding: 50px;
}
#local .bar-solder .sec001 .inner .list_wrap h3 {
  font-family: "Zen Old Mincho", serif;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1em;
  padding-left: 1em;
  border-left: 1px solid #0c1c4d;
}
#local .bar-solder .sec001 .inner .list_wrap .txt {
  margin-bottom: 30px;
  padding-left: 2em;
}

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

    会社概要

========================================================*/
#local .company .title {
  height: 500px;
  background: url(../img/company/bg_title.png) no-repeat center top/cover;
}
#local .company .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .company .title .ttl::before {
  background: #fff !important;
}
#local .company .sec001 .inner nav .nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 0 100px;
}
@media screen and (max-width: 767px) {
  #local .company .sec001 .inner nav .nav {
    margin: 0 0;
  }
}
#local .company .sec001 .inner nav .nav li {
  width: calc(25% - 10px);
}
@media screen and (max-width: 767px) {
  #local .company .sec001 .inner nav .nav li {
    width: calc(50% - 10px);
    margin-bottom: 20px;
  }
}
#local .company .sec001 .inner .flex {
  justify-content: space-between;
}
#local .company .sec001 .inner .flex .cont {
  width: calc(70% - 30px);
}
@media screen and (max-width: 767px) {
  #local .company .sec001 .inner .flex .cont {
    width: 100%;
    margin-bottom: 30px;
  }
}
#local .company .sec001 .inner .flex figure {
  width: calc(30% - 30px);
}
@media screen and (max-width: 767px) {
  #local .company .sec001 .inner .flex figure {
    width: 100%;
  }
}
#local .company .sec002 .inner .rinen {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.8rem;
  text-align: center;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #local .company .sec002 .inner .rinen {
    font-size: 2rem;
    text-align: left;
  }
}
#local .company .sec004 {
  background: #ecedf1;
}
#local .company .sec004 .inner .box {
  padding: 50px;
  background: #fff;
}
@media screen and (max-width: 767px) {
  #local .company .sec004 .inner .box {
    padding: 15px;
  }
}
#local .company .sec004 .inner .box table {
  width: 100%;
  box-sizing: border-box;
}
#local .company .sec004 .inner .box table tr th {
  padding: 15px 0;
  border-bottom: 1px solid #c2c6d2;
  line-height: 1.6;
  text-align: left;
}
@media screen and (max-width: 767px) {
  #local .company .sec004 .inner .box table tr th {
    width: 100%;
    box-sizing: border-box;
    display: block;
  }
}
#local .company .sec004 .inner .box table tr td {
  padding: 15px;
  border-bottom: 1px solid #c2c6d2;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  #local .company .sec004 .inner .box table tr td {
    width: 100%;
    box-sizing: border-box;
    display: block;
  }
}
#local .company .sec004 .inner .box table tr td iframe {
  width: 100%;
}
#local .company .sec005 {
  background: #ecedf1;
}
#local .company .sec005 .inner ul {
  position: relative;
}
#local .company .sec005 .inner ul::before {
  height: 95%;
  width: 1px;
  background: #1a2f9e;
  position: absolute;
  left: 8px;
  top: 10px;
  content: "";
}
#local .company .sec005 .inner ul li {
  margin-bottom: 1em;
  font-size: 1.8rem;
  padding-left: 60px;
  text-indent: -60px;
  line-height: 1.6;
}
#local .company .sec005 .inner ul li::before {
  content: "●";
  color: #1a2f9e;
  margin-right: 40px;
}
#local .company .sec006 {
  background: url(../img/company/bg_csr.png) no-repeat center top/cover;
}
#local .company .sec006 .inner .lead {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.8rem;
  text-align: center;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #local .company .sec006 .inner .lead {
    font-size: 2rem;
    text-align: left;
  }
}
#local .company .sec007 {
  background: url(../img/company/bg_csr02.png) no-repeat center top/cover;
}
#local .company .sec007 .inner .box {
  margin-bottom: 50px;
}
#local .company .sec007 .inner .box02 {
  margin: 100px 0;
  padding-bottom: 50px;
  border-bottom: 1px solid #0c1c4d;
}
#local .company .sec007 .inner .box02.last {
  border-bottom: 0;
}

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

    技術サポート

========================================================*/
#local .support .title {
  height: 500px;
  background: url(../img/support/bg_title.png) no-repeat center top/cover;
}
#local .support .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .support .title .ttl::before {
  background: #fff !important;
}
#local .support .sec004 .inner .txt {
  margin-bottom: 50px;
}
#local .support .sec004 .inner nav .flex {
  justify-content: space-between;
}
#local .support .sec004 .inner nav .flex li {
  width: calc(25% - 10px);
}
@media screen and (max-width: 767px) {
  #local .support .sec004 .inner nav .flex li {
    width: 100%;
    margin-bottom: 20px;
  }
}
#local .support .sec004 .inner nav .flex li a {
  font-size: 1.6rem;
  text-align: center;
  display: block;
  padding: 20px;
  background: #ecedf1;
  border: 1px solid #0c1c4d;
  color: #0c1c4d;
  position: relative;
}
#local .support .sec004 .inner nav .flex li a::after {
  content: url(../img/common/arrow_nav.svg);
  position: absolute;
  top: 20px;
  right: 10px;
}
#local .support .sec005 .inner .box {
  margin-bottom: 50px;
}
#local .support .sec005 .inner .box .txt {
  margin-bottom: 1em;
  padding-left: 2em;
}
#local .support .sec005 .inner .box .flex {
  justify-content: space-between;
}
#local .support .sec005 .inner .box .flex figure {
  width: calc(50% - 10px);
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  #local .support .sec005 .inner .box .flex figure {
    width: 100%;
    margin-bottom: 20px;
  }
}
#local .support .sec001 .inner dl {
  padding-bottom: 40px;
  margin-bottom: 40px;
  border-bottom: 2px solid #0c1c4d;
}
#local .support .sec001 .inner dl dt {
  font-size: 2.4rem;
  display: flex;
  align-items: center;
  margin-bottom: 30px;
  line-height: 1.6;
}
#local .support .sec001 .inner dl dt span {
  text-align: center;
  width: 70px;
  height: 70px;
  box-sizing: border-box;
  font-size: 2.8rem;
  background: #0c1c4d;
  padding: 15px;
  color: #fff;
  display: inline-block;
  margin-right: 20px;
  font-family: "Zen Old Mincho", serif;
}
#local .support .sec001 .inner dl dd {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
}
#local .support .sec001 .inner dl dd span {
  text-align: center;
  width: 70px;
  height: 70px;
  box-sizing: border-box;
  font-size: 2.8rem;
  background: #ecedf1;
  padding: 15px;
  display: inline-block;
  margin-right: 20px;
  font-family: "Zen Old Mincho", serif;
}
#local .support .sec002 .inner .box {
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  #local .support .sec002 .inner .box .flex {
    justify-content: space-between;
  }
}
#local .support .sec002 .inner .box .flex li {
  width: calc(25% - 30px);
  margin-right: 30px;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  #local .support .sec002 .inner .box .flex li {
    margin-right: 0;
    width: calc(50% - 10px);
  }
}
#local .support .sec002 .inner .box .flex li:nth-child(4) {
  margin-right: 0;
}
#local .support .sec002 .inner .box .flex li h4 {
  margin-bottom: 1em;
}
#local .support .sec002 .inner .box .flex li .more {
  margin-top: 20px;
  text-align: center;
}
#local .support .sec003 .inner .box {
  margin-bottom: 40px;
}

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

    松尾ハンダの強み

========================================================*/
#local .advantage {
  background: #ecedf1;
}
#local .advantage .title {
  height: 500px;
  background: url(../img/advantage/bg_title.png) no-repeat center top/cover;
}
#local .advantage .title .ttl {
  color: #fff;
  padding-top: 300px;
}
#local .advantage .title .ttl::before {
  background: #fff !important;
}
#local .advantage .sec001 .inner h2 {
  font-size: 4.8rem;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  margin-bottom: 1em;
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec001 .inner h2 {
    font-size: 3.4rem;
  }
}
#local .advantage .sec001 .inner h2 span {
  color: #1a2f9e;
  font-size: 7.8rem;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec001 .inner h2 span {
    font-size: 5rem;
  }
}
#local .advantage .sec002 figure {
  margin: 60px 0;
}
#local .advantage .sec002 .box01 {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box01 {
    display: block;
  }
}
#local .advantage .sec002 .box01 figure {
  width: 50%;
  position: relative;
  z-index: 2;
  margin: 0;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box01 figure {
    width: 100%;
  }
}
#local .advantage .sec002 .box01 .cont {
  display: flex;
  justify-content: flex-end;
  width: 90%;
  box-sizing: border-box;
  padding: 50px 100px 50px;
  background: #fff;
  margin-top: 15%;
  position: relative;
  z-index: 1;
  margin-left: -40%;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box01 .cont {
    width: 100%;
    padding: 20px;
    margin-left: 0;
    margin-top: 0;
  }
}
#local .advantage .sec002 .box01 .cont .cont_inner {
  width: calc(50% - 20px);
  margin-right: calc(50% - 50vw);
  padding-right: calc(50vw - 50%);
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box01 .cont .cont_inner {
    width: 100%;
    margin: 0;
    padding: 0;
  }
}
#local .advantage .sec002 .box01 .cont .cont_inner h3 {
  font-size: 4.8rem;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  margin-bottom: 1em;
  line-height: 1.6;
  color: #1a2f9e;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box01 .cont .cont_inner h3 {
    font-size: 3.3rem;
  }
}
#local .advantage .sec002 .box01 .cont .cont_inner h3 span {
  font-size: 3.5rem;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box01 .cont .cont_inner h3 span {
    font-size: 2.3rem;
  }
}
#local .advantage .sec002 .box02 {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box02 {
    flex-wrap: wrap;
  }
}
#local .advantage .sec002 .box02 figure {
  width: 50%;
  position: relative;
  z-index: 2;
  margin: 0;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box02 figure {
    width: 100%;
    order: 1;
  }
}
#local .advantage .sec002 .box02 .cont {
  width: 80%;
  padding: 50px 100px 50px;
  background: #fff;
  margin-top: 15%;
  margin-right: -40%;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box02 .cont {
    width: 100%;
    padding: 20px;
    order: 2;
    margin: 0;
  }
}
#local .advantage .sec002 .box02 .cont .cont_inner {
  width: calc(50% - 20px);
  margin-left: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box02 .cont .cont_inner {
    width: 100%;
    margin: 0;
    padding: 0;
  }
}
#local .advantage .sec002 .box02 .cont .cont_inner h3 {
  font-size: 4.8rem;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  margin-bottom: 1em;
  line-height: 1.6;
  color: #1a2f9e;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box02 .cont .cont_inner h3 {
    font-size: 3.3rem;
  }
}
#local .advantage .sec002 .box02 .cont .cont_inner h3 span {
  font-size: 3.5rem;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec002 .box02 .cont .cont_inner h3 span {
    font-size: 2.3rem;
  }
}
#local .advantage .sec003 {
  margin-top: -200px;
  background: url(../img/advantage/bg_bottom.png) no-repeat center center/cover;
  padding: 600px 0;
}
@media screen and (max-width: 767px) {
  #local .advantage .sec003 {
    padding: 250px 0;
  }
}

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

    NEWS

========================================================*/
#local .no_bg {
  background: url(../img/movie/bg_title.png) no-repeat center top/100%;
}
#local .no_bg .news {
  padding-top: 200px;
}
#local .no_bg .news .news_inner .inner ul {
  background: #fff;
}
#local .no_bg .news .news_inner .inner ul li {
  font-size: 1.4rem;
  display: flex;
  padding: 15px 0;
  border-bottom: 1px solid #3d4a71;
  line-height: 1.6;
}
#local .no_bg .news .news_inner .inner ul li:first-child {
  border-top: 1px solid #3d4a71;
}
#local .no_bg .news .news_inner .inner ul li .date {
  margin-right: 30px;
  font-size: 1.8rem;
}
#local .no_bg .news .news_inner .inner ul li .post a {
  font-size: 2rem;
}
#local .no_bg .news .news_inner .inner ul li .post .cat {
  display: block;
}
#local .no_bg .news .news_inner .inner ul li .post .cat a {
  font-size: 1.8rem;
}
#local .no_bg .news .news_inner .inner ul li .post .new {
  background: #ee2a7b;
  padding: 1px 3px;
  color: #fff;
  font-size: 1.2rem;
  margin-right: 10px;
}
#local .no_bg .news .news_detail .inner h2 {
  line-height: 1.6;
  font-size: 2.4rem;
  padding-bottom: 20px;
  border-bottom: 1px solid #0c1c4d;
}
#local .no_bg .news .news_detail .inner h2 .date {
  font-size: 1.4rem;
  display: block;
}
#local .no_bg .news .news_detail .inner .post_inner {
  background: #fff;
  padding: 50px;
  border-bottom: 1px solid #333333;
}
@media screen and (max-width: 767px) {
  #local .no_bg .news .news_detail .inner .post_inner {
    padding: 15px;
  }
}
#local .no_bg .news .news_detail .inner .post_inner p {
  overflow-wrap: anywhere;
}
#local .no_bg .news .news_detail .inner .post_inner .pager {
  margin-top: 70px;
}
#local .no_bg .news .news_detail .inner .post_inner .pager ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  #local .no_bg .news .news_detail .inner .post_inner .pager ul {
    justify-content: space-between;
  }
}
#local .no_bg .news .news_detail .inner .post_inner .pager ul li {
  margin: 0 10px;
}
@media screen and (max-width: 767px) {
  #local .no_bg .news .news_detail .inner .post_inner .pager ul li {
    width: calc(50% - 20px);
    margin: 0;
  }
}

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

    お問い合わせ

========================================================*/
#local .contact {
  padding-top: 200px;
}
#local .contact .form .f12 {
  font-size: 1.2rem;
}
#local .contact .form .txt {
  margin-bottom: 50px;
}
#local .contact .form .form_box {
  background: #ecedf1;
  padding: 60px;
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  #local .contact .form .form_box {
    padding: 15px;
  }
}
#local .contact .form .form_box .txt {
  color: #0c1c4d;
  text-align: center;
}
#local .contact .form .form_box dl {
  padding-bottom: 20px;
  border-bottom: 1px solid #3d4a71;
  margin-bottom: 40px;
}
#local .contact .form .form_box dl dt {
  margin-bottom: 1em;
}
#local .contact .form .form_box dl dt em {
  background: #ee2a7b;
  padding: 1px 3px;
  color: #fff;
  font-size: 1.2rem;
  margin-left: 10px;
}
#local .contact .form .form_box dl dt .free {
  padding: 1px 3px;
  font-size: 1.2rem;
  margin-left: 10px;
  border: 1px solid #0c1c4d;
}
#local .contact .form .form_box dl dd {
  margin-bottom: 30px;
}
#local .contact .form .form_box dl dd input, #local .contact .form .form_box dl dd textarea {
  padding: 15px;
  border: 0;
  width: 100%;
  box-sizing: border-box;
  background: #fff;
}
#local .contact .form .form_box .submit {
  text-align: center;
  margin-top: 30px;
}
#local .contact .form .form_box .submit input {
  border: 0;
  background: url(../img/contact/bg_submit.png) no-repeat center top/cover;
  color: #fff;
  font-weight: 500;
  font-size: 2.2rem;
  padding: 20px;
  width: 375px;
}
@media screen and (max-width: 767px) {
  #local .contact .form .form_box .submit input {
    width: 100%;
    box-sizing: border-box;
  }
}

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

    MOVIE

========================================================*/
#local .bg_movie {
  background: url(../img/movie/bg_title.png) no-repeat center top/100%;
}
#local .bg_movie .movie {
  padding-top: 200px;
}
#local .bg_movie .movie video {
  width: 100%;
}
#local .bg_movie .movie .sec002 .inner .flex .vid_contents {
  width: calc(33.333333% - 5px);
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  #local .bg_movie .movie .sec002 .inner .flex .vid_contents {
    width: 100%;
    margin: 0 0 20px 0;
  }
}
#local .bg_movie .movie .sec002 .inner .flex .vid_contents video {
  width: 100%;
}
#local .bg_movie .movie .sec003 .inner .flex .vid_contents {
  width: calc(33.333333% - 5px);
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  #local .bg_movie .movie .sec003 .inner .flex .vid_contents {
    width: 100%;
    margin: 0 0 20px 0;
  }
}
#local .bg_movie .movie .sec003 .inner .flex .vid_contents video {
  width: 100%;
}
#local .bg_movie .movie .sec003 .inner .flex div.vid_contents {
  width: 100%; /*背景色を横幅いっぱいに広げる*/
  text-align: center;
  margin: auto;
  padding: 4% 4% 4% 4%; /*ここで動画の周りの余白を調整*/
  background: #e6e6e6; /*余白の背景色*/
}
#local .bg_movie .movie .sec003 .inner .flex video.vid_main {
  width: 100%;
  max-width: 920px; /*PC版での最大幅*/
}

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

    Privacy Policy

========================================================*/
#local .bg_privacy {
  background: url(../img/movie/bg_title.png) no-repeat center top/100%;
}
#local .bg_privacy .privacy {
  padding-top: 200px;
}
#local .bg_privacy .privacy .sec002 .box {
  margin-bottom: 40px;
}
#local .bg_privacy .privacy .sec002 .box ul {
  list-style: disc;
  padding-left: 1em;
  line-height: 1.8;
}/*# sourceMappingURL=style.css.map */