#shopping {
  padding-top: 200px;
}
@media screen and (max-width: 767px) {
  #shopping {
    padding-top: 120px;
  }
}
#shopping h1 {
  text-align: center;
  font-size: clamp(2.6rem, 2.2307692308rem + 0.4807692308vw, 3rem);
}
@media screen and (max-width: 767px) {
  #shopping h1 {
    font-size: 3rem;
  }
}
#shopping h1 {
  font-weight: 500;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  #shopping h1 {
    font-size: 2.2rem;
    margin-bottom: 0;
    text-align: left;
  }
}
#shopping .first-lead a {
  text-decoration: underline;
}
#shopping .first-lead a:hover {
  color: #E59736;
}
#shopping .section-block {
  background-color: #fff;
  border-radius: 10px;
  padding: 50px 40px;
}
@media screen and (max-width: 767px) {
  #shopping .section-block {
    padding: 30px 8%;
  }
}
#shopping .section-block .layout {
  justify-content: space-between;
}
#shopping .section-block .layout .image-col {
  width: 30%;
  max-width: 315px;
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .image-col {
    width: 100%;
    margin-bottom: 0px;
  }
}
#shopping .section-block .layout .image-col a {
  display: block;
}
#shopping .section-block .layout .image-col .hide {
  display: none;
}
#shopping .section-block .layout .text {
  flex: 1;
  padding-left: 5%;
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .text {
    padding-left: 0;
  }
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .text table {
    display: block;
  }
}
#shopping .section-block .layout .text table th {
  border-bottom: 1px solid #E0D8C2;
  padding-block: 16px;
  width: 15%;
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .text table th {
    display: block;
    width: 100%;
    padding-bottom: 0;
    border: none;
    color: #002d54;
  }
}
#shopping .section-block .layout .text table td {
  border-bottom: 1px solid #E0D8C2;
  padding-block: 16px;
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .text table td {
    display: block;
    width: 100%;
    padding-top: 0;
  }
}
#shopping .section-block .layout .text table td h3 {
  font-size: clamp(1.7rem, 1.4230769231rem + 0.3605769231vw, 2rem);
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .text table td h3 {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #shopping .section-block .layout .text table td h3 {
    font-size: 1.8rem;
    line-height: 1.5;
  }
}
#shopping .section-block .layout .text table td select {
  padding: 4px 15px 4px 8px;
}
#shopping .bottom-block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  #shopping .bottom-block {
    display: block;
    padding-bottom: 30px;
  }
}
#shopping .bottom-block .link a {
  text-decoration: underline;
  margin-right: 20px;
}
@media screen and (max-width: 767px) {
  #shopping .bottom-block .link a {
    display: block;
    margin-bottom: 10px;
  }
}
#shopping .bottom-block .link a:hover {
  color: #E59736;
}
#shopping .bottom-block .buy input {
  cursor: pointer;
  background-color: #003F75;
  color: #fff;
  font-weight: 500;
  text-align: center;
  font-size: clamp(1.7rem, 1.4230769231rem + 0.3605769231vw, 2rem);
}
@media screen and (max-width: 767px) {
  #shopping .bottom-block .buy input {
    font-size: 2rem;
  }
}
#shopping .bottom-block .buy input {
  border-radius: 50px;
  line-height: 1;
  padding: 12px;
  width: 263px;
  transition: background-color 0.3s;
}
@media screen and (max-width: 767px) {
  #shopping .bottom-block .buy input {
    width: 100%;
  }
}
#shopping .bottom-block .buy input:hover {
  background-color: #002d54;
}

.news .section-block {
  display: flex;
  gap: 8%;
  padding-top: 100px;
}
@media screen and (max-width: 767px) {
  .news .section-block {
    flex-direction: column;
    gap: 3rem;
    padding-top: 0;
  }
}
.news .section-block a {
  text-decoration: underline;
}
.news .section-block a:hover {
  color: #E59736;
}
.news .section-block .content-wrap {
  width: 80%;
}
@media screen and (max-width: 767px) {
  .news .section-block .content-wrap {
    width: 100%;
  }
}
.news .section-block #list {
  border-top: 1px solid rgba(0, 0, 0, 0.25);
}
.news .section-block #list dl {
  padding: 20px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}
