@charset "UTF-8";
@import url("../../../resources/fonts/paperlogy/font_paperlogy.css");
@import url("../../../resources/css/common/default.css");
@import url("../../../resources/css/common/common.css");
:root {
  --ff1: "Paperlogy";
  --fs: 1.8rem;
  --cl: #333;
  --lh: 1.6;
  --bdc: #e0e0e0;
  --cl1: #00105D;
  --cl2: #F3533B;
}

/*-------------------------------------------------
title       : 뉴스레터
Author      : ㅈㅁㅈ
Create date : 2025-09-09
-------------------------------------------------*/
#newsletter {
  width: 86rem;
  max-width: 100%;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden;
  padding: 2rem 3.5rem 0;
  letter-spacing: -0.05rem;
}

#header {
  position: relative;
  margin-bottom: 4rem;
  padding-top: 4rem;
  font-family: var(--ff1);
  color: #222;
  text-align: center;
}
#header h1 img {
  height: 7rem;
}
#header small {
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.4rem;
}
#header b {
  display: inline-block;
  position: relative;
  top: -0.1rem;
  margin-left: 0.5rem;
  font-size: 2rem;
  font-weight: 900;
  color: var(--cl1);
  vertical-align: middle;
}
#header .active {
  color: var(--cl2);
}
#header .hnb {
  position: absolute;
  left: 0;
  top: 0;
  font-size: 1.4rem;
}
#header .hnb::before {
  font-family: "remixicon";
  content: "\ee1d";
  display: inline-block;
  position: relative;
  top: -0.1rem;
  vertical-align: middle;
  margin-right: 1rem;
  font-size: 2rem;
}
#header nav {
  overflow: hidden;
  overflow-x: auto;
  margin-top: 3rem;
  padding: 1.5rem;
  background-color: var(--cl1);
  font-weight: 700;
  color: #fff;
  text-align: center;
  white-space: nowrap;
}
#header nav a {
  margin: 0 3rem;
}

#footer {
  position: relative;
  margin: 0 -3.5rem;
  padding-bottom: 5rem;
  background-color: #000;
  font-size: 1.6rem;
  color: #fff;
  text-align: center;
}
#footer address {
  padding: 0 2rem;
}
#footer #subscribe {
  position: relative;
  z-index: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 12rem;
  margin-bottom: 5rem;
  background-color: #fff;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#footer #subscribe::before {
  position: absolute;
  left: 3.5rem;
  top: 0;
  right: 3.5rem;
  height: 1px;
  background-color: var(--bdc);
  content: "";
}
#footer #subscribe strong {
  margin-right: 3rem;
  font-family: var(--ff1);
  font-size: 2rem;
  color: #000;
}
#footer #subscribe a {
  display: inline-block;
  height: 4rem;
  padding: 0 3.5rem;
  border-radius: 0.7rem;
  border: 1px solid var(--cl2);
  background-color: var(--cl2);
  font-weight: 500;
  vertical-align: middle;
  line-height: 3.8rem;
  -webkit-transition: var(--time2);
  transition: var(--time2);
}
#footer #subscribe a::after {
  font-family: "remixicon";
  content: "\ea6c";
  display: inline-block;
  position: relative;
  top: -0.1rem;
  vertical-align: middle;
  margin: 0 -0.5rem 0 1rem;
  font-size: 2rem;
}
#footer #subscribe a:hover, #footer #subscribe a:focus {
  background-color: #fff;
  color: var(--cl2);
}
#footer #subscribe.active {
  background: url("/template/newsletter/img/bg2.png") no-repeat center bottom;
}
#footer #subscribe.active::before {
  background-color: rgba(255, 255, 255, 0.3);
}
#footer #subscribe.active strong {
  color: #fff;
}
#footer p {
  margin: 3rem 0 2rem;
}
#footer p a {
  display: inline-block;
  overflow: hidden;
  width: 3rem;
  height: 3rem;
  text-align: center;
  line-height: 3rem;
  vertical-align: middle;
  border-radius: 100%;
  background-color: rgba(255, 255, 255, 0.2);
}

#top {
  display: inline-block;
  overflow: hidden;
  width: 3.5rem;
  height: 3.5rem;
  text-align: center;
  line-height: 3.5rem;
  vertical-align: middle;
  position: absolute;
  right: 2.5rem;
  top: 15rem;
  border-radius: 100%;
  border: 1px solid #fff;
  font-size: 2.2rem;
}
#top::before {
  font-family: "remixicon";
  content: "\ea76";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: inherit;
}

