@charset "UTF-8";

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
  max-width: 100%;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
  height: 100%;
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

/* common styles */

html {
  box-sizing: border-box;
  font-size: 14px;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

@media only screen and (max-width: 374px) {
  html {
    font-size: 3.733333vw;
  }
}

body {
  font-size: 1rem;
  font-family: 'Noto Sans JP', YuGothic, 'Yu Gothic', Meiryo, 'ヒラギノ角ゴ Pro', sans-serif;
  color: #231815;
  line-height: 1.75;
  padding: 6.357143em 0 0;
}

.pageWrap {
  overflow-x: hidden;
}

@media only screen and (min-width: 900px) {
  body {
    padding-top: 8em;
  }
}

p {
  margin: 0 0 1em;
}

p:last-child {
  margin-bottom: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}


.spOnly {
  display: none;
}
.pcOnly {
  display: block;
}
@media (max-width: 767px) {
  .spOnly {
    display: block;
  }
  .pcOnly {
    display: none;
  }
}

/* header */

.mainHeader {
  background: linear-gradient(to right, #008cd6 0%, #002c7d 100%);
  padding: 0.357143em 0 0;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 1000;
  width: 100%;
}

.headerInner1 {
  background-color: #FFF;
}

.headerInner2 {
  width: 100%;
  height: 3em;
  background-color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  position: relative;
  padding: 0 0.7142855em 0 1.428571em;
  z-index: 1;
}

@media only screen and (min-width: 900px) {
  .mainHeader {
    padding-top: 2em;
    border-bottom: 1px solid #231815;
  }

  .headerInner1 {
    padding: 0 calc(50vw - 500px);
  }

  .headerInner2 {
    height: 6em;
    padding: 0 0 1em;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}

.ttlWrap {
  margin: 0;
}

.siteTtl {
  font-size: 0.5em;
  font-weight: 500;
  line-height: 1;
  margin: 0 0 0.5em 0.5em;
}

.headerLogo {
  font-size: 1em;
  line-height: 1;
  margin: 0;
  width: 12.5em;
}

.headerLogo a {
  transition: opacity 0.2s ease-out;
}

.headerLogo a:hover {
  opacity: 0.7;
}

@media only screen and (min-width: 900px) {
  .siteTtl {
    font-size: 0.785714em;
    position: absolute;
    color: #FFF;
    top: -1.75em;
    margin-bottom: 0;
  }

  .headerLogo {
    width: 19.285714em;
  }
}

.headerCart {
  width: 2.75em;
  height: 2.571429em;
  margin: 0 1.25em 0 auto;
  line-height: 1;
}

.headerCart .cartWrap {
  display: block;
  text-decoration: none;
  color: inherit;
  position: relative;
  width: 100%;
  height: 100%;
  background: url(../img/common/icon_cart.svg) no-repeat left bottom;
  background-size: 2.357143em auto;
  transition: opacity 0.2s ease-out;
  cursor: pointer;
}

.headerCart .cartWrap:hover {
  opacity: 0.7;
}

.headerCart .cartItems {
  font-size: 0.714286em;
  color: #FFF;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  min-width: 1.8em;
  height: 1.8em;
  border-radius: 0.9em;
  background-color: #EB6100;
  position: absolute;
  top: 0;
  right: 0;
  padding: 0 0.25em;
}

@media only screen and (min-width: 900px) {
  .headerCart {
    width: 3em;
    height: 2.785714em;
    margin: 0 1.428571em;
  }

  .headerCart .cartWrap {
    background-size: 2.642857em auto;
  }

  .headerCart .cartItems {
    font-size: 0.857143em;
  }
}

.navToggle {
  display: block;
  font: inherit;
  font-size: 1em;
  border: none;
  margin: 0;
  padding: 0;
  background: none;
  outline: none;
}

.navToggleBox {
  width: 1.642857em;
  height: 1.107143em;
  display: block;
  position: relative;
  
}

.navToggleInner {
  display: block;
  top: 50%;
  margin-top: -0.1em;
  transition-duration: 0.075s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.navToggleInner,
.navToggleInner::before,
.navToggleInner::after {
  width: 1.642857em;
  height: 0.178571em;
  background-color: #231815;
  position: absolute;
  transition-property: transform;
  transition-duration: 0.15s;
  transition-timing-function: ease;
}

.navToggleInner::before,
.navToggleInner::after {
  display: block;
  content: '';
}

.navToggleInner::before {
  top: -0.576923em;
  transition: top 0.075s 0.12s ease, opacity 0.075s ease;
}

.navToggleInner::after {
  bottom: -0.576923em;
  transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.navToggle.opened .navToggleInner {
  transform: rotate(45deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.navToggle.opened .navToggleInner::before {
  top: 0;
  opacity: 0;
  transition: top 0.075s ease, opacity 0.075s 0.12s ease;
}

.navToggle.opened .navToggleInner::after {
  bottom: 0;
  transform: rotate(-90deg);
  transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

@media only screen and (min-width: 900px) {
  .navToggle {
    display: none;
  }
}

.spSearchWrap {
  background-color: #7E7978;
  width: 100%;
  height: 3em;
  display: block;
  padding: .45em 0.714286em 0;
}

.ec-headerSearch {
  width: 100%;
}

.spSearch .ec-headerSearch select {
  display: none;
}

.headerSearch {
  margin: 0;
}

.headerSearch select {
  display: none;
}

.headerSearchBlock,
.spSearchBlock {
  border-radius: 3px;
  background-color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0;
}

.spSearchBlock {
  width: 100%;
  height: 2.071429em;
}

.headerSearchBlock {
  /* width: 18.214286em; */
  width: 100%;
  height: 2.071429em;
  margin-right: 0.714286em;
  background-color: transparent;
  position: relative;
  display: flex;
}

.headerSearchBlock input[type=search] {
  flex-grow: 1;
  border-radius: 3px;
}

.headerSearchBlock button[type=text],
.spSearchBlock button[type=text] {
  border: none;
  font-size: 0.857143em;
  outline: none;
  padding: 0.1em 0.75em;
  width: calc(100% - 2.416667em);
  display: block;
  margin: 0;
}

.headerSearchBlock button[type=submit],
.spSearchBlock button[type=submit] {
  display: block;
  margin: 0;
  border: none;
  padding: 0;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  font-size: 0.857143em;
  height: 100%;
  width: 2.416667em;
  background: url(../img/common/icon_search__sp.svg) no-repeat center center;
  background-size: 1.333333em auto;
  outline: none;
  position: static;
  transform: none;
  cursor: pointer;
  z-index: 0;
}

.headerSearchWrap .headerSearchBlock {
  width: 100%;
  height: 2.857143em;
  border: 1px solid #7E7978;
  margin-bottom: 1.071429em;
}


@media only screen and (min-width: 900px) {
  .spSearchWrap {
    display: none;
  }

  .headerSearchWrap {
    margin: 0 1.428571em 0 auto;
  }

  .headerSearch {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .headerSearch select {
    display: block;
    font-size: 0.785714em;
    width: 8.818182em;
    height: 2.272727em;
    border: none;
    color: #FFF;
    border-radius: 0;
    outline: none;
    padding: 0 1.5em 0 0.5em;
    -webkit-appearance: none;
   -moz-appearance: none;
    appearance: none;
    background: #7E7978 url(../img/common/arrow_02.svg) no-repeat right 0.75em center;
    background-size: 0.727273em auto;
  }
  
  .headerSearch select::-ms-expand {
    display: none;
  }

  .headerSearchWrap .headerSearchBlock {
    margin-bottom: 0;
    font-size: 0.785714em;
    height: 2.272727em;
    width: 15em;
    border-radius: 0;
    background-color: #ffffff;
    border: 1px solid #7E7978;
    margin-bottom: 0;
  }


  .headerSearchBlock input[type=search],
  .headerSearchBlock button[type=submit] {
    font-size: 1em;
  }

  .headerSearchBlock input[type=search] {
    width: calc(100% - 2.272727em);
  }

  .headerSearchBlock button[type=submit] {
    width: 2.272727em;
    background-image: url(../img/common/icon_search__pc.svg);
    background-size: 0.818182em auto;
  }
}

.logInBlock,
.linksBlock {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  margin: 0 0 2.142857em;
}

.logInBlock > p,
.linksBlock > p {
  width: 11.428571em;
  margin: 0;
}

.logInBlock a,
.linksBlock a,
.logInBtn a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-decoration: none;
  color: inherit;
  border: 1px solid;
  margin: 0;
  border-radius: 3px;
  width: 100%;
  height: 2.857143em;
  font-weight: 500;
  transition: opacity 0.2s ease-out;
}

.logInBlock a:hover,
.linksBlock a:hover,
.logInBtn a:hover {
  opacity: 0.7;
}

.logInBtn a {
  background: #FFDB00 url(../img/common/icon_login.svg) no-repeat 0.333333em center;
  background-size: 1.357143em auto;
  padding: 0 0 0 1.75em;
  border-color: #FFDB00;
}

.spSearchWrap .logInBtn {
  height: 2.071429em;
  width: 6.428571em;
}

.spSearchWrap .logInBtn a {
  height: 100%;
  font-size: 0.857143em;
  font-weight: 400;
  background-size: 2.083333em auto;
  padding: 0 0 0 2.5em;
}

.logInLink a {
  color: #003894;
  border-color: #003894;
}

.link1 a {
  color: #FFF;
  border-color: #79BD28;
  background-color: #79BD28;
}

.link2 a {
  color: #00A0E9;
  border-color: #00A0E9;;
}

@media only screen and (min-width: 900px) {
  .logInBlock,
  .linksBlock {
    display: block;
    margin: 0;
    width: 8em;
  }

  .logInBlock > p,
  .linksBlock > p {
    width: auto;
  }

  .linksBlock > p:last-child {
    margin-top: 0.357143em;
  }

  .logInBlock a,
  .linksBlock a {
    font-size: 0.785714em;
    height: 2.272727em;
  }

  .logInBlock .logInLink {
    padding-bottom: 0.5em;
  }

  .logInBlock .logInLink a {
    height: auto;
    background: transparent;
    border: none;
    display: inline-block;
    width: auto;
  }

  .logInBlock .logInLink a::before {
    content: '▶︎';
    display: inline-block;
    margin: 0 0.25em 0 0.5em;
  }

  .logInBlock .logInBtn a {
    background-image: none;
    padding-left: 0;
  }
}

.headerNav {
  width: 100%;
  height: calc(100vh - 3.357143em);
  position: absolute;
  left: 0;
  top: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  transition: transform 0.25s ease-out;
  border-top: 1px solid;
  padding: 1.428571em;
  background-color: #FFF;
  transform: scale(1, 0);
  transform-origin: center top;
}

.headerNav.opened {
  transform: scale(1, 1);
}

@media only screen and (min-width: 900px) {
  .headerNav {
    display: none;
  }
}

.asideBlock1__sp,
.asideBlock2__sp {
  margin: 0 0 2.142857em;
}

.asideTtl1 {
  font-weight: 700;
  font-size: 1em;
  margin: 0 0 0.5em;
}

.accList,
.navList1 {
  margin: 0;
  border: 1px solid #7E7978;
}

.navList1 {
  background-color: #F7F5F5;
}

.navList2 {
  background-color: #EFF8FE;
}

.accList > dt,
.accList > dd,
.navList1 > dt,
.navList1 > dd {
  margin: 0;
  border-top: 1px solid #7E7978;
}

.accList > dd {
  display: none;
}

.navList1 > dt,
.navList1 > dd {
  border-color: #FFF;
}

.accList > dt:first-child,
.navList1 > dt:first-child {
  border-top: none;
}

.accList > dt,
.asideBlock1__pc .navList1 > dt a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 3.571429em;
  font-weight: 500;
  padding: 0 1.357143em;
}

.navList1 > dt a {
  background-color: #DEDEDE;
}

.accList > dt::before,
.accList > dt::after {
  content: '';
  display: block;
  width: 0.714386em;
  height: 1px;
  background-color: #231815;
  position: absolute;
  right: 1.357143em;
  top: 50%;
  transform: translateY(-50%);
}

.accList > dt::after {
  transition: transform 0.2s ease-out;
  transform: translateY(-50%) rotate(-90deg);
}

.accList > dt.opened::after {
  transform: translateY(-50%) rotate(0deg);
}

.accList ul,
.navList1 ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.accList ul > li,
.navList1 ul > li {
  margin: 0;
  border-top: 1px solid #7E7978;
}

.navList1 ul > li {
  border-color: #FFF;
}

.accList ul > li:first-child,
.navList1 ul > li:first-child {
  border-top: none;
}

.accList ul a,
.navList1 ul a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 1.357143em;
  height: 3.571429em;
  color: inherit;
}

.accList ul li:not(.allLinks) a {
  padding-left: 2.714286em;
}

.navList1 ul a {
  color: #003894;
}

.navList2 ul a {
  font-size: 0.928571em;
  padding: 0 1.461538em 0 3em;
  height: 3.846154em;
}

@media only screen and (min-width: 768px) {
  .asideBlock1__pc .navList1 > dt a,
  .navList1 ul a {
    height: 2.571429em;
    padding: 0 1em;
  }
}

/* footer */

.mainFooter {
  margin: 3.571429em 0 0;
}

.footerInner1 {
  padding: 1.428571em;
  margin: 0;
}

.footerInner1:nth-child(1) {
  background-color: #0051A8;
}

.footerInner1:nth-child(2) {
  background-color: #231815;
}

.footerList1 {
  margin: 0 auto;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 1000px;
}

.footerList1 > li {
  font-size: 0.857143em;
  width: calc(50% - 1em);
  margin: 1.5em 0 0 2em;
  color: #FFF;
}

.footerList1 > li:nth-child(-n+2) {
  margin-top: 0;
}

.footerList1 > li:nth-child(odd) {
  margin-left: 0;
}

.footerInner2 {
  margin: 0 auto;
  max-width: 1000px;
}

.footerInfo1 {
  margin: 0;
}

.footerInfo1 > dt {
  font-size: 0.928571em;
  font-weight: 700;
  color: #FFF;
  margin: 0;
  line-height: 2;
}

.footerInfo1 > dd {
  font-size: 0.857143em;
  color: #FFF;
  margin: 0;
  line-height: 2;
}

.copyright {
  color: #FFF;
  font-size: 0.785714em;
  margin: 2em 0 0;
}

@media only screen and (min-width: 768px) {
  .mainFooter {
    margin-top: 6em;
  }

  .footerInner1:nth-child(1) {
    padding: 0.678571em 1.428571em;
  }

  .footerInner1:nth-child(2) {
    padding: 2.5em 1.428571em;
  }

  .footerList1 {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  
  .footerList1 > li {
    font-size: 1em;
    width: auto;
    margin: 0.75em 2.428571em;
  }
  
  .footerList1 > li:nth-child(-n+2) {
    margin-top: 0.75em;
  }
  
  .footerList1 > li:nth-child(odd) {
    margin-left: 2.428571em;
  }

  .footerInner2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    width: 100%;
  }

  .footerInfo1 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  .footerInfo1 > dt {
    font-size: 1.285714em;
    line-height: 1.5;
    margin-right: 1em;
  }

  .footerInfo1 > dd {
    line-height: 1.5;
  }

  .footerInfo1 > dd br {
    display: none;
  }

  .copyright {
    font-size: 0.857143em;
    width: 100%;
  }
}

@media only screen and (min-width: 960px) {
  .copyright {
    margin-top: 0;
    width: auto;
  }
}

/* main */

.subPage {
  margin-top: 30px;
}

.contentWrap {
  margin: 0 auto;
  max-width: 1000px;
}

.contentBlock {
  margin: 0;
}

.menuBlock {
  margin: 2.857143em auto;
  padding: 0 1.428571em;
}

@media (min-width: 768px) and (max-width: 1020px) {
  .contentWrap {
    margin: 0 20px;
  }
}

@media only screen and (max-width: 899px) {
  .subPage .menuBlock {
    display: none;
  }
}

@media only screen and (min-width: 900px) {
  .subPage {
    margin-top: 0;
  }
  .contentWrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-top: 1.428571em;
  }

  .contentBlock {
    width: calc(100% - 17.142857em);
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .menuBlock {
    width: 15.714286em;
    margin: 0;
    padding: 0;
  }
}

.asideBlock2__pc {
  border: 1px solid #707070;
  background-color: #EFF8FE;
  padding: 1.428571em;
}

.asideBlock2__pc .txt1 {
  text-align: center;
  font-size: 0.857143em;
  font-weight: 700;
  color: #004288;
  margin: 0 0 1em;
}

.asideBlock2__pc .logo1 {
  line-height: 1;
  text-align: center;
  margin: 0 0 2em;
}

.asideBlock2__pc .logo1 img {
  width: 12.928571em;
}

.list1 {
  margin: 0 0 1.5em;
  padding: 0;
  list-style: none;
}

.list1:last-child {
  margin-bottom: 0;
}

.list1 > li {
  padding: 0 0 0 1.666667em;
  margin: 0 0 0.75em;
  background: url(../img/common/icon_check.svg) no-repeat left 0.6em;
  background-size: 1em auto;
}

.list1 > li:last-child {
  margin-bottom: 0;
}

.asideBlock2__pc .list1 {
  background: url(../img/common/illust_01.svg) no-repeat right bottom;
  background-size: 4em auto;
}

.asideBlock2__pc .list1 > li {
  font-size: 0.857143em;
}

@media only screen and (min-width: 768px) {
  .asideBlock2__pc {
    padding: 1em 0.75em;
  }

  .asideBlock2__pc .txt1 {
    font-size: 1em;
    text-align: left;
  }

  .asideBlock2__pc .logo1 {
    margin-bottom: 1em;
    text-align: left;
  }

  .asideBlock2__pc .logo1 img {
    width: 100%;
    max-width: 13.571429em;
  }

  .asideBlock2__pc .list1 {
    background-size: 3em auto;
  }
}

.secBlock1 {
  margin: 0 auto 2.857143em;
  padding: 0 1.428571em;
}

.secBlock1:last-child {
  margin-bottom: 0;
}

@media only screen and (min-width: 768px) {
  .secBlock1 {
    margin-bottom: 3.214286em;
  }
}

@media only screen and (min-width: 900px) {
  .secBlock1 {
    padding: 0;
  }
}

.secTtl1 {
  font-weight: 700;
  font-size: 1em;
  margin: 0 0 1em;
}

.secTtl2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 1em;
  font-weight: 500;
  line-height: 1.5;
  min-height: 2.5em;
  padding: 0 0.714286em;
  background-color: #DEDEDE;
  margin: 2.5em 0 1.428571em;
}

.secTtl1 + .secTtl2,
.secTtl2:first-child {
  margin-top: 0;
}

.secTtl2 > a {
  display: block;
  color: #0051A8;
  font-size: 0.857143em;
  font-weight: 700;
  background: #FFF url(../img/common/arrow_01.svg) no-repeat right 0.5em center;
  background-size: 0.416667em auto;
  width: 7.5em;
  line-height: 2;
  padding: 0 0.833333em;
  border: 1px solid #0051A8;
  border-radius: 3px;
  transition: opacity 0.2s ease-out;
}

.secTtl2 > a:hover {
  opacity: 0.7;
  text-decoration: none;
}

@media only screen and (min-width: 768px) {
  .secTtl1 {
    font-size: 1.714286em;
  }

  .secTtl2 {
    font-size: 1.428571em;
    min-height: 2em;
    padding: 0 1.8em 0 0.75em;
    margin: 3em 0 1em;
  }

  .secTtl2 > a {
    font-size: 0.6em;
    line-height: 2.333333;
    width: 6.666667em;
  }
}

.itemsList1 {
  margin: 0 0 2.5em;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.itemsList1:last-child {
  margin-bottom: 0;
}

.itemsList1 > li {
  width: 47.761194%;
  margin: 1.428571em 0 0 4.477612%;
}

.itemsList1 > li:nth-child(-n+2) {
  margin-top: 0;
}

.itemsList1 > li:nth-child(odd) {
  margin-left: 0;
}

.itemsList1 a {
  display: block;
  transition: opacity 0.2s ease-out;
}

.itemsList1 a:hover {
  opacity: 0.7;
  text-decoration: none;
}

.itemImg1 {
  border: 1px solid #707070;
  line-height: 1;
  text-align: center;
  margin: 0 0 0.25em;
}

.itemName1 {
  color: #0051A8;
  font-size: 0.928571em;
  font-weight: 700;
  margin: 0;
}

.itemPrice1 {
  font-size: 0.857143em;
  font-weight: 700;
  margin: 0;
}

.itemPrice1 span {
  font-size: 0.857143em;
}

@media only screen and (min-width: 768px) {
  .itemsList1 > li {
    width: 31.578947%;
    margin: 2em 0 0 2.6315795%;
  }
  
  .itemsList1 > li:nth-child(-n+3) {
    margin-top: 0;
  }
  
  .itemsList1 > li:nth-child(odd) {
    margin-left: 2.6315795%;
  }

  .itemsList1 > li:nth-child(3n+1) {
    margin-left: 0;
  }

  .itemImg1 {
    margin-bottom: 0.5em;
  }
  
  .itemName1 {
    /* font-size: 1.428571em; */
    font-size: 16px;
  }
  
  .itemPrice1 {
    font-size: 1em;
  }
}

.asideBlock1__pc {
  padding: 0 1.428571em;
  margin: 0 0 2.857143em;
}

.asideBlock1__pc .allLinks {
  display: none;
}

@media only screen and (min-width: 768px) and (max-width: 899px) {
  .asideBlock1__pc {
    margin-left: auto;
    margin-right: auto;
    width: 34.285714em;
  }
}

@media only screen and (min-width: 900px) {
  .asideBlock1__pc {
    padding: 0;
    margin-bottom: 1.428571em;
  }
}

.asideTtl1 {
  color: #FFF;
  font-size: 1em;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: #7E7978;
  height: 3em;
  margin: 0;
  padding: 0 1em;
}

@media only screen and (min-width: 768px) {
  .asideTtl1 {
    height: 2.857143em;
  }
}

#linkList3_wrap {
  background-color: #FFF;
  padding: 1.428571em;
}

#linkList3_wrap .linkList3 {
  margin: 0;
  padding: 0;
  list-style: square;
  list-style-position: inside;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  color: #0051A8;
  font-size: 0.857143em;
}

#linkList3_wrap .linkList3 > li {
  width: calc(50% - 0.5em);
  margin: 1.5em 0 0 1em;
  text-indent: -1.5em;
  padding-left: 1.5em;
}

#linkList3_wrap .linkList3 > li:nth-child(-n+2) {
  margin-top: 0;
}

#linkList3_wrap .linkList3 > li:nth-child(odd) {
  margin-left: 0;
}

.txt2 {
  font-size: 0.857143em;
  margin: 1em 0 3em;
}

.txt2 img {
  width: auto;
  height: 1em;
  vertical-align: middle;
  margin-bottom: 0.2em;
}

@media only screen and (min-width: 768px) {
  #linkList3_wrap {
    padding: 1em;
  }

  #linkList3_wrap .linkList3 {
    display: block;
  }

  #linkList3_wrap .linkList3 > li {
    width: 100%;
    margin: 0.5em 0 0;
  }

  #linkList3_wrap .linkList3 > li:nth-child(2) {
    margin-top: 0.5em;
  }

  .txt2 {
    font-size: 0.785714em;
    margin-bottom: 2em;
  }
}

