@charset "utf-8";
/*====================================================================
INFORMATION
====================================================================*/

body {
    font-family: "Noto Sans JP", sans-serif;
    color: #333333;
    padding-top: 74px;
}

section {
    clear: both;
    width: 100%;
    padding: 0 0 0 0;
    position: relative;
}

h2 {
    font-size: clamp(24px, 3vw, 29px);
    font-weight: bold;
    text-align: center;
    margin-bottom: 12px;
    color: #333333;
    line-height: 1.4;
}

h3 {
    font-size: clamp(22px, 2.4vw, 26px);
    font-weight: bold;
    text-align: center;
    margin-bottom: 12px;
    color: #333333;
    line-height: 1.4;
}

h4 {
    font-size: clamp(18px, 2vw, 22px);
    font-weight: bold;
    text-align: center;
    margin-bottom: 12px;
    color: #333333;
    line-height: 1.4;
}

h5 {
    font-size: clamp(16px, 1.8vw, 18px);

    text-align: center;
    margin-bottom: 12px;
    line-height: 1.4;
}

p{
  font-size: clamp(14px, 1.5vw, 16px);  
}

a {
    text-decoration: none;
}

a.nav-link {
    color: #0660df;
}

a:hover {
    color: #35b1e3;
    text-decoration: underline;
}

.red {
    color: red;
}

.container {
    position: relative;
    z-index: 1;
}

.container-r {
    padding: 60px 10px;
}

@media screen and (max-width: 767px) {
    section {
        clear: both;
        width: 100%;
        padding: 30px 0;
        position: relative;
    }

    .last-item {
        display: none !important;
    }
    h2 {
        font-size: calc((24 / 390) * 100vw);
    }
    h3 {
        font-size: calc((20 / 390) * 100vw);
    }
    h4 {
        font-size: calc((18 / 390) * 100vw);
    }
    h5 {
        font-size: calc((16 / 390) * 100vw);
    }
}

.unlink {
    pointer-events: none;
    cursor: pointer;
}

img {
    max-width: 100%;
    height: auto;
}

.mb48 {
    margin-bottom: 48px;
}


/* ------------------------------
000: 見出し
 ------------------------------ */
.desc {
    clear: both;
    text-align: center;
    padding: 24px 0;
}

.desc p {
   font-size: clamp(14px, 1.6vw, 18px);
}

blockquote {
    position: relative;
    padding: 5px 15px 5px 55px;
    box-sizing: border-box;
    font-style: italic;
    color: #464646;
    background: #fff;
    max-width: 680px;
    margin: 0 auto;
}

blockquote:before {
    display: inline-block;
    position: absolute;
    top: 0;
    left: 8px;
    width: 38px;
    height: 30px;
    vertical-align: middle;
    text-align: center;
    content: "\f10d";
    font-family: FontAwesome;
    color: #fff;
   font-size: clamp(14px, 1.6vw, 18px);
    line-height: 30px;
    background: #e77817;
    font-weight: 900;
}

blockquote:after {
    content: "";
    position: absolute;
    left: 8px;
    top: 30px;
    height: 0;
    width: 0;
    border-left: 19px solid #ff785b;
    border-right: 19px solid #ff785b;
    border-bottom: 10px solid transparent;
}

.quote23 blockquote p {
    position: relative;
    padding: 0;
    margin: 10px 0;
    z-index: 3;
    line-height: 1.7;
}

blockquote cite {
    display: block;
    text-align: right;
    color: #888888;
   font-size: clamp(10px, 1vw, 12px);
}








/* ------------------------------
 button
 ------------------------------ */
.button-wrapper {
    clear: both;
    position: relative;
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
    padding: 24px 0;
}

.button {
    display: block;
    position: relative;
    width: 100%;
    border-width: 1px;
    border-style: solid;
    padding: 15px;
    font-size: clamp(14px, 1.6vw, 18px);
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
    border-color: #52c2b4;
    background-color: #52c2b4;
    color: white;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    -webkit-border-radius: 14px;
    -moz-border-radius: 14px;
    border-radius: 14px;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.20);
}

.button:after {
    content: "\f105";
    font-family: FontAwesome;
    font-style: normal;
   font-size: clamp(12px, 1.2vw, 14px);
    color: #fff;
    right: 25px;
        line-height: 1.5;
    position: absolute;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;

}

.button:hover:after {
    right: 15px;

}
.button:hover {
  filter: brightness(110%);
  text-decoration: none;
  color: #fff;
}

/* ------------------------------
001: Header
 ------------------------------ */
#header2,
#header {
  padding: 100px 0;
  max-width: 100%;
  margin: 0 auto;
  background-image: url(../images/bg-header-support.jpg);
  background-repeat: no-repeat;
  background-size: cover;
}
#header2 h2 br,
#header h2 br{
    display: none;
}
#header .logo {
    width: 210px;
}

#header h1 {}

#header2 h2,
#header h2 {
    font-size: clamp(24px, 3.4vw, 32px);
    line-height: 1.6;
    font-weight: bold;
    color: #333333;
    margin-bottom: 0;
}

#search {}

.screen-reader-text {
    display: none;
}

#result {
    padding: 30px 0;
}

.result-num {
    text-align: center;
    padding: 10px;
    margin-top: -20px;
}

#result ul {
    margin: 10px 0;
    padding: 30px;
    background: #fff;
}

#result ul li {
    list-style-type: none;
    padding-left: 45px;
    position: relative;
    line-height: 2;
    color: #888888;
    border-top: 1px dotted #cdd6d9;
    padding: 10px 10px 10px 45px;
    background-image: url(/assets/images/Q.png);
    background-repeat: no-repeat;
    background-size: 24px;
    background-position: 10px center;
}

#result ul li:last-child {
    border-bottom: 1px dotted #cdd6d9;
}

#result ul li span {
   font-size: clamp(12px, 1.2vw, 14px);
}

/*
#result ul li:before{
    position: absolute;
    left: 26px;
    top: 0;
    content: "Ⓠ";
}*/
#faq {
    clear: both;

    border-top: none !important;
    margin-bottom: 60px;
}

@media screen and (max-width: 767px) {
    #header,
    #header2{
      padding: 60px 0;
    }
    #header h2 {
        font-size: 24px;
        font-size: 2.4rem;
        font-weight: bold;
    }
    #header2 h2 br,
    #header h2 br{
        display: block;
    }

}

#s {
    width: 360px;
    height: 40px;
    border: none;

    padding: 10px;

    background-color: #fff;
    -webkit-appearance: none;
    border-radius: 0;
    outline: none;
    border: 1px solid #333333;
    border-radius:8px;
}

#searchsubmit {
    background-color: #71DBCC;
    color: #fff;
    outline: 0;

    top: 0;
    _top: 1px;
    left: 288px;
    font-size: 11px;
    font-size: 1.1rem;
    border: none;
    -webkit-appearance: none;
    border-radius: 0;
    height: 40px;
    padding: 0 20px;
    font-family: FontAwesome;
    font-size: clamp(18px, 2vw, 24px);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: 20px;
}

.center-search-form {

    padding: 30px 15px;
}


#searchform {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
}

.popup-modal-dismiss {
    max-width: 220px;
    margin: 0 auto;
    padding: 60px 0;
    position: relative;
}

.popup-modal-dismiss a {
    display: block;
    padding: 10px 30px;
    background-color: #fff;
    color: #3d3d37;
    border: 1px solid #3d3d37;
    border-radius: 0;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    position: relative;
}

.popup-modal-dismiss a:hover {
    background-color: #3d3d37;
    color: #fff;
}

.popup-modal-dismiss a span {
    display: inline-block;
    width: 14px;
    height: 14px;
    background: url(/assets/images/icon-close.png);
    background-repeat: no-repeat;
    position: absolute;
    left: 10px;
    background-size: cover;
    top: 12px;
}

.popup-modal-dismiss a:hover span {
    background: url(/assets/images/icon-close-hover.png);
}

.button-wrapper {
    margin-right: 0;
    margin-left: auto;
}

.faq-block h2 {
    text-align: left;
    letter-spacing: 0;
}

.category-name {
    font-size: clamp(12px, 1.2vw, 14px);
    font-size: 1.2rem;
    color: #888888;
    border-bottom: 1px dotted #ecf0f1;
    padding-bottom: 6px;
}

#faq.result {
    padding: 0 0 30px 0;
    background-color: #fff;
    margin-bottom: 40px;

    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

#faq.result .single {
    margin: 10px 0;
    padding: 30px;
    background: #fff;
}

#faq.result .faq-block h2 {
    padding: 15px;
    border: 2px solid #707070;
    border-radius: 10px;
    width: 70%;
    margin-left: 50px;
    display: inline-block;
    position: relative;
    font-family: "HuiFontP109";
    font-size: clamp(16px, 1.6vw, 18px);
}

#faq.result .accordion-content {
    margin-left: 10px;
    padding: 0 0 0 0;
    background-position: left top;
}

@media (max-width: 768px) {
    #searchform {
        width: 310px;
    }
}

/* ------------------------------
 Footer
 ------------------------------ */
#footer {
    text-align: center;
    padding: 0 0 0 0;

    background: white;
    position: relative;
}

#copy {
    text-align: center;
    padding: 10px;
    padding-bottom: 120px;
}

#copy p {
    font-size: 11px;
    font-size: 1.1rem;
}

#footer p {}

.footer-nav {
    padding: 30px 0;
}

