/*!
 * ress.css • v1.2.2
 * MIT License
 * github.com/filipelinhares/ress
 */
html {
    box-sizing: border-box;
    overflow-y: scroll;
    -webkit-text-size-adjust: 100%
}

*,
:after,
:before {
    background-repeat: no-repeat;
    box-sizing: inherit
}

:after,
:before {
    text-decoration: inherit;
    vertical-align: inherit
}

* {
    padding: 0;
    margin: 0
}

audio:not([controls]) {
    display: none;
    height: 0
}

hr {
    overflow: visible
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
    display: block
}

summary {
    display: list-item
}

small {
    font-size: 80%
}

[hidden],
template {
    display: none
}

abbr[title] {
    border-bottom: 1px dotted;
    text-decoration: none
}

a {
    background-color: transparent;
    -webkit-text-decoration-skip: objects
}

a:active,
a:hover {
    outline-width: 0
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace
}

b,
strong {
    font-weight: bolder
}

dfn {
    font-style: italic
}

mark {
    background-color: #ff0;
    color: #000
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

input {
    border-radius: 0
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
    cursor: pointer
}

[disabled] {
    cursor: default
}

[type=number] {
    width: auto
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

textarea {
    overflow: auto;
    resize: vertical
}

button,
input,
optgroup,
select,
textarea {
    font: inherit
}

optgroup {
    font-weight: 700
}

button {
    overflow: visible
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: 0;
    padding: 0
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
    outline: 1px dotted ButtonText
}

[type=reset],
[type=submit],
button,
html [type=button] {
    -webkit-appearance: button
}

button,
select {
    text-transform: none
}

button,
input,
select,
textarea {
    background-color: transparent;
    border-style: none;
    color: inherit
}

select {
    -moz-appearance: none;
    -webkit-appearance: none
}

select::-ms-expand {
    display: none
}

select::-ms-value {
    color: currentColor
}

legend {
    border: 0;
    color: inherit;
    display: table;
    max-width: 100%;
    white-space: normal
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

img {
    border-style: none
}

progress {
    vertical-align: baseline
}

svg:not(:root) {
    overflow: hidden
}

audio,
canvas,
progress,
video {
    display: inline-block
}

@media screen {
    [hidden~=screen] {
        display: inherit
    }

    [hidden~=screen]:not(:active):not(:focus):not(:target) {
        position: absolute !important;
        clip: rect(0 0 0 0) !important
    }
}

[aria-busy=true] {
    cursor: progress
}

[aria-controls] {
    cursor: pointer
}

[aria-disabled] {
    cursor: default
}

::-moz-selection {
    background-color: #b3d4fc;
    color: #000;
    text-shadow: none
}

::selection {
    background-color: #b3d4fc;
    color: #000;
    text-shadow: none
}

html {
    font-size: 100%;
    letter-spacing: .22em;
    visibility: hidden
}

html.wf-active {
    visibility: visible
}

body {
    font-family: Noto Sans JP, apple-system, blinkMacSystemFont, Helvetica Neue, Segoe UI, YuGothicM, YuGothic, Meiryo, Yu Gothic Medium, ヒラギノ角ゴ Pro W3, sans-serif;
    line-height: 1.5;
    color: #403c3d;
    font-weight: 400;
    background-color: #fff;
    letter-spacing: 1.3px
}

body.fixed {
    width: 100%;
    position: fixed;
    overflow: hidden
}

.wrapper {
    padding: 0 15px
}

.max-extend,
.wrapper {
    max-width: 1180px;
    margin: 0 auto
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 2rem;
    line-height: 1
}

@media screen and (max-width:576px) {

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-size: 1.5rem
    }
}

p {
    line-height: 1.5
}

@media screen and (max-width:576px) {
    p {
        font-size: 1rem
    }
}

a {
    text-decoration: none;
    color: #403c3d
}

img {
    max-width: 100%
}

button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

button,
input {
    outline: none
}

.sp-br {
    display: none
}

@media screen and (max-width:768px) {
    .sp-br {
        display: block
    }
}

.responsive-br {
    display: block
}

@media screen and (max-width:768px) {
    .responsive-br {
        display: none
    }
}

table {
    border-collapse: collapse
}

table td,
table th {
    padding: 5px;
    text-align: left
}

.regular {
    font-weight: 300
}

.page-top {
    height: 100vh
}

ul {
    list-style: none
}

.justify-center {
    justify-content: center
}

select {
    -webkit-appearance: revert;
    -moz-appearance: revert;
    appearance: revert
}

.link-btn-more:before {
    position: absolute;
    content: "";
    top: 50%;
    width: 8px;
    height: 8px;
    right: 0;
    border-top: 2px solid #403c3d;
    border-right: 2px solid #403c3d;
    transform: rotate(45deg);
    margin-top: -3px
}

.common-content {
    padding-bottom: 100px
}

.content {
    margin-bottom: 14px
}

.content-type1,
.content-type2,
.content-type3,
.content-type4 {
    padding: 15px 15px;
    border: 1px solid #618bde;
    border-radius: 15px
}

.content-type1 .title,
.content-type2 .title,
.content-type3 .title,
.content-type4 .title {
    font-size: 1.125rem;
    padding-left: 15px;
    position: relative;
    color: #403c3d;
    margin-bottom: 5px
}

.content-type1 .title:before,
.content-type2 .title:before,
.content-type3 .title:before,
.content-type4 .title:before {
    position: absolute;
    content: "";
    background-color: #403c3d;
    width: 4px;
    left: 0;
    height: 1.125rem;
    top: 50%;
    transform: translateY(-45%);
    border-radius: 5px
}

.link-btn-more {
    text-align: right;
    padding-right: 15px;
    display: block;
    margin-top: 15px;
    margin-bottom: 5px;
    position: relative;
    color: #618bde;
    font-size: .75rem
}

.link-btn-more:before {
    border-color: #618bde
}

.link-btn-detail,
.link-btn-shortcut {
    display: block;
    background-color: #214793;
    padding: 8px 15px;
    border-radius: 5px;
    color: #fff;
    text-align: center;
    font-size: .75rem
}

.link-btn-shortcut {
    background-color: #214793;
    padding: 10px 5px;
    font-size: .875rem;
    height: 40px;
    display: table-cell;
    vertical-align: middle;
    width: 200px
}

.link-btn-shortcut.pd {
    font-size: .575rem
}

.push-btn {
    position: relative;
    filter: drop-shadow(0 1px 0 rgba(0, 0, 0, .2));
    transition: all .1s
}

.push-btn:hover {
    transform: translateY(1px);
    filter: drop-shadow(0 0 0 rgba(0, 0, 0, .2))
}

.content-type2,
.content-type4 {
    padding: 0;
    overflow: hidden;
    background-color: #f4f6fc;
    border-radius: 0
}

.content-type2 .title,
.content-type4 .title {
    padding: 13px 30px;
    background-color: #618bde;
    font-size: 1rem;
    color: #fff
}

.content-type2 .title:before,
.content-type4 .title:before {
    left: 15px;
    background-color: #fff
}

.content-type2 .inner-content,
.content-type4 .inner-content {
    padding: 10px 15px
}

.content-type3 {
    background-color: #f4f6fc;
    border-radius: 0
}

.content-type3 .name {
    font-size: 1.125rem;
    color: #214793;
    margin-bottom: 10px
}

.content-type4 {
    border-radius: 15px;
    background-color: #fff
}

.shop {
    color: #ebb591
}

.outlet {
    color: #9cc6c4
}

.owner {
    color: #618bde
}

.community {
    color: #6fb978
}

.point {
    color: #d1d17e
}

.dx {
    color: #a0a0a0
}

.event {
    color: #ffbe00
}

.dx {
    color: #b56b7c
}

.earth {
    color: #34d2de
}

.cost {
    color: #727272
}

.cog {
    color: #618bde
}

.bell {
    color: #cece6e
}

.title-block {
    padding-top: 50px;
    padding-bottom: 45px;
    text-align: center
}

.notice {
    font-size: .75rem;
    color: #eb6565
}

.align-center,
.common-form {
    text-align: center
}

.common-form {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    padding: 25px;
    border: 1px solid #403c3d
}

.common-form .form-table {
    width: 100%;
    margin-bottom: 35px
}

.common-form .form-table td,
.common-form .form-table th {
    vertical-align: middle
}

.common-form .form-table th {
    white-space: nowrap
}

.common-form .form-table td input,
.common-form .form-table td select,
.common-form .form-table td textarea {
    padding: 5px;
    border-radius: 5px;
    background-color: #eeeff0;
    border: 1px solid #777;
    width: 100%
}

.common-form .form-table td input::-moz-placeholder,
.common-form .form-table td select::-moz-placeholder,
.common-form .form-table td textarea::-moz-placeholder {
    font-size: .875rem;
    color: #a0a0a0
}

.common-form .form-table td input:-ms-input-placeholder,
.common-form .form-table td select:-ms-input-placeholder,
.common-form .form-table td textarea:-ms-input-placeholder {
    font-size: .875rem;
    color: #a0a0a0
}

.common-form .form-table td input::placeholder,
.common-form .form-table td select::placeholder,
.common-form .form-table td textarea::placeholder {
    font-size: .875rem;
    color: #a0a0a0
}

.agree input {
    margin-right: 5px
}

.form-message {
    margin-bottom: 15px;
    font-size: .875rem
}

.required-mark {
    color: #eb6565
}

.regular-btn {
    max-width: 200px;
    width: 100%;
    display: block;
    padding: 5px 15px;
    border-radius: 25px;
    background-color: #214793;
    color: #fff;
    margin: 15px auto
}

.login-link {
    display: block;
    font-size: .875rem;
    margin-bottom: 5px
}

.detail-link,
.login-link {
    text-decoration: underline
}

.detail-link {
    color: #214793
}

.wide {
    max-width: 400px
}

.bold {
    font-weight: 700
}

.header-above {
    background-color: #214793;
    padding: 5px
}

.header-above .header-above-flex {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.header-above .header-above-flex .head-title {
    font-size: .75rem;
    color: #fff
}

.header-above .header-above-flex .head-title a {
    color: #fff;
    font-size: .75rem;
    font-weight: 400;
    text-align: left
}

.header-above .header-above-flex .login-btns {
    display: flex;
    align-items: center
}

.header-above .header-above-flex .login-btns .login-header-link {
    font-size: .75rem;
    color: #fff;
    margin-left: 10px
}

.page-header {
    margin-top: 24px;
    background-color: #fff;
    width: 100%;
    padding-top: 25px;
    padding-bottom: 45px
}

.header-nav {
    display: flex;
    align-items: center;
    justify-content: space-between
}

.header-nav .logo-header {
    flex: 1;
    text-align: center;
    display: block
}

.header-nav .logo-header .logo-mark {
    width: 350px
}

.left-menu,
.right-menu {
    flex: 1
}

.left-menu .menu-list,
.right-menu .menu-list {
    display: flex;
    justify-content: space-around
}

.left-menu .menu-list li .nav-item,
.right-menu .menu-list li .nav-item {
    text-align: center;
    padding-right: 10px
}

.left-menu .menu-list li .nav-item p img,
.right-menu .menu-list li .nav-item p img {
    width: 32px
}

.left-menu .menu-list li .nav-item .name,
.right-menu .menu-list li .nav-item .name {
    text-align: center;
    font-size: .575rem;
    padding-left: 3px;
    font-weight: 700;
    letter-spacing: .3px
}

.toggle-hamburger {
    cursor: pointer;
    width: 35px;
    height: 48px;
    padding-top: 10px
}

.toggle-hamburger,
.toggle-hamburger span {
    display: block;
    position: relative
}

.toggle-hamburger span:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 5px;
    background-color: #403c3d;
    top: 5px;
    left: 0;
    transform: translateY(-5px) rotate(0);
    transition: all .3s
}

.toggle-hamburger span:nth-of-type(2):before {
    transform: translateY(5px)
}

.toggle-hamburger p {
    position: absolute;
    font-size: .575rem;
    letter-spacing: 0;
    text-align: center;
    bottom: 0;
    left: 0;
    white-space: nowrap
}

.toggle-hamburger.close {
    border-color: #fff
}

.toggle-hamburger.close span:first-of-type:before {
    transform: rotate(-135deg)
}

.toggle-hamburger.close span:nth-of-type(2):before {
    transform: rotate(135deg) translateY(0)
}

.nav-bar {
    position: relative
}

.nav-bar .global-menu {
    position: absolute;
    right: 45px;
    top: 0;
    z-index: -1;
    height: 0;
    transition: all .3s ease-out;
    overflow: hidden;
    visibility: hidden
}

.nav-bar .global-menu .menu-list {
    padding: 15px 25px;
    background-color: #f4f6fc;
    border: 1px solid #618bde;
    z-index: 105;
    align-items: flex-start;
    display: none
}

.nav-bar .global-menu .menu-list li {
    padding-bottom: 10px
}

.nav-bar .global-menu .menu-list li a {
    display: flex;
    color: #214793
}

.nav-bar .global-menu .menu-list li a .icon {
    padding-right: 10px
}

.nav-bar .global-menu .menu-list li a .name {
    white-space: nowrap
}

.nav-bar .global-menu.show {
    visibility: visible;
    z-index: 105;
    height: 500px
}

.nav-bar .global-menu.show .menu-list {
    display: block
}

.left-aside {
    padding-right: 7px
}

.left-toggle-hamburger {
    cursor: pointer;
    width: 35px;
    height: 45px;
    padding-top: 10px
}

.left-toggle-hamburger,
.left-toggle-hamburger span {
    display: block;
    position: relative
}

.left-toggle-hamburger span:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 5px;
    background-color: #403c3d;
    top: 5px;
    left: 0;
    transform: translateY(-5px) rotate(0);
    transition: all .3s
}

.left-toggle-hamburger span:nth-of-type(2):before {
    transform: translateY(5px)
}

.left-toggle-hamburger p {
    position: absolute;
    font-size: .575rem;
    letter-spacing: 0;
    text-align: center;
    bottom: 0;
    left: 0;
    white-space: nowrap
}

.left-toggle-hamburger.close {
    border-color: #fff
}

.left-toggle-hamburger.close span:first-of-type:before {
    transform: rotate(-135deg)
}

.left-toggle-hamburger.close span:nth-of-type(2):before {
    transform: rotate(135deg) translateY(0)
}

.left-nav-bar,
.pr-left {
    width: 47px;
    transition: all .3s ease
}

.show.left-nav-bar,
.show.pr-left {
    width: 230px;
    overflow: hidden
}

.left-nav-bar {
    padding: 15px 5px;
    background-color: #f4f6fc;
    border: 1px solid #618bde;
    margin-bottom: 15px
}

.left-nav-bar.show {
    padding: 15px 15px
}

.left-nav-bar .global-menu {
    padding-top: 15px;
    visibility: hidden
}

.left-nav-bar .global-menu .menu-list {
    width: 0;
    overflow: hidden;
    transition: all .3s ease
}

.left-nav-bar .global-menu .menu-list li {
    padding-bottom: 10px
}

.left-nav-bar .global-menu .menu-list li a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: #214793
}

