@charset "UTF-8";

/* topチョコソース */
.choco_area {
  position: relative;
}

.choco_area p span,
.about h2 span {
  letter-spacing: 5px;
  font-family: 'Lucida Sans', 'Lucida Sans Regular', 'Lucida Grande', 'Lucida Sans Unicode', Geneva, Verdana, sans-serif;
}

.logo-mg {
  display: inline-block;
  margin-left: 10px;
}

.choco2 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.choco_area .top-title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: medium;
  font-weight: bolder;
  width: 300px;
  padding: 20px;
  background-color: #ffffff90;
  border-radius: 50%;
  text-shadow: 1px 1px 0 #FF7BAC, -1px -1px 0 #FF7BAC,
    -1px 1px 0 #FF7BAC, 1px -1px 0 #FF7BAC,
    0px 1px 0 #FF7BAC, 0-1px 0 #FF7BAC,
    -1px 0 0 #FF7BAC, 1px 0 0 #FF7BAC;
  text-align: center;
}

.top-about {
  position: absolute;
  bottom: 5%;
  right: 5%;
  text-shadow: 1px 1px 0 #AFEEEE, -1px -1px 0 #AFEEEE,
    -1px 1px 0 #AFEEEE, 1px -1px 0 #AFEEEE,
    0px 1px 0 #AFEEEE, 1px 0 0 #AFEEEE;
}

.section {
  margin: 20px;
}

.section h2 {
  padding-bottom: 10px;
}

/* トップページメニュー */

.menu figure {
  display: flex;
  margin-bottom: 20px;
}

.menu figure img {
  width: 50%;
}

.menu figure figcaption {
  width: 50%;
  margin: 0 15px;
  font-size: 1.2em;
  font-weight: 500;
}

.menu figure figcaption p {
  margin: 0 auto;
}

.level,
.price {
  font-size: medium;
  padding-top: 15px;
}

.level::after {
  content: "";
  display: inline-block;
  background: url(../img/Mint-400x210.png) no-repeat;
  background-position: center center;
  width: 25px;
  aspect-ratio: 2/1.4;
  background-size: contain;
  vertical-align: middle;
  margin-left: 10px;
  margin-bottom: 3px;
}

.eat a::before {
  /* <img src: url(); */
  content: "\f2e7";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  /* ソリッド */
}

.top-about a::after,
.more a::after {
  content: "\f101";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  /* ソリッド */
  margin-left: 5px;
}

.more {
  text-align: right;
}

/* マップ */
.map {
  position: relative;
  padding-top: 50%;
}

.map iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  padding-bottom: 10px;
}


/* contact */
.contact-link {
  text-align: center;
  font-size: large;
  border-radius: 5px;
  text-shadow: 1px 1px 0 #AFEEEE, -1px -1px 0 #AFEEEE,
    -1px 1px 0 #AFEEEE, 1px -1px 0 #AFEEEE,
    0px 1px 0 #AFEEEE, 1px 0 0 #AFEEEE;
}

.contact-link a {
  display: inline-block;
  width: 100%;
  padding: 10px;
  background-color: #500000;
  border-radius: 5px;
}



/* パンくず */
#path {
  margin: 10px 20px;
}

#path ol {
  list-style-type: none;
  max-width: 960px;
  margin: 20px auto;
}

#path ol li {
  display: inline;
  margin-right: 5px;
}

#path ol li a {
  padding-right: 15px;
}

#path ol li:first-child:after {
  content: ">";
}

/* ここからabout css */
.mint-content {
  list-style-type: none;
}


.mint-content li::before {
  content: "▪";
}

.mint-content p {
  text-indent: 1.5em;
  padding-bottom: 10px;
}

.mint-level h2::after {
  content: "";
  display: inline-block;
  background: url(../img/Mint-400x210.png) no-repeat;
  background-position: center center;
  width: 50px;
  aspect-ratio: 2/1.4;
  background-size: contain;
  vertical-align: middle;
  margin-left: 10px;
  margin-bottom: 8px;
}