#tabmenu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  overflow-x: auto;
  width: 73.5rem;
  max-width: 100%;
  margin: 0 auto 5rem;
  padding-bottom: 1rem;
  text-align: center;
  white-space: nowrap;
  gap: 0.5rem;
}
#tabmenu a {
  position: relative;
  z-index: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  min-width: 18rem;
  height: 5rem;
  border-radius: 5rem;
  background-color: #EFEFEF;
  font-size: 1.6rem;
  font-weight: 600;
  color: #737882;
  text-align: center;
  line-height: 1.2;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
#tabmenu .active {
  background-color: #222;
  color: #fff;
}
#tabmenu .active::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  position: absolute;
  bottom: -1rem;
  z-index: -1;
  width: 2rem;
  height: 2rem;
  background-color: #222;
  content: "";
  -webkit-transform: rotate(45deg) translateX(-50%);
          transform: rotate(45deg) translateX(-50%);
}

#contents {
  margin-bottom: 6rem;
}
#contents p {
  word-break: auto-phrase;
  text-align: justify;
}
#contents p + p {
  margin-top: 3.5rem;
}

.title1 {
  font-size: 3rem;
  color: #333;
  line-height: var(--lh);
  display: block;
  margin: 4rem auto 3.5rem;
  font-family: var(--ff1);
  text-align: center;
  white-space: nowrap;
}
.title1:first-child {
  margin-top: 0;
}
.title1 span {
  position: relative;
  z-index: 0;
  display: inline-block;
  padding: 1rem 0 1rem 7rem;
  background: url("/template/newsletter/img/title1.png") no-repeat 0 0;
  background-size: auto 5.9rem;
  text-align: left;
  line-height: 1.1;
  word-break: keep-all;
  vertical-align: middle;
}
.title1 span::before {
  position: absolute;
  left: 6.5rem;
  bottom: 1rem;
  z-index: -1;
  width: calc(100% - 6.5rem);
  height: 1.3rem;
  background-color: #FFE8C7;
  content: "";
}

.title2 {
  font-size: 1.6rem;
  color: #757575;
  line-height: var(--lh);
  display: block;
  margin: 7rem 0 3.5rem;
  border-bottom: 0.2rem solid #002D64;
  font-weight: 400;
}
.title2:first-child {
  margin-top: 0;
}
.title2 i {
  font-size: 2.6rem;
}
.title2 strong {
  display: inline-block;
  position: relative;
  top: -0.2rem;
  margin-right: 0.5rem;
  font-family: var(--ff1);
  font-size: 2.8rem;
  color: #333;
  vertical-align: middle;
}

.title3 {
  font-size: 2rem;
  color: #000;
  line-height: var(--lh);
  display: block;
  margin: 7rem 0 3.5rem;
  text-align: center;
}
.title3:first-child {
  margin-top: 0;
}
.title3 span {
  display: block;
  font-size: 1.4rem;
  color: var(--cl2);
}

.title4 {
  font-size: 2.2rem;
  color: #333;
  line-height: var(--lh);
  display: block;
  margin: 3.5rem 0 0;
}
.title4:first-child {
  margin-top: 0;
}
.title4 + [class*=list] {
  margin-top: 1rem;
}
.title4 + i {
  display: block;
  margin-top: 1rem;
}
.title4 + p.txt_center sup {
  font-size: 1.2rem;
}

p.bul1, ul.bul1 > li {
  position: relative;
  padding-left: 1.5rem;
  text-align: left;
}
p.bul1::before, ul.bul1 > li::before {
  position: absolute;
  left: 0;
  top: auto;
  content: "";
}
p.bul1::before, ul.bul1 > li::before {
  top: 1rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 100%;
  background-color: #b9b9b9;
}
p.bul1:first-child:nth-last-child(3) span, ul.bul1 > li:first-child:nth-last-child(3) span {
  display: block;
  margin-left: 7rem;
}

.bul1 {
  margin-top: 1rem;
}

span.bul2::before, ul.bul2 > li::before {
  margin-right: 0.5rem;
  content: "·";
}

