@charset "UTF-8";
/* =======================================
【BASE】ナビが単独で最終段にあり(MAX3段) header01、header02、header_nav　参考（https://www.shonan-ds.co.jp/）
========================================== */
h1 {
  padding-top: 21px;
}

.h_tel a {
  color: #fbfbfb;
}
.h_tel .num span {
  padding-left: 0.9em;
  background: url(../img/tel.svg) no-repeat left bottom 4px/0.67em;
}

.header01 {
  display: flex;
  justify-content: space-between;
  color: #fbfbfb;
}

.header01 .nav01 {
  display: flex;
}
.header01 .nav01 ul {
  display: flex;
}
.header01 .nav01 > ul:nth-child(1) {
  padding-top: 10px;
}
.header01 .nav01 > ul:nth-child(1) li:not(:last-child) {
  margin-right: 20px;
}
.header01 .nav01 > ul:nth-child(1) .btn01.cart a {
  padding-right: 16px !important;
  padding-left: 4em !important;
  background: url(../img/cart.svg) no-repeat left 1.2em bottom 13px/1.7em,
    #101010;
}
.header01 .nav01 > ul:nth-child(1) .btn01.youtube a {
  padding-right: 16px !important;
  padding-left: 4em !important;
  background: url(../img/youtube.svg) no-repeat left 1.2em bottom 15px/1.7em,
    #101010;
}

.header02 {
  display: flex;
  justify-content: space-between;
}

.header02 .logo {
  width: 13.57em;
  padding-top: 3px;
}

.header02 > div {
  display: flex;
  color: #fbfbfb;
  margin-top: 13px;
}

.header02 > div > .tel {
  padding-right: 30px;
}

.header02 > div > .tel a {
  width: 218px;
  padding-top: 4px;
  display: block;
}

.header02 > div > .con_line {
  position: relative;
  padding-left: 32px;
}

.header02 > div > .con_line:before {
  content: "";
  width: 1px;
  height: calc(100% - 7px);
  background: #e8e3d6;
  position: absolute;
  left: -5px;
  top: 2px;
}

.header02 > div > .con_line > ul {
  display: flex;
  font-weight: 600;
}

.header02 > div > .con_line > ul li:nth-child(1) {
  background: url(../img/icon_mail.svg) no-repeat center left 0/1.3em;
}

.header02 > div > .con_line a {
  color: #232220;
  padding-left: 1.6em;
  line-height: 100%;
}

.header02 > div > .con_line > ul li:nth-child(2) {
  background: url(../img/icon_line.svg) no-repeat center left 0/1.3em;
  margin-left: 27px;
}

.header_nav {
  background: linear-gradient(90deg, #ff5500, #ea8b00);
  margin-top: 21px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.0901960784);
}
.header_nav .nav {
  width: 1200px;
  margin: 0 auto;
  padding: 0;
  display: flex;
  position: relative;
  z-index: 9;
}
.header_nav .nav > li {
  list-style: none;
  width: 14.2857142857%;
  position: relative;
}
.header_nav .nav li a {
  display: block;
  text-align: center;
  color: #fff;
  text-decoration: none;
  border-right: 1px solid rgba(255, 255, 255, 0.5411764706);
  box-sizing: border-box;
  padding: 11px 0 13px;
}
.header_nav .nav li ul {
  width: calc(100% + 8em);
  display: none;
  margin-left: -4em;
  position: absolute;
  z-index: 999;
  background: #fff;
}
.header_nav .nav li ul li a {
  border-top: 3px solid #1c2c3b !important;
  color: #fff;
  padding: 8% 2%;
  background: url(../img/bg_nav.jpg) no-repeat center bottom/cover;
  font-family: "Kosugi", sans-serif;
  text-shadow: 2px 2px 1px rgba(48, 52, 61, 0.5);
}
.header_nav .content {
  width: 750px;
  height: 200px;
  background: #eee;
  margin: 0 auto;
  padding: 10px;
  text-align: left;
  box-sizing: border-box;
}
.header_nav .nav li a:nth-child(1) {
  border-left: 1px solid rgba(255, 255, 255, 0.5411764706);
}

/* =======================================
	【common】左がロゴ＋右側がその他
========================================== */
header {
  background: #efefef;
  width: 100%;
  position: sticky;
  top: 0;
  right: 0;
  z-index: 999;
  box-shadow: 2px 2px 12px rgba(48, 52, 61, 0.2);
}

.headerArea {
  display: flex;
  justify-content: space-between;
}

h1.logo a {
  display: inline-block;
  width: 20.3em;
}

.header02 {
  display: block;
}
.header02 .nav01 > ul {
  width: 100%;
  gap: 0 33px;
}
.header02 .nav01 .h_tel a,
.header02 .nav01 .h_contact a {
  display: inline-block;
  width: 100%;
}
.header02 .nav01 .tel_icon {
  padding-left: 2.3em;
  background: url(../img/tel.svg) no-repeat left center/1.9em;
}
.header02 .nav01 .contact_icon {
  padding-left: 1.9em;
  background: url(../img/mail.svg) no-repeat left center/1.56em;
}
.header02 .nav01 .h_btn a {
  background: #004f92;
  color: #fff;
  padding: 6px 23px;
  text-align: center;
  position: relative;
  border: 2px solid #004f92;
}
.header02 .nav01 .h_btn a::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: #efefef;
  transform-origin: 100% 50%;
  transform: scaleX(0);
  transition: transform ease 0.3s;
}
.header02 .nav01 .h_btn a:hover {
  color: #004f92 !important;
  font-weight: bold;
}
.header02 .nav01 .h_btn a:hover::before {
  transform-origin: 0% 50%;
  transform: scaleX(1);
}

.header_nav {
  background: none;
  box-shadow: none;
  justify-content: flex-end;
  margin-top: 3px !important;
  margin-bottom: 8px;
}
.header_nav .nav {
  max-width: 1200px;
  width: 100%;
  justify-content: flex-end;
  gap: 0 19px;
}
.header_nav .nav li a {
  display: block;
  text-align: center;
  color: #02121c;
  text-decoration: none;
  text-align: center;
  padding: 5px;
  line-height: 90%;
}
.header_nav .nav li a span {
  color: #747c89;
}
.header_nav .nav > li {
  list-style: none;
  width: auto;
  position: relative;
}

.header_nav .nav li a:nth-child(1) {
  border: none;
} /*# sourceMappingURL=header.css.map */