.asideBlock3__pc {
  border: 1px solid #707070;
}

.asideTtl2 {
  font-size: 0.928571em;
  background-color: #DEDEDE;
  height: 2.615385em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 1em;
  margin: 0;
}

.asideTtl2 span::before {
  content: '';
  display: inline-block;
  width: 1.923077em;
  height: 1.038462em;
  background: url(../img/common/logo5.svg) no-repeat center center;
  background-size: contain;
  vertical-align: middle;
  margin: 0 0.5em 0 0;
}

#linkList4_wrap {
  padding: 1em 1em 1em 3.25em;
}

#linkList4_wrap .linkList4 {
  margin: 0;
  padding: 0;
  list-style: square;
  font-size: 0.857143em;
}

#linkList4_wrap .linkList4 li {
  margin-bottom: 1em;
  color: #7E7978;
}

#linkList4_wrap .linkList4 li:last-child {
  margin-bottom: 0;
}

#linkList4_wrap .linkList4 li a {
  color: #231815;
}

@media only screen and (min-width: 768px) {
  #linkList4_wrap {
    padding-left: 2.5em;
  }

  #linkList4_wrap .linkList4 {
    font-size: 0.785714em;
  }
}

@media only screen and (min-width: 768px) and (max-width: 899px) {
  .menuBlock {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 34.285714em;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
  }

  .menuBlock > div {
    width: 15.714286em;
  }

  .menuBlock > .txt2 {
    margin-bottom: 0;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    width: 20em;
  }
}

