@charset "UTF-8";

/*======================================================================
  Reset CSS for HTML5
======================================================================*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, main, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
ul,ol {
    list-style:none;
}
blockquote, q {
    quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
img {
    line-height: 1;
    vertical-align: middle;
}

/*change colours to suit your needs*/
ins {
    background-color:#ff9;
    color:#222;
    text-decoration:none;
}
mark {
    background-color:#ff9;
    color:#222;
    font-style:italic;
    font-weight:bold;
}
del {
    text-decoration: line-through;
}
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
table {
    border-collapse:collapse;
    border-spacing:0;
    text-align:left;
}
hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
input, select {
    vertical-align:middle;
}


/*======================================================================
  BASIC
======================================================================*/
html { font-size: 62.5%; }
body {
    width: 100%;
    padding-top: 80px;
    line-height: 1.5;
    font-family: 'Arial', 'Verdana', 'Helvetica',  sans-serif;
    color: #212121;
    font-size: 1.4rem;
    word-break: break-word;
    background: #fff;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: 100%;
}

@media screen and (max-width:375px) {
    body {
        padding-top: 60px;
    }
}

p { line-height: 1.5; }

a {
    display: inline-block;
    color: #212121;
    font-weight: normal;
    text-decoration: none;
    transition: all 0.2s ease-in-out;
}
a:hover {
    text-decoration: none;
    opacity: .5;
}

* { box-sizing: border-box; }

