/* base css */

html,
body {
  height: 100%;
  margin: 0;
  font-size: 1rem;
}


body {
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  font-family: "Helvetica Neue",
    Arial,
    'メイリオ',
    'Meiryo',
    "Hiragino Kaku Gothic ProN",
    sans-serif;
}


*,
*::before,
*::after {
  box-sizing: border-box;
}

img,
picture,
video,
canvas,
svg,
figure {
  max-width: 100%;
  margin: 0;
  height: auto;
}

iframe {
  max-width: 100%;
}


input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6,
div {
  overflow-wrap: break-word;
}


/* link color */
a {
  color: #01309a;
  transition: .25s;
}

a:hover {
  text-decoration: none;
  opacity: .7;
}



/* pc only display */
.hp_lgOnly {
  display: block;
}

@media screen and (max-width:768px) {
  .hp_lgOnly {
    display: none;
  }
}

/* sp only display*/
.hp_md0nly {
  display: none;
}

@media screen and (max-width:768px) {
  .hp_md0nly {
    display: block;
  }
}


/* base_width */
.hp_inner {
  width: 100%;
  max-width: 1000px;
  padding: 0 25px;
  margin: 0 auto;
}

/* bg */

.hp_bg {
  background-color: #efefef;
}




/* ttl */

.bl_ttlBlock {
  text-align: center;
}

.el_ttlLv1 {
  font-size: 36px;
  line-height: 1.5;
  margin: 0;
  padding: 0;
}

.el_ttlLv1 span {
  font-size: 20px;
}

.ly_mainContentPage .bl_ttlBlock {
  background-color: #eaeaea;
  padding-bottom: 25px;
  margin-bottom: 70px;
}

.el_ttlLv1Page {
  font-size: 22px;
  font-weight: normal;
  margin: 0;
  padding: 0;
}

.el_ttlLv2 {
  font-size: 18px;
  margin: 0 0 15px 0;
}

/* hamburgerIcon */

.el_hamburgerIcon {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 18px;
  width: 22px;
  cursor: pointer;

}

.el_hamburgerIcon_bar {
  width: 100%;
  height: 3px;
  background-color: #333;
  transition: all 0.3s ease-in-out;
  border-radius: 10px;
}



.el_hamburgerIcon.is_active .el_hamburgerIcon_bar:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}

.el_hamburgerIcon.is_active .el_hamburgerIcon_bar:nth-child(2) {
  opacity: 0;
}

.el_hamburgerIcon.is_active .el_hamburgerIcon_bar:nth-child(3) {
  transform: translateY(-4px) rotate(-45deg);
}

.el_hamburgerIcon__txt {
  position: relative;
  height: 33px;
  padding-bottom: 18px;

}

.el_hamburgerIcon__txt:after {
  display: inline-block;
  content: "MENU";
  font-size: 11px;
  color: #333;
  position: absolute;
  bottom: 0;
  left: -5px
}



/* header */


.ly_header {
  padding: 30px 0;
  border-bottom: solid 1px #ccc;
  ;
}

@media screen and (max-width:768px) {
  .ly_header {
    padding: 20px 0;
  }
}


.bl_header {
  display: flex;
  justify-content: space-between;
  position: relative
}

.bl_header_nav {
  padding: 20px 0 0 0;
}

.el_logo {
  width: 315px
}

@media screen and (max-width:768px) {
  .el_logo {
    width: 250px
  }
}