.path {
  margin: 1em 0;
  padding: 0 1.428571em;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.path > li {
  margin: 0;
  font-size: 0.857143em;
}

.path > li::after {
  content: '＞';
  display: inline-block;
  margin: 0 0.25em;
}

.path > li:last-child::after {
  display: none;
}

@media only screen and (min-width: 900px) {
  .path {
    margin-top: 0;
    padding: 0;
  }
}

.pagination1 {
  margin: 2.857143em 0 0;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 1em;
}

.pagination1 > li {
  margin: 0 0 0 0.666667em;
}

.pagination1 > li:first-child {
  margin-left: 0;
}

.pagination1 > li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 1.666667em;
  height: 1.666667em;
  text-align: center;
  border: 1px solid #231815;
  transition: all 0.2s ease-out;
  line-height: 1;
}

.pagination1 > li a:hover,
.pagination1 > li a.current {
  background-color: #231815;
  color: #FFF;
  text-decoration: none;
}

.pagination1 > .pagPrev a span,
.pagination1 > .pagNext a span {
  display: block;
  width: 100%;
  height: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 0.416667em auto;
}

.pagination1 > .pagPrev a span {
  background-image: url(../img/common/arrow_04.svg);
}

.pagination1 > .pagNext a span {
  background-image: url(../img/common/arrow_05.svg);
}

.pagination1 > .pagPrev a:hover span {
  background-image: url(../img/common/arrow_04_w.svg);
}

.pagination1 > .pagNext a:hover span {
  background-image: url(../img/common/arrow_05_w.svg);
}

@media only screen and (min-width: 768px) {
  .pagination1 {
    margin-top: 5.714286em;
  }
}



/* デフォルトCSSの相殺 */
body {
  background-color: #ffffff;
}

.headerSearchBlock input[type=search] {
  border: none;
}

.ec-shelfGrid .ec-shelfGrid__item-image {
  height: auto;
}

@media only screen and (min-width: 768px) {
  .ec-mypageRole {
    padding: 0;
  }
  .ec-contactRole {
    padding: 0;
  }
  .ec-pageHeader h1 {
    margin: 0 0 48px;
    padding: 0 0 8px;
  }
  .ec-off1Grid .ec-off1Grid__cell {
    width: 100%;
    margin-left: 0;
  }
  .ec-role {
    padding: 0;
  }
}