/*======================================================================
  FORMAT
======================================================================*/
/* block class */
.wrap {
    overflow: hidden;
	max-width: 1440px;
    margin: 0 auto;
    padding: 0 20px;
}
.col {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

/* responsive */
.sp {
    display: none;
}
.sp_img {
    width: 100%;
    max-width: 100%;
    height: auto;
    backface-visibility: hidden;
}
@media screen and (max-width:414px) {
    .sp {
        display: block;
    }
    .pc {
        display: none;
    }
}

/*======================================================================
  HEADER
======================================================================*/
.hd_tp {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: #fff;
    box-shadow: 0 5px 5px rgba(0, 0, 0, .2);
    z-index: 99;
}
.hd_tp .wrap {
    padding: 20px;
    align-items: center;
}
.lang_switch li {
    font-weight: bold;
}
.lang_switch li:nth-child(1):after {
    content: '|';
    margin: 0 .5rem;
    font-weight: normal;
}
.lang_switch li a {
    color: #bbb;
    font-weight: bold;
}
.lang_switch li a:hover {
    color: #333;
    opacity: 1;
}
.mv_wrap {
    position: relative;
    height: 660px;
}
.mv {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(images/mv.jpg) center / cover no-repeat;
}
.mv .wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}
.fadein {
    color: #fff;
    text-shadow: 0 0 5px #005193;
    text-align: center;
    animation-name: fadein;
    animation-duration: 1s;
    animation-iteration-count: 1;
}
@keyframes fadein {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.fadein h1 {
    font-weight: normal;
    font-size: 9rem;
    line-height: 1;
}
.fadein p {
    margin-top: 65px;
    font-size: 2.4rem;
}
.nav_box {
    padding: 40px 0px;
    background: #1e79c7;
}
.nav ul {
    justify-content: flex-end;
}
.nav li {
    margin-right: 40px;
}
.nav li:last-child {
    margin: 0;
}
.nav a {
    padding-left: 24px;
    color: #fff;
    background: url(images/arw.png) left top 3px no-repeat;
    background-size: 14px;
}

@media screen and (max-width:768px) {
    .fadein h1 {
        font-size: 7rem;
    }
}
@media screen and (max-width:414px) {
    .mv_wrap {
        height: 330px;
    }
    .fadein h1 {
        font-size: 5rem;
    }
    .fadein p {
        margin-top: 20px;
    }
    .nav_box {
        padding: 30px 0px;
    }
    .nav li:nth-child(2) {
        margin-right: 0;
    }
    .nav li:last-child {
        margin-top: 10px;
    }
}
@media screen and (max-width:375px) {
    .hd_logo img {
        width: auto;
        height: 20px;
    }
    .mv_wrap {
        height: auto;
        padding-top: 70.1%;
    }
    .fadein h1 {
        font-size: 3.2rem;
        letter-spacing: -.05rem;
    }
    .fadein p {
        margin-top: 32px;
        font-size: 1.4rem;
    }
    .nav_box {
        padding: 15px 0;
    }
    .nav li {
        margin-right: 11px;
    }
    .nav li:last-child {
        margin-top: 0;
    }
    .nav a {
        padding-left: 15px;
        font-size: 1.2rem;
        background: url(images/arw_sp.png) left top 3px no-repeat;
        background-size: 9px;
    }
}
@media screen and (max-width:320px) {
    .nav li:nth-child(2) {
        margin-right: 0;
    }
}

/*======================================================================
  MAIN
======================================================================*/
/* common */
section {
    padding: 160px 0;
    color: #333;
    font-size: 1.8rem;
}
section:first-child {
    padding-top: 170px;
}
h2 {
    margin-bottom: 50px;
    color: #1e79c7;
    font-size: 7rem;
    line-height: 1.1;
}
h3 {
    margin-bottom: 50px;
    font-size: 5rem;
    line-height: 1.3;
}

@media screen and (max-width:768px) {
    section {
        padding: 70px 0;
        font-size: 1.6rem;
    }
    section:first-child {
        padding-top: 100px;
    }
    h2 {
        font-size: 5rem;
    }
    h3 {
        margin-bottom: 20px;
        font-size: 3rem;
    }
}
@media screen and (max-width:414px) {
    section {
        padding: 50px 0;
        font-size: 1.4rem;
    }
    section:first-child {
        padding-top: 70px;
    }
    h2 {
        margin-bottom: 30px;
        font-size: 3rem;
    }
    h3 {
        font-size: 2rem;
    }
}
@media screen and (max-width:375px) {
    section:first-child {
        padding-top: 50px;
    }
    h2 {
        margin-bottom: 20px;
        font-size: 2.5rem;
    }
    h3 {
        margin-bottom: 20px;
    }
}

/* bg_box */
.bg_box {
    position: relative;
    margin-top: 70px;
}
.bg_img {
    position: absolute;
    top: 0;
}
.bg_txt_wrap {
    display: flex;
    align-items: center;
}
.bg_txt {
    width: 63%;
    padding: 70px;
    background: #fff;
    z-index: 1;
}
.bg_txt_2026 {
    width: 100%;
    padding: 90px 0 45px;
    background: #fff;
    z-index: 1;
}

.bg_box_l .bg_img {
    left: 0;
}
.bg_box_l .bg_txt {
    margin-left: auto;
    border-radius: 20px 0 0 20px;
}

.bg_box_r .bg_img {
    right: 0;
}
.bg_box_r .bg_txt {
    border-radius: 0 20px 20px 0;
}

@media screen and (max-width:1400px) {
    .bg_txt {
        padding: 40px;
    }
}
@media screen and (max-width:1180px) {
    .bg_img {
        width: 40%;
    }
    .bg_txt {
        margin-top: 20px;
    }
}
@media screen and (max-width:768px) {
    .bg_txt {
        padding-bottom: 0;
    }
    .bg_box_l .bg_txt {
        padding: 40px 0 0 40px;
    }
    .bg_box_r .bg_txt {
        padding: 40px 40px 0 0;
    }
}
@media screen and (max-width:414px) {
    .bg_box {
        margin-top: 20px;
    }
    .bg_img {
        position: relative;
        width: auto;
    }
    .bg_box .wrap {
        margin: -40px 0 0 0;
    }
    .bg_txt_wrap {
        height: auto;
    }
    .bg_txt {
        width: 100%;
    }
    .bg_box_l .bg_img {
        margin-right: 20px;
    }
    .bg_box_l .bg_txt {
        padding: 20px 0 0 20px;
        border-radius: 10px 0 0 10px;
    }
    .bg_box_r .bg_img {
        margin-left: 20px;
    }
    .bg_box_r .bg_txt {
        padding: 20px 20px 0 0;
        border-radius: 0 10px 10px 0;
    }
}

/*======================================================================
  About ISB
======================================================================*/
#about h2 {
    margin-bottom: 60px;
}
/* Profile */
.prof p {
    width: 53%;
    line-height: 1.7;
}
.prof_deta {
    width: 41.4%;
    margin: 15px 0 0 40px;
}
.prof_deta dl {
    font-weight: bold;
    text-align: center;
}
.prof_deta dl:nth-child(2) {
    margin: 0 20px;
}
.prof_deta dt {
    margin-bottom: 8px;
    color: #1e79c7;
    font-size: 2rem;
}
.prof_deta dd {
    font-size: 4rem;
}