.table1 {
  overflow: hidden;
  margin: 1rem 0;
  border-top: 0.2rem solid #333;
  word-break: keep-all;
}
.table1 table {
  position: relative;
  left: -1px;
}
.table1 th, .table1 td {
  border-left: 1px solid var(--bdc);
  border-bottom: 1px solid var(--bdc);
  text-align: center;
}
.table1 th {
  padding: 1rem;
  background-color: #f5f5f5;
  line-height: 1.2;
}
.table1 td {
  padding: 2rem 1rem;
  font-size: 1.6rem;
}
.table1 ul.bul2 > li + li {
  margin-top: 1rem;
}
.table1.type1 {
  overflow-x: auto;
}
.table1.type1 th {
  font-size: 1.6rem;
  font-weight: 500;
}
.table1.type1 th, .table1.type1 td {
  padding: 1.5rem 1rem;
}
.table1.type1 th span, .table1.type1 td {
  white-space: nowrap;
}

.box1 {
  position: relative;
  margin: 8rem 0 3.5rem !important;
  padding: 3.5rem 5rem;
}
.box1::before {
  position: absolute;
  left: 0;
  top: -4rem;
  width: 100%;
  height: 1px;
  background-color: var(--bdc);
  content: "";
}
.box1 i {
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  position: absolute;
  right: 4.5rem;
}
.box1 strong {
  display: block;
  margin: 1.5rem 0 4.5rem;
  font-size: 2.6rem;
}
.box1.type1 {
  background-color: #FFFAED;
}
.box1.type2 {
  background-color: #F0F7FF;
}
.box1.type3 {
  background-color: #EFFDFB;
}
.box1.type4 {
  background-color: #F9FFEB;
}

.box2 {
  padding: 2rem 3rem;
  border: 0.2rem solid var(--bdc);
  font-size: 1.6rem;
}
.box2 span {
  display: block;
  padding-left: 4.5rem;
  text-indent: -4.5rem;
}

.box3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  min-height: 9rem;
  margin-top: 6rem !important;
  padding: 0 0 2rem 8.5rem;
  border-bottom: 1px solid var(--bdc);
  font-family: var(--ff1);
  color: #757575;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.box3 i {
  display: inline-block;
  overflow: hidden;
  width: 7rem;
  height: 7rem;
  text-align: center;
  line-height: 7rem;
  vertical-align: middle;
  position: absolute;
  left: 0;
  top: 0;
  border-radius: 2rem;
}
.box3 strong {
  display: block;
  font-size: 2.6rem;
  color: #222;
  line-height: 1.2;
  word-break: keep-all;
}
.box3:first-child {
  margin-top: 0 !important;
}
.box3 .type1 {
  background-color: #F9EDBD;
}
.box3 .type2 {
  background-color: #F9D2C0;
}
.box3 .type3 {
  background-color: #C9EBEF;
}
.box3 .type4 {
  background-color: #C0FFEC;
}

.box4 {
  display: grid;
  font-size: 2rem;
  color: #000;
  grid-template-areas: "a1 a2" "a1 a3";
  -webkit-column-gap: 4rem;
     -moz-column-gap: 4rem;
          column-gap: 4rem;
  grid-template-columns: 41.5rem auto;
  grid-template-rows: auto 5rem;
}
.box4 i {
  grid-area: a1;
  grid-row: span 2;
}
.box4 .btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  grid-area: a3;
  margin-top: auto;
  gap: 0.5rem;
}
.box4 .btns a {
  padding: 0;
  white-space: nowrap;
  -webkit-box-flex: 1;
      -ms-flex: 1 1;
          flex: 1 1;
}
.box4 span {
  grid-area: a2;
  align-self: center;
  word-break: keep-all;
}
.box4 span::before {
  display: block;
  height: 2.5rem;
  margin-bottom: 1rem;
  background: url("/template/newsletter/img/quotes.png") no-repeat center 0;
  background-size: auto 100%;
  content: "";
}