.left-nav-bar .global-menu .menu-list li a .imatch-logo {
    width: 170px;
    margin-bottom: 5px
}

.left-nav-bar .global-menu .menu-list li a .icon {
    font-size: 1.5rem;
    width: 25px;
    text-align: center;
    margin-right: 10px
}

.left-nav-bar .global-menu .menu-list li a .name {
    white-space: nowrap;
    font-size: .875rem
}

.left-nav-bar .global-menu.show {
    visibility: visible
}

.left-nav-bar .global-menu.show .menu-list {
    width: 100%
}

.pr-left .pr-left-img {
    position: relative;
    padding-top: 66.6%;
    overflow: hidden;
    margin-bottom: 10px
}

.pr-left .pr-left-img img {
    position: absolute;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    top: 0;
    left: 0
}

.pr-left {
    width: 0
}

.two-column {
    display: flex
}

.two-column .main-column {
    width: 100%;
    padding-right: 7px;
    padding-left: 7px
}

.two-column .aside-column {
    max-width: 380px;
    width: 100%;
    padding-left: 7px
}

.news-list li a {
    color: #618bde;
    display: flex;
    align-items: center;
    padding-top: 10px;
    padding-bottom: 10px;
    border-bottom: 1px dashed #618bde
}

.news-list li a .news-date {
    font-size: .75rem;
    padding-right: 10px;
    white-space: nowrap
}