@media screen and (max-width:1180px) {
    .prof p {
        width: 70%;
        margin: auto;
    }
    .prof_deta {
        justify-content: center;
        width: 100%;
        margin: 40px 0 0 0;
    }
    .prof_deta dl {
        width: 33%;
    }
    .prof_deta dl:nth-child(2) {
        margin: 0;
    }
}
@media screen and (max-width:768px) {
    #about h2 {
        margin-bottom: 40px;
    }
    .prof p {
        width: 100%;
    }
    .prof_deta dd {
        font-size: 3rem;
    }
}
@media screen and (max-width:414px) {
    .prof_deta dt {
        height: 48px;
        font-size: 1.6rem;
    }
    .prof_deta dd {
        font-size: 1.8rem;
    }
}
@media screen and (max-width:375px) {
    #about h2 {
        margin-bottom: 25px;
    }
    .prof_deta {
        margin-top: 27px;
    }
    .prof_deta dl {
        width: auto;
    }
    .prof_deta dl:nth-child(2) {
        margin: 0 14px;
    }
    .prof_deta dt {
        height: auto;
        font-size: 1.2rem;
    }
    .prof_deta dd {
        font-size: 2rem;
    }
}

/* ISB Group */
.group {
    margin-top: 120px;
}
.group .bg_txt_wrap {
    height: 508px;
}
.group .bg_txt {
    width: 58%;
    padding: 40px 70px;
}
.group h3 {
    margin-bottom: 13px;
}
.group ul {
    margin-top: 60px;
}
.group li {
    width: calc(100% / 2 - 10px);
    margin-top: 20px;
    font-weight: bold;
    font-size: 2rem;
}
.group li:nth-child(1),
.group li:nth-child(2) {
    margin-top: 0;
}
.group li a {
    padding-right: 24px;
    color: #1e79c7;
    font-weight: bold;
    background: url(images/arw_bl.png) right top 5px no-repeat;
}

@media screen and (max-width:1400px) {
    .group ul {
        margin-top: 30px;
    }
}
@media screen and (max-width:1180px) {
    .group .bg_txt_wrap {
        height: auto;
    }
    .group .bg_txt {
        margin-top: 0;
        padding: 20px;
    }
}
@media screen and (max-width:768px) {
    .group {
        margin-top: 65px;
    }
    .group ul {
        margin-top: 20px;
    }
    .group .bg_txt {
        padding-bottom: 0;
    }
    .group li {
        width: 100%;
    }
    .group li:nth-child(2) {
        margin-top: 20px;
    }
}
@media screen and (max-width:414px) {
    .group {
        margin-top: 50px;
    }
    .group.bg_box .wrap {
        margin: 0;
    }
    .group .bg_txt {
        width: 100%;
        padding: 40px 0 0 0;
    }
    .group ul {
        margin-top: 30px;
    }
    .group li,
    .group li:nth-child(2) {
        margin-top: 15px;
        font-size: 1.6rem;
    }
    .group li a {
        padding-right: 20px;
        background: url(images/arw_bl_sp.png) right top 3px no-repeat;
    }
}
@media screen and (max-width:375px) {
    .group {
        margin-top: 30px;
    }
    .group ul {
        margin-top: 25px;
    }
    .group li {
        width: 50%;
        margin-top: 15px;
        font-size: 1.1rem;
    }
    .group li:nth-child(2) {
        margin-top: 0;
        font-size: 1.1rem;
    }
    .group li a {
        padding-right: 8px;
        background-position-y: 4px;
        background-size: 5px;
    }
}