.news .section-block #list dl dt {
  font-weight: 400;
}
.news .section-block #list dl dd {
  font-weight: 400;
}
.news .section-block #list #pagination {
  display: flex;
  justify-content: center;
  margin-top: 40px;
  align-items: center;
  gap: 30px;
}
.news .section-block #list #pagination .prev,
.news .section-block #list #pagination .next {
  position: relative;
  width: 48px;
  height: 48px;
  border-radius: 100px;
}
.news .section-block #list #pagination .prev:hover,
.news .section-block #list #pagination .next:hover {
  background-color: #504B3C;
  color: #fff;
}
.news .section-block #list #pagination .prev:hover::after,
.news .section-block #list #pagination .next:hover::after {
  border-color: #fff;
}
.news .section-block #list #pagination .prev::after,
.news .section-block #list #pagination .next::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
}
.news .section-block #list #pagination .prev::after {
  width: 12px;
  height: 12px;
  border-left: 1px solid #504B3C;
  border-top: 1px solid #504B3C;
  transform: translate(-50%, -50%) rotate(-45deg);
  left: 55%;
}
.news .section-block #list #pagination .next::after {
  width: 12px;
  height: 12px;
  border-right: 1px solid #504B3C;
  border-top: 1px solid #504B3C;
  transform: translate(-50%, -50%) rotate(45deg);
  left: 45%;
}
.news .section-block #list #pagination ul {
  display: flex;
  gap: 8px;
}
.news .section-block #list #pagination ul li a {
  display: inline-block;
  width: 48px;
  height: 48px;
  padding: 10px 20px;
  font-size: clamp(1.3rem, 1.1153846154rem + 0.2403846154vw, 1.5rem);
}
@media screen and (max-width: 767px) {
  .news .section-block #list #pagination ul li a {
    font-size: 1.5rem;
  }
}
.news .section-block #list #pagination ul li a {
  margin: 0 5px;
  color: #504B3C;
  border-radius: 100px;
  text-decoration: none;
}
.news .section-block #list #pagination ul li a.active {
  background-color: #504B3C;
  color: #fff;
}
.news .section-block #list #pagination ul li a:hover {
  background-color: #504B3C;
  color: #fff;
}
.news .section-block #post-body .title-top {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.news .section-block #post-body h1 {
  margin-block: 1rem;
  color: #504B3C;
  line-height: 1.8;
  display: inline-block;
  font-size: clamp(2rem, 1.6307692308rem + 0.4807692308vw, 2.4rem);
}
@media screen and (max-width: 767px) {
  .news .section-block #post-body h1 {
    font-size: 2.4rem;
  }
}
.news .section-block #post-body h1 {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .news .section-block #post-body h1 {
    font-size: 2rem;
  }
}
.news .section-block #post-body .date {
  font-weight: 500;
}
.news .section-block #post-body .category {
  display: inline-block;
  background-color: #aaa;
  color: #fff;
  padding: 4px 8px 6px;
  border-radius: 4px;
  font-size: 14px;
}
.news .section-block #post-body .category.cat1 {
  background-color: rgb(192, 0, 0);
}
@media screen and (max-width: 767px) {
  .news .section-block #post-body {
    padding-top: 2rem;
  }
}
.news .section-block #post-body .content-body p {
  margin: 1rem 0;
}
.news .section-block #post-body .content-body img {
  height: auto;
  max-width: 100%;
}
.news .section-block #post-body .content-body a {
  text-decoration: underline;
}
.news .section-block #post-body .content-body a:hover {
  color: #504B3C;
}
.news .section-block #sidemenu {
  width: 20%;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .news .section-block #sidemenu {
    width: 100%;
  }
}
.news .section-block #sidemenu h2 {
  font-size: clamp(1.4rem, 1.2153846154rem + 0.2403846154vw, 1.6rem);
}
@media screen and (max-width: 767px) {
  .news .section-block #sidemenu h2 {
    font-size: 1.6rem;
  }
}
.news .section-block #sidemenu h2 {
  margin-bottom: 20px;
}
.news .section-block #sidemenu ul {
  border-top: 1px solid rgba(0, 0, 0, 0.25);
}
.news .section-block #sidemenu ul li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  padding: 10px 0;
}

#live .first-lead {
  margin-bottom: 100px;
}
#live .live-block {
  background-color: #fff;
  border-radius: 6px;
}
#live .live-block h2 {
  text-align: center;
  margin-bottom: 0;
  transform: translateY(-50%);
}
#live .live-block h2 span {
  display: inline-block;
  background-color: #E0D8C2;
  line-height: 1;
  font-size: clamp(2.2rem, 1.8307692308rem + 0.4807692308vw, 2.6rem);
}
@media screen and (max-width: 767px) {
  #live .live-block h2 span {
    font-size: 2.6rem;
  }
}
#live .live-block h2 span {
  border-radius: 30px;
  padding: 14px 45px;
}
#live .live-block .layout {
  padding: 75px 5%;
  gap: 60px;
}
#live .live-block .layout .image {
  width: 50%;
  position: relative;
  line-height: 0;
}
#live .live-block .layout .image::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 30%;
  max-width: 118px;
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  background: rgba(255, 255, 255, 0.1) url(/oze/assets/image/live.svg) no-repeat center center;
  border-radius: 50%;
  border: 1px solid #fff;
}
#live .live-block .layout .text {
  width: 50%;
}
#live #bottom-content .note {
  margin-bottom: 100px;
}
#live #bottom-content .section-block .block {
  background-color: #fff;
  border-radius: 6px;
  padding: 30px 5%;
  margin-bottom: 40px;
}
#live #bottom-content .section-block .block h2 {
  margin-bottom: 20px;
}
#live #bottom-content .section-block .block a {
  text-decoration: underline;
}
#live #bottom-content .section-block .block a:hover {
  color: #E59736;
}