.status-table {
    width: 100%;
    text-align: center;
    background-color: #fff
}

.status-table td,
.status-table th {
    border: 1px solid #403c3d;
    padding: 5px 3px;
    font-size: .875rem
}

.status-table th {
    background-color: #214793;
    color: #fff;
    border-color: #214793;
    border-right-color: #fff
}

.status-table th:last-child {
    border-right-color: #214793
}

.status-table td {
    color: #403c3d;
    border-color: #a0a0a0
}

.status-table td.date {
    letter-spacing: 1px
}

.shortcut-list {
    display: grid;
    gap: 5px;
    grid-template-columns: repeat(2, 1fr)
}

.point-block {
    background-color: #fff;
    filter: drop-shadow(0 2px 3px rgba(0, 0, 0, .2));
    padding: 10px;
    color: #214793
}

.point-block .p-label {
    text-align: left;
    font-size: .75rem;
    line-height: 1
}

.point-block .p-num {
    line-height: 1;
    font-size: 2rem;
    font-weight: 700;
    text-align: right
}

.pr-content1 .title {
    font-weight: 700;
    padding-left: 15px;
    position: relative;
    color: #403c3d;
    margin-bottom: 5px
}

.pr-content1 .title:before {
    position: absolute;
    content: "";
    background-color: #403c3d;
    width: 4px;
    left: 0;
    height: 1.125rem;
    top: 50%;
    transform: translateY(-45%);
    border-radius: 5px
}

.pr-flex,
.pr-seminar-flex {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 5px
}

.pr-flex a,
.pr-seminar-flex a {
    position: relative;
    display: block;
    flex: 1;
    padding-top: 66.6%;
    overflow: hidden
}

.pr-flex a img,
.pr-seminar-flex a img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.pr-seminar-flex {
    grid-template-columns: repeat(3, 1fr);
    margin-bottom: 8px
}

#line-chart,
#pie-chart {
    max-width: 100%
}

.pr-right {
    position: relative;
    padding-top: 40%;
    overflow: hidden
}

.pr-right img {
    position: absolute;
    top: 0;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    height: 100%
}

.title-flex {
    display: flex;
    justify-content: flex-start;
    position: relative;
    align-items: flex-end
}

.title-flex .small {
    padding-left: 10px;
    font-size: .575rem
}

.title-flex .link-right {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%)
}

.empty-info {
    padding: 0 15px 15px
}

.empty-info .notice {
    font-size: .75rem;
    margin-bottom: 10px;
    color: #214793
}

.empty-info .room-flex {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    font-weight: 700;
    color: #214793
}

.empty-info .room-flex .num {
    padding: 5px;
    border-radius: 10px;
    background-color: #fff;
    border: 1px solid #a0a0a0;
    text-align: right;
    max-width: 130px;
    width: 100%;
    font-size: 1.25rem
}

.empty-info .room-flex .room {
    padding-bottom: 5px;
    padding-left: 5px
}

.movein-info .info-block {
    width: 80%;
    margin: 10px auto 0;
    padding: 10px;
    border: 1px solid #a0a0a0;
    color: #214793;
    font-weight: 700
}

.movein-info .info-block .line {
    margin-bottom: 5px
}

.movein-info .info-block .line-flex {
    display: flex;
    justify-content: space-between
}

.movein-info .info-block .line-center {
    text-align: center
}

.recommend-content {
    border-color: #ebb591
}