/*======================================================================
  Financial Documentsi
======================================================================*/
/* pdf link */
.pdf_link li {
    width: calc(100% /2 - 40px);
    margin-bottom: 70px;
}
.pdf_link li:last-child {
    margin-bottom: 0;
}
.pdf_link li a {
    font-weight: bold;
}
.pdf_link p {
    margin-bottom: 13px;
    font-size: 2.4rem;
    line-height: 1.6;
}
.pdf_link span {
    display: inline-block;
    padding-right: 20px;
    color: #1e79c7;
    background: url(images/arw_bl.png) right top 5px no-repeat;
}

@media screen and (max-width:768px) {
    .pdf_link li {
        margin-bottom: 30px;
    }
    .pdf_link p {
        margin-bottom: 5px;
        font-size: 2rem;
    }
}
@media screen and (max-width:414px) {
    .pdf_link li {
        width: 100%;
        margin-bottom: 25px;
    }
    .pdf_link p {
        margin-bottom: 4px;
        font-size: 1.6rem;
    }
    .pdf_link span {
        font-size: 1.4rem;
        background: url(images/arw_bl_sp.png) right top 3px no-repeat;
        background-size: 8px;
    }
}
@media screen and (max-width:375px) {
    .pdf_link p {
        font-size: 1.2rem;
    }
    .pdf_link span {
        padding-right: 15px;
        font-size: 1.1rem;
        background-position-y: 4px;
        background-size: 5px;
    }
}

/* 2021 Financial Results Summary */
.results h3,
.category h3 {
    margin-top: 120px
}
.results h3 {
    margin-bottom: 45px;
}
.results dl {
    text-align: center;
    font-weight: bold;
}
.results dt {
    margin-bottom: 7px;
    color: #1e79c7;
    font-size: 2.4rem;
}
.results dd {
    font-size: 3rem;
}
.results dd:before {
    content: url(images/yen.png);
    vertical-align: middle;
}
.results .unit {
    display: inline-block;
    padding-left: 2px;
    font-size: 2rem;
}

@media screen and (max-width:1200px) {
    .results dl {
        width: 30%;
    }
    .results dl:nth-child(n+4) {
        margin-top: 20px;
    }
}
@media screen and (max-width:768px) {
    .results h3,
    .category h3 {
        margin-top: 65px;
    }
    .results h3 {
        margin-bottom: 0;
    }
    .results dl {
        margin-top: 30px;
    }
    .results dt {
        font-size: 2rem;
    }
    .results dd {
        display: inline-block;
        padding-left: 20px;
        font-size: 2.5rem;
        background: url(images/yen.png) left top 7px no-repeat;
        background-size: 19px;
    }
    .results dd:before {
        content: none;
    }
    .results .unit {
        font-size: 1.6rem;
    }
}
@media screen and (max-width:550px) {
    .results dl {
        width: 50%;
    }
    .results dl:nth-child(n+3) {
        margin-top: 20px;
    }
}
@media screen and (max-width:414px) {
    .results h3 {
        margin: 50px 0 0;
    }
    .results dl {
        width: 50%;
        margin-top: 30px;
    }
    .results dt {
        font-size: 1.8rem;
    }
    .results dd {
        padding-left: 18px;
        font-size: 2rem;
        background: url(images/yen_sp.png) left top 6px no-repeat;
        background-size: 16px;
    }
    .category h3 {
        margin-top: 50px;
    }
}
@media screen and (max-width:375px) {
    .results dl,
    .results dl:nth-child(n+3) {
        width: calc(100% / 3);
        margin-top: 30px;
    }
    .results dt {
        font-size: 1.2rem;
    }
    .results dd {
        padding-left: 10px;
        font-size: 1.5rem;
        background-position-y: 5px;
        background-size: 10px;
    }
    .results .unit {
        font-size: 1.1rem;
    }
    .results h3 {
        margin: 60px 0 0;
    }
    .category h3 {
        margin: 60px 0 30px;
    }
}
@media screen and (max-width:320px) {
    .results .unit {
        letter-spacing: -.03rem;
    }
}

