.animate .fadein {
  opacity: 0;
  transform-style: preserve-3d;
  transition-property: opacity;
  transition-duration: 2000ms;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-delay: 0ms;
}
.animate.show .fadein {
  opacity: 1;
}
.animate .slidein_left {
  opacity: 0;
  transform: translateX(-100px);
  transform-style: preserve-3d;
  transition-property: opacity, transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-delay: 0ms;
}
.animate .slidein_right {
  opacity: 0;
  transform: translateX(100px);
  transform-style: preserve-3d;
  transition-property: opacity, transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-delay: 0ms;
}
.animate.show .slidein_left, .animate.show .slidein_right {
  opacity: 1;
  transform: translateX(0);
}
.animate .slidein_top {
  opacity: 0;
  transform: translateY(-20px);
  transform-style: preserve-3d;
  transition-property: opacity, transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-delay: 0ms;
}
.animate .slidein_bottom {
  opacity: 0;
  transform: translateY(20px);
  transform-style: preserve-3d;
  transition-property: opacity, transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-delay: 0ms;
}
.animate.show .slidein_top, .animate.show .slidein_bottom {
  opacity: 1;
  transform: translateY(0);
}
.animate .zoomin {
  opacity: 0;
  transform: scale(1.5, 1.5);
  transform-style: preserve-3d;
  transition-property: opacity, transform;
  transition-duration: 1000ms;
  transition-delay: 0ms;
}
.animate .zoomout {
  opacity: 0;
  transform: scale(0.5, 0.5);
  transform-style: preserve-3d;
  transition-property: opacity, transform;
  transition-duration: 1000ms;
  transition-delay: 0ms;
}
.animate.show .zoomin, .animate.show .zoomout {
  opacity: 1;
  transform: scale(1, 1);
}
.animate .d1 {
  transition-delay: 100ms;
}
.animate .d2 {
  transition-delay: 200ms;
}
.animate .d3 {
  transition-delay: 300ms;
}
.animate .d4 {
  transition-delay: 400ms;
}
.animate .d5 {
  transition-delay: 500ms;
}
.animate .d6 {
  transition-delay: 600ms;
}
.animate .d7 {
  transition-delay: 700ms;
}
.animate .d8 {
  transition-delay: 800ms;
}
.animate .d9 {
  transition-delay: 900ms;
}
.animate .d10 {
  transition-delay: 1000ms;
}
.animate .d11 {
  transition-delay: 1100ms;
}
.animate .d12 {
  transition-delay: 1200ms;
}
.animate .d13 {
  transition-delay: 1300ms;
}
.animate .d14 {
  transition-delay: 1400ms;
}
.animate .d15 {
  transition-delay: 1500ms;
}
.animate .d16 {
  transition-delay: 1600ms;
}
.animate .d17 {
  transition-delay: 1700ms;
}
.animate .d18 {
  transition-delay: 1800ms;
}
.animate .d19 {
  transition-delay: 1900ms;
}
.animate .d20 {
  transition-delay: 2000ms;
}