.recommend-content .title {
    background-color: #ebb591
}

.pickup-content {
    border-color: #9cc6c4
}

.pickup-content .title {
    background-color: #9cc6c4
}

.shop-block .item-list li .item .item-img {
    position: relative;
    padding-top: 120%;
    overflow: hidden;
    margin-bottom: 5px
}

.shop-block .item-list li .item .item-img img {
    position: absolute;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    top: 0;
    left: 0
}

.shop-block {
    padding: 0 15px 15px
}

.shop-block .shop-title {
    font-weight: 700
}

.shop-block .item-list {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 10px
}

.shop-block .item-list li .item .item-name {
    font-weight: 700;
    margin-bottom: 5px;
    line-height: 1;
    font-size: .875rem;
    min-height: 28px
}

.shop-block .item-list li .item .item-price {
    color: #eb6565;
    font-weight: 700;
    font-size: .75rem;
    letter-spacing: .3px
}

.slider-topics {
    padding: 4px 14px;
    border: 1px solid #403c3d;
    max-width: 900px;
    margin: auto
}

.slider-topics a {
    color: #618bde;
    font-weight: 700
}

.slider-topics a .date {
    font-weight: 400;
    margin-right: 8px;
    font-size: .875rem
}

.topics-block {
    margin-bottom: 24px
}

.thx-intro-content .title {
    padding: 4px;
    background-color: #618bde;
    color: #fff;
    margin-bottom: 14px
}

.thx-intro-content .thx-table {
    width: 100%
}

.thx-intro-content .thx-table td {
    border: 1px solid #403c3d;
    font-size: .875rem
}

.thx-intro-content .thx-table .prefecture {
    white-space: nowrap
}

.right-menu-list {
    padding: 15px;
    border: 1px solid #618bde;
    background-color: #f4f6fc;
    margin-bottom: 16px
}

.right-menu-list li a {
    display: flex;
    justify-content: flex-start;
    color: #214793;
    font-size: .875rem;
    align-items: center
}

.right-menu-list li a .icon {
    font-size: 1.5rem;
    width: 25px;
    text-align: center;
    margin-right: 10px
}

.login-title {
    font-size: 1.5rem;
    margin-bottom: 20px
}

.flex-input {
    display: flex;
    gap: 14px
}

.flex-input input {
    flex: 1
}

.owner-pr-block {
    padding-top: 48px;
    margin-bottom: 24px
}

.slider-block {
    margin-bottom: 15px
}

.pr-list {
    display: flex
}

.pr-list li {
    flex: 1
}

.owner-btns-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px
}

.owner-btns-list li a {
    display: flex;
    align-items: center;
    padding: 15px 25px;
    background-color: #7fbbd2;
    color: #fff
}

.owner-btns-list li a .icon-img {
    flex: 1;
    text-align: center
}

.owner-btns-list li a .icon-img img {
    width: 100px;
    -o-object-fit: cover;
    object-fit: cover
}

.owner-btns-list li a .name {
    flex: 2;
    font-size: 1.5rem;
    font-weight: 700
}

.chatbot-block {
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 5;
    text-align: right
}

.banner-btns-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px
}

.banner-btns-list li a {
    display: block;
    position: relative;
    padding-top: 66.6%;
    border: 1px solid #eeeff0;
    background-color: #7fbbd2
}

.banner-btns-list li a .inner {
    position: absolute;
    display: flex;
    top: 50%;
    left: 50%;
    color: #fff;
    font-weight: 700;
    font-size: 1.5rem;
    transform: translate(-50%, -50%);
    align-items: center;
    justify-content: space-between;
    width: 100%
}

.banner-btns-list li a .inner .img {
    flex: 1;
    text-align: center
}

.banner-btns-list li a .inner .img img {
    width: 50px
}

.banner-btns-list li a .inner span {
    flex: 1
}

.banner-btns-list li a .banner {
    position: absolute;
    top: 0;
    left: 0
}

.service-request-block {
    text-align: center
}

.service-request-block .contact-message,
.service-request-block .contact-message-below {
    margin-bottom: 24px
}

.lp-header-above {
    margin-bottom: 0
}

.lp-a4-2-main-content,
.lp-a4-3a-main-content {
    padding-bottom: 0
}

.lp-a4-2-main-content .main-flex,
.lp-a4-3a-main-content .main-flex {
    display: flex
}

.lp-a4-2-main-content .main-flex .left-block,
.lp-a4-3a-main-content .main-flex .left-block {
    flex: 1;
    padding-bottom: 100px;
    padding-right: 14px;
    padding-left: 4%
}

.lp-a4-2-main-content .main-flex .left-block .logo,
.lp-a4-3a-main-content .main-flex .left-block .logo {
    margin-top: 48px;
    margin-bottom: 150px;
    font-size: 1.25rem
}

.lp-a4-2-main-content .main-flex .left-block .service-copy,
.lp-a4-3a-main-content .main-flex .left-block .service-copy {
    margin-bottom: 150px;
    font-weight: 700;
    font-size: 1.25rem
}

.lp-a4-2-main-content .main-flex .right-block,
.lp-a4-3a-main-content .main-flex .right-block {
    flex: 1;
    max-height: 600px
}

.lp-a4-2-main-content .main-flex .right-block img,
.lp-a4-3a-main-content .main-flex .right-block img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.lp-a4-2-about {
    background-color: #f4f6fc
}

.lp-a4-2-about-content {
    padding-top: 56px
}

.lp-a4-2-about-content .title {
    text-align: center;
    margin-bottom: 48px;
    font-size: 3rem;
    font-weight: 700;
    font-family: M PLUS\ 1p, sans-serif
}