/* 2021 Sales by Category */
.category .sp strong {
    display: block;
    margin: 15px 0 8px;
    padding: 5px;
    color: #fff;
    font-size: 1.6rem;
    background: #1e79c7;
}
.category .sp .col {
    justify-content: flex-end;
    font-weight: bold;
    font-size: 2rem;
}
.category .sp .col div:nth-child(2) {
    margin-left: 30px;
}
.category .sp .unit {
    padding-left: 2px;
    font-size: 1.6rem;
}

@media screen and (max-width:375px) {
    .category .sp strong {
        font-size: 1.2rem;
    }
    .category .sp .col {
        font-size: 1.5rem;
    }
    .category .sp .col div:nth-child(2) {
        margin-left: 20px;
    }
    .category .sp .unit {
        font-size: 1.1rem;
    }
}

/*======================================================================
  Mid-term Business Plan 2023
======================================================================*/
@media screen and (max-width:414px) {
    #plan h2 {
        margin-bottom: 30px;
    }
}
@media screen and (max-width:375px) {
    #plan h2 {
        margin-bottom: 20px;
        letter-spacing: -.05rem;
    }
}

/* Objective */
.objective .bg_txt_wrap {
    height: 390px;
}
.objective h3  {
    margin-bottom: 40px;
}
.objective p {
    line-height: 1.7;
}

@media screen and (max-width:1400px) {
    .objective h3 {
        margin-bottom: 20px;
    }
}
@media screen and (max-width:1180px) {
    .objective .bg_txt_wrap {
        height: auto;
    }
}
@media screen and (max-width:414px) {
    .objective h3  {
        margin-bottom: 15px;
    }
}

/* ISB Group's 2023 Sales Goals */
.goals .bg_txt_wrap {
    height: 418px;
}
.goals .col {
    width: 85%;
}
.goals dl {
    font-weight: bold;
}
.goals dl:nth-child(2) {
    margin: 0 24px;
}
.goals dt {
    color: #1e79c7;
    font-size: 2rem;
}
.goals dd {
    font-size: 4rem;
}
.goals dd.goals_yen:before {
    content: url(images/yen_goals.png);
}
.goals .unit {
    padding-left: 2px;
    font-size: 2rem;
}

@media screen and (max-width:1400px) {
    .goals h3 {
        margin-bottom: 20px;
    }
}
@media screen and (max-width:1240px) {
    .goals .col {
        width: 100%;
    }
}
@media screen and (max-width:1180px) {
    .goals .bg_txt_wrap {
        height: auto;
    }
}
@media screen and (max-width:995px) {
    .goals dl:nth-child(3) {
        margin-top: 20px;
    }
}
@media screen and (max-width:768px) {
    .goals .col {
        width: 100%;
    }
    .goals dd {
        font-size: 2.5rem;
    }
    .goals dd.goals_yen {
        padding-left: 19px;
        background: url(images/yen_goals.png) left top 9px no-repeat;
        background-size: 17px;
    }
    .goals dd.goals_yen:before {
        content: none;
    }
}
@media screen and (max-width:680px) {
    .goals dl {
        width: 100%;
    }
    .goals dl:nth-child(2) {
        margin: 20px 0 0 0;
    }
}
@media screen and (max-width:414px) {
    .goals h3 {
        margin-bottom: 15px;
    }
    .goals dl {
        width: auto;
    }
    .goals dl:nth-child(2) {
        margin: 0;
    }
    .goals dl:nth-child(3) {
        margin-top: 0;
    }
    .goals dt {
        font-size: 1.6rem;
    }
    .goals dd {
        font-size: 2rem;
    }
    .goals dd.goals_yen {
        padding-left: 16px;
        background: url(images/yen_sp.png) left top 7px no-repeat;
        background-size: 14px;
    }
    .goals .unit {
        font-size: 1.6rem;
    }
}
@media screen and (max-width:375px) {
    .goals dt {
        font-size: 1.2rem;
    }
    .goals dd {
        font-size: 1.5rem;
    }
    .goals dd.goals_yen {
        padding-left: 12px;
        background-position-y: 5px;
        background-size: 11px;
    }
    .goals .unit {
        font-size: 1.1rem;
    }
}