.footer-nav ul {
    padding: 0 0 0 0;
    margin: 0 0 0 0;

    display: -moz-flex;
    display: -webkit-flex;
    display: -o-flex;
    display: -ms-flex;
    flex-wrap: wrap;
    display: flex;
    justify-content: space-around;
    align-items: center;
}

.footer-nav ul li {
    list-style: none;
    position: relative;
}

.footer-nav ul li a {
  color: #333333;
  padding: 5px 0px;
  display: block;
  position: relative;
   font-size: clamp(12px, 1.4vw, 16px);
}
.footer-nav ul li a::after {
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  content: "";
  width: 0%;
  height: 2px;
  background: #FF94A6;
  transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.footer-nav ul li a:hover::after {
  width: 100%;
}

.footer-nav ul li a:hover {
  text-decoration: none;
}

.footer-logo {
  width: 140px;
  margin: 0 auto;
}


.page-top {
    display: none;
    max-width: 80px;
    margin: 0 auto;
    position: relative;
    top: -50px;
}

.page-top a {
    display: block;
    border: 2px solid #333333;
    padding: 15px 10px;
    background-color: #edf0f4;
    font-size: 15px;
    text-decoration: none;
    color: #333333;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    border-radius: 50%;
    font-weight: 700;
    background-color: #3691CC;
    width: 80px;
    height: 80px;
    text-align: center;
}

.page-top a:hover {
    filter: brightness(110%);
}

.arrow-top {
    margin: 0 auto;
    line-height: 1;
}

.arrow-top img {
    display: block;
    width: 100%;
}

.page-top a:hover>.arrow-top img {
    -webkit-filter: brightness(800);
    -moz-filter: brightness(800);
    -o-filter: brightness(800);
    -ms-filter: brightness(800);
    filter: brightness(800);
}

#gotobuy {
    position: fixed;
    bottom: -140px;
    right: 20px;
    z-index: 13;
    width: 100px;
    display: none;
}

#gotobuy a,
#gotobuy span {
    display: block;
    color: #3d3d37;
    font-size: clamp(12px, 1.2vw, 14px);
    text-align: center;
}

#gotobuy a:hover,
#gotobuy a:hover>span {
    color: #0660df;
}

@media screen and (max-width: 1099px) {}

@media screen and (max-width: 991px) {}

@media screen and (max-width: 768px) {

    #gotobuy a,
    #gotobuy span {
        font-size: clamp(10px, 1vw, 12px);
    }

    .footer-nav ul {
        display: block;
        max-width: 90%;
        text-align: center;
        margin: 0 auto;
    }

    .footer-nav ul li {
        padding: 0px 15px;
        display: inline-block;
        text-align: left;
    }

    #gotobuy {
        width: 70px;
    }

    #gotobuy a {
        font-size: clamp(10px, 1vw, 12px);
    }

    .page-top {
        max-width: 62px;
        top: -42px;
    }

    .page-top a {}

    .footer-nav ul li {
        display: block;
    }
}

@media screen and (max-width: 480px) {}

/* リニューアル用調整 */

#copy,
#footer {}

.footer-nav {
    padding: 30px 0 10px 0;
}

@media screen and (max-width: 767px) {
    #copy {
        text-align: center;
    }
}

/* ------------------------------
 タイトル
 ------------------------------ */
.title {
    text-align: center;
}

.title p {
    color: #1e272e;
    font-size: clamp(16px, 1.8vw, 18px);
    font-size: 1.8rem;
    line-height: 1.8;
}

/* ------------------------------
 タイトル
 ------------------------------ */

#service-right h3 {
    text-align: left;
    color: #1e272e;
}

#service-right h3 span {
    color: #e77817;
}

.service-list {
    margin: 12px 0;
}

.service-list ul {
    background-color: #fff;
    border: 1px solid #ffdbbb;
    border-radius: 6px;
    padding: 0 0 0 0;
}

.service-list ul li {
    font-size: clamp(12px, 1.2vw, 14px);
    font-weight: 400;
    line-height: 1.5833333333;
    border-left: 1px solid #ffdbbb;

    position: relative;
    width: calc(100% / 3);
    float: left;
    list-style: none;
    padding: 20px;
}

.service-list ul li:first-child {
    border-left: none;
}

.service-list ul li h5,
.service-list ul li i {
    color: #e77817;
}

.service-list ul li i {
    font-size: 24px;
    font-size: 2.4rem;
    padding-bottom: 12px;
}

.merit {
    padding-bottom: 24px;
}

.merit p img {
    max-width: 140px;
    margin: 0 auto;
}

.merit h5 {
    margin: 24px 0;
}

.video-meetings {
    margin-bottom: 100px;
}

@media screen and (max-width: 767px) {
    .service-list ul li {
        padding: 10px;
    }
}

/* ------------------------------
 利用規約 & プライバシーポリシー
 ------------------------------ */
#legal,
#terms,
#privacy,
#agreement {
    margin-top: 40px;
}

#legal h1,
#faq h1,
#privacy h1,
#terms h1,
#agreement h1 {
    text-align: center;
    font-size: 28px;
    font-size: 2.8rem;
    margin-bottom: 24px;
}

#legal h2,
#privacy h2,
#agreement h2 {
    text-align: left;
    font-size: clamp(16px, 1.8vw, 18px);
    font-size: 1.8rem;
    margin-bottom: 12px;
}

.legal-block,
.privacy-block,
.terms-block .agreement-block {

}
.terms-block,
.legal-block{
    margin-bottom: 40px;
}
.legal-block .ttl,
.terms-block .ttl{
    margin-bottom: 20px;
    margin-left: 10px;
}

.legal-block h3,
.privacy-block h3,
.terms-block h3,
.agreement-block h3 {
    text-align: left;
    font-size: clamp(16px, 1.8vw, 18px);
    font-size: 1.8rem;
    margin-bottom: 0;
    color: #333333;
    padding: 10px 0;
    border-bottom: 1px solid #969696;
    line-height: 1;
}


.legal-block h3:before,
.privacy-block h3:before,
.terms-block h3:before,
.agreement-block h3:before {
    content: "";
    display: inline-block;
    background-color: #ffaeb8;
    width: 4px;
    height: 1.2em;
    margin-right: 8px;
    vertical-align: middle;
    margin-left: -8px;
    margin-top: -4px;

}



.agreement-block>p {
    margin-bottom: 15px;
}

#legal ul,
#privacy ul,
#terms ul,
#agreement ul {
    padding-left: 0px;
}

#legal ul li,
#privacy ul li,
#terms ul li,
#agreement ul li {
    list-style-type: none;
}

#legal ol,
#privacy ol,
#terms ol,
#agreement ol {
    padding-left: 20px;
}

#legal ol {
    padding-left: 28px;
}

/*
#legal ol{
  padding-left: 0;
  list-style-position: inside;
}*/

#terms h1 {
    text-align: center;
    font-size: 24px;
    font-size: 2.4rem;
    margin-bottom: 24px;
}

.terms-block {
    margin-bottom: 36px;
}

#terms ul {
    padding-left: 0px;
}

#terms ul li {
    list-style-type: none;
}

#terms ol {
    padding-left: 20px;
}

.table.table-policy {
    border-right: 1px solid #e8e8e8;
}

.table.table-policy td {
    border-top: 1px solid #e8e8e8;
    border-left: 1px solid #e8e8e8;
    border-bottom: 1px solid #e8e8e8;
    text-align: left;
}

.table.table-policy td:first-child {
    background-color: #f5f5f5;
    width: 20%;
    min-width: 200px;
}

.legal-block table.table {
    margin: 15px auto 10px auto;
}

.legal-block table.table td {
    text-align: left;
}

.legal-block p.small {
    margin-bottom: 20px;
    line-height: 1.4;
}

.legal-block table.table-bordered>thead>tr>th,
.legal-block table.table-bordered>tbody>tr>th,
.legal-block table.table-bordered>tfoot>tr>th,
.legal-block table.table-bordered>thead>tr>td,
.legal-block table.table-bordered>tbody>tr>td,
.legal-block table.table-bordered>tfoot>tr>td {
    border-top: 1px solid #5e5d55;
    border-left: 1px solid #5e5d55;
    border-bottom: 1px solid #5e5d55;
    border-right: 1px solid #5e5d55;
}

/* ------------------------------
 FAQ
 ------------------------------ */
#faq {}

#faq .container {
    max-width: 820px;
    margin:0 auto;
}

.accordion {
    width: 100%;
    margin: 0 auto;
}

#faq .accordion h1,
#faq .accordion h2,
#faq .accordion h3,
#faq .accordion h4 {
    cursor: pointer;
    margin: 0 0 0 0;
    margin-bottom: 0 !important;
    text-align: left;
    color: #fff;
    border-radius: 40px;

}

#faq .accordion h1 {
display: block;
    position: relative;
    width: 100%;
    border-width: 1px;
    border-style: solid;
    padding: 15px;
    font-size: clamp(14px, 1.6vw, 18px);
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
    border-color: #52c2b4;
    background-color: #52c2b4;
    color: white;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    -webkit-border-radius: 14px;
    -moz-border-radius: 14px;
    border-radius: 14px;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.20);
}

#faq .accordion div {
    display: none;
    padding: 20px 0;
    padding-bottom: 30px;
}

#faq .accordion div.faq-text-wrap {
    display: flex !important;
    width: 100%;
}

#faq .accordion div.faq-text {
    display: flex !important;
    align-items: center;
    padding: 15px;
}