.lp-a4-2-about-content .about-text {
    max-width: 650px;
    margin: auto;
    text-align: center;
    font-size: 1.25rem
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content,
.lp-a4-2-image-content,
.lp-a4-2-point,
.lp-a4-2-trouble-content,
.lp-a4-3a-download-content,
.lp-a4-3a-flow,
.lp-a4-3a-voice-content,
.lp-a4-3b-achieve-content,
.lp-a4-3b-download-content,
.lp-a4-3b-image,
.lp-a4-3b-price {
    padding-top: 56px
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .title,
.lp-a4-2-image-content .title,
.lp-a4-2-point .title,
.lp-a4-2-trouble-content .title,
.lp-a4-3a-download-content .title,
.lp-a4-3a-flow .title,
.lp-a4-3a-voice-content .title,
.lp-a4-3b-achieve-content .title,
.lp-a4-3b-download-content .title,
.lp-a4-3b-image .title,
.lp-a4-3b-price .title {
    text-align: center;
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 56px;
    font-family: M PLUS\ 1p, sans-serif
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .trouble-list,
.lp-a4-2-image-content .trouble-list,
.lp-a4-2-point .trouble-list,
.lp-a4-2-trouble-content .trouble-list,
.lp-a4-3a-download-content .trouble-list,
.lp-a4-3a-flow .trouble-list,
.lp-a4-3a-voice-content .trouble-list,
.lp-a4-3b-achieve-content .trouble-list,
.lp-a4-3b-download-content .trouble-list,
.lp-a4-3b-image .trouble-list,
.lp-a4-3b-price .trouble-list {
    padding: 34px;
    margin: auto;
    border: 1px solid #214793;
    background-color: #eeeff0;
    border-radius: 32px;
    width: 900px
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .trouble-list li,
.lp-a4-2-image-content .trouble-list li,
.lp-a4-2-point .trouble-list li,
.lp-a4-2-trouble-content .trouble-list li,
.lp-a4-3a-download-content .trouble-list li,
.lp-a4-3a-flow .trouble-list li,
.lp-a4-3a-voice-content .trouble-list li,
.lp-a4-3b-achieve-content .trouble-list li,
.lp-a4-3b-download-content .trouble-list li,
.lp-a4-3b-image .trouble-list li,
.lp-a4-3b-price .trouble-list li {
    font-weight: 700;
    font-size: 1.5rem;
    margin-bottom: 14px
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .trouble-list li .icon,
.lp-a4-2-image-content .trouble-list li .icon,
.lp-a4-2-point .trouble-list li .icon,
.lp-a4-2-trouble-content .trouble-list li .icon,
.lp-a4-3a-download-content .trouble-list li .icon,
.lp-a4-3a-flow .trouble-list li .icon,
.lp-a4-3a-voice-content .trouble-list li .icon,
.lp-a4-3b-achieve-content .trouble-list li .icon,
.lp-a4-3b-download-content .trouble-list li .icon,
.lp-a4-3b-image .trouble-list li .icon,
.lp-a4-3b-price .trouble-list li .icon {
    color: #214793;
    margin-right: 14px
}

.lp-a4-2-point {
    background-color: #618bde;
    color: #fff
}

.lp-a4-2-point .title {
    color: #fff;
    margin-bottom: 56px;
    font-family: M PLUS\ 1p, sans-serif
}

.lp-a4-2-point .point-block {
    filter: none;
    background-color: initial
}

.lp-a4-2-point .point-block .point-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px
}

.lp-a4-2-point .point-block .point-list li .title {
    text-align: left;
    font-size: 1.25rem;
    border-bottom: 1px solid #fff;
    margin-bottom: 14px;
    padding-bottom: 14px
}

.lp-a4-2-point .point-block .point-list li .text {
    color: #fff
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .title,
.lp-a4-2-image-content .title,
.lp-a4-3a-download-content .title,
.lp-a4-3a-flow .title,
.lp-a4-3a-voice-content .title,
.lp-a4-3b-achieve-content .title,
.lp-a4-3b-download-content .title,
.lp-a4-3b-image .title,
.lp-a4-3b-price .title {
    margin-bottom: 56px;
    font-family: M PLUS\ 1p, sans-serif
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .image-block .item-flex,
.lp-a4-2-image-content .image-block .item-flex,
.lp-a4-3a-download-content .image-block .item-flex,
.lp-a4-3a-flow .image-block .item-flex,
.lp-a4-3a-voice-content .image-block .item-flex,
.lp-a4-3b-achieve-content .image-block .item-flex,
.lp-a4-3b-download-content .image-block .item-flex,
.lp-a4-3b-image .image-block .item-flex,
.lp-a4-3b-price .image-block .item-flex {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-bottom: 48px
}

.lp-a4-2-feature-below .lp-a4-2-feature-below-content .image-block .item-flex .text-area .title,
.lp-a4-2-image-content .image-block .item-flex .text-area .title,
.lp-a4-3a-download-content .image-block .item-flex .text-area .title,
.lp-a4-3a-flow .image-block .item-flex .text-area .title,
.lp-a4-3a-voice-content .image-block .item-flex .text-area .title,
.lp-a4-3b-achieve-content .image-block .item-flex .text-area .title,
.lp-a4-3b-download-content .image-block .item-flex .text-area .title,
.lp-a4-3b-image .image-block .item-flex .text-area .title,
.lp-a4-3b-price .image-block .item-flex .text-area .title {
    text-align: left;
    font-size: 1.5rem;
    margin-bottom: 24px
}

.lp-a4-2-request {
    background-color: #f4f6fc
}

.lp-a4-2-request .lp-a4-2-request-content {
    padding-top: 56px
}

.lp-a4-2-request .lp-a4-2-request-content .request-flex {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 120px
}

.lp-a4-2-request .lp-a4-2-request-content .request-flex .item .title {
    text-align: center;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 14px
}

.lp-a4-2-request .lp-a4-2-request-content .request-flex .item .img {
    margin-bottom: 14px
}

.lp-a4-2-request .lp-a4-2-request-content .request-flex .item .btn a {
    margin: auto
}

.lp-a4-3a-main {
    background-position: 50%;
    background-size: cover;
    background-repeat: no-repeat
}

.lp-a4-3a-main-content .logo {
    font-size: 1.25rem
}

.lp-a4-3a-main-content .service-name {
    margin-bottom: 150px;
    text-align: center;
    font-weight: 700;
    font-size: 3rem
}

.a4-3a-main-btn a {
    margin: auto;
    width: 320px;
    padding: 14px
}

.lp-a4-3a-catch {
    padding-top: 56px;
    text-align: center
}

.lp-a4-3a-catch .catch-block .title {
    color: #214793;
    font-size: 2.5rem;
    font-weight: 700
}

.lp-a4-3a-catch .catch-block .sub-title {
    color: #214793;
    margin-bottom: 24px;
    font-size: 1.5rem;
    font-weight: 700
}

.lp-a4-3a-feature {
    background-color: #214793;
    padding: 24px 0
}

.lp-a4-3a-feature .feature-flex {
    display: grid;
    grid-template-columns: repeat(3, 1fr)
}

.lp-a4-3a-feature .feature-flex .item {
    text-align: center
}

.lp-a4-3a-feature .feature-flex .item img {
    margin-bottom: 8px
}

.lp-a4-3a-feature .feature-flex .item .title {
    color: #fff
}

.lp-a4-2-feature-below {
    background-color: #f4f6fc
}

.lp-a4-3a-voice-content .voice-block .voice-list {
    max-width: 700px;
    margin: auto
}

.lp-a4-3a-voice-content .voice-block .voice-list .item-flex {
    display: flex;
    align-items: center;
    margin-bottom: 24px
}

.lp-a4-3a-voice-content .voice-block .voice-list .item-flex .img-block {
    white-space: nowrap;
    text-align: center;
    padding-right: 14px;
    width: 150px
}

.lp-a4-3a-voice-content .voice-block .voice-list .item-flex .img-block img {
    margin-bottom: 8px;
    width: 100%
}

.lp-a4-3a-voice-content .voice-block .voice-list .item-flex .img-block .name-block {
    font-weight: 700;
    color: #214793
}

.lp-a4-3a-voice-content .voice-block .voice-list .item-flex .img-block .name-block .company {
    font-size: .875rem
}

.lp-a4-3a-voice-content .voice-block .voice-list .item-flex .balloon-block {
    width: 100%
}

.balloon2-left {
    margin-left: 24px;
    position: relative;
    display: inline-block;
    padding: 24px;
    max-width: 100%;
    font-size: 16px;
    background: #fff;
    border: 3px solid #214793;
    box-sizing: border-box;
    border-radius: 14px
}

.balloon2-left:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -24px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-right: 12px solid #fff;
    z-index: 2
}

.balloon2-left:after {
    content: "";
    position: absolute;
    top: 50%;
    left: -30px;
    margin-top: -14px;
    border: 14px solid transparent;
    border-right: 14px solid #214793;
    z-index: 1
}

.balloon2-left p {
    margin: 0;
    padding: 0
}

.lp-a4-3a-flow {
    background-color: #618bde;
    color: #fff
}

.lp-a4-3a-flow .flow-list li {
    display: flex;
    background-color: #fff;
    border-radius: 34px;
    padding: 24px 34px;
    max-width: 1000px;
    margin: 0 auto 24px
}

.lp-a4-3a-flow .flow-list li img {
    padding-right: 24px
}

.lp-a4-3a-flow .flow-list li .text-block .title {
    text-align: left;
    font-size: 1.25rem;
    color: #214793;
    display: inline-block;
    margin-bottom: 14px;
    position: relative
}

.lp-a4-3a-flow .flow-list li .text-block .title:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 2px;
    background-color: #214793;
    left: 0;
    bottom: -4px
}

.lp-a4-3a-flow .flow-list li .text-block .description {
    color: #403c3d
}

.lp-a4-3a-download-content .download-flex {
    display: flex;
    align-items: center
}

.lp-a4-3a-download-content .download-flex .img {
    padding-right: 14px;
    flex: 1
}

.lp-a4-3a-download-content .download-flex .text {
    padding-left: 14px;
    flex: 1
}

.lp-a4-3a-download-content .download-flex .text .logo {
    font-size: 1.25rem;
    margin-bottom: 100px;
    font-weight: 700
}

.lp-a4-3a-download-content .download-flex .text .service-name {
    font-weight: 700;
    font-size: 3rem;
    margin-bottom: 100px;
    text-align: center
}

.lp-a4-3b-main-content .main-img {
    max-height: 600px;
    overflow: hidden;
    height: 100%
}

.lp-a4-3b-main-content .main-img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.lp-a4-3b-about-content {
    padding-top: 56px
}

.lp-a4-3b-about-content .about-flex {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px
}

.lp-a4-3b-about-content .about-flex .text-area .title {
    color: #214793;
    font-size: 2rem;
    font-family: M PLUS\ 1p, sans-serif;
    margin-bottom: 34px;
    font-weight: 800
}

.lp-a4-3b-about-content .about-flex .img-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px
}

.lp-a4-3b-image {
    background-color: #618bde;
    color: #fff
}

.lp-a4-3b-image .image-block .image-list {
    max-width: 700px;
    margin: auto
}

.lp-a4-3b-image .image-block .image-list li {
    margin-bottom: 56px
}

.lp-a4-3b-image .image-block .image-list li .title {
    font-size: 1.25rem;
    margin-bottom: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid #fff
}

.lp-a4-3b-image .image-block .image-list li .description {
    margin-bottom: 34px
}

.lp-a4-3b-image .image-block .image-list li img {
    width: 100%
}

.lp-a4-3b-achieve-content .achieve-flex {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-bottom: 56px
}

.lp-a4-3b-achieve-content .achieve-flex .item {
    border-radius: 14px;
    overflow: hidden
}

.lp-a4-3b-achieve-content .achieve-flex .item .info {
    background-color: #f4f6fc;
    padding: 14px
}

.lp-a4-3b-achieve-content .achieve-flex .item .info .company-name {
    color: #618bde;
    margin-bottom: 8px
}

.lp-a4-3b-achieve-content .achieve-list-block .achieve-list {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 14px
}

.lp-a4-3b-price {
    background-color: #f4f6fc
}

.lp-a4-3b-price .price-flex {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px
}

.lp-a4-3b-price .price-flex .item {
    background-color: #fff;
    filter: drop-shadow(0 2px 3px rgba(0, 0, 0, .2))
}

.lp-a4-3b-price .price-flex .item .head {
    padding: 8px;
    text-align: center;
    background-color: #214793;
    color: #fff
}

.lp-a4-3b-price .price-flex .item .price {
    color: #fff;
    font-weight: 700;
    font-size: 3rem;
    text-align: center;
    padding: 14px
}

.lp-a4-3b-price .price-flex .item .price.green {
    background-color: #9cd085
}

.lp-a4-3b-price .price-flex .item .price.blue {
    background-color: #5596ff
}

.lp-a4-3b-price .price-flex .item .price.orange {
    background-color: #f2c776
}

.lp-a4-3b-price .price-flex .item .price .month {
    margin-left: 14px;
    font-size: .875rem;
    font-weight: 400
}

.lp-a4-3b-price .price-flex .item .description-list {
    padding: 16px
}

.lp-a4-3b-price .price-flex .item .description-list p {
    padding: 8px
}

.lp-a4-3b-price .price-flex .item .description-list p:nth-of-type(2n) {
    background-color: #f4f4f4
}

.lp-a4-3b-download-content .download-form {
    border-radius: 16px;
    border-color: #214793
}

.lp-a4-3b-download-content .download-form .a4-3a-main-btn {
    margin-top: 16px
}

.main-btns {
    display: flex;
    gap: 14px;
    justify-content: center
}

.main-btns .btn-above {
    text-align: center;
    font-size: .875rem
}

.conversion-btn,
.conversion-btn-green {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px 34px;
    background-color: #618bde;
    border-radius: 8px;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    width: 250px
}

.conversion-btn-green .icon,
.conversion-btn .icon {
    font-size: 1.75rem;
    margin-right: 8px
}

.conversion-btn-green {
    background-color: #57ba63
}

.sdgs-header {
    text-align: center;
    padding: 16px;
    filter: drop-shadow(0 2px 3px rgba(0, 0, 0, .2));
    background-color: #fff;
    position: fixed;
    width: 100%;
    z-index: 105
}

.sdgs-main-content {
    padding-top: 150px
}

.sdgs-main-content .logo {
    text-align: center;
    margin-bottom: 50px
}

.sdgs-main-content .sdgs-icon-grid {
    padding: 0 4%;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    line-height: 0;
    gap: 16px
}

.sdgs-main-content .sdgs-icon-grid img {
    filter: drop-shadow(0 2px 3px rgba(0, 0, 0, .2))
}

.sdgs-about-blcok {
    max-width: 800px;
    width: 100%;
    background-color: #eeeff0;
    margin: auto;
    padding: 34px
}

.sdgs-about-blcok .about-title {
    font-size: 2rem;
    margin-bottom: 24px;
    color: #2c6277;
    text-align: center
}

.sdgs-about-blcok .about-text {
    font-size: .875rem
}

.sdgs-mission {
    padding-top: 80px;
    background-color: #edf8fc
}

.sdgs-mission .sdgs-mission-content {
    text-align: center
}

.sdgs-mission .sdgs-mission-content .mission-title {
    margin-bottom: 34px
}

.sdgs-mission2-content {
    padding-top: 80px
}

.mission2-flex {
    display: flex;
    margin-bottom: 80px
}

.mission2-flex .item-image img {
    max-width: 330px
}

.mission2-flex .item-text {
    padding-left: 50px
}

.mission2-flex .item-text .item-title {
    font-size: 1.5rem;
    margin-bottom: 24px
}

.mission2-flex .item-text .item-title-above {
    padding-top: 24px;
    padding-bottom: 16px;
    margin-bottom: 34px;
    border-bottom: 1px solid #403c3d;
    text-align: center;
    font-size: 1.25rem
}

.mission2-flex .item-text .description {
    margin-bottom: 34px
}

.mission2-flex .item-text .title-1 {
    color: #e4011e
}

.mission2-flex .item-text .title-2 {
    color: #1b973a
}

.mission2-flex .item-text .title-3 {
    color: #d39206
}

.mission2-flex .item-text .attempt-block {
    font-weight: 700;
    color: #2c6277
}

.mission2-flex .item-text .attempt-block .attempt-title {
    font-size: 1.25rem
}

.mission2-flex .item-text .attempt-block .attempt-list {
    padding-left: 24px
}

.mission2-flex .item-text .attempt-block .attempt-list li {
    margin-bottom: 16px
}

.mission2-flex:nth-of-type(2) .item-image {
    order: 2;
    padding-left: 50px
}

.mission2-flex:nth-of-type(2) .item-text {
    order: 1;
    padding-left: 0
}

.tngw-header {
    background-color: #fff;
    filter: drop-shadow(0 2px 3px rgba(64, 60, 61, .2));
    position: fixed;
    width: 100%;
    z-index: 105
}

.tngw-header-content {
    padding: 16px 4%
}

.tngw-lp .tngw-lp-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 48px
}

.tngw-header-flex {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.tngw-header-flex .logo {
    width: 270px;
    -o-object-fit: contain;
    object-fit: contain
}

.tngw-header-flex .login .login-btn {
    margin: 0;
    width: 250px;
    text-align: center
}

.tngw-main {
    background-color: #edf8fc
}

.tngw-main .tngw-main-content .tngw-main-flex {
    display: flex
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column {
    padding: 180px 34px 120px 4%;
    flex: 1
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column .main-title-block {
    position: relative;
    padding-top: 120px
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column .main-title-block .main-title {
    color: #2c6277;
    white-space: nowrap;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column .title-under {
    margin-bottom: 80px
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column .feature-grid {
    max-width: 500px;
    margin: auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column .feature-grid .item {
    text-align: center
}

.tngw-main .tngw-main-content .tngw-main-flex .left-column .feature-grid .item .title {
    font-weight: 700
}

.tngw-main .tngw-main-content .tngw-main-flex .right-column {
    flex: 1;
    position: relative;
    background-color: #fff
}

.tngw-main .tngw-main-content .tngw-main-flex .right-column p {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.tngw-about-content {
    padding-top: 80px
}

.tngw-about-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 48px
}

.tngw-about-content .about-image {
    margin-bottom: 34px
}

.tngw-about-content .about-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    max-width: 700px;
    margin: auto
}

.tngw-about-content .about-grid .item {
    border: 1px solid #403c3d;
    padding: 24px;
    position: relative
}

.tngw-about-content .about-grid .item img {
    margin-bottom: 8px
}

.tngw-about-content .about-grid .item .description {
    margin-bottom: 16px
}

.tngw-about-content .about-grid .item .item-title {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 8px
}

.tngw-about-content .about-grid .item .item-title.owner {
    color: #7fbbd2
}

.tngw-about-content .about-grid .item .item-title.responsible {
    color: #72cea3
}

.tngw-about-content .about-grid .item .detail-link {
    position: absolute;
    bottom: -24px;
    left: 8px;
    padding: 12px 24px;
    border-radius: 24px;
    text-decoration: none;
    color: #fff
}

.tngw-about-content .about-grid .item .detail-link span {
    padding-right: 16px
}

.tngw-about-content .about-grid .item .detail-link.owner {
    background-color: #7fbbd2
}

.tngw-about-content .about-grid .item .detail-link.responsible {
    background-color: #72cea3
}

.tngw-trouble {
    background-color: #edf8fc
}

.tngw-trouble .tngw-trouble-content {
    padding-top: 80px
}

.tngw-trouble .tngw-trouble-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 16px
}

.tngw-trouble .tngw-trouble-content .title-under {
    text-align: center;
    font-size: 1.25rem;
    margin-bottom: 48px
}

.tngw-trouble .tngw-trouble-content .trouble-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px
}

.tngw-trouble .tngw-trouble-content .trouble-grid .item {
    padding: 24px;
    background-color: #fff;
    filter: drop-shadow(0 2px 3px rgba(64, 60, 61, .2))
}

.tngw-trouble .tngw-trouble-content .trouble-grid .item img {
    margin-bottom: 8px
}

.tngw-trouble .tngw-trouble-content .trouble-grid .item .item-title {
    font-weight: 700;
    color: #2c6277;
    margin-bottom: 16px;
    font-size: 1.25rem;
    text-align: center
}

.tngw-solution-content {
    padding-top: 80px
}

.tngw-solution-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 48px
}

.tngw-solution-content .solution-list .item-flex {
    padding: 24px;
    border: 1px solid #403c3d;
    display: flex;
    margin-bottom: 34px
}

.tngw-solution-content .solution-list .item-flex .left-column {
    flex: 1
}

.tngw-solution-content .solution-list .item-flex .right-column {
    flex: 3;
    padding-left: 38px
}

.tngw-solution-content .solution-list .item-flex .right-column .item-title {
    font-size: 1.25rem;
    color: #2c6277;
    margin-bottom: 16px;
    font-weight: 700
}

.tngw-owner-service-content .owner-service-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px
}

.tngw-owner-service-content .owner-service-list .item {
    background-color: #7fbbd2;
    display: flex;
    padding: 14px 24px;
    align-items: center
}

.tngw-owner-service-content .owner-service-list .item .img {
    flex: 1;
    padding-right: 24px
}

.tngw-owner-service-content .owner-service-list .item .name {
    white-space: nowrap;
    flex: 3;
    color: #fff;
    font-weight: 700;
    font-size: 1.5rem
}

.tngw-voice {
    background-color: #edf8fc
}

.tngw-voice .tngw-voice-content {
    padding-top: 80px
}

.tngw-voice .tngw-voice-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 48px
}

.tngw-voice .tngw-voice-content .voice-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 34px
}

.tngw-voice .tngw-voice-content .voice-grid .item img {
    margin-bottom: 8px
}

.tngw-voice .tngw-voice-content .voice-grid .item .item-title {
    font-weight: 700;
    color: #2c6277;
    font-size: 1.25rem;
    margin-bottom: 16px
}

.tngw-voice .tngw-voice-content .voice-grid .item .voice {
    font-size: 1.25rem;
    margin-bottom: 16px
}

.tngw-flow-content {
    padding-top: 80px
}

.tngw-flow-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 48px
}

.flow-list li {
    padding: 32px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative
}

@media screen and (max-width:576px) {
    .flow-list li {
        flex-direction: column;
        padding: 32px 8px
    }
}

.flow-list li:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-20%);
    margin-left: -15px;
    border: 32px solid transparent;
    z-index: 1
}