.box5 {
  display: block;
  margin-top: 1rem;
  padding: 3rem;
  background-color: #F6F6F6;
  font-size: 1.6rem;
  color: #000;
}
.box5 h3 {
  margin-bottom: 1.5rem;
  font-size: 2rem;
}
.box5 li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.box5 strong {
  width: 7rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.box5 i {
  margin-right: 1rem;
  font-weight: 400;
}
.box5 + i {
  display: block;
  margin: 3rem 0;
}

.list1 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  word-break: keep-all;
}
.list1 span {
  display: block;
  margin-bottom: 1rem;
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--cl2);
}
.list1 a {
  display: block;
  position: relative;
  height: 14rem;
  padding: 3.5rem 1.5rem 0;
  border-radius: 0.7rem;
  background: -webkit-gradient(linear, left top, left bottom, from(#00105D), to(#0021C3));
  background: linear-gradient(to bottom, #00105D, #0021C3);
  color: #fff;
  text-align: center;
  line-height: 1.2;
}
.list1 a::before {
  font-family: "remixicon";
  content: "\ea70";
  position: absolute;
  right: 1rem;
  top: 2rem;
  font-size: 2.5rem;
  line-height: 0.5;
  opacity: 0.8;
}

.list2 {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  -webkit-column-gap: 1rem;
     -moz-column-gap: 1rem;
          column-gap: 1rem;
  row-gap: 0.5rem;
}
.list2 a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 6rem;
  padding: 0 0.5rem;
  border: 1px solid var(--bdc);
  background-color: #fff;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.list3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 1rem 0;
  gap: 5rem;
  counter-reset: list3;
  word-break: keep-all;
}
.list3 + .table1 {
  margin-top: 4rem;
}
.list3 > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  min-height: 18rem;
  padding: 5rem 0.5rem 0;
  border-radius: 1.2rem;
  border: 1px solid var(--bdc);
  -webkit-box-flex: 1;
      -ms-flex: 1 1;
          flex: 1 1;
  font-size: 1.6rem;
  text-align: center;
  line-height: 1.4;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  counter-increment: list3;
}
.list3 > li::before {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 5rem;
  border-radius: 1.1rem 1.1rem 0 0;
  background-color: #E9F0FD;
  font-size: 1.8rem;
  font-weight: 700;
  color: #3B6AE1;
  content: "0" counter(list3);
  line-height: 5rem;
}
.list3 > li + li::after {
  font-family: "remixicon";
  content: "\f00a";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  position: absolute;
  right: 100%;
  width: 5rem;
  color: #3B6AE1;
}

.list4 {
  display: grid;
  overflow: hidden;
  overflow-x: auto;
  gap: 0;
  margin: 1rem 0;
  font-size: 1.6rem;
  text-align: center;
  word-break: keep-all;
  grid-template-columns: auto auto auto 28rem;
}
.list4 span, .list4 strong {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 0.4rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.list4 strong {
  min-height: 4.5rem;
  color: #fff;
  line-height: 1.2;
}
.list4 span {
  height: 15rem;
  margin-top: 0.5rem;
  border: 1px solid var(--bdc);
}
.list4 .label3 {
  color: #0D188F;
}
.list4 > li {
  position: relative;
  min-width: 15rem;
  padding-right: 2rem;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.list4 > li::after {
  font-family: "remixicon";
  content: "\f00a";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  position: absolute;
  right: 0;
  width: 2rem;
  font-size: 1.2rem;
}
.list4 > li:last-child {
  padding-right: 0;
}
.list4 > li:last-child::after {
  display: none;
}
.list4 .label1 {
  border-color: #4760E8;
  background-color: #4760E8;
}
.list4 .label2 {
  border-color: #0D188F;
  background-color: #0D188F;
}
.list4 .label3 {
  border-color: #EAEDFF;
  background-color: #EAEDFF;
}
.list4 .group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 28rem;
  gap: 2rem;
}
.list4 .group + .group {
  margin-top: 1rem;
}
.list4 .group span {
  height: 4rem;
}
.list4 .group p {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex: 1;
      flex: 1;
}
.list4 .group .label3 {
  width: 6.5rem;
  height: 9.5rem;
  margin-top: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.list4 .group > * {
  position: relative;
}
.list4 .group > * + *::after {
  font-family: "remixicon";
  content: "\f00a";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  position: absolute;
  right: 100%;
  width: 2rem;
  font-size: 1.2rem;
}
.list4.type1 {
  grid-template-columns: repeat(4, 1fr);
}
.list4.type1 span {
  height: 12rem;
  margin-top: 2rem;
  border: 0 none;
  background-color: #F5F5F5;
}
.list4.type1 .label1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 20rem;
  border-radius: 0.5rem;
  font-weight: 600;
  color: #fff;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.list4.type1 .label2 {
  height: 6rem;
  font-weight: 400;
}
.list4.type1 .label3 {
  height: 5.5rem;
  margin-top: 1.5rem;
  font-weight: 600;
  line-height: 1.2;
}
.list4.type1 > li:nth-child(n+3)::after {
  top: 87.5%;
}
.list4.type1 > li:nth-child(3) span {
  position: relative;
  height: 10rem;
  margin-top: 4rem;
}
.list4.type1 > li:nth-child(3) span::before {
  font-family: "remixicon";
  content: "\f00a";
  position: absolute;
  position: absolute;
  left: 0;
  bottom: 100%;
  width: 100%;
  height: 4rem;
  font-size: 1.2rem;
  line-height: 4rem;
}

.txt1 {
  display: block;
  font-size: 1.6rem;
  color: #00105D;
}
.txt1 + p.txt_center {
  margin-top: 4rem;
}

small.txt_right {
  display: block;
  margin-bottom: -1rem;
}

.icon1 {
  height: 3rem;
  border: 1.11px solid var(--cl2);
  line-height: calc(3rem - 2.22px);
  display: inline-block;
  padding: 0 1rem;
  background-color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--cl2);
  vertical-align: middle;
  line-height: 2.9rem;
}

.btns {
  margin-top: 4rem;
  text-align: center;
}

.btn1 {
  font-size: 1.6rem;
  color: #000;
  line-height: inherit;
  overflow: hidden;
  line-height: 5rem;
  text-overflow: ellipsis;
  display: -webkit-box;
  max-height: calc(5rem * type1);
  line-clamp: type1;
  -webkit-line-clamp: type1;
  box-orient: vertical;
  -webkit-box-orient: vertical;
  height: 5rem;
  border: 1px solid #000;
  line-height: calc(5rem - 2px);
  display: inline-block;
  padding: 0 3.5rem;
  background-color: #fff;
  text-align: center;
  vertical-align: middle;
  -webkit-transition: var(--time2);
  transition: var(--time2);
  border-radius: 1rem;
  font-weight: 600;
}
.btn1 i {
  margin-left: 0.5rem;
  font-size: 2rem;
  font-weight: 400;
}

#visual {
  position: relative;
  z-index: 0;
  display: block;
  margin-bottom: 6rem;
  padding: 11rem 3rem 3rem;
  background-color: #000;
  font-size: 1.4rem;
  color: #fff;
  text-align: center;
}
#visual i {
  position: absolute;
  top: 0;
  z-index: -1;
  height: 100%;
  content: "";
  left: 0;
  width: 100%;
  overflow: hidden;
  opacity: 0.55;
}
#visual img {
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  position: absolute;
  max-width: inherit;
  height: 100%;
  -webkit-transition: var(--time2);
  transition: var(--time2);
}
#visual h2 {
  margin: 0.5rem 0 1rem;
  font-family: var(--ff1);
  font-size: 3.6rem;
  line-height: 1.2;
}
#visual span {
  height: 3rem;
  border: 1px solid #fff;
  line-height: calc(3rem - 2px);
  display: inline-block;
  padding: 0 1rem;
  border-radius: 3rem;
  font-family: var(--ff1);
  font-weight: 600;
  vertical-align: middle;
  -webkit-transition: var(--time2);
  transition: var(--time2);
}