#faq .accordion h2,
#faq .accordion h3,
#faq .accordion h4 {
    padding: 20px 0;
    font-size: clamp(14px, 1.6vw, 16px);
    font-weight: normal;
    color: #333333;
}

#faq .accordion h1,
#faq .accordion h2,
#faq .accordion h3,
#faq .accordion h4 {
    position: relative;
    padding-left: 15px;
}

#faq .accordion h2 {}

#faq .accordion h1:before {}

#faq .accordion h1:before {
    font-family: "fontawesome";
    content: "\f078";
    position: absolute;
    right: 25px;

    transition: all 0.2s ease-in-out;
    display: block;
    width: 8px;
    height: 8px;
    font-size: clamp(14px, 1.4vw, 16px);
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
}

#faq .accordion h1.dropdown_toggle:before {}



#faq .accordion-content {
    padding: 15px 0px;
    padding-left: 45px;
    position: relative;
}

/*#faq .accordion-content:before{
  position: absolute;
  left: 26px;
  top: 15px;
  content: "Ⓐ";
}*/

#faq .accordion-content {}


.faq-block aside h2:before {
    position: absolute;
    content: "";
    border: 10px solid transparent;
    border-right: 10px solid #707070;
    top: 15px;
    left: 10px;
}

.faq-block aside h2:after {
    position: absolute;
    content: "";
    border: 10px solid transparent;
    border-right: 10px solid #fff;
    top: 15px;
    left: -18px;
    margin-left: 0;
    z-index: 10;
}

.accordion .opened-for-codepen {
    display: block;
}

ul.navbar-nav {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    width: 100%;
    display: inline-block;
    display: flex;
    justify-content: center;
    align-items: center;
}

.navbar-nav li {
    list-style-type: none;
}

.faq-block .navbar-nav li {
    position: relative;
    text-align: left;
    list-style-type: none;

    margin: 0 15px;
}

.faq-block .navbar-nav li a {
    display: inline-block;
    border-width: 2px;
    border-style: solid;
    padding: 20px 30px;
    font-size: clamp(14px, 1.4vw, 16px);
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
    text-align: center;
    color: #333333;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    text-decoration: none;
    border-radius: 4px;
    border-color: #3691CC;
    background-color: transparent;
    display: block;
    max-width: 240px;
    margin: 10px auto;
}

.faq-block .navbar-nav li a:hover {
    color: #0660df;
    text-decoration: none;
}

.faq-thum {
    margin: 15px auto;
}

.faq-thum img {
    display: block;
    max-width: 100%;
    height: auto;
}


#faq .accordion h2 {

}

#faq .navbar {
    margin-bottom: 40px;

}

#faq .accordion h1 {


    margin-bottom: 20px !important;
}

.q-icon {
    clear: both;
    float: left;
    width: 20%;
    max-width: 100px;
    margin-right: 40px;
}

.accordion-content .q-icon {}

#faq .accordion div.faq-text-wrap {
    padding: 0 0 0 0;
    padding-bottom: 20px;
}

#faq .accordion div.faq-tex {
    padding: 15px;
    border: 2px solid #707070;
    border-radius: 10px;
    width: 70%;
    margin-left: 100px;

    display: inline-block;
    position: relative;
}

.faq-text p {}

.faq-text {
    margin-left: auto;
    margin-right: 50px;
}

.accordion-content {
    display: flex;
}

.accordion-content p.q-icon {
    margin-right: 0;
}

.accordion-content p.q-icon::before,
.accordion-content p.q-icon::after {
    display: none;
}

.accordion-content p.q-icon {
    padding: 0;
    border: none;
    border-radius: 10px;
    width: 100%;
    margin-left: 0px;
    display: inline-block;
    position: relative;
    float: right;
    margin-left: 0px;
}

.accordion h2 {}

.accordion h2 {
    padding: 15px;
    border: 2px solid #707070;
    border-radius: 10px;

    margin-left: 50px;

    display: inline-block;
    position: relative;
}

.accordion h2::before {
    content: "";
    position: absolute;
    left: 0;
    margin-left: -31px;
    top: 14px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 16px 34px 0px 0;
    border-color: #ffffff00 #ffffff transparent transparent;
    z-index: 1;
}

.accordion h2::after {
    content: "";
    position: absolute;

    left: 0;
    margin-left: -39px;
    top: 12px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 20px 40px 0px 0;
    border-color: transparent #707070 transparent transparent;
    z-index: 0;
}

.accordion hr {
    clear: both;
    border-top: 2px solid #3691CC;
    margin: 60px 0;
}

#faq div.accordion-content {
    padding: 15px 0px;
    clear: both;

    position: relative;
    display: flex;
}

.faq-q {
    display: block !important;
}

.single-faq-text {}

.single-faq-text span {
    display: inline-block;
    width: 15px;
    position: absolute;
    left: 15px;
}

.single-faq-text {
    padding: 15px 15px 15px 20px;
    border: 2px solid #707070;
    border-radius: 10px;
    width: 70%;
    margin-left: 20px;

    display: inline-block;
    position: relative;
}

.single-faq-text p {}

.single-faq-text::before {
    content: "";
    position: absolute;
    left: 0;
    margin-left: -31px;
    top: 14px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 16px 34px 0px 0;
    border-color: #ffffff00 #ffffff transparent transparent;
    z-index: 1;
}

.single-faq-text::after {
    content: "";
    position: absolute;

    left: 0;
    margin-left: -39px;
    top: 12px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 20px 40px 0px 0;
    border-color: transparent #707070 transparent transparent;
    z-index: 0;
}

.product-faq-block.faq-answer .single-faq-text {
    margin-left: auto;
    margin-right: 50px;
}

.product-faq-block.faq-answer .single-faq-text::before {
    left: auto;
    right: 0;
    margin-right: -31px;
    top: 14px;
    border-width: 16px 34px 0px 0;
    transform: scale(-1, 1);
}

.product-faq-block.faq-answer .single-faq-text::after {
    left: auto;
    right: 0;
    margin-right: -39px;
    top: 12px;
    border-width: 20px 40px 0px 0;
    border-color: transparent #707070 transparent transparent;
    transform: scale(-1, 1);
}

.product-faq-block.faq-answer .single-faq-text p {
    font-family: "Noto Sans JP", sans-serif;
}

#faq .accordion h2 {
    cursor: pointer;
}
#faq .accordion h2 span {
    display: inline-block;
    width: 15px;
    position: absolute;
    left: 15px;
}

#faq .accordion h2 em {
    position: absolute;
    right: 0px;
    top: 15px;
    font-style: normal;

    width: 30px;
    height: 30px;
    border-radius: 50%;
    transform: scale(1, 1);
    z-index: -1;

}

#faq .accordion h2 em:after {
    content: "\f078";
    font-family: FontAwesome;
    font-style: normal;
    font-size: clamp(14px, 1.4vw, 16px);
    color: #333;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;


    transform: scale(1, 1);
    transition: all 0.2s ease-in-out;
    width: 30px;
    height: 30px;
     z-index: -1;
}

#faq .accordion h2.click em:after {
    content: "\f078";
    font-family: FontAwesome;
    font-style: normal;
    font-size: clamp(14px, 1.4vw, 16px);

    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;

    transform: scale(1, -1);

    transition: all 0.2s ease-in-out;
}

#faq .accordion div.ans {
    display: block !important;
    padding: 20px 20px 20px 35px;
}

.faq-text span {
    position: absolute;
    width: 15px;
    margin-top: 20px;
    left: 22px;
    top: 0;
}

div.ans p span {
    display: inline-block;
    width: auto;
    left: auto;
    position: relative;
}





/* ------------------------------
 取扱説明書
 ------------------------------ */
#manual {}

/* ------------------------------
 ガイド
 ------------------------------ */
#guide {
    /*height: 100vh;*/
    height: calc(100vh - 258px);
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.close-button {
    text-align: center;
}

/* ------------------------------
 FAQ詳細
 ------------------------------ */

.product-faq {
    padding: 15px 30px;
}

.product-faq-block .faq-icon {
    clear: both;
    float: left;
    width: 20%;
    max-width: 100px;
}

.product-faq-block {
    margin-bottom: 30px;
    display: flex;
}

.product-faq-block.faq-answer .faq-icon {}

.product-block {
    margin-bottom: 40px;
}

.faq-text {
    padding: 15px;
    border: 2px solid #707070;
    border-radius: 10px;
    width: 100%;
    margin-left: 0px;

    display: inline-block;
    position: relative;
}

.faq-text p {}

#faq{
    padding-top: 0;
}

#faq .accordion div.faq-text::before {
    position: absolute;
    content: "";
    border: 10px solid transparent;
    border-right: 10px solid #707070;
    top: 15px;
    left: -20px;
}

#faq .accordion div.faq-text::after {
    position: absolute;
    content: "";
    border: 10px solid transparent;
    border-right: 10px solid #fff;
    top: 15px;
    left: -18px;
}

#faq .accordion .ac-content .faq-text::before,
#faq .accordion .accordion-content .faq-text::before {
    left: auto;
    right: -20px;
    transform: scale(-1, 1);
}

#faq .accordion .ac-content .faq-text::after,
#faq .accordion .accordion-content .faq-text::after {
    left: auto;
    right: -17px;
    transform: scale(-1, 1);
}

/* ------------------------------
 スマホ
 ------------------------------ */