@media screen and (max-width:576px) {
    .flow-list li:before {
        border: 24px solid transparent
    }
}

.flow-list li.one {
    background-color: #7fbbd2
}

.flow-list li.one:before {
    border-top: 32px solid #7fbbd2
}

@media screen and (max-width:576px) {
    .flow-list li.one:before {
        border-top: 24px solid #7fbbd2
    }
}

.flow-list li.two {
    background-color: #b1daea
}

.flow-list li.two:before {
    border-top: 32px solid #b1daea
}

@media screen and (max-width:576px) {
    .flow-list li.two:before {
        border-top: 24px solid #b1daea
    }
}

.flow-list li.three {
    background-color: #7fd2a9
}

.flow-list li .num-block {
    flex: 1;
    text-align: right;
    padding-right: 50px
}

@media screen and (max-width:576px) {
    .flow-list li .num-block {
        padding-right: 0;
        margin-bottom: 8px
    }
}

.flow-list li .num-block .maru-num {
    display: inline-block;
    background-color: #fff;
    border-radius: 50%;
    width: 64px;
    height: 64px;
    position: relative
}

.flow-list li .num-block .maru-num.one,
.flow-list li .num-block .maru-num.three,
.flow-list li .num-block .maru-num.two {
    color: #2c6277
}