.main1 ~ [class*=main] {
  position: relative;
  margin-top: 7rem;
}
.main1 ~ [class*=main] .more {
  display: inline-block;
  overflow: hidden;
  width: 2rem;
  height: 2rem;
  text-align: center;
  line-height: 2rem;
  vertical-align: middle;
  position: absolute;
  right: 1rem;
  top: 1.5rem;
  font-size: 2rem;
  color: var(--cl2);
}
.main1 ~ [class*=main] .more::before {
  font-family: "remixicon";
  content: "\ea10";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: inherit;
}
.main1 ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3rem;
}
.main1 ul i {
  display: inline-block;
  overflow: hidden;
  width: 12.5rem;
  height: 12.5rem;
  text-align: center;
  line-height: 12.5rem;
  vertical-align: middle;
  display: block;
  margin: 0 auto 2rem;
}
.main1 ul strong {
  display: block;
  margin: 1.5rem 0 2rem;
  font-size: 2.6rem;
  word-break: keep-all;
  line-height: 1.2;
}
.main1 ul span {
  display: block;
  margin-top: 1.5rem;
  font-size: 1.4rem;
  font-weight: 500;
}
.main1 ul p {
  overflow: hidden;
  line-height: 2.6rem;
  text-overflow: ellipsis;
  display: -webkit-box;
  max-height: 13rem;
  line-clamp: 5;
  -webkit-line-clamp: 5;
  box-orient: vertical;
  -webkit-box-orient: vertical;
  color: #616161;
}
.main1 ul li {
  border: 1px solid var(--bdc);
  border-top: 0.3rem solid var(--cl2);
}
.main1 ul li:nth-child(2), .main1 ul li:nth-child(3) {
  background-color: #F8F8F8;
}
.main1 ul a {
  display: block;
  position: relative;
  padding: 2.5rem 3rem;
  font-size: 1.6rem;
}
.main1 ul a::before {
  font-family: "remixicon";
  content: "\ea70";
  position: absolute;
  right: 1rem;
  top: 3rem;
  font-size: 6rem;
  color: var(--bdc);
  line-height: 0.5;
  -webkit-transition: var(--time2);
  transition: var(--time2);
}