@media screen and (max-width: 767px) {
    #header .logo {
        max-width: 140px;
        width: 100%;
    }

    #header h2 {
        font-size: clamp(24px, 2.0vw, 24px);
    }
    #search{
        padding: 0;
        margin-bottom: 0;
    }

    #result {
        margin-bottom: 20px;
    }

    #result {
        margin-top: -20px;
    }

    #result ul li {
        padding: 10px 10px 10px 30px;
        background-size: 20px;
        background-position: left center;
        line-height: 1.4;
    }

    #result ul,
    #faq.result .single {
        padding: 20px;
    }

    #faq.result .accordion-content,
    #faq.result .faq-block h2 {}

    .button-wrapper {
        max-width: 100%;
    }

    #faq .accordion div {
        padding: 0 0 0 0;
    }

    #faq .accordion div.ans {
        padding: 20px 10px 20px 40px;
    }



    #faq .accordion-content {}

    #faq.result .faq-block h2 {
        margin-left: 35px;
    }

    .center-search-form input {
        max-width: 255px !important;
    }

    .faq-text p {
        padding-right: 40px;
    }

    .accordion-content {
        display: flex;
    }

    .product-faq {
        padding: 15px 0;
    }

    .faq-text span {
        left: 20px;
    }
    #faq .accordion div.faq-text{
        padding-bottom: 20px;
    }
    .faq-block{
        padding: 0 10px;
    }
    #legal, #terms, #privacy, #agreement {
        margin-top: 0px;
    }
}

/* ------------------------------
 404
 ------------------------------ */
.pagenotfound {
    clear: both;
    text-align: center;
}

.pagenotfound ul {
    margin: 20px 0;
    padding: 0 0 0 0;
    text-align: center;
    display: flex;
    justify-content: center;
}

.pagenotfound ul li {}

.pagenotfound ul li a {
    display: block;
    padding: 10px;
}

/* ------------------------------
 フォーム
 ------------------------------ */
#contact .container {
    max-width: 800px;
    margin: 0 auto;
}

.contact {
    padding: 30px 15px;
}

.contact ul {
    padding: 0 0 0 0;
    margin: 0 0 0 0;
}

.contact ul li {

    list-style: none;
    list-style-position: inside;
}

#contact .table {
    margin-top: 10px;
}

#contact .table *{
  color: #333333;
  line-height: 2;
}

#contact .table td,
#contact .table th {
    text-align: left;
    background-color: none;
    border: none;
}

#contact .table th {
    width: 35%;
    min-width: 120px;
}

#contact .table td {
    width: 65%;
    word-break: break-word;
}

#contact .button-wrapper-contact{
    margin: 30px 0;
}

.required {

    color: #fff!important;
    font-size: clamp(11px, 1vw, 12px);
    margin-left: 5px;
    background-color: #FF909D;
    padding: 2px 5px;
    border-radius: 4px;
    margin-right: 5px;
}

#contact .button-wrapper {
    margin: 0 auto;
}

#contact .button-wrapper-contact {
    display: flex;
    justify-content: space-between;
    gap: 40px;
}

#contact .button-wrapper-contact button {

    display: inline-block;
}

#contact .button-wrapper-contact #back {
    background-color: #fff;
    color: #52c2b4;
}

#contact .button-wrapper-contact #back:after{
    content: "\f104";
    color: #52c2b4;;
    left: 25px;
    width: fit-content;
}

#contact .button-wrapper-contact #back:hover:after{
    left: 20px;
}

#contact .button-wrapper-contact #send {}

#contact .button-wrapper input[type="submit"] {
    font-family: FontAwesome;
}

#form-kanji-sei,
#form-kanji-mei,
#form-kana-sei,
#form-kana-mei,
#form-phone1,
#form-phone2,
#form-phone3 {
    width: auto;
    display: inline-block;
}


#contact #form-postaddress.form-control{
    width: 100%;
}


.notice {
    font-size: clamp(12px, 1.2vw, 14px);
    padding-top: 5px;
}

#contact .button-wrapper button {
    position: relative;
    padding: 15px 50px;
}

#contact .button-wrapper button:after {
    content: "\f105";
    font-family: FontAwesome;
    font-style: normal;
   font-size: clamp(12px, 1.2vw, 14px);
    color: #fff;
    right: 25px;
        line-height:2;
    position: absolute;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}


#contact .button-wrapper button:hover:after {
    right: 15px;

}

#contact .form-control {
    width: auto;
    border-radius: 6px;
}
#form-contact2.form-control,
#form-contact.form-control,
#form-email.form-control,
#form-email2.form-control {
    width: 100%;
}

label.error {
    color: red!important;
    display: block;
    font-size: clamp(12px, 1.2vw, 14px);
    padding: 3px 0;
}

#form-kanji-sei,
#form-kana-sei {
    margin-right: 20px;
}

.flex-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

#contact .table-confirm td{
    background-color: #ffefef;
    border-radius: 6px;
}

#contact .table-confirm tr{
    margin-bottom: 20px;
    display: flex;
}
.notice-confirm{
    padding: 30px 0;
}


#contact .table a{
        color: #005EFF;
}

@media screen and (max-width: 768px) {
    #contact{
        padding-bottom: 60px;
    }

    .selectbox select {
        padding: 6px;
    }
    #contact .button-wrapper-contact{
        display: block;
    }
    #contact .button-wrapper-contact button,
    #contact .button-wrapper-contact #back {
        margin-bottom: 20px;
        width: 100%;
        max-width: 100%;
    }
    #contact .table td,
    #contact .table th{
        width: 100%;
        display: block;
    }
    .contact{
        padding: 15px 0;
    }
    #contact #flexbox-imei{
        justify-content: space-between;
    }
    #contact #flexbox-imei .form-control{
        width: 70%;
    }
}



.table .flex-container .flexbox {
    min-width: 0;
}

@-moz-document url-prefix() {
    .table .flex-container .flexbox {
        padding-right: 10px;
    }
}

/* ------------------------------
 agreement
 ------------------------------ */

#agreement .container {
    max-width: 800px;
    margin: 0 auto;
}

.agreement-pre {
    /*
    height: 300px;
    overflow-y: scroll;
    */
    padding: 15px;
    background: #F2F2F2;
    margin-top: 15px;
}

.agreement-button {
    text-align: center;
}

.agreement-button .button-wrapper {
    margin-right: auto;
}

.agreement-table td {
    vertical-align: top;
}

.agreement-table td:first-child {
    width: 30%;
}

/* ------------------------------
 お問い合わせ
 ------------------------------ */

table #flexbox-imei {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.form-control.disabled {
    background: #c9c9c9;
    color: transparent;
    cursor: not-allowed;
    pointer-events: none;
}

#form-imei {
    max-width: 140px;
}

/* ------------------------------
001: Header
 ------------------------------ */
header {
    width: 100%;
    text-align: center;
    background-color: rgba(255, 255, 255, 0.4);
    position: absolute;
    z-index: 11;
}

.fix-header {
    background-color: #fff;

    top: 0px;
    left: 0;
    text-align: center;
    width: 100%;
    margin: 0 auto;

    padding: 10px 0;
    position: fixed;
    opacity: 1;
    z-index: 11;
    /*  opacity: 0; */
    height: 74px;

    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}
.fix-header .h-inner{
  max-width: 1440px;
  margin: 0 auto;
}
.fix-header ul {
    list-style-type: none;
}

.fix-header li {
    float: left;
}

.fix-header li a{
    display: block;
    color: #333333;
    text-decoration: none;
    font-weight: 800;
    font-size: 16px;
}

.fix-header li:nth-child(4) {}

.fix-header li a {
    padding: 5px 0;
}
.fix-header li a{
    margin:0 10px;
}
.fix-header li:last-child a {
    margin:0;
}

.fix-header li:last-child {
    margin: 0px 25px 10px 0px;
}

.fix-header li:last-child a img{
    width: 42px;
    position: relative;
    top: 5px;
}

.fix-header li:last-child a::after{
    display: none;
}

.icon-faq-tablet {
    display: none;
}

#fix-header-logo {
    float: left;
}
#fix-header-logo  a{
    display: block;
}



#fix-header-logo img {
    width: 210px;
}

#fix-header-menus {
    float: right;
    text-align: right;
}

.icon-faq {
    position: absolute;
    right: 0;
    top: -58px;
}

#global-nav ul {
    padding: 0;
    margin: 0;
    display: -moz-flex;
    display: -webkit-flex;
    display: -o-flex;
    display: -ms-flex;
    flex-wrap: wrap;
    display: flex;
    justify-content: center;
    align-items: center;
}

.fix-header li,
#global-nav ul li {
    list-style-type: none;
    margin: 10px 25px;
}

#global-nav ul li a {
    padding: 5px 0;
    display: block;
    color: #3d3d37;
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
}

.fix-header ul li a,
#global-nav ul li a {
    position: relative;
}

.fix-header li a:hover,
#global-nav ul li a:hover {
    text-decoration: none;
}

.fix-header li a::after,
#global-nav ul li a::after {
    position: absolute;
    left: 0;
    bottom: 0;
    display: block;
    content: "";
    width: 0%;
    height: 2px;
    background: #FF94A6;
    transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.fix-header li a:hover::after,
#global-nav ul li a:hover::after {
    width: 100%;
}

@media screen and (max-width: 991px) {
    #fix-header-logo img {
        width: 180px;
        padding-top:3px;
    }

    .fix-header li {
        margin-left: 15px;
        margin-right: 15px;
    }
}

@media screen and (max-width: 768px) {
    #global-nav {
        display: none;
    }

    .fix-header {
        top: 0 !important;
        opacity: 1 !important;
        z-index: 100 !important;
        display: flex;
        align-items: center;
    }

    #info {
        margin-top: 15px;
    }
    #fix-header-logo{
      float: none;
    }
}