@media screen and (min-width: 1200px) {
  #main main.teemo article .main_content section .text h2 {
    line-height: 60px !important;
    font-size: 36px !important;
  }
  #main main.teemo article .main_content section.reassurance .large_image, #main main.teemo article .main_content section.plan .large_image {
    width: 50%;
  }
  #main main.teemo article .main_content section.reassurance .large_image p.img, #main main.teemo article .main_content section.plan .large_image p.img {
    width: 100%;
    aspect-ratio: 4/3;
    line-height: 0;
  }
  #main main.teemo article .main_content section.reassurance .large_image p.img img, #main main.teemo article .main_content section.plan .large_image p.img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  #main main.teemo article .main_content section.plan .side_table {
    width: 50%;
  }
  #main main.teemo article .main_content section.plan .side_table table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
  }
  #main main.teemo article .main_content section.plan .side_table table th, #main main.teemo article .main_content section.plan .side_table table td {
    padding: 8px 15px;
    min-height: 32px;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #3B3938;
    line-height: 18px;
    font-size: 14px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.plan .side_table table thead {
    background: #B6DBEA;
  }
  #main main.teemo article .main_content section.plan .side_table table thead tr th {
    border-top: 1px solid #3B3938;
    border-right: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.plan .side_table table thead tr th:last-child {
    border-right: 0;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr.last {
    border-bottom: 2px solid #3B3938;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr th {
    border-right: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr th span.logo {
    margin: 0 auto;
    width: 110px;
    display: block;
    line-height: 0;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr th span.logo img {
    width: 100%;
    height: auto;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr td.text {
    text-align: left;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr td.cost {
    padding-right: 22px;
    border-left: 1px solid #3B3938;
    text-align: right;
  }
  #main main.teemo article .main_content section.member .inner {
    display: block;
  }
  #main main.teemo article .main_content section.member .text {
    width: 100%;
  }
  #main main.teemo article .main_content section.member .text p.text {
    margin-bottom: 82px;
  }
  #main main.teemo article .main_content section.member .full_table {
    width: 100%;
  }
  #main main.teemo article .main_content section.member .full_table table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
  }
  #main main.teemo article .main_content section.member .full_table table th, #main main.teemo article .main_content section.member .full_table table td {
    padding: 12px 30px;
    min-height: 58px;
    box-sizing: border-box;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #3B3938;
    line-height: 26px;
    font-weight: normal;
  }
  #main main.teemo article .main_content section.member .full_table table thead {
    background: #B6DBEA;
  }
  #main main.teemo article .main_content section.member .full_table table thead tr th {
    border-top: 2px solid #3B3938;
    border-bottom-width: 2px;
    border-right: 1px solid #3B3938;
    font-size: 22px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.member .full_table table thead tr th:first-child {
    width: 285px;
  }
  #main main.teemo article .main_content section.member .full_table table thead tr th:last-child {
    border-right: 0;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr th {
    border-right: 1px solid #3B3938;
    font-size: 20px;
    color: #ffffff;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr th.teemo-member {
    background: #41C3E1;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr th.lite-member {
    background: #F8AE58;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td {
    text-align: left;
    font-size: 21px;
    font-weight: bold;
    line-height: 1.5;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td:last-child {
    border-left: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td small {
    font-size: 16px;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td sup {
    color: #41C3E1;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr:last-child th, #main main.teemo article .main_content section.member .full_table table tbody tr:last-child td {
    border-bottom-width: 2px;
  }
  #main main.teemo article .main_content section.price .inner {
    display: block;
  }
  #main main.teemo article .main_content section.price .text p.text {
    margin-bottom: 82px;
  }
  #main main.teemo article .main_content section.price .full_table {
    width: 100%;
  }
  #main main.teemo article .main_content section.price .full_table.lite {
    margin-top: 98px;
  }
  #main main.teemo article .main_content section.price .full_table table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
    border-bottom: 2px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table th, #main main.teemo article .main_content section.price .full_table table td {
    padding: 12px 30px;
    min-height: 58px;
    box-sizing: border-box;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #3B3938;
    line-height: 26px;
    font-weight: normal;
  }
  #main main.teemo article .main_content section.price .full_table table thead {
    background: #B6DBEA;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th {
    border-top: 2px solid #3B3938;
    border-right: 1px solid #3B3938;
    font-size: 22px;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th.category {
    padding: 4px;
    line-height: 40px;
    font-size: 28px;
    font-weight: bold;
    background: #41C3E1;
    color: #ffffff;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th:first-child {
    width: 285px;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th:last-child {
    border-right: 0;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr:nth-child(2) th {
    font-weight: bold;
  }
  #main main.teemo article .main_content section.price .full_table table thead.lite {
    background: #FFE9D0;
  }
  #main main.teemo article .main_content section.price .full_table table thead.lite th.category {
    background: #F8AE58;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr:first-child th, #main main.teemo article .main_content section.price .full_table table tbody tr:first-child td {
    border-top: 2px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr th {
    border-right: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr th span.logo {
    width: 188px;
    display: block;
    line-height: 0;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr th span.logo img {
    width: 100%;
    height: auto;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td {
    font-size: 21px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td:last-child {
    border-left: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td.quick-charge {
    border-right: 1px solid #3B3938;
    width: 15px;
    writing-mode: vertical-rl;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td.disabled {
    line-height: 60px;
    font-size: 26px;
    font-weight: bold;
    color: #A7A7A7;
  }
  #main main.teemo article .main_content section.price .bnr {
    margin-top: 46px;
    padding: 0 50px;
  }
  #main main.teemo article .main_content section.price .bnr a {
    display: block;
    overflow: hidden;
    border-radius: 10px;
    line-height: 0;
  }
  #main main.teemo article .main_content section.price .bnr img {
    width: 100%;
  }
  #main main.teemo article .main_content section.price .note.note1 {
    margin-bottom: 99px;
    padding-top: 20px;
  }
}
@media screen and (max-width: 1199px) {
  #main main.teemo article .main_content section .text h2 {
    line-height: 46px;
    font-size: 30px;
  }
  #main main.teemo article .main_content section.reassurance .large_image, #main main.teemo article .main_content section.plan .large_image {
    width: 100%;
  }
  #main main.teemo article .main_content section.reassurance .large_image p.img, #main main.teemo article .main_content section.plan .large_image p.img {
    width: 100%;
    aspect-ratio: 4/3;
    line-height: 0;
  }
  #main main.teemo article .main_content section.reassurance .large_image p.img img, #main main.teemo article .main_content section.plan .large_image p.img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  #main main.teemo article .main_content section.plan .side_table {
    width: 100%;
  }
  #main main.teemo article .main_content section.plan .side_table table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
  }
  #main main.teemo article .main_content section.plan .side_table table th, #main main.teemo article .main_content section.plan .side_table table td {
    padding: 4px 6px;
    min-height: 28px;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #3B3938;
    line-height: 16px;
    font-size: 12px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.plan .side_table table thead {
    background: #B6DBEA;
  }
  #main main.teemo article .main_content section.plan .side_table table thead tr th {
    border-top: 1px solid #3B3938;
    border-right: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.plan .side_table table thead tr th:last-child {
    border-right: 0;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr.last {
    border-bottom: 2px solid #3B3938;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr th {
    border-right: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr th span.logo {
    margin: 0 auto;
    width: 80px;
    display: block;
    line-height: 0;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr th span.logo img {
    width: 100%;
    height: auto;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr td.text {
    text-align: left;
  }
  #main main.teemo article .main_content section.plan .side_table table tbody tr td.cost {
    padding-right: 22px;
    border-left: 1px solid #3B3938;
    text-align: right;
  }
  #main main.teemo article .main_content section.member .inner {
    display: block;
  }
  #main main.teemo article .main_content section.member .text p.text {
    margin-bottom: 40px;
  }
  #main main.teemo article .main_content section.member .full_table table {
    width: 500px;
    border-collapse: collapse;
    background: #ffffff;
  }
  #main main.teemo article .main_content section.member .full_table table th, #main main.teemo article .main_content section.member .full_table table td {
    padding: 12px 30px;
    min-height: 58px;
    box-sizing: border-box;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #3B3938;
    line-height: 28px;
    font-weight: normal;
  }
  #main main.teemo article .main_content section.member .full_table table thead {
    background: #B6DBEA;
  }
  #main main.teemo article .main_content section.member .full_table table thead tr th {
    border-top: 2px solid #3B3938;
    border-bottom-width: 2px;
    border-right: 1px solid #3B3938;
    font-size: 18px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.member .full_table table thead tr th:first-child {
    width: 200px;
  }
  #main main.teemo article .main_content section.member .full_table table thead tr th:last-child {
    border-right: 0;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr th {
    border-right: 1px solid #3B3938;
    font-size: 16px;
    color: #ffffff;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr th.teemo-member {
    background: #41C3E1;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr th.lite-member {
    background: #F8AE58;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td {
    text-align: left;
    font-size: 16px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td:last-child {
    border-left: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td small {
    font-size: 16px;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr td sup {
    color: #41C3E1;
  }
  #main main.teemo article .main_content section.member .full_table table tbody tr:last-child th, #main main.teemo article .main_content section.member .full_table table tbody tr:last-child td {
    border-bottom-width: 2px;
  }
  #main main.teemo article .main_content section.price .inner {
    display: block;
  }
  #main main.teemo article .main_content section.price .text p.text {
    margin-bottom: 82px;
  }
  #main main.teemo article .main_content section.price .full_table.lite {
    margin-top: 98px;
  }
  #main main.teemo article .main_content section.price .full_table table {
    width: 580px;
    border-collapse: collapse;
    background: #ffffff;
  }
  #main main.teemo article .main_content section.price .full_table table th, #main main.teemo article .main_content section.price .full_table table td {
    padding: 8px 20px;
    min-height: 58px;
    box-sizing: border-box;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #3B3938;
    line-height: 24px;
    font-weight: normal;
  }
  #main main.teemo article .main_content section.price .full_table table thead {
    background: #B6DBEA;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th {
    border-top: 2px solid #3B3938;
    border-right: 1px solid #3B3938;
    font-size: 18px;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th.category {
    padding: 4px;
    line-height: 40px;
    font-size: 20px;
    font-weight: bold;
    background: #41C3E1;
    color: #ffffff;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr th:last-child {
    border-right: 0;
  }
  #main main.teemo article .main_content section.price .full_table table thead tr:nth-child(2) th {
    font-weight: bold;
  }
  #main main.teemo article .main_content section.price .full_table table thead.lite {
    background: #FFE9D0;
  }
  #main main.teemo article .main_content section.price .full_table table thead.lite th.category {
    background: #F8AE58;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr:first-child th, #main main.teemo article .main_content section.price .full_table table tbody tr:first-child td {
    border-top: 2px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr:last-child th, #main main.teemo article .main_content section.price .full_table table tbody tr:last-child td {
    border-bottom: 2px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr th {
    border-right: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr th span.logo {
    margin: 0 auto;
    width: 100px;
    display: block;
    line-height: 0;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr th span.logo img {
    width: 100%;
    height: auto;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td {
    font-size: 16px;
    font-weight: bold;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td:last-child {
    border-left: 1px solid #3B3938;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td.quick-charge {
    border-right: 1px solid #3B3938;
    width: 15px;
    writing-mode: vertical-rl;
  }
  #main main.teemo article .main_content section.price .full_table table tbody tr td.disabled {
    line-height: 60px;
    font-size: 16px;
    font-weight: bold;
    color: #A7A7A7;
  }
  #main main.teemo article .main_content section.price .bnr {
    margin-top: 23px;
  }
  #main main.teemo article .main_content section.price .bnr a {
    margin: 0 auto;
    max-width: 500px;
    display: block;
    overflow: hidden;
    border-radius: 10px;
    line-height: 0;
  }
  #main main.teemo article .main_content section.price .bnr img {
    width: 100%;
  }
  #main main.teemo article .main_content section.price .note.note1 {
    margin-bottom: 50px;
  }
}