/* ここからmenu */

#menu figure a {
  width: 50%;
}

#menu figure img {
  width: 100%;
}


.morelist {
  display: flex;
  flex-wrap: wrap;
}

.morelist dl {
  margin-top: 15px;
}

.morelist dt {
  width: 55%;
  font-size: 1.1em;
  font-weight: 500;
}

.morelist dd {
  width: 45%;
  text-align: right;
}

.morelist dd::before {
  content: "----- ";
}

.morelist dt::before {
  content: "・";
}


.lst li {
  list-style-type: disc;
}

/* ここからinfomation */

/* 文字数が同じだから */
.infomation dl {
  display: flex;
  gap: 2em;
  padding-bottom: 10px;
}

/* 文字数が同じだから */
.infomation dt {
  width: fit-content;
  /* ←文字数にフィット */
  white-space: nowrap;
}

#infomation p {
  padding-bottom: 10px;
}

.access-list {
  display: flex;
  flex-wrap: wrap;
}

.access-list dt {
  width: 30%;
}

.access-list dd {
  width: 70%;
  padding-bottom: 10px;
}

/* ここからcontact. */

#entryform {
  line-height: 1.5;
}

#entryform input[type="text"],
#entryform input[type="email"],
#entryform input[type="tel"] {
  width: 80%;
  padding: 5px;
}

#entryform textarea {
  width: 80%;
  height: 80px;
  overflow-y: scroll;
}

.comment {
  margin-bottom: 25px;
}

#entryform dt {
  margin-bottom: 5px;
}

#entryform dd {
  margin-bottom: 20px;
}

#entryform span {
  padding: 3px;
  border: 1px solid #500000;
  background-color: #FF7BAC;
  border-radius: 5px;
}

#entryform p:last-child {
  text-align: center;
}

#entryform input[type="submit"] {
  width: 100%;
  margin: 10px 0;
  padding: 10px;
  text-align: center;
  font-size: large;
  font-weight: bold;
  background-color: #500000;
  border-radius: 5px;
  color: #AFEEEE;
}

#entryform input[type="text"],
#entryform input[type="email"],
#entryform input[type="tel"],
#entryform textarea {
  outline: none;
  border: 2px solid #fff;
}

#entryform input[type="text"]:focus,
#entryform input[type="email"]:focus,
#entryform input[type="tel"]:focus,
#entryform textarea:focus {
  border: 2px solid #FF7BAC;
}



/* ここからプライバシーポリシー */
.privacy {
  margin-top: 10px;
}

.privacy dl {
  display: flex;
  flex-wrap: wrap;
  margin-top: 10px;
}

.privacy dt {
  width: 40%;
}

.privacy dd {
  width: 60%;
}

.privacy dt::after {
  content: ":";
}


/* topへ */
.pagetop {
  width: 45px;
  height: 45px;
  position: fixed;
  right: 15px;
  bottom: 70px;
}

.pagetop a {
  display: block;
  width: 45px;
  height: 45px;
  padding-top: 10px;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.5);
  border-radius: 50%;
  text-decoration: none;
  text-align: center;
  font-size: 12px;
}

.pagetop a::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  margin: auto;
  border-top: 1px solid #500000;
  border-right: 1px solid #500000;
  transform: rotate(-45deg);
}


/* アニメーション */

.choco2 {
  z-index: 10;
}

.choco_area h2 {
  position: relative;
}