.flow-list li .num-block .maru-num .center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

.flow-list li .num-block .maru-num .step {
    font-size: .75rem;
    text-align: center;
    line-height: 1
}

.flow-list li .num-block .maru-num .num {
    text-align: center;
    font-size: 1.75rem;
    line-height: 1;
    font-weight: 700
}

.flow-list li .info-block {
    flex: 4;
    color: #fff;
    padding-right: 8px
}

@media screen and (max-width:576px) {
    .flow-list li .info-block {
        padding-right: 0;
        margin-bottom: 8px
    }
}

.flow-list li .info-block a {
    color: #fff;
    text-decoration: underline;
    font-size: .875rem
}

.flow-list li .info-block .step-title {
    font-size: 1.25rem;
    margin-bottom: 8px
}

@media screen and (max-width:576px) {
    .flow-list li .info-block .step-title {
        text-align: center
    }
}

.flow-list li .info-block .description {
    font-size: .875rem
}

.tngw-register-content .title {
    font-size: 2.375rem;
    color: #2c6277;
    text-align: center;
    margin-bottom: 48px
}

.tngw-register-content .login-form {
    border: none
}

.tab-panel {
    max-width: 700px;
    margin: auto
}

.tab-group {
    display: flex;
    justify-content: center
}

.tab {
    flex-grow: 1;
    padding: 5px;
    list-style: none;
    text-align: center;
    cursor: pointer;
    background-color: #d2d2d2;
    color: #fff
}