.main2 ul {
  display: grid;
  font-family: var(--ff1);
  grid-template-columns: repeat(2, 1fr);
  -webkit-column-gap: 4rem;
     -moz-column-gap: 4rem;
          column-gap: 4rem;
  row-gap: 3.5rem;
  counter-reset: main2;
}
.main2 ul strong {
  display: block;
  font-size: 2.6rem;
  line-height: 1.2;
}
.main2 ul li {
  padding-top: 2.5rem;
  counter-increment: main2;
}
.main2 ul i {
  display: inline-block;
  overflow: hidden;
  width: 7rem;
  height: 7rem;
  text-align: center;
  line-height: 7rem;
  vertical-align: middle;
  position: absolute;
  right: 2.5rem;
  top: 2.5rem;
  border-radius: 2rem;
  background-color: rgba(255, 255, 255, 0.5);
}
.main2 ul i img {
  max-width: 60%;
  max-height: 60%;
}
.main2 ul a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  height: 18.5rem;
  padding: 0 4.5rem;
  border-radius: 0 1rem 1rem 1rem;
  background-color: #FFE54D;
  color: #000;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.main2 ul a::before {
  position: absolute;
  left: 0;
  top: -2.5rem;
  width: 10rem;
  height: 2.5rem;
  padding-top: 1rem;
  border-radius: 1rem 1rem 0 0;
  background-color: #FFE54D;
  font-size: 1.4rem;
  font-weight: 900;
  color: rgba(0, 0, 0, 0.2);
  text-align: center;
  content: "0" counter(main2);
}
.main2 ul a::after {
  position: absolute;
  left: 8.5rem;
  top: -2.5rem;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0 0.5rem 0 0;
  background-color: #FFE54D;
  content: "";
  -webkit-transform: skewX(45deg);
          transform: skewX(45deg);
}
.main2 ul li:nth-child(1) a, .main2 ul li:nth-child(1) a::before, .main2 ul li:nth-child(1) a::after {
  background-color: #FFE54D;
}
.main2 ul li:nth-child(2) a, .main2 ul li:nth-child(2) a::before, .main2 ul li:nth-child(2) a::after {
  background-color: #FBB57D;
}
.main2 ul li:nth-child(3) a, .main2 ul li:nth-child(3) a::before, .main2 ul li:nth-child(3) a::after {
  background-color: #A5E5ED;
}
.main2 ul li:nth-child(4) a, .main2 ul li:nth-child(4) a::before, .main2 ul li:nth-child(4) a::after {
  background-color: #A9EFDA;
}

.main4 {
  position: relative;
  z-index: 0;
  padding: 6rem 0 8.5rem;
}
.main4::before {
  position: absolute;
  top: 0;
  z-index: -1;
  height: 100%;
  content: "";
  left: 50%;
  width: 10000%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -3;
  width: calc(100% + 7rem);
  background: url("/template/newsletter/img/bg1_1.png") no-repeat;
  background-size: 100% 100%;
}
.main4::after {
  position: absolute;
  top: 0;
  z-index: -1;
  height: 100%;
  content: "";
  left: 0;
  width: 100%;
  z-index: -2;
  background: url("/template/newsletter/img/bg1_2.png") no-repeat center bottom;
}
.main4 .more {
  top: 7rem !important;
}
.main4 .group {
  margin-top: 4rem;
}
.main4 .group::before, .main4 .group::after {
  position: absolute;
  z-index: -1;
  background-size: auto 100% !important;
  content: "";
}
.main4 .group::before {
  left: 5.5rem;
  bottom: -1.5rem;
  width: 18rem;
  height: 14.7rem;
  background: url("/template/newsletter/img/main4_1.png") no-repeat 0 bottom;
  content: "";
}
.main4 .group::after {
  right: 3.5rem;
  bottom: -2rem;
  width: 11.2rem;
  height: 17rem;
  background: url("/template/newsletter/img/main4_2.png") no-repeat right bottom;
  content: "";
}