#access .first-lead {
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  #access .first-lead {
    margin-bottom: 30px;
  }
}
#access #transportation .trans-block {
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  #access #transportation .trans-block {
    margin-bottom: 30px;
  }
}
#access #transportation .trans-block h2 {
  margin-bottom: 40px;
}
#access #transportation .trans-block dl {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 767px) {
  #access #transportation .trans-block dl {
    display: block;
  }
}
#access #transportation .trans-block dl dt {
  width: 30%;
  font-size: clamp(1.9rem, 1.6230769231rem + 0.3605769231vw, 2.2rem);
}
@media screen and (max-width: 767px) {
  #access #transportation .trans-block dl dt {
    font-size: 2.2rem;
  }
}
#access #transportation .trans-block dl dt {
  font-weight: 500;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  padding-block: 20px;
}
@media screen and (max-width: 767px) {
  #access #transportation .trans-block dl dt {
    width: 100%;
    padding-block: 10px;
    font-size: 1.8rem;
  }
}
#access #transportation .trans-block dl dd {
  width: 70%;
  padding: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 767px) {
  #access #transportation .trans-block dl dd {
    width: 100%;
    padding: 10px 0;
  }
}
#access #transportation .trans-block dl dd h3 {
  margin-bottom: 20px;
  font-size: clamp(1.5rem, 1.2230769231rem + 0.3605769231vw, 1.8rem);
}
@media screen and (max-width: 767px) {
  #access #transportation .trans-block dl dd h3 {
    font-size: 1.8rem;
  }
}
#access #transportation .trans-block dl dd h3 {
  font-weight: 500;
}
#access #transportation .trans-block dl dd p {
  margin-bottom: 20px;
  font-weight: 400;
}
#access #transportation .trans-block dl dd a {
  text-decoration: underline;
}
#access #transportation .trans-block dl dd a:hover {
  color: #E59736;
}
#access #route h2 {
  margin-bottom: 40px;
}
#access #route .route-block {
  background-color: #fff;
  border-radius: 6px;
  padding: 50px 5%;
  margin-bottom: 60px;
}
#access #route .route-block h3 {
  text-align: center;
  font-size: clamp(2.2rem, 1.8307692308rem + 0.4807692308vw, 2.6rem);
}
@media screen and (max-width: 767px) {
  #access #route .route-block h3 {
    font-size: 2.6rem;
  }
}
#access #route .route-block h3 {
  font-weight: 500;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  #access #route .route-block h3 {
    font-size: 2rem;
    margin-bottom: 10px;
    text-align: left;
  }
}
#access #route .route-block .layout {
  display: flex;
  gap: 60px;
}
@media screen and (max-width: 767px) {
  #access #route .route-block .layout {
    display: block;
  }
}
#access #route .route-block .layout .image {
  width: 50%;
}
@media screen and (max-width: 767px) {
  #access #route .route-block .layout .image {
    width: 100%;
    margin-bottom: 30px;
  }
}
#access #route .route-block .layout .text {
  width: 50%;
}
@media screen and (max-width: 767px) {
  #access #route .route-block .layout .text {
    width: 100%;
  }
}
#access #route .route-block .layout .text h4 {
  font-weight: 500;
  font-size: clamp(1.7rem, 1.4230769231rem + 0.3605769231vw, 2rem);
}
@media screen and (max-width: 767px) {
  #access #route .route-block .layout .text h4 {
    font-size: 2rem;
  }
}
#access #route .route-block .layout .text h4 {
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  #access #route .route-block .layout .text h4 {
    font-size: 1.8rem;
    margin-bottom: 0px;
  }
}
#access #route .route-block .layout .text p {
  border-top: 1px solid rgba(0, 0, 0, 0.25);
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  padding-block: 14px;
}
@media screen and (max-width: 767px) {
  #access #route .route-block .layout .text p {
    margin-bottom: 2rem;
  }
}