.anime {
  position: absolute;
  left: 0;
  top: 0px;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.animation1 {
  width: 100%;
}


.animation2 {
  position: absolute;
  width: 100%;
  animation: slide-2 10s linear infinite;
}

.animation3 {
  position: absolute;
  width: 100%;
  animation: slide-3 10s linear infinite;
}



@keyframes slide-2 {

  0% {
    opacity: 0;
  }

  20% {
    opacity: 0;
  }

  
  33% {
    opacity: 1;
  }

 48%{
    opacity: 1;
  }

  66% {
    opacity: 0;
  }

  100% {
    opacity: 0;
  }
}

@keyframes slide-3{

  0% {
    opacity: 0;
  }

  50% {
    opacity: 0;
  }

  66% {
    opacity: 1;
  }

  85% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }

}
/* --------------------------------------------------
  幅768px未満のスタイル指定 ここまで
-------------------------------------------------- */



/* 
--------------------------------------------------
  幅769px以上のスタイル指定 ここから
-------------------------------------------------- */

@media screen and (min-width: 769px) {

  body {
    background-image: url(../img/foot-bg-choco-afeeee.png);
    background-position: 0 -160px;
  }


  .index {
    background-image: url(../img/foot-bg-choco-afeeee.png)
  }

  a {
    text-decoration: none;
  }


  .section {
    max-width: 960px;
    margin: 40px auto;
  }

  .container {
    margin-left: 20px;
    margin-right: 20px;
  }

  .logo {
    padding: 5px 0 20px 0;
  }


  .menu-btn {
    display: none;
  }

  .gnav {
    position: relative;
    left: 0;
    top: 0;
  }

  .gnav ul {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    padding: 0;
    max-width: 960px;
  }

  .gnav ul li {
    width: 15%;
    border: 3px solid #e5f5f5;
    border-radius: 5px;
  }

  .gnav ul li a {
    display: inline-block;
    padding: 15px 0;
    text-align: center;
    text-decoration: none;
  }

  .gnav ul li a::before {
    display: none;
  }

  .gnav ul li a:hover {
    background: #e5f5f5;
    color: #FF7BAC;
  }


  /* menu */

  #top .menu ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  #top .menu figure {
    width: 300px;
  }


  .level {
    padding-top: 5px;
    font-size: 0.7em;
  }

  .price {
    padding-top: 5px;
  }


  /* maniac */
  .choco_area .top-title {
    font-size: 1.5em;
    width: 600px;
    padding: 30px 0;
  }


  /* メニューhtml */

  #menu .menu ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  #menu .menu li {
    width: 300px;
  }

  .morelist dt {
    width: 25%;
  }

  .morelist dd {
    width: 75%;
    text-align-last: left;
  }


  .menu li {
    display: flex;
    flex-wrap: wrap;
  }

  .menu figure a,
  .menu figcaption {
    width: 150px;
  }


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

  .morelist dt {
    width: 25%;
  }

  .morelist dd {
    width: 25%;
  }

  .morelist dd:nth-of-type(odd) {
    text-align: left;
  }

  .menu img {
    margin-bottom: 15px;
  }

  .menu figcaption {
    margin: 5px 0 5px 10px;
  }

  .level {
    padding-top: 5px;
    font-size: 0.8em;
  }

  .price {
    padding-top: 5px;
  }

  .more-drink {
    margin-top: 5px;
  }



  /* プライバシーポリシー */
  .privacy dt {
    width: 30%;
  }

  .privacy dd {
    width: 70%;

  }


  /* フッター */

  .footer {
    padding-top: 20px;
    background-image: url(../img/top-bg-choco-afeeee.png);
  }

  .foot {
    margin-right: 20px;
    margin-left: 20px;
  }

  .f-nav {
    display: flex;
    justify-content: space-between;
    max-width: 960px;
    margin: 0 auto 20px;
  }

  .pagetop {
    bottom: 40px;
  }


  /* ホバー */

  .choco_area a:hover,
  .container a:hover,
  .footer a:hover {
    color: #FF7BAC;
  }

  .pagetop a:hover::before {
    border-color: #FF7BAC;
  }

  .contact-link a:hover,
  #entryform input[type="submit"]:hover {
    background: #6c3524;
    color: #FF7BAC;
  }



}