/* ------------------------------
breadcrumbs
 ------------------------------ */
#breadcrumb {
    padding: 10px 0 !important;
    background: #f5f5f5;
    display: none;
}

.breadcrumbs {
    width: 100%;
    margin: 0 auto;
    text-align: left;
    font-size: clamp(12px, 1.2vw, 14px);
    padding: 0 0 0 0;
}

.breadcrumbs a {
    padding: 10px 0px;
    color: #3d3d37;
}

.breadcrumbs>span {
    padding: 0 5px;
    display: inline-block;
}

.breadcrumbs>span:fist-child {
    padding-left: 0;
}

.breadcrumbs>span:last-child {
    color: #0660df;
}

.breadcrumbs a {
    position: relative;
}

.breadcrumbs a {
    text-decoration: none;
}

/* ------------------------------
2022.01追記 FAQ
 ------------------------------ */
#faq .q-icon {
    max-width: 35px;
    width: 100%;
    margin-right: 0;
    float: none;
    display: inline-block;
    float: left;
    padding-top: 12px;
}

#faq .accordion h2 {
    border: none;
    font-weight: bold;
    float: left;
    width: calc(100% - 40px);
    max-width:800px;
    padding: 20px 40px 20px 20px;

}


#faq .accordion h2 span {
    display: none;
}

#faq .faq-block aside h2:before,
#faq .faq-block aside h2:after {
    display: none;
}

#faq .accordion div.faq-text {
    margin: 0;
    padding: 0;
    border: none;
}

#faq .accordion div.ans {
    padding: 0;
    width: calc(100% - 40px);
    float: left;
}

#faq div.accordion-content {

}

#faq .accordion-content p.q-icon {
    display: none;
}

#faq .accordion .accordion-content .faq-text::before,
#faq .accordion .accordion-content .faq-text::after {
    display: none;
}

.faq-text span {

    width: 35px;
    margin: 0 0 20px;
    left: auto;
}

.accordion hr {
    margin: 0;
    clear: both;
}

.faq-text p {
    padding-left: 50px;
    word-wrap: break-word;

}

.faq-text ol,
.faq-text ul {
    padding-left: 68px;
}



#faq .faq-text-wrap>.q-icon {
    display: none;
}

#faq .accordion .ac-content .faq-text::before,
#faq .accordion .accordion-content .faq-text::before {
    display: none;
}

#faq .accordion .ac-content .faq-text::after,
#faq .accordion .accordion-content .faq-text::after {
    display: none;
}

#faq .accordion .ac-content {
    padding-left: 0;
    padding-right: 0;
}





.product-faq-block {
    align-items: center;
}

.single-faq-text::before,
.single-faq-text::after {
    display: none;
}

.single-faq-text {
    border: none;
    padding: 0;
    width: auto;
}

.product-faq-block.faq-answer .faq-icon {
    display: none;
}

.product-faq-block.faq-answer .single-faq-text {
    margin: 0 0 0 20px;
}

.product-faq-block .faq-icon {
    max-width: 25px;
    width: 100%;
}

.product-faq-block.faq-answer {
    display: flex;
    padding-top: 10px;
}

.product-faq-block.faq-answer>span {
    display: block;
    max-width: 25px;
    width: 100%;

}



@media screen and (max-width: 767px) {
    #faq .accordion div.ans {
        width: 100%;
    }
}

/*---------------------------------------

シニア

---------------------------------------*/
.seniorFv a,
.seniorMain a {
    color: #333333;
}

.seniorFv a:hover,
.seniorMain a:hover {
    text-decoration: none;
}

.inner {
    max-width: 1280px;
    width: 100%;
    margin: 0 auto;
    padding: 0 20px;
}

.seniorBtn {
    display: inline-block;
    width: 250px;
    text-align: center;
    background-color: #3691CC;
    font-size: clamp(18px, 2vw, 24px);
    font-weight: bold;
    padding: 9px 0;
    border-radius: 50px;
    border: 3px solid #333333;
    letter-spacing: 0.05em;
    position: relative;
    -webkit-box-shadow: 7px 7px 0 #333333;
    box-shadow: 7px 7px 0 #333333;
    -webkit-transition: .3s;
    transition: .3s;
}

@media screen and (max-width: 768px) {
    .seniorBtn {
        font-size: clamp(14px, 1.4vw, 16px);
        width: 200px;
        padding: 5px 0;
    }
}

.seniorBtn:hover {
    -webkit-transform: translate(7px, 7px);
    transform: translate(7px, 7px);
    -webkit-box-shadow: none;
    box-shadow: none;
}

.seniorFv {

    padding: 74px 0 200px 0;



    z-index: 1;
    max-width: 1400px;
    margin: 0 auto;
    margin-top: 0;
}



.seniorFv img {
    margin: 0 auto;
}


.seniorFv .star1 img {
    margin: 0 auto;
    position: relative;
    left: -15px;
}

.visual-buy-button {
    width: 100%;
    max-width: 100svw;
    background-color: rgba(255, 255, 255, 0.9);
    bottom: 0;
    position: fixed;
    z-index: 100;
}

.visual-buy-button .inner {
    display: flex;
    width: 100%;
    padding: 10px 0px;
    align-items: center;
    justify-content: center;
    align-items: center;
    max-width: 1240px;
    margin: 0 auto;

}

.visual-buy-button .inner img {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
    margin: 0 auto;

}

.visual-buy-button .inner p {
    margin-left: auto;
}