#contact {
  padding-top: 200px;
}
@media screen and (max-width: 767px) {
  #contact {
    padding-top: 130px;
  }
}
#contact h1 {
  text-align: center;
  font-size: clamp(2.6rem, 2.2307692308rem + 0.4807692308vw, 3rem);
}
@media screen and (max-width: 767px) {
  #contact h1 {
    font-size: 3rem;
  }
}
#contact h1 {
  font-weight: 500;
  margin-bottom: 50px;
}
#contact .first-lead {
  margin-bottom: 3rem;
}
#contact .first-lead a {
  text-decoration: underline;
}
#contact .first-lead a:hover {
  color: #E59736;
}
#contact .first-lead b {
  font-weight: bold;
}
#contact .first-lead b.red {
  color: red;
}
#contact .form-wrap {
  background-color: #fff;
  border-radius: 10px;
  padding: 50px 40px;
}
#contact .form-wrap .form-row {
  margin-bottom: 2rem;
}
#contact .form-wrap h3 {
  display: block;
  color: #003F75;
  font-size: clamp(1.5rem, 1.2230769231rem + 0.3605769231vw, 1.8rem);
}
@media screen and (max-width: 767px) {
  #contact .form-wrap h3 {
    font-size: 1.8rem;
  }
}
#contact .form-wrap h3 {
  font-weight: 500;
}
#contact .form-wrap h3 .hi {
  color: #D65C5C;
  font-size: clamp(1.1rem, 0.9153846154rem + 0.2403846154vw, 1.3rem);
}
@media screen and (max-width: 767px) {
  #contact .form-wrap h3 .hi {
    font-size: 1.3rem;
  }
}
#contact .form-wrap h3 .hi {
  padding-left: 20px;
}
#contact .form-wrap input[type=text],
#contact .form-wrap input[type=email],
#contact .form-wrap textarea {
  font-size: clamp(1.4rem, 1.2153846154rem + 0.2403846154vw, 1.6rem);
}
@media screen and (max-width: 767px) {
  #contact .form-wrap input[type=text],
  #contact .form-wrap input[type=email],
  #contact .form-wrap textarea {
    font-size: 1.6rem;
  }
}
#contact .form-wrap input[type=text],
#contact .form-wrap input[type=email],
#contact .form-wrap textarea {
  padding: 10px 15px;
  width: 100%;
  border: none;
  background-color: #F2F5F8;
}
#contact .policy h2 {
  font-size: clamp(2.6rem, 2.2307692308rem + 0.4807692308vw, 3rem);
}
@media screen and (max-width: 767px) {
  #contact .policy h2 {
    font-size: 3rem;
  }
}
#contact .policy h2 {
  font-weight: 500;
  color: #003F75;
  margin-bottom: 20px;
}
#contact .policy .note {
  text-align: left;
  margin-bottom: 50px;
}
#contact .policy .policy-text {
  font-size: clamp(1.3rem, 1.1153846154rem + 0.2403846154vw, 1.5rem);
}
@media screen and (max-width: 767px) {
  #contact .policy .policy-text {
    font-size: 1.5rem;
  }
}
#contact .policy .policy-text {
  line-height: 1.5;
  margin-bottom: 20px;
  background-color: #F4F4F4;
  padding: 40px;
  height: 300px;
  overflow-y: auto;
}
#contact .policy .policy-text b {
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #contact .policy .policy-text {
    font-size: 1.4rem;
    padding: 5%;
  }
}
#contact .bottom-block {
  text-align: center;
}
#contact .bottom-block .doui label {
  cursor: pointer;
}
#contact .bottom-block .doui a {
  text-decoration: underline;
}
#contact .bottom-block .doui a:hover {
  color: #E59736;
}
#contact .form-btn {
  text-align: center;
}
#contact .form-btn #submit-btn {
  margin-top: 2rem;
  cursor: pointer;
  background-color: #003F75;
  color: #fff;
  font-weight: 500;
  text-align: center;
  font-size: clamp(1.7rem, 1.4230769231rem + 0.3605769231vw, 2rem);
}
@media screen and (max-width: 767px) {
  #contact .form-btn #submit-btn {
    font-size: 2rem;
  }
}
#contact .form-btn #submit-btn {
  border-radius: 50px;
  line-height: 1;
  padding: 12px 60px;
  transition: background-color 0.3s;
}
#contact .form-btn #submit-btn:hover {
  background-color: #002d54;
}

#sns {
  padding-top: 200px;
}
@media screen and (max-width: 767px) {
  #sns {
    padding-top: 130px;
  }
}
#sns h1 {
  text-align: center;
  font-size: clamp(2.6rem, 2.2307692308rem + 0.4807692308vw, 3rem);
}
@media screen and (max-width: 767px) {
  #sns h1 {
    font-size: 3rem;
  }
}
#sns h1 {
  font-weight: 500;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  #sns h1 {
    font-size: 2rem;
  }
}