.panel-group {
    border: 1px solid #7fbbd2;
    border-top: none;
    background: #fff
}

.panel {
    display: none
}

.tab.is-active {
    background: #7fbbd2;
    color: #fff;
    transition: all .2s ease-out
}

.tab.is-active.green {
    background-color: #7fd2a9
}

.panel.is-show {
    display: block
}

.footer-fixed {
    background-color: #edf8fc;
    position: fixed;
    width: 100%;
    padding: 24px;
    filter: drop-shadow(0 -2px 3px rgba(64, 60, 61, .2));
    text-align: center;
    bottom: 0;
    left: 0;
    z-index: 5
}

.footer-fixed.hidden {
    display: none
}

.footer-fixed .register-btn-block .title {
    font-size: 1.25rem;
    margin-bottom: 16px;
    color: #2c6277;
    font-weight: 700
}

.footer-fixed .register-btn-block .register-btn {
    background-color: #7fbbd2;
    border-radius: 34px;
    color: #fff;
    display: block;
    margin: auto;
    filter: drop-shadow(0 2px 3px rgba(64, 60, 61, .2));
    justify-content: space-between;
    width: 350px;
    padding: 12px;
    font-size: 1.25rem;
    position: relative
}

.footer-fixed .register-btn-block .register-btn .icon {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%)
}

.code-link {
    text-align: right
}

.code-link .code-link-inner {
    display: inline-block;
    cursor: pointer;
    font-size: .75rem
}

.code-link .code-input {
    margin-right: 0;
    margin-left: auto;
    padding: 5px;
    border-radius: 5px;
    background-color: #eeeff0;
    border: 1px solid #a0a0a0
}

.code-link .code-input::-moz-placeholder {
    color: #a0a0a0;
    font-size: .875rem
}

.code-link .code-input:-ms-input-placeholder {
    color: #a0a0a0;
    font-size: .875rem
}

.code-link .code-input::placeholder {
    color: #a0a0a0;
    font-size: .875rem
}

.footer {
    position: relative;
    z-index: 1;
    background-color: #214793;
    color: #fff;
    font-size: .75rem;
    padding-top: 15px;
    padding-bottom: 15px
}

.footer-bottom {
    text-align: center
}