a.button-green {
    display: inline-block;
    position: relative;
    text-align: center;
    color: #fff;
    font-size: clamp(16px, 1.8vw, 20px);
    font-weight: bold;
    text-decoration: none;
    padding: 12px 0;
     min-width: 450px;
    border-radius: 14px;
    cursor: pointer;
    background: linear-gradient(270deg, #71DBCC, #59CBEF, #B1A9E0, #FFAEB8); 
    background-size: 800% 800%;
    animation: gradientLoop 20s ease infinite;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

a.button-green:after {
    display: inline-block;
    font-family: FontAwesome;
    content: "\f054";
    position: absolute;
    right: 25px;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    transition: right 0.3s;
}

a.button-green:hover:after {
    right: 15px;
}


@keyframes gradientLoop {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

a.button-green:hover {
    transform: scale(1.05);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

a.button-green:active {
    transform: scale(0.97);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.visual-buy-button .inner img.price-fixed{
  max-width: 750px;
  width: 100%;
}
@media screen and (max-width: 768px) {

    a.button-green{
            font-size: clamp(16px, 1.8vw, 18px);
    }
    .price-fixed-sp{
      display: block!important;
    }
    a.button-green {
        min-width: 100px;
        display: block;

    }
    .visual-buy-button .inner p {
      min-width: 182px;
    }
}

@media screen and (max-width: 768px) {
    .seniorFv>.inner {
        padding: 0;
    }
}

.seniorFv_box {
    max-width: 540px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

@media screen and (max-width: 768px) {
    .seniorFv_box {
        max-width: none;
        margin: 0 auto;
    }
}

.seniorFv_box_img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 17px;
}

@media screen and (max-width: 768px) {
    .seniorFv_box_img {
        padding: 0 20px;
        max-width: 400px;
        margin: 0 auto 11px;
    }
}

.seniorFv_box_img .img1 {
    width: 60.6%;
}

.seniorFv_box_img .img2 {
    width: 35%;
}

.seniorFv_box_img .img2 img {
    -webkit-filter: drop-shadow(10px 5px 30px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(10px 5px 30px rgba(0, 0, 0, 0.2));
}

.seniorFv_box_txt1 {
    text-align: center;
    margin-bottom: 20px;
    font-weight: bold;
    font-size: 25px;
}

@media screen and (max-width: 768px) {
    .seniorFv_box_txt1 {
        margin-bottom: 216px;
        font-size: clamp(16px, 1.6vw, 18px);
    }
}

.seniorFv_box_btn {
    text-align: center;
    margin-bottom: 40px;
}

@media screen and (max-width: 768px) {
    .seniorFv_box_btn {
        -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
        order: 3;
        margin-bottom: 0;
        padding-bottom: 55px;
        background-color: rgba(255, 255, 255, 0.7);
    }
}

.seniorFv_box_txt2 {
    font-weight: bold;
    font-size: clamp(18px, 2vw, 24px);
    background-color: rgba(255, 255, 255, 0.7);
    padding: 17px 29px;
}

@media screen and (max-width: 768px) {
    .seniorFv_box_txt2 {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
        font-size: clamp(12px, 1.2vw, 14px);
        padding-bottom: 16px;
    }
}

.seniorFv_box_txt2 .txt {
    line-height: 1.5;
    letter-spacing: 0.05em;
}

.seniorFv_box_txt2 .txt:not(:last-child) {
    margin-bottom: 0.5em;
}

.seniorFv_scroll {
    display: block;
    background: url(../images/senior/scroll.png) no-repeat center center/contain;
    width: 58px;
    height: 43px;
    position: absolute;
    bottom: 16px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

@media screen and (max-width: 768px) {
    .seniorFv_scroll {
        background-image: url(../images/senior/scroll_sp.png);
        width: 45px;
        height: 29px;
        bottom: 8px;
    }
}

.seniorMain {

    padding: 120px 0 210px;
    position: relative;
    z-index: 1;
}

@media screen and (max-width: 768px) {
    .seniorMain {

        padding: 36px 0 85px;
    }
}

.seniorMain_ttl {
    text-align: center;
    font-size: 36px;
    font-weight: bold;
    margin-bottom: 60px;
    letter-spacing: 0.05em;
    color: #fff;

}

.seniorMain_ttl:after {
    border: none;
    background: none;

}

.seniorMain_ttl p {
    font-size: clamp(16px, 1.8vw, 18px);
    font-weight: normal;
}

.seniorMain_ttl p.small {
    font-size: clamp(12px, 1.2vw, 14px);
}

@media screen and (max-width: 768px) {
    .seniorMain_ttl {
        font-size: 28px;
    }

    .seniorMain_ttl p {
        font-size: 13px;
    }
}

.seniorMain_ttl span {
    display: inline-block;

}

@media screen and (max-width: 768px) {
    .seniorMain_ttl span {
        padding-bottom: 5px;
    }
}

@media screen and (min-width: 769px) {}

.seniorMain_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 110px;
    max-width: 850px;
    margin: 0 auto 100px auto;
}

@media screen and (max-width: 991px) {
    .seniorMain_box {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        gap: 100px;
        margin-bottom: 110px;
    }
}

.seniorMain_box_item {
    position: relative;
    z-index: 1;
}

@media screen and (max-width: 991px) {
    .seniorMain_box_item {
        text-align: center;
    }
}

.seniorMain_box_item::before {}

@media screen and (max-width: 768px) {
    .seniorMain_box_item::before {
        width: 340px;
        height: 340px;
        top: 137px;
    }
}

.seniorMain_box_item>a {
    position: relative;
    display: inline-block;
}

.seniorMain_box_item>a:hover .img img {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
}

.seniorMain_box_item>a:hover .ttl {
    -webkit-box-shadow: none;
    box-shadow: none;
    -webkit-transform: translate(05px, 5px);
    transform: translate(0px, 5px);
}

.seniorMain_box_item>a::after {
    content: "";
    position: absolute;
    z-index: 1;
    width: 126px;
    height: 71px;
}

.seniorMain_box_item p.ttl::after {
    content: "\f105";
    font-family: FontAwesome;
    font-style: normal;
    font-size: clamp(16px, 1.8vw, 18px);
    color: #333333;
    right: 25px;
    top: 17px;
    position: absolute;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

@media screen and (max-width: 768px) {
    .seniorMain_box_item>a::after {}
}

.seniorMain_box_item .img {
    width: 300px;
    height: 300px;
    border-radius: 50%;
    position: relative;
    z-index: 1;
    margin: 0 auto;
    overflow: hidden;
}

@media screen and (max-width: 768px) {
    .seniorMain_box_item .img {
        width: 275px;
        height: 275px;
    }
}

.seniorMain_box_item .img img {
    -webkit-transition: .3s;
    transition: .3s;
}

.seniorMain_box_item .ttl {
    display: block;
    position: relative;
    z-index: 1;
    width: 370px;
    text-align: center;
    background-color: #fff;
    font-size: 26px;
    font-weight: bold;

    padding: 9px 0;
    border-radius: 50px;

    margin-top: -25px;
    -webkit-box-shadow: 0px 5px 0 rgba(0, 0, 0, 0.6);
    box-shadow: 0px 5px 0 rgba(0, 0, 0, 0.6);
    -webkit-transition: .3s;
    transition: .3s;
}

@media screen and (max-width: 768px) {
    .seniorMain_box_item .ttl {
        width: 334px;
        font-size: clamp(16px, 1.6vw, 18px);
        border-width: 2px;
        margin: -23px auto 0;
    }

    .seniorMain_box_item p.ttl::after {

        top: 8px;

    }
}

.seniorMain_box_item:nth-child(1)>a::after {
    left: 0px;
    top: 0px;
    background: url(../images/eye1.png) no-repeat center center/contain;
}

@media screen and (max-width: 768px) {
    .seniorMain_box_item:nth-child(1)>a::after {}
}

.seniorMain_box_item:nth-child(2) {}

@media screen and (max-width: 991px) {
    .seniorMain_box_item:nth-child(2) {}
}

.seniorMain_box_item:nth-child(2)>a::after {
    right: 0px;
    top: 0px;
    background: url(../images/eye2.png) no-repeat center center/contain;
}

@media screen and (max-width: 768px) {
    .seniorMain_box_item:nth-child(2)>a::after {}
}

.seniorMain_cta {
    max-width: 850px;
    margin: 0 auto;
}

.seniorMain_cta_box {
    background-color: rgba(255, 255, 255, 0.8);
    padding: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    border-radius: 20px;
    position: relative;
    margin-bottom: 100px;
}

@media screen and (max-width: 991px) {

}


.seniorMain_cta_box_l {
    max-width: 460px;
}

@media screen and (max-width: 991px) {
    .seniorMain_cta_box_l {
        margin-bottom: 23px;
    }
}

.seniorMain_cta_box_r {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    max-width: 250px;
}

@media screen and (max-width: 991px) {
    .seniorMain_cta_box_r {
        width: 50%;
    }
}


.seniorMain_cta_box_r .img2 {
    width: 100%;
    right: -10px;
    position: relative;
}

.seniorMain_cta_btn {
    text-align: right;
    margin-top: -34px;
    position: relative;
}

@media screen and (max-width: 991px) {
    .seniorMain_cta_btn {
        text-align: center;
    }
}

@media screen and (max-width: 768px) {
    .seniorMain_cta_btn {
        margin-top: -28px;
    }
}

@media screen and (max-width: 768px) {
    .seniorMain_cta_btn .seniorBtn {
        width: 210px;
        padding: 10px 0 9px;
    }
}



@media screen and (max-width: 768px) {

    .seniorMain_cta {
        margin: 0 25px;
    }

    .seniorMain_cta_box {
        box-shadow: none;
        text-align: center;
    }

    .seniorFv {}
}

.kids-bg-star{
    background-image: url(../images/kids-bg-star.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 100%;
}

/*---------------------------------------

ヘッダーサブメニュー

---------------------------------------*/
.subMenu {
    padding: 5px 0;
    position: relative;
    color: #3d3d37;
    text-decoration: none;
    font-weight: bold;
    font-size: 1.6rem;
    cursor: pointer;
}

@media screen and (max-width: 1200px) {
    .subMenu {
        font-size: 1.4rem;
    }
}

.subMenu::after {
    position: absolute;
    left: 0;
    bottom: 0;
    display: block;
    content: "";
    width: 0%;
    height: 2px;
    background: #3691CC;
    -webkit-transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.subMenu .list {
    position: absolute;
    top: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    padding-top: 14px;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.subMenu .list_item {
    width: 130px;
    padding: 4px 0;
    text-align: center;
    background-color: #3691CC;
}

.subMenu .list_item:not(:last-child) {
    border-bottom: 1px #fff solid;
}

.subMenu .list_item a {
    font-size: 1.2rem !important;
}

.subMenu .list_item a:hover {
    text-decoration: underline;
}

.subMenu:hover::after {
    width: 100%;
}

.subMenu:hover .list {
    visibility: visible;
    opacity: 1;
}

/*---------------------------------------

同意画面

---------------------------------------*/
.a-table {
    border: none;
    width: 100%;
}

.a-table tr:not(:last-child) {
    border-bottom: none;
}

.a-table th {
    border-right: none;
    font-weight: normal;
    background-color: #E3E3E3;
    vertical-align: top;

}

.a-table th,
.a-table td {
    padding: 6px;
    display: block;
}

td span.notice{
    line-height: 1.6!important;
    display: block;
}

#agreement {
    padding-bottom: 60px;
}

@media screen and (max-width: 768px) {

    .a-table tr,
    .a-table th,
    .a-table td {
        display: block;
        word-break: break-word;
    }
}

.pagenotfound li {
    list-style: none;
}

.pagenotfound ul li:last-child {}

.pagenotfound li:last-child a:after {
    display: block;
}

@media screen and (max-width: 768px) {
    .pagenotfound ul {
        display: block;
    }

    .pagenotfound li {
        float: none;
    }
}

/*---------------------------------------

フォーム

---------------------------------------*/
#contact .table {
    table-layout: fixed;
}

#contact .table th {
    min-width: auto;
}

#contact .form-control {
    max-width: 100%;
}

@media screen and (max-width: 768px) {
    #contact .flex-container .flexbox {
        width: 100%;
    }

    #contact #form-kanji-sei,
    #contact #form-kanji-mei,
    #contact #form-kana-sei,
    #contact #form-kana-mei {
        width:100%;

    }

    #form-kanji-sei,
    #form-kana-sei {
        margin-right: 0;
    }

    #form-shopname {
        max-width: 100%;
    }
    #contact .form-control{
        width: 100%;
    }
    .flex-container{
        gap: 20px;
    }
}



#global-styles-inline-css {
    display: none;
}

.form-control {
    font-size: clamp(14px, 1.4vw, 16px);
}



.visual-topix {
    display: flex;
    align-items: center;
    max-width: 850px;
    margin: 0 auto;
    margin-bottom: 80px;
    margin-top: 80px;
}

.visual-topix-title {
    /*
    border-radius: 60px;
    border: 3px solid #fff;
    color: #fff;
    font-weight: bold;
    padding: 10px 30px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);*/
    margin-right: 20px;
}

.visual-topix-title p {
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1;
}

.visual-topix-title p img{
    display: block;
    max-width: 155px;
}

.visual-topix-wp {
    background-color: #fff;
    border-radius: 60px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    width: 100%;
    padding: 10px 30px;
}