.main6 {
  position: relative;
  z-index: 0;
  padding: 7rem 0 3rem;
  color: #fff;
  text-align: center;
  word-break: keep-all;
  letter-spacing: -0.1rem;
}
.main6::before {
  position: absolute;
  top: 0;
  z-index: -1;
  height: 100%;
  content: "";
  left: 50%;
  width: 10000%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -2;
  background-color: #162350;
}
.main6 h3 {
  font-family: var(--ff1);
  font-size: 2.8rem;
}
.main6 h3::after {
  display: block;
  width: 7.5rem;
  height: 0.3rem;
  margin: 2.5rem auto;
  background-color: #fff;
  content: "";
}

@media (max-width: 860px) {
  html {
    font-size: 9px;
  }
}
@media (max-width: 768px) {
  html {
    font-size: 8px;
  }
  #header nav a {
    margin: 0 1.5rem;
  }
  #tabmenu a {
    min-width: 0;
    padding: 0 2rem;
  }
  .title1 {
    font-size: 2.5rem;
    white-space: normal;
  }
  .title1 span {
    padding-left: 4.5rem;
    background-size: auto 4rem;
  }
  .title1 span::before {
    display: none;
  }
  .title2 span {
    display: block;
    margin: -1rem 0 1rem;
  }
  .box1 {
    padding: 3rem;
    word-break: keep-all;
  }
  .box1 span {
    margin-right: 13rem;
  }
  .box1 i {
    right: 3rem;
    top: auto;
    bottom: 3rem;
    width: 10rem;
    -webkit-transform: inherit;
            transform: inherit;
  }
  .box4 {
    font-size: inherit;
    line-height: 1.3;
    -webkit-column-gap: 3rem;
       -moz-column-gap: 3rem;
            column-gap: 3rem;
    grid-template-columns: 30rem auto;
  }
  .box4 span::before {
    height: 2rem;
  }
  .list1 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 1.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .list1 strong {
    display: block;
    min-height: 4.5rem;
  }
  #visual h2 {
    font-size: 3rem;
  }
  #visual p br {
    display: none;
  }
  .main1 ul a {
    padding: 2.5rem;
  }
  .main1 ul b {
    display: block;
  }
  .main1 ul strong {
    font-size: 2rem;
  }
  .main2 ul a {
    padding: 5rem 2rem 0;
    font-size: 1.6rem;
  }
  .main2 ul strong {
    font-size: 2rem;
  }
}
@media (max-width: 500px) {
  html {
    font-size: 7px;
  }
  #header h1 img {
    height: 5rem;
  }
  .box1 b {
    display: block;
  }
  .main4 .group::before, .main4 .group::after {
    display: none;
  }
  #footer #subscribe {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #footer #subscribe strong {
    margin: 0 0 1rem;
  }
  .list1 {
    gap: 0.5rem;
  }
  .list1 strong {
    overflow: hidden;
    line-height: inherit;
    text-overflow: ellipsis;
    display: -webkit-box;
    max-height: calc(inherit * 4);
    line-clamp: 4;
    -webkit-line-clamp: 4;
    box-orient: vertical;
    -webkit-box-orient: vertical;
  }
  .list2 {
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem;
  }
  .list3 {
    gap: 1rem;
  }
  .list3 > li + li::after {
    width: 1rem;
  }
  .box4 {
    display: block;
  }
  .box4 a {
    display: block;
  }
  .box4 span {
    display: block;
    position: relative;
    margin: 3rem 0 2rem;
  }
  .box4 span::before {
    position: absolute;
    right: 0;
    bottom: 100%;
    width: 4rem;
    height: 2.5rem;
  }
  .main1 ul {
    display: block;
  }
  .main1 ul li + li {
    margin-top: 1rem;
  }
  .main1 ul b {
    display: inline;
  }
  .main2 ul {
    gap: 1rem;
  }
  .main2 ul a {
    padding: 0 0 2rem 2rem;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
  }
  .main2 ul i {
    width: 5rem;
    height: 5rem;
    border-radius: 1rem;
    line-height: 5rem;
  }
  .main2 ul strong {
    font-size: 1.8rem;
  }
}