/* Strategic Focus */
.focus .bg_txt_wrap {
    height: 780px;
}
.focus li {
    margin-top: 60px;
}
.focus li:first-child {
    margin-top: 0;
}
.focus strong {
    display: block;
    margin-bottom: 15px;
    color: #1e79c7;
    font-size: 2.6rem;
}

@media screen and (max-width:1400px) {
    .focus h3 {
        margin-bottom: 20px;
    }
    .focus li {
        margin-top: 30px;
    }
}
@media screen and (max-width:1180px) {
    .focus .bg_txt_wrap {
        height: auto;
    }
}
@media screen and (max-width:768px) {
    .focus li {
        margin-top: 30px;
    }
    .focus strong {
        font-size: 2rem;
        line-height: 1.3;
    }
}
@media screen and (max-width:414px) {
    .focus li {
        margin-top: 20px;
    }
    .focus strong {
        margin-bottom: 10px;
        font-size: 1.8rem;
    }
}
@media screen and (max-width:375px) {
    .focus li {
        margin-top: 15px;
    }
    .focus strong {
        font-size: 1.6rem;
    }
    .focus strong br {
        display: none;
    }
}


/*======================================================================
  Note
======================================================================*/
#note {
    padding-bottom: 320px;
}
#note .bg_txt_wrap {
    height: 394px;
}
#note .bg_box {
    margin: 0;
}
#note .bg_box .wrap {
    margin-top: 0;
}
#note .bg_txt {
    width: 58%;
    margin: 0;
    padding: 40px 70px 40px 0;
}
#note h2 {
    margin-bottom: 30px;
    font-size: 2.6rem;
}
#note p {
    line-height: 1.7;
}

@media screen and (max-width:768px) {
    #note {
        padding-bottom: 40px;
    }
    #note .bg_txt_wrap {
        height: auto;
    }
    #note .bg_txt {
        padding: 0 20px 0 0;
    }
    #note h2 {
        font-size: 2rem;
    }
}
@media screen and (max-width:414px) {
    #note {
        padding-bottom: 100px;
    }
    #note .bg_box {
        padding: 0;
    }
    #note .bg_txt {
        width: 100%;
        padding: 26px 0 0 0;
    }
    #note h2 {
        margin-bottom: 15px;
        font-size: 1.8rem;
    }
}
@media screen and (max-width:375px) {
    #note {
        padding-bottom: 80px;
    }
    #note .bg_txt_wrap {
        height: auto;
    }
    #note .bg_txt {
        width: 100%;
    }
    #note h2{
        font-size: 1.6rem;
    }
}


/*======================================================================
  FOOTER
======================================================================*/
footer {
    font-size: 1.4rem;
    text-align: center;
    padding: 26px 0;
    background: #f2f2f2;
}
.page_top {
    position: fixed;
    right: 20px;
    bottom: 16px;
    z-index: 50;
}
.page_top a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: #fff;
    border: 1px solid #1e79c7;
}
footer.ft_in .page_top a {
    background: #f2f2f2;
}

@media screen and (max-width:414px) {
    .page_top a { 
        display: none;
    }
}

@media screen and (max-width:375px) {
    footer {
        padding: 12px 0;
        font-size: 1.1rem;
    }
}


/*======================================================================
  SCROLL ANIM
======================================================================*/
/* common */
.body_wrap {
    overflow-x: hidden;
}
.anim {
    opacity: 0;
}
.anim.is-animated {
    opacity: 1;
}

/* img */
.fadeIn_left.is-animated,
.fadeIn_right.is-animated {
    animation-duration: 2s;
    animation-fill-mode: forwards;
}
.fadeIn_left.is-animated {
    animation-name: fadeLeftAnime;
    opacity: 0;
}
@keyframes fadeLeftAnime{
    from {
        opacity: 0;
        transform: translateX(-100px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.fadeIn_right.is-animated {
    animation-name: fadeRightAnime;
    opacity: 0;
}
@keyframes fadeRightAnime{
    from {
        opacity: 0;
        transform: translateX(100px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* txt */
.smooth {
    clip-path: inset(0 100% 0 0);
    display: inline-block;
    transition: 1s cubic-bezier(0.37, 0, 0.63, 1);
    transition-property: clip-path;
}
.smooth.is-animated {
    clip-path: inset(0);
}