.visual-topix-wp p span.date {
    margin-right: 10px;
}

.visual-topix-wp a {
    color: #0168B3;
}

.visual-topix-wp a:hover {
    text-decoration: underline;
}













.dokokana-ttl {
    text-align: center;
}

.dokokana-ttl h3 {
    position: relative;
    padding: 0.3rem;
    margin-bottom: 0.2rem;
    border-bottom: 6px double #F2C714;
    color: #fff;
    font-weight: bold;
    display: inline-block;
    font-size: 38px;
    text-align: center;
    margin-bottom: 80px;
}

.dokokana-block {
    max-width: 850px;
    margin: 0 auto;
    color: #006CB5;
    position: relative;
}





.dokokana-block-text h4 {
    text-align: left;
    font-size: 26px;
    line-height: 1.5;
    margin-bottom: 10px;
}

.dokokana-block-text p {
    margin-bottom: 30px;
    font-size: clamp(16px, 1.6vw, 18px);
}
.free-month p.small,
.free-month-senior p.small,
.dokokana-function-text p.small,
.dokokana-block-text p.small {
    margin-bottom: 0;
    font-size: clamp(12px, 1.2vw, 14px);
    text-indent: -1em;
    padding-left: 1em;
}

.dokokana-block .container-r {
    padding: 60px 60px;
    max-width: 850px;
    position: relative;
    margin: 0 0 180px 0;
}


.dokokana-block-text {
    width: 70%;
}

.dokokana-block-thum {
    position: absolute;
    right: -63px;
    top: 0;
    max-width: 250px;
}

.dokokana-block-eye {
    position: absolute;
    left: -60px;
    bottom: -30px;
    width: 125px;
}

.container-2 .dokokana-block-thum {
    left: -120px;
    right: 0;
    max-width: 400px;
    top: -57px;
}

.container-2 .dokokana-block-eye {
    left: auto;
    right: -60px;
}

.container-2 .dokokana-block-text {
    max-width: 100%;
    width: 100%;
}


.container-3 .dokokana-block-thum {
    position: absolute;
    right: -230px;
    top: -64px;
    max-width: 445px;
}




.container-4 .dokokana-block-thum {
    left: -162px;
    right: auto;
    max-width: 362px;
    top: 0;
}

.container-4 .dokokana-block-eye {
    left: auto;
    right: -60px;
}

.container-4 .dokokana-block-text {
    margin-left: auto;
    max-width: 75%;
}


.dokokana-block .seniorMain_cta_box_l {
    max-width: 320px;
    position: relative;
}

.b-device,
.b-eye{
    position: absolute;
}
.b-device{
    top: 75px;
    left: 65px;
    width: 180px;
}





.b-eye{
  right: -28px;
  top: 0;
}
.dokokana-block .seniorMain_cta_box_r {

    max-width: 463px;
    padding-left: 50px;
}

.seniorMain_cta .dokokana-ttl h3 {
    color: #006CB5;
    margin-bottom: 20px;
}
.img2 .dokokana-ttl.pc{
    text-align: left;
}

.seniorMain_cta_box_r .dokokana-block-text {
    width: 100%;
}


.free-month {
    background-image: url(../images/kids-free.jpg);
    background-repeat: no-repeat;
    background-size: cover;
        min-width: 1000px;
}

.free-month-senior {
    background-image: url(../images/senior-free.jpg);
}

.free-month .dokokana-ttl {
    text-align: left;
    margin-bottom: 0;
}

.free-month .dokokana-ttl h3 {
    margin-bottom: 15px;
    color: #333333;
    font-size: 28px;
    letter-spacing: 0.1em;
}

.free-month .dokokana-ttl h3 span {
    font-size: 40px;
}

.free-month-inner {
    padding: 200px 0;
    width: 395px;
    margin-left: 60%;
    margin-right: auto;
}


.dokokana-function {
    padding: 100px 0;
    max-width: 870px;
    margin: 0 auto;
}

.dokokana-function-list {
    display: flex;
}

.dokokana-function-item {
    width: 25%;
    color: #fff;
    padding: 0 15px;
}

.dokokana-function-thum {
    margin-bottom: 20px;
}

.dokokana-function-text h5 {
    margin-bottom: 20px;
    font-size: clamp(16px, 1.8vw, 18px);
    font-weight: bold;
}


.dokokana-function-text p {
    font-weight: normal;
}

.dokokana-function-text p.small {
    margin-top: 10px;
}

#pagetop {
  position: fixed;
  right: 20px;
  left: auto;
  width: 90px;
  bottom: 90px;
  opacity: 0; /* 最初は透明にして非表示 */
  pointer-events: none; /* 非表示中はクリック無効 */
  transition: bottom 0.6s ease-in-out, opacity 0.3s ease;
  z-index: 2;
}
#pagetop a{
  display: block;
  width: 100%;
}


#pagetop.show {
  opacity: 1;
  pointer-events: auto;
}

.eye-effect {
    position: absolute;
    z-index: 10;
    left: -46px;
    top: -40px;
    opacity: 0;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

.eye-effect-right {
    left: auto;
    top: -40px;
    right: -40px;
}

.seniorMain_box_item>a:hover .eye-effect {
    opacity: 1;
}

.fadeleft {
    opacity: 0;
    transform: translate(100px, 0);
    transition: all 0.8s;
}

.fadeleft.active {
    opacity: 1;
    transform: translate(0, 0);
}

.faderight {
    opacity: 0;
    transform: translate(-100px, 0);
    transition: all 0.8s;
}

.faderight.active {
    opacity: 1;
    transform: translate(0, 0);
}


.fadepush{
    opacity: 0;
    transform: translate(0, 50px);
    transition: all 0.2s;
    transition-delay: 300ms; 
    position: absolute;
    top: 90px;
    right: 0;
}

.fadepush.active {
    opacity: 1;
    transform: translate(0, 0);
}



.star1 .inner{
    max-width: 1440px;
}





.dokokana-block .container-1{
    padding: 80px 45px;
}
.container-1 .dokokana-block-thum{
        top: -66px;
}

.dokokana-block .container-2{
    background-color: rgba(255, 255, 255, 0.8);
}
.dokokana-block .container-2 img{
    padding-top: 40px;
}


.dokokana-block .container-2 h4{
    font-size: 36px;
    font-weight: bold;

}
.dokokana-block .container-2 h4 span{
       display: inline-block;
    border-bottom: 6px double #F2C714; 
}
.container-5 .dokokana-block-thum {
    right: -63px;
    top: -72px;
    max-width: 345px;
}
@media screen and (max-width: 768px) {

    .container-1 .dokokana-block-thum{
            top: -365px;
    }


}

@media screen and (max-width: 768px) {
    .eye-effect {
        opacity: 1;
    }

    .seniorMain_box_item>a::after {
        width: 100px;
    }

    .eye-effect {
        width: 40px;
    }


    .eye-effect {
        left: -10px;
        top: -20px;
    }

    .eye-effect-right {
        right: -10px;
        left: auto;
    }

    .visual-buy-button .inner img {
        display: none;
    }

    .visual-buy-button .inner p {
        margin: 0 auto;
        width: 100%;
    }

    .visual-buy-button .inner {
        padding: 10px 28px;
    }

    .visual-topix {
        display: block;
        text-align: center;
        padding: 0 25px;
    }

    .visual-topix-title {
        display: inline-block;
        margin: 0 auto 20px auto;
    }

    .visual-topix-wp a {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        width: 100%;
        display: block;
    }

    .visual-topix-wp {
        text-align: left;
    }

    .visual-topix-title p {
        font-size: clamp(16px, 1.8vw, 18px);
    }

    #pagetop{
        width: 79px;
    }

    .dokokana-block-eye {
        display: none;
    }

    .dokokana-ttl h3 {
        font-size: 24px;
    }

    .dokokana-block .container-r {
        padding: 70px 30px 20px 30px;
        max-width: 100%;
        position: relative;
        margin: 320px 20px 120px 20px;
    }

    .dokokana-block-text h4 {
        font-size: clamp(16px, 1.8vw, 18px);
        text-align: center;
    }

    .dokokana-block-text p {
        font-size: clamp(14px, 1.4vw, 16px);
        text-align: left;
    }

    .container-4 .dokokana-block-text,
    .container-3 .dokokana-block-text,
    .container-2 .dokokana-block-text,
    .dokokana-block-text {
        width: 100%;
        max-width: 100%;
    }

    .dokokana-block-thum {
        position: absolute;
        right: auto;
        top: -360px;
        max-width: 200px;
        left: 50%;
        margin-left: -100px;
    }

    .container-2 .dokokana-block-thum {
        left: 0;
        right: 0;

        margin-left: 0;
        top: -260px;
        max-width: 300px;
        left: 50%;
        margin-left: -150px;
    }

    .container-r.container-2 {
        margin-top: 0;
        padding-top: 20px;
    }

     .container-r.container-2 h4{
        line-height: 1.4;
     }


    .container-r.container-3 {
        margin-bottom: 420px;
    }

    .container-3 .dokokana-block-thum {
        left: 0;
        right: 0;
        margin-left: 0;
        top: -359px;
        max-width: 300px;
        left: 50%;
        margin-left: -150px;
    }

    .container-4 .dokokana-block-thum {
        left: 0;
        right: 0;
        margin-left: 0;
        top: -359px;
        max-width: 300px;
        left: 50%;
        margin-left: -150px;
    }

    .dokokana-block .seniorMain_cta_box_r {
        max-width: 100%;
        padding-left: 0px;
        width: 100%;
        display: block;
    }

    .dokokana-block .seniorMain_cta_box_l {
        margin-bottom: 20px;
        display: inline-block;
        position: relative;
        left: 0;
        right: 0;
        bottom: 0;
        top: 0;
    }

    .dokokana-function-list {
        display: block;
    }

    .dokokana-function-item {
        width: 100%;
        text-align: center;
        margin-bottom: 60px;
        padding: 0 25px;
    }

    .dokokana-function-text p.small {
        text-align: left;
    }

    .dokokana-function-text p {
        font-size: clamp(14px, 1.4vw, 16px);
    }

    .dokokana-block-text p.small,
    .dokokana-function-text p.small {
        font-size: clamp(12px, 1.2vw, 14px);
        text-indent: -1em;
        padding-left: 1em;
    }

    .seniorMain_cta_box_r {
        display: none;
    }

    #footer {
        text-align: center;

    }

    .seniorMain_cta_box {
        padding: 40px 20px;
        margin-bottom: 20px;
        display: block;
    }

    .seniorMain_cta_box_l {
        margin-bottom: 0;
    }

    .free-month {
        background-image: url(../images/kids-free_sp.jpg);
        min-width: auto;
        background-position: center top;
    }

    .free-month-senior {
        background-image: url(../images/senior-free_sp.jpg);
        background-position: center top;
    }

    .free-month-inner {
        width: 100%;
        margin: 0 auto;
        padding: 0 30px;
    }
    .free-month.free-month-senior .dokokana-ttl{
        padding-bottom: 200px;
    }

    .free-month-inner p{
        line-height: 1.6;
    }

    .free-month {
        padding: 100px 0 20px 0;
    }

    .free-month .dokokana-ttl {
        text-align: center;
        padding-bottom: 230px;
    }
    .seniorMain_box_item:nth-child(1)>a::after{
        left: 15px;
    }
    .seniorMain_box_item:nth-child(2)>a::after{
        right: 15px;
    }
    .seniorMain_cta_box_r .img2{
        right: 0;
    }
    .b-device {
        top: 13vh;
        left: 50%;
        width: 150px;
        margin-left: -55px!important;
    }
    .b-eye {
        right: -10px;
        top: 8px;
    }
    .seniorFv .star1 img {
        margin: 0 auto;
        left: -9px;
        position: relative;
    }


    body.landscape.iphone .b-device{
            top: 100px;
    }

    .container-3 .dokokana-block-thum{
        top: -258px;
    }

    .dokokana-block .container-5{
        margin-top: 440px;
    }
    .container-5 .dokokana-block-thum{
        left: 0;
        right: 0;
        margin-left: 0;
        top: -359px;
        max-width: 300px;
        left: 50%;
        margin-left: -150px;
    }

    .dokokana-block .container-2 h4 span{
        font-size: 24px;
    }

    .accordion hr{
        margin: 0 0 0 0!important;
    }
}

