@charset "UTF-8";
/* layout
----------------------------- */
.co_container_box_inner {
  width: 965px;
  margin: 0 auto;
}
.contentsArea {
  margin: 0 auto;
  padding-bottom: 35px;
  width: 770px;
  background: #b4e6e6;
  float: right;
  line-height: 1.5;
  text-align: left;
}
.contentsArea * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.contentsArea img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.container {
  padding: 24px 35px 0;
  position: relative;
}
.container + .container {
  margin-top: 8px;
}
/* common
----------------------------- */
.imgBlock {
  text-align: center;
}
.imgBlock a {
  display: block;
}
.underline {
  text-decoration: underline;
  text-underline-position: under;
  text-decoration-line: underline;
  text-decoration-skip-ink: none;
}
.indent_1em {
  padding-left: 1em;
  text-indent: -1em;
}
.contentsArea .ttl {
  height: 56px;
  border-radius: 40px 40px 0 0;
  background: #1591ce;
  line-height: 56px;
  text-align: center;
}
.contentsArea .ttl img {
  width: auto;
  height: 39px;
}
.contentsArea a:not(.btn, .icon_reload) {
  text-decoration: underline;
}
.contentsArea a img {
  transition: all .2s;
}
.contentsArea a:hover img {
  opacity: .7;
}
.contentsArea .small {
  font-size: 14px;
}
.contentsArea .center {
  text-align: center;
}
.contentsArea .left {
  text-align: left;
}
.contentsArea .red {
  color: #d00;
}
.contentsArea .br_hidden {
  display: none;
}
.contentsArea .pc_hidden {
  display: none;
}
/* button
----------------------------- */
.contentsArea .btn {
  margin: 12px auto;
  padding: 12px 0;
  max-width: 300px;
  border-radius: 40px;
  background: #e17265;
  color: #fff;
  display: block;
  letter-spacing: .05em;
  text-align: center;
}
.contentsArea .btn img {
  height: 24px;
  width: auto;
}
.contentsArea .btn:hover {
  opacity: .7;
}
.contentsArea .btn:hover,
.contentsArea .btn:active,
.contentsArea .bnt:visited {
  color: #fff;
  text-decoration: none;
}
/* login (coupon)
----------------------------- */
.login_area {
  margin: 0 35px 0!important;
  padding: 32px;
  border-radius: 0 0 40px 40px;
  background: #fff;
  letter-spacing: .05em;
  text-align: center;
}
.login_area p {
  font-size: 20px;
  font-weight: bold;
}
.login_area .btn_wrap {
  display: flex;
  gap: 40px;
  justify-content: space-between;
}
.login_area .btn_wrap .btn {
  margin-top: 24px;
  width: 46%;
  font-size: 22px;
  font-weight: bold;
  transition: all .3s;
}
.login_area .btn_wrap .btn:hover {
  opacity: 0.7;
}
/* header
----------------------------- */
.head_area {
  margin: 0 auto;
}
.head_area img {
  width: 100%;
  height: auto;
  aspect-ratio: 12 / 5;
  background: #aaa;
  display: block;
}
.term_text {
  padding: 8px;
  background: #1591ce;
  line-height: 1.5;
}
.term_text p {
  color: #fff;
  font-size: 18px;
  text-align: center;
}
.term_text .date {
  font-size: 24px;
  font-weight: bold;
  letter-spacing: .05em;
}
.end_comment {
  margin: 40px auto 16px;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
/* weekend_msg
----------------------------- */
.weekend_msg {
  margin: 32px auto 0;
  padding: 8px;
  border: 2px solid #1591ce;
  border-radius: 16px;
  width: 500px;
  background: #fff;
  color: #000;
  font-weight: bold;
  text-align: center;
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
}
.weekend_msg * {
  font-size: 20px;
  letter-spacing: .05em;
}
.weekend_msg > span img {
  width: 60px;
}
/* otenki_area
----------------------------- */
.otenki_area a:first-child {
  display: block;
}
.otenki_area .today_otenki_ttl {
  margin-top: 16px;
  position: relative;
}
.otenki_area .today_otenki_ttl::after {
  content: "";
  margin: auto;
  position: absolute;
  right: 0;
  left: 0;
  bottom: -23px;
  height: 0;
  width: 0;
  border-right: 18px solid transparent;
  border-top: 24px solid #fff;
  border-left: 18px solid transparent;
}
.otenki_area .today_otenki {
  margin: 32px auto;
}
/* coupon_area
----------------------------- */
.coupon_area {
  background: #fff;
  margin: 0 35px;
  padding: 40px;
  border-radius: 40px;
}
.coupon_area p:first-of-type {
  margin-top: 8px;
}
.coupon_area .btn {
  margin-top: 16px;
  max-width: 360px;
  background: #ffd900;
}
.coupon_area .btn.niji img {
  height: 39px;
}
.coupon_area::before {
  content: "";
  margin: auto;
  position: absolute;
  right: 0;
  left: 0;
  top: -23px;
  height: 0;
  width: 0;
  border-right: 18px solid transparent;
  border-bottom: 24px solid #fff;
  border-left: 18px solid transparent;
}
.coupon_area.nologin {
  border-radius: 40px 40px 0 0;
}
.coupon_area.nologin::after {
  content: "";
  background: rgb(255 255 255 / 70%);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 40px;
  text-align: center;
}
.coupon_area .nologin_msg {
  margin: auto;
  padding: 8px;
  width: 300px;
  background: #aaa;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%) rotate(-5deg);
  z-index: 1;
}
.coupon_area + .login_area {
  border-top: 2px dashed #b4e6e6;
}
@media screen and (max-width: 340px) {
  .coupon_area .br_hidden {
    display: block;
  }
}
/* howto_area
----------------------------- */
.howto_area .comment {
  position: absolute;
  right: 100px;
  bottom: 43px;
  font-size: 14px;
}
/* detail_area
----------------------------- */
.detail_area {
  margin: 0 auto;
  text-align: left;
}
.detail_area p {
  padding-top: 10px;
}
.detail_contents {
  border-radius: 40px;
  background: #fff;
  color: #333;
  line-height: 1.6;
  text-align: left;
}
.detail_contents:not(:first-child) {
  margin-top: 24px;
}
.detail_box dt {
  font-size: 14px;
  font-weight: bold;
}
.detail_box dd + dt {
  margin-top: 10px;
}
.detail_box .marker {
  margin-top: 1em;
}
.detail_box dt + .marker {
  margin-top: 0;
}
.detail_box {
  padding: 20px;
  font-size: 14px;
}
.detail_box * {
  font-size: 14px;
}
.detail_box .detail_weather > dl {
  margin-top: 1em;
  padding: 8px;
  background: #f4f1d9;
}
.detail_box .detail_weather .ribbon{
  padding: 0 20px 0 12px;
  margin-bottom: 4px;
  margin-left: -12px;
  height: 24px;
  line-height: 24px;
  background: #ffe344;
  display: inline-block;
  position: relative;
}
.detail_box .detail_weather .ribbon::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  height: 0;
  width: 0;
  border-top: 12px solid transparent;
  border-right: 6px solid #f4f1d9;
  border-bottom: 12px solid transparent;
}
.detail_box .emoji {
  font-family: "Segoe UI Emoji", "Segoe UI Symbol", "Apple Color Emoji", "Noto Color Emoji", "Noto Emoji";
  font-style: normal;
}
/* btn_areas(sns)
----------------------------- */
.btn_areas {
  margin: 0 35px;
  padding: 12px 0 0;
}
.btn_areas img {
  height: 20px;
}
/* end
----------------------------- */
.end_area {
  margin: 24px 0 0;
  text-align: center;
}
.end_area p {
  font-size: 18px;
  font-weight: bold;
}