.bl_nav,
.bl_nav_item {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bl_nav {
  display: flex;
}

.bl_nav_item {
  display: block;
  margin-left: 20px;
}

.bl_nav_item:last-child {
  margin-left: 40px;
}

.bl_nav_link {
  color: #000;
  text-decoration: none;
  font-size: 14px;
}

.material-symbols-outlined {
  vertical-align: -3px;
  margin-right: 5px;
  font-size: 19px;
}

.bl_spMenuWrap {
  display: none;
  position: absolute;
  top: 70px;
  right: 0;
  padding: 5%;
  background-color: rgba(255, 255, 255, 0.95);
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
  width: 100%;
  max-width: 450px;
}

@media screen and (max-width:768px) {
  .bl_spMenuWrap {
    padding: 70px 50px;
  }
}

.bl_spMenuWrap.is_active {
  display: block;
}

.bl_navList,
.bl_navList_item {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bl_navList {
  padding: 30px 0
}

.bl_navList_link {
  display: inline-block;
  color: #000;
  text-decoration: none;
  font-size: 16px;
  background: url(/static/public/image/icon@2x.png) no-repeat left 50%;
  background-size: 10px;
  padding: 15px 15px 15px 25px;
}

.bl_navList__border {
  border-bottom: solid 1px #ccc;
}

.ly_mainContent {
  border-top: solid 30px #eaeaea;

}

@media screen and (max-width:768px) {

  .bl_nav_item:first-child,
  .bl_nav_item:nth-child(2) {
    display: none;
  }
}

.bl_mainCont {
  padding-bottom: 200px;
}

.ly_mainContentTop .bl_mainCont {
  margin-top: 75px
}


/* bl_card */

.bl_cardUnit,
.bl_card {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bl_cardUnit {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  justify-content: space-between;

}

.bl_ownerList {
  margin-top: 70px;
}

.bl_card {
  background-color: #fff;
}

.bl_card_link {
  display: block;
  text-decoration: none;
}



.bl_ownerList .bl_card_imgWrapper {
  border: solid 10px #efefef;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

.bl_card_imgWrapper img {
  width: 100%;
  height: auto;
  max-height: 100%;
  object-fit: contain;
}

.bl_ownerList .bl_card_body {
  padding: 15px 10px;
  line-height: 1.5;
}

.bl_card_ttl,
.bl_card_txt {
  color: #000;
  text-decoration: none;
  font-size: 15px;
}

.bl_card_ttl {
  font-size: 20px;
  padding: 0;
  margin: 0
}

.bl_card_txt {
  margin: 10px 0 0 0;
  padding: 0
}


.bl_cardUnit.bl_cardUnit__col3 {
  margin-bottom: 10px;
}

.bl_cardUnit.bl_cardUnit__col3::after {
  content: "";
  display: block;
  width: 31.707%;
}



.bl_cardUnit__col3>.bl_card {
  width: 31.707%;
  margin-right: 2.43902%;
  margin-bottom: 30px;
}

.bl_cardUnit__col3>.bl_card:nth-of-type(3n) {
  margin-right: 0;
}


.bl_cardUnit.bl_cardUnit__col4 {
  margin-bottom: -20px;
}

.bl_cardUnit__col4>.bl_card {
  width: 22%;
  margin-right: 3%;
  margin-bottom: 20px;
}

.bl_cardUnit__col4::before {
  content: "";
  display: block;
  width: 22%;
  order: 1;
}

.bl_cardUnit__col4::after {
  content: "";
  display: block;
  width: 22%;
}




.bl_cardUnit__col4>.bl_card:nth-of-type(4n) {
  margin-right: 0;
}

@media screen and (max-width: 768px) {
  .bl_cardUnit.bl_cardUnit__col3 {
    margin-bottom: -20px;
  }

  .bl_cardUnit.bl_cardUnit__col4 {
    margin-bottom: -15px;
  }

  .bl_cardUnit>.bl_card {
    width: 48%;
    margin-right: 0;
    margin-bottom: 20px;
  }
}

.bl_card_more {
  background: url(/static/public/image/icon@2x.png) no-repeat left 4px;
  background-size: 10px;
  color: #eb6d73;
  font-size: 14px;
  padding: 0 0 0 20px;
  margin-top: 15px
}


.bl_products_list .bl_card_imgWrapper {
  background-color: #eee;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}



.ly_footer {
  background-color: #f2f2f2;

}

.bl_address {
  text-align: center;
  padding: 45px 25px;
}

.bl_address p {
  margin: 0;
  padding: 0;
}

.bl_address_name {
  font-size: 20px;
}

.bl_address_hp a {
  color: #000;
}

.bl_copy {
  border-top: solid 1px #ccc;
  font-size: 12px;
  text-align: center;
  padding: 15px 25px;
}

.bl_usrInfo {
  display: flex;
  justify-content: space-between;
  padding-bottom: 30px;
}

.bl_usrInfo_icon {
  width: 22%;
  text-align: center;
}

.bl_usrInfo_icon img {
  max-width: 200px;
  height: auto;
  max-height: 300px;
}

.bl_usrInfo_smappon {
  width: 22%;
  text-align: center;
}

.bl_usrInfo_smappon img {
  max-width: 180px;
  height: auto;
}

.bl_usrInfo_date {
  width: 40%;
  line-height: 1.5;
}

.bl_usrInfo_date:last-child {
  width: 71%;
}


.bl_usrInfo_sub {
  font-size: 18px;
  margin: 0;
  padding: 0;
}

.bl_usrInfo_name {
  font-size: 35px;
  font-weight: bold;
  margin: 10px 0 0 0;
  padding: 0;
}

.bl_usrInfo_url,
.bl_usrInfo_url li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bl_usrInfo_url {
  margin-top: 25px;
}

.bl_usrInfo_url li {
  font-size: 13px;
  font-weight: bold;
  margin-bottom: 5px;
}

.bl_usrInfo_sns,
.bl_usrInfo_sns li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bl_usrInfo_sns {
  margin-top: 35px;
}

.bl_usrInfo_sns li {
  display: inline-block;
  margin-right: 22px
}



@media screen and (max-width:768px) {
  .bl_usrInfo {
    display: block;
  }

  .bl_usrInfo_icon {
    width: 100%;
  }

  .bl_usrInfo_smappon {
    display: none;
  }

  .bl_usrInfo_date {
    width: 100%;
  }

  .bl_usrInfo_sub {
    font-size: 16px;
  }

  .bl_usrInfo_name {
    font-size: 30px;
    margin: 0;
  }

  .bl_usrInfo_url {
    margin-top: 15px;
  }
}

.bl_usrMessage {
  border-top: solid 1px #ddd;
  padding: 50px 0 0 0;
}

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



.bl_shopInfo_img {
  width: 42%
}

.bl_shopInfo_img img {
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: 500px;
}

.bl_shopInfo_txt {
  width: 50%;
}


@media screen and (max-width:768px) {
  .bl_shopInfo {
    display: flex;
    flex-direction: column-reverse
  }

  .bl_shopInfo_img {
    width: 100%;
    margin-bottom: 20px;
  }

  .bl_shopInfo_txt {
    width: 100%;
  }

}



.bl_ownerVoice {
  margin-top: 50px;
}

.bl_products {
  margin-top: 80px;
  padding-top: 80px;
  border-top: solid 1px #ddd;
}

.bl_products_list .bl_card_ttl {
  font-size: 16px;
  margin: 10px 0 0 0;
  padding: 0;
  line-height: 1.5;
}

.bl_products .el_ttlLv2 {
  font-size: 30px;
  text-align: center;
  margin-bottom: 30px;
}

/* ====== added on 20241025 ====== */

.search_form .keywords_outer {
  background-color: #f2f6fe;
  border-radius: 0.25em 0.5em;
  text-align: center;
  padding: 2em 1em 1.5em 1em;
}

.search_form .keywords_outer .input_keywords {
  width:100%;
  max-width: 26em;
  padding: 0.25em;
  font-size: 0.9em;
  border-color: #ddd;
  border-style: solid;
  border-width: 1px;
  border-radius: 0.25em;
}

.search_form .keywords_outer .button_search:hover {
  opacity: 0.8;
}

.search_form .keywords_outer .button_search {
  background-color: #33abd3;
  color: #fff;
  padding: 0.3em 2em;
  margin-top: 0.5em;
  border:none;
  border-radius: 10em;
}

.search_form .link_menu {
  margin-top: 0.5em;
  font-size: 0.75em;
  text-align: right;
}

.search_form .link_menu a {
  text-decoration: none;
  color: #aaa;
}

.search_form .label {
  margin: 0.25em 0;
}

.search_form .label * {
  vertical-align: middle;
}

.search_form .label .icon {
  width:1.2em;
  height:1.2em;
  margin-right: 0.25em;
}

.search_form .radio_area label > * {
  vertical-align: middle;
}

.search_form .radio_area {
  display: flex;
}

.search_form .radio_area label {
  background-color: #f2f6fe;
  font-size: 0.9em;
  width: 11em;
  max-width: 47%;
  padding: 0.25em 0.5em;
  margin:0;
  border-style: solid;
  border-color: #ddd;
  border-width: 1px;
}

.search_form .radio_area label:first-child {
  border-top-left-radius: 0.25em;
  border-bottom-left-radius: 0.25em;
}

.search_form .radio_area label:last-child {
  border-top-right-radius: 0.25em;
  border-bottom-right-radius: 0.25em;
  border-left-width: 0;
}

.search_form .radio_area label:has(input[type="radio"]:checked) {
  background-color: #e1edf9;
}

.search_form .radio_area input[type="radio"] {
  appearance: none;
  background-image: url("/static/public/image/icon_off.svg");
  background-size: contain;
  width: 1.2em;
  height: 1.2em;
  margin: 0 0.25em 0 0;
}

.search_form .radio_area input[type="radio"]:checked {
  background-image: url("/static/public/image/icon_on.svg");
}

/* ====== added on 20250702 ====== */

.bl_card_txt_staff_day {
  margin-top:15px;
  color:#FF6600;
  word-break: keep-all;
  font-size:0.65em;
}
.bl_card_txt_staff_day br {
      display: none;
  }
.bl_card_txt_staff_day .label {
  font-weight:bold;
}
@media screen and (max-width: 768px) {
  .bl_card_txt_staff_day br {
      display: inline;
  }
}

.staff_day_label{
  color:#FF6600;
}
.bl_shopInfo_staff_day {
  margin-bottom:25px;
  color:#FF6600;
}
.bl_shopInfo_staff_day ul {
  margin:0;
  padding:0;
  list-style-type:none;
}

input:focus::placeholder {
  color: transparent;
}

textarea:focus::placeholder {
  color: transparent;
}