@media screen and (max-width: 360px) {
    .free-month .dokokana-ttl {
        text-align: center;
        padding-bottom: 240px;
    }
}


.visual-buy-button .inner img.price-1{
    max-width: 229px;
}

.visual-buy-button .inner img.price-2{
    max-width: 539px;
}

@media (orientation: portrait){
    body.ipad .seniorFv{
        padding-top: 74px;
    }
    body.ipad .dokokana-block .container-r{
        width: 800px;
    }

    body.ipad .container-2 .dokokana-block-thum{
        left: -55px;
    }
    body.ipad .visual-buy-button .inner img.price-1{
        max-width: 140px;
    }
    body.ipad .visual-buy-button .inner img.price-2{
        max-width: 400px;
    }
    body.ipad .dokokana-block-text{
        width: 100%;
    }
    body.ipad .container-2 .dokokana-block-text {
        max-width: 50%;
    }

}

body.ipad .sp{
    display: none!important;
}
 body.ipad .pc{
    display: block!important;
}

@media screen and (max-width: 768px) {

    body.ipad .seniorFv{
        padding-top: 74px;
        background-size: cover;
    }
    body.ipad .dokokana-block .container-r {
        padding: 40px 60px;
        width:680px;
        position: relative;
        margin: 0 auto 120px auto;
    }

    body.ipad .dokokana-block-thum {
        position: absolute;
        right: -32px;
        top: 0;
        max-width: 223px;
        margin-left: auto;
    }

    body.ipad .container-2 .dokokana-block-thum {
        left: 0;
        right: 0;
        margin-left: 0;
        top: -36px;
        max-width: 345px;
        left: -28px;
        margin-left: 0;
    }
    body.ipad .container-3 .dokokana-block-thum {
        position: absolute;
        right: -83px;
        top: 0;
        max-width: 305px;
    }

    body.ipad .container-4 .dokokana-block-thum {
        left: -60px;
        right: auto;
        max-width: 296px;
        top: -64px;
    }

    body.ipad .free-month-inner {
        padding: 150px 0;
        width: 600px;
        margin-left:auto;
        margin-right: auto;
    }
    body.ipad .dokokana-function-list{
        display: flex;
    }
    body.ipad .dokokana-function-item {
        width: 25%;
        color: #fff;
        padding: 0 15px;
    }
    body.ipad .free-month{
            padding: 0px 0 20px 0;
    }
    body.ipad .dokokana-block .seniorMain_cta_box_r {
        max-width: 363px;
        padding-left: 50px;
    }
    body.ipad .b-device {
        top: 17px;
        left: 93px;
        width: 150px;
        opacity: 1;
    }

    body.ipad .seniorMain_box{
        max-width: 700px;
        flex-direction: row;
        gap: 28px;
    }

    body.ipad .seniorMain_cta_box{
            flex-direction: row;
    }
    body.ipad .seniorMain_cta_box_l{
        margin:0 auto;
    }
    body.ipad .fix-header li,
    body.ipad #global-nav ul li{
      list-style-type: none;
        margin: 8px 10px;
    }
    body.ipad .footer-nav ul li a,
    body.ipad .fix-header li a,
    body.ipad .fix-header li a:visited {
    font-size: 13px;
    font-size: 1.3rem;

    }
    body.ipad .fix-header li:last-child a img{
        top: 0;
    }
    body.ipad .footer-nav ul,
    body.ipad .footer-nav ul li{
        display: flex;
    }
     body.ipad .footer-nav ul li{
        padding: 0 5px;
     }
     body.ipad .free-month {
        background-image: url(../images/kids-free_sp_ipadmimi.jpg);
    }

     body.ipad .free-month-senior{
            background-image: url(../images/senior-free_sp_ipadmini.jpg);
     }


    body.ipad .free-month .dokokana-ttl{
        padding-bottom: 500px;
    }
    body.ipad .b-eye {
        right: -40px;
        top: -47px;
        opacity: 1!important;
    }
}

body.ipad a.button-green{
        font-size: clamp(14px, 1.4vw, 16px);
}


/*----------------------
 すみっこぐらし
-----------------------*/

.sumikko{
    max-width: 850px;
    margin:0 auto;
}

.sumikko img{
    max-width: 100%;
}

.sumikko h4{
    padding-top: 30px;
}
.sumikko-header{
    background-color: #DDEDF8;
    border-top-right-radius: 20px;
    border-top-left-radius: 20px;
    padding: 60px 60px 30px 60px;
}

.sumikko-wrap{
    background-image: url(../images/bg-sumikko.jpg);
    background-repeat: repeat;
    background-size:auto 103%;
    padding: 30px 60px 35px 60px;
    border-bottom-right-radius: 20px;
    border-bottom-left-radius: 20px;

}

.sumikko-product{
    display: flex;
}

.sumikko-item{
    width: 25%;
}

.sumikko-item p{
    text-align: center;
    padding-top: 10px;
    font-size: clamp(16px, 1.8vw, 18px);
}


.sumikko-right{
    text-align: right;
    font-size: 11px;
    padding-top: 20px;
}

.sumikko-banner{
    position: absolute;
    right: 0;
    top: 83px;
    z-index: 1;
}

.sumikko-banner img{
    max-width: 200px;
}

.sumikko-item p.sumikko-text-left{
    text-align: left;
}

.sumikko-item p.sumikko-text-right{
    text-align: right;
}


.sumikko-item p.sumikko-text-edit{
    text-align: left;
    padding-left: 35px;
}


@media screen and (max-width: 768px){

    .sumikko-banner{
        top: 50px;
    }
    .sumikko {
        margin: 0 25px;
        padding-bottom: 28%;
    }

    .sumikko-header{
            padding: 40px 40px 30px 40px;

    }
    .sumikko-wrap{
        padding: 30px 30px 40px 30px;
        background-image: url(../images/bg-sumikko_sp.jpg);
    }

    .sumikko-product{
        display: block;
    }
    .sumikko-item{
        width: 100%;
        padding: 0 15px;
    }

    .sumikko-right{
        text-align: center;
        padding-bottom: 20px;
    }

    .sumikko-item p{
        margin-bottom: 20px;
    }
    .sumikko-banner img{
        max-width: 160px;
    }
    .sumikko-item p.sumikko-text-left{
        text-align: center;
    }

    .sumikko-item p.sumikko-text-right{
        text-align: center;
    }

}


.legacydevice-button{
    text-align: center;
    padding: 15px 0;
}

.legacydevice-button a{
    text-decoration: underline;
    font-size: clamp(16px, 1.8vw, 18px);
}


.legacydevice-button a:hover{
    text-decoration: none;
}






