@charset "Shift_JIS";

/* **************************************************

Name: top.css

Description: CSS for Hitachi.co.jp top page

Create: 2014.02.13
Update: 2017.10.02

Copyright 2017 Hitachi, Ltd.

***************************************************** */



html, body {height: 100%;}

body {background-color: #fff;}
.JS body {background-color: #000;}



/* Skip Link
=========================================================================================== */

#top {
    position: fixed;
    z-index: 5;
    width: 100%;
    min-width: 965px;
    left: 0;
    top: 0;
}



/* Header
=========================================================================================== */

#HeaderArea:before {display: none;}

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

#HeaderArea {
    position: fixed;
    z-index: 6;
    width: 100%;
    top: 0;
}


/* --- Search Box --- */

#Search .BtnOpen {z-index: 6;}

#Search .BtnOpen a.Current {background: none #ccc;}
#Search .BtnOpen a.Current:after {
    content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 0;
    bottom: -8px;
    left: 50%;
    margin: 0 0 0 -15px;
    border-top: solid 15px #ccc;
    border-left: solid 15px transparent;
    border-right: solid 15px transparent;
}

#SearchArea {background-color: rgba(0, 0, 0, .8);}

#Search dt {color: #fff;}

#Search li a:link,
#Search li a:visited {color: #fff;}
#Search li a:hover,
#Search li a:active {color: #fff;}


/* --- Country/Region Selector --- */

#CountryRegion .BtnOpen {z-index: 6;}

#CountryRegion .BtnOpen a.Current {background: none #ccc;}
#CountryRegion .BtnOpen a.Current:after {
    content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 0;
    bottom: -8px;
    left: 50%;
    margin: 0 0 0 -15px;
    border-top: solid 15px #ccc;
    border-left: solid 15px transparent;
    border-right: solid 15px transparent;
}

#CountryRegionArea {background-color: rgba(0, 0, 0, .8);}

#CountryRegion .Inner h2 a:link,
#CountryRegion .Inner h2 a:visited {color: #fff;}
#CountryRegion .Inner h2 a:hover,
#CountryRegion .Inner h2 a:active {color: #fff;}

#CountryRegion .Inner h3 a {
    border-top: solid 1px #444;
    border-bottom: solid 1px #444;
}
#CountryRegion .Inner h3 a:link,
#CountryRegion .Inner h3 a:visited {color: #fff;}

#CountryRegion .Inner ul.Global {border-left: solid 1px #444;}

#CountryRegion .Inner li {
    position: relative;
    color: #fff;
    background-image: none;
}
#CountryRegion .Inner ul:not(.Global) li:after {
    content: "";
    position: absolute;
    display: block;
    width: 4px;
    height: 4px;
    top: 8px;
    left: 5px;
    background-color: #999;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}

#CountryRegion .Inner li a:link,
#CountryRegion .Inner li a:visited {color: #fff;}
#CountryRegion .Inner li a:hover,
#CountryRegion .Inner li a:active {color: #fff;}


/* --- Ultra Global Navigation --- */

#UltraGlobalNavi .BtnOpen {z-index: 6;}

#UltraGlobalNavi .BtnOpen a.Current {background: none #b1000e;}
#UltraGlobalNavi .BtnOpen a.Current:after {
    content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 0;
    bottom: -8px;
    left: 50%;
    margin: 0 0 0 -15px;
    border-top: solid 15px #b1000e;
    border-left: solid 15px transparent;
    border-right: solid 15px transparent;
}

.SuperGlobalNavi {background-color: rgba(0, 0, 0, .8);}

.SuperGlobalNavi h2 a:link,
.SuperGlobalNavi h2 a:visited {color: #fff;}
.SuperGlobalNavi h2 a:hover,
.SuperGlobalNavi h2 a:active {color: #fff;}

.SuperGlobalNavi ul.SubMenu:after {border-bottom: solid 1px #444;}

.SuperGlobalNavi h3 a:link,
.SuperGlobalNavi h3 a:visited {color: #fff;}
.SuperGlobalNavi h3 a:hover,
.SuperGlobalNavi h3 a:active {color: #fff;}

.SuperGlobalNavi li a:link,
.SuperGlobalNavi li a:visited {color: #fff;}
.SuperGlobalNavi li a:hover,
.SuperGlobalNavi li a:active {color: #fff;}

#TopCover {
    position: fixed;
    z-index: 5;
    display: none;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #fff;
}

}



/* You Tube
=========================================================================================== */

#ModalYouTubeCover {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    z-index: 100;
}

#ModalYouTube {
    display: none;
    position: absolute;
    padding: 50px;
    z-index: 102;
}

#ModalYouTube .Inner {
    position: relative;
    background-color: #000;
    box-shadow: 0 0 35px rgba(0, 0, 0, .4);
    -moz-box-shadow: 0 0 35px rgba(0, 0, 0, .4);
    -webkit-box-shadow: 0 0 35px rgba(0, 0, 0, .4);
    -o-box-shadow: 0 0 35px rgba(0, 0, 0, .4);
    -ms-box-shadow: 0 0 35px rgba(0, 0, 0, .4);
}

#ModalYouTube iframe {
    display: block;
    width: 100%;
}

#ModalYouTube .Title {
    height: 50px;
    background-color: #f2f2f2;
    overflow: hidden;
}

#ModalYouTube .Title p {
    display: table-cell;
    height: 50px;
    padding: 0 80px 0 20px;
    vertical-align: middle;
    font-size: 90%;
    font-weight: bold;
    line-height: 130%;
    color: #575757;
}

#ModalYouTube .BtnClose {
    position: absolute;
    right: 0;
    bottom: 0;
    line-height: 130%;
}

#ModalYouTube .BtnClose a {
    display: table-cell;
    min-width: 50px;
    height: 30px;
    padding: 20px 5px 0;
    font-size: 76%;
    text-align: center;
    background-image: url(../../../image/en/r1/icon/icon_close_hd.gif);
    background-position: center 7px;
    background-repeat: no-repeat;
    background-size: 16px 16px;
    -moz-background-size: 16px 16px;
    -webkit-background-size: 16px 16px;
    -o-background-size: 16px 16px;
    -ms-background-size: 16px 16px;
    vertical-align: middle;
}
#ModalYouTube .BtnClose a:link,
#ModalYouTube .BtnClose a:visited {
    color: #fff;
    background-color: #e60027;
    text-decoration: none;
}
#ModalYouTube .BtnClose a:hover,
#ModalYouTube .BtnClose a:active {
    color: #fff;
    background-color: #b1000e;
    text-decoration: none;
}



/* Video / Image
=========================================================================================== */

#TopImgCover {
    position: fixed;
    z-index: 3;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #000;
    opacity: .3;
}

.RDVideoHelper,
#RDHTML5Video {display: none;}

#TopImg {
    position: absolute;
    width: 100%;
    min-width: 965px;
}
.JS #TopImg {
    display: block;
    position: fixed;
    top: 50px;
    width: 100%;
    min-width: 965px;
    height: 100%;
    z-index: 2;
    overflow: hidden;
}
.Flash #TopImg {z-index: 1;}

@media screen and (min-width: 768px) {
    #TopImg {margin-top: 0 !important;}
}

#TopImg .Inner {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
}
.JS #TopImg .Inner {
    position: relative;
    max-width: none;
    height: 100%;
    overflow: hidden;
}

#TopImg .Inner div {
    width: 100%;
    height: 500px;
    overflow: hidden;
    background-color: #000;
}
.JS #TopImg .Inner div {
    position: absolute;
    display: none;
    height: 100%;
    top: 0;
    left: 0;
    background-color: transparent;
}
.NoVideo #TopImg .Inner div {z-index: 1;}
.NoVideo #TopImg1 {z-index: 2}
.JS #TopImg #TopImg1 {display: block;}

#TopImg img {width: 100%;}
#TopImg .FirstImg {display: none;}
#TopImg .LastImg {
    display: inline;
    opacity: .7;
}
.JS #TopImg .FirstImg {display: inline;}
.JS #TopImg .LastImg {
    display: none;
    opacity: 1;
}
.NoVideo #TopImg .FirstImg {display: none;}
.NoVideo #TopImg .LastImg {display: inline;}

.JS #TopMovie {
    position: fixed;
    z-index: 1;
    width: 100%;
    min-width: 965px;
    height: 100%;
    top: 50px;
    overflow: hidden;
}
.Flash #TopMovie {z-index: 2;}

@media screen and (min-width: 768px) {
    #TopMovie {margin-top: 0 !important;}
}

.HTML5 #TopMovie div,
.Flash #TopMovie div {position: relative;}

.HTML5 #TopMovie video {
    display: none;
    width: 100%;
}
.HTML5 #TopMovie video#TopMovie1 {display: block;}

.NoticeArea {
    width: 935px;
    margin: 0 auto 20px;
    padding: 15px 15px 0;
    background-color: #f2f2f2;
    overflow: hidden;
}
.JS .NoticeArea {background-color: #fff;}

.NoticeArea h2 {
    margin: 0;
    padding: 0 0 10px;
    font-size: 90%;
    font-weight: bold;
    color: #575757;
    background-image: none;
}



/* Main
=========================================================================================== */

#Main {
    position: relative;
    z-index: 4;
    width: 965px;
    margin: 0 auto;
}
.JS #Main {
    height: 100%;
    min-height: 640px;
    top: -80px;
    padding: 120px 0 70px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

.JS #StatementArea {
    width: 100%;
    height: 100%;
    padding: 0 0 14.093264%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

.JS #StatementArea .Inner {
    position: relative;
    width: 100%;
    height: 100%;
}
.JS #StatementArea .Inner:before {
    content: "";
    display: inline-block;
    width: 0;
    height: 100%;
    margin: 0 0 0 -.36em;
    vertical-align: middle;
}

.YouTubeLink {position: relative;}

.YouTubeLink:before {
    content: "";
    position: absolute;
    z-index: 1;
    width: 50px;
    height: 50px;
    top: 50%;
    left: 50%;
    margin: -25px 0 0 -25px;
    background-color: #e60027;
    opacity: .5;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.YouTubeLink:after {
    content: "";
    position: absolute;
    z-index: 1;
    width: 36px;
    height: 36px;
    top: 50%;
    left: 50%;
    margin: -18px 0 0 -18px;
    background-color: #e60027;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.PC .YouTubeLink:hover:before,
.PC .YouTubeLink:active:before,
.PC .YouTubeLink:hover:after,
.PC .YouTubeLink:active:after {background-color: #b1000e;}

.YouTubeLink .Img {
    position: relative;
    display: block;
}
.YouTubeLink .Img:after {
    content: "";
    position: absolute;
    z-index: 2;
    width: 0;
    height: 0;
    top: 50%;
    left: 50%;
    margin: -9px 0 0 -3px;
    border-left: solid 9px #fff;
    border-top: solid 9px transparent;
    border-bottom: solid 9px transparent;
}

#StatementArea .Statement {
    position: relative;
    z-index: 1;
    display: block;
    width: 50%;
    height: 400px;
    padding: 100px 0 0;
}
.JS #StatementArea .Statement {
    position: static;
    display: inline-block;
    height: auto;
    padding: 0;
    vertical-align: middle;
}
.JS #StatementArea .Statement:not(#Statement1) {display: none;}
#StatementArea .Statement.RightAdjust,
.JS #StatementArea .Statement.RightAdjust {
    padding-left: 50%;
    text-align: left;
}

#StatementArea .Statement .Copy {
    margin: 0 0 0 -1.4%;
    padding: 0 0 10px;
}

#StatementArea .Banner {overflow: hidden;}

#StatementArea .Banner li {
    position: relative;
    float: left;
    width: 50%;
}

#StatementArea .Banner li a {
    display: block;
    font-size: 90%;
    text-align: center;
    background-color: #000;
    overflow: hidden;
}
#StatementArea .Banner li a:link,
#StatementArea .Banner li a:visited,
#StatementArea .Banner li a:hover,
#StatementArea .Banner li a:active {
    color: #fff;
    text-decoration: none;
}

#StatementArea .Banner li a strong {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    color: #fff;

}

#StatementArea .Banner li a strong span {
    position: absolute;
    display: block;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 10px 15px;
    font-weight: normal;
    line-height: 140%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
}

.PC #StatementArea .Banner li a img {
    transition: transform .2s ease-out, opacity .2s linear;
    -moz-transition: -moz-transform .2s ease-out, opacity .2s linear;
    -webkit-transition: -webkit-transform .2s ease-out, opacity .2s linear;
    -o-transition: -o-transform .2s ease-out, opacity .2s linear;
    -ms-transition: -ms-transform .2s ease-out, opacity .2s linear;
}
.PC #StatementArea .Banner li a:hover img,
.PC #StatementArea .Banner li a:active img {
    opacity: .7;
    transform:scale(1.1);
    -moz-transform:scale(1.1);
    -webkit-transform:scale(1.1);
    -o-transform:scale(1.1);
    -ms-transform:scale(1.1);
}



/* Video Controller
=========================================================================================== */

.JS #VideoControl {
    position: absolute;
    width: 100%;
    height: 25px;
    bottom: -20px;
    left: 0;
    text-align: center;
}

#VideoControl ul {
    display: none;
    overflow: hidden;
}

.JS #VideoControl .Indicator {
    float: left;
    width: 19px;
    height: 19px;
    margin: 4px 12px 0 0;
    overflow: hidden;
}

.JS #VideoControl #VideoPlay {
    float: left;
    width: 27px;
    height: 27px;
    margin: 0 12px 0 0;
    cursor: pointer;
}
.JS #VideoControl .NoIndicator #VideoPlay {
    width: 85px;
    margin: 0;
    background-image: url(/image/jp/r5/main/top_text_play.png);
    background-repeat: no-repeat;
    background-position: top right;
    background-size: 53px 54px;
}
.JS #VideoControl .NoIndicator #VideoPlay.Current {background-position: bottom right;}

.JS #VideoControl .Indicator a {
    position: relative;
    display: block;
    width: 11px;
    height: 11px;
    margin: 4px;
    text-indent: -9999px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.JS #VideoControl .Indicator a:link,
.JS #VideoControl .Indicator a:visited,
.JS #VideoControl .Indicator a:hover,
.JS #VideoControl .Indicator a:active {background-color: #fff;}
.PC #VideoControl .Indicator a:hover,
.PC #VideoControl .Indicator a:active,
.JS #VideoControl .Indicator.Current a {background-color: #e6000e !important;}

.JS #VideoControl .Indicator a:before {
    content: "";
    position: absolute;
    display: none;
    width: 19px;
    height: 19px;
    top: -4px;
    left: -4px;
    background-color: #e6000e;
    opacity: .5;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.PC #VideoControl .Indicator a:hover:before,
.PC #VideoControl .Indicator a:active:before,
.JS #VideoControl .Indicator.Current a:before {display: block;}

.JS #VideoControl #VideoPlay a {
    position: relative;
    display: block;
    width: 19px;
    height: 19px;
    margin: 4px;
    text-indent: -9999px;
    background-color: #e6000e;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.JS #VideoControl #VideoPlay a:before {
    content: "";
    position: absolute;
    display: block;
    width: 27px;
    height: 27px;
    top: -4px;
    left: -4px;
    background-color: #e6000e;
    opacity: .5;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.JS #VideoControl #VideoPlay a:after {
    content: "";
    position: absolute;
    display: block;
    width: 3px;
    height: 11px;
    top: 50%;
    left: 50%;
    margin: -5.5px 0 0 -4.5px;
    border-left: solid 3px #fff;
    border-right: solid 3px #fff;
}
.JS #VideoControl #VideoPlay.Current a:after {
    width: 0;
    height: 0;
    top: 50%;
    left: 50%;
    margin: -5px 0 0 -2px;
    border-left: solid 5px #fff;
    border-right: 0 none;
    border-top: solid 5px transparent;
    border-bottom: solid 5px transparent;
}
.PC #VideoControl #VideoPlay:hover a,
.PC #VideoControl #VideoPlay:hover a:before {background-color: #b1000e;}

#StatementArea .Note {
    position: absolute;
    height: 20px;
    bottom: 15px;
    right: 0;
}
.JS #StatementArea .Note {bottom: -19px;}

#StatementArea .Note img {
    max-width: 100%;
    height: auto;
}



/* News Ticker
=========================================================================================== */

#MainMenuSet {padding: 40px 0 0;}

.JS #MainMenuSet {
    position: absolute;
    width: 100%;
    bottom: 0;
    padding: 0;
}

.JS #News {
    position: relative;
    width: 965px;
    margin: 0 auto;
    background-color: rgba(0, 0, 0, .4);
    overflow: hidden;
}

.JS #News h2 {
    float: left;
    display: block;
    margin: 0;
    padding: 0;
    background-image: none !important;
}

#News h2,
#NewsControl {display: none;}

#News noscript .ButtonStyle1 a {
    width: 25%;
    margin: 0;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

.JS #News h2 span {
    padding: 0;
    font-size: 83%;
    font-weight: normal;
    line-height: 160%;
    background-color: transparent;
}

.JS #News h2 a {
    display: table-cell;
    min-width: 131px;
    height: 39px;
    padding: 1px 5px 0 15px;
    vertical-align: middle;
    background-image: none;
}
.JS #News h2 a:link,
.JS #News h2 a:visited {
    color: #fff;
    background-color: #e60027;
    text-decoration: none;
}
.JS #News h2 a:hover,
.JS #News h2 a:active {
    color: #fff;
    background-color: #b1000e;
    text-decoration: none;
}

.JS #News h2 a:after {
    content: "";
    display: inline-block;
    width: 18px;
    height: 16px;
    margin: 0 0 0 3px;
    background-image: url(../../../image/en/r1/icon/icon_link_right_white_hd.gif);
    background-repeat: no-repeat;
    vertical-align: middle;
    background-size: 16px 16px;
    -moz-background-size: 16px 16px;
    -webkit-background-size: 16px 16px;
    -o-background-size: 16px 16px;
    -ms-background-size: 16px 16px;
}
.JS #News h2 a:link:after,
.JS #News h2 a:visited:after {background-position: top left;}
.JS #News h2 a:hover:after,
.JS #News h2 a:active:after {background-position: top right;}

.JS #News .DateListStyle2 {display: none;}

.JS #News #NewsBody {
    position: absolute;
    height: 1.6em;
    top: 0;
    bottom: 0;
    left: auto !important;
    right: 0 !important;
    margin: auto;
    text-indent: 0;
    overflow: hidden;
}

.JS #News #NewsBodyInner {
    padding: 0 10px 0 15px;
    font-size: 90%;
    white-space: nowrap;
    color: #fff;
}

.JS #News #NewsBodyInner a {
    padding: 0 17px 0 13px;
    color: #fff;
    background-repeat: no-repeat;
    background-position: right center;
    background-size: 16px 16px;
    -moz-background-size: 16px 16px;
    -webkit-background-size: 16px 16px;
    -o-background-size: 16px 16px;
    -ms-background-size: 16px 16px;
}
.JS #News #NewsBodyInner a:link,
.JS #News #NewsBodyInner a:visited {
    background-image: url(../../../image/en/r1/icon/icon_link_right_hd.gif);
    text-decoration: none;
}
.JS #News #NewsBodyInner a:hover,
.JS #News #NewsBodyInner a:active {
    background-image: url(../../../image/en/r1/icon/icon_link_right_hover_hd.gif);
    text-decoration: underline;
}

.JS #News #NewsBodyInner img {
    margin-left: 5px;
    vertical-align: middle;
}

.JS #NewsControl {
    float: left;
    display: block;
    width: 90px;
}

.JS #NewsControl li {
    float: left;
    overflow: hidden;
}

.JS #NewsControl li a {
    position: relative;
    display: block;
    width: 30px;
    height: 40px;
    text-align: center;
    overflow: hidden;
    vertical-align: middle;
    text-indent: -9999px;
}
.JS #NewsControl li a:link,
.JS #NewsControl li a:visited,
.JS #NewsControl li a:hover,
.JS #NewsControl li a:active  {background-color: #e60027;}
.PC #NewsControl li a:hover,
.PC #NewsControl li a:active {background-color: #b1000e;}

.JS #NewsControl #NewsPlay a:after {
    content: "";
    position: absolute;
    display: block;
    width: 3px;
    height: 11px;
    top: 50%;
    left: 50%;
    margin: -5px 0 0 -4px;
    border-left: solid 3px #fff;
    border-right: solid 3px #fff;
}
.JS #NewsControl #NewsPlay a.Current:after {
    width: 0;
    height: 0;
    top: 50%;
    left: 50%;
    margin: -5px 0 0 -1px;
    border-left: solid 5px #fff;
    border-right: 0 none;
    border-top: solid 5px transparent;
    border-bottom: solid 5px transparent;
}

.JS #NewsControl #NewsPrev a:after {
    content: "";
    position: absolute;
    display: block;
    width: 7px;
    height: 7px;
    top: 50%;
    left: 50%;
    margin: -4px 0 0 -3px;
    border-bottom: solid 2px #fff;
    border-left: solid 2px #fff;
    transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
}

.JS #NewsControl #NewsNext a:after {
    content: "";
    position: absolute;
    display: block;
    width: 7px;
    height: 7px;
    top: 50%;
    left: 50%;
    margin: -4px 0 0 -6px;
    border-bottom: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
}



/* Main Menu
=========================================================================================== */

#MainMenu {
    width: 965px;
    margin: 0 auto;
    overflow: hidden;
}

#MainMenu li {
    position: relative;
    float: left;
    width: 25%;
}

#MainMenu a {
    display: block;
    font-size: 90%;
    text-align: center;
    overflow: hidden;
    background-color: #000;
}
#MainMenu a:link,
#MainMenu a:visited,
#MainMenu a:hover,
#MainMenu a:active {
    color: #fff;
    text-decoration: none;
}

.PC #MainMenu a img {
    transition: transform .2s ease-out, opacity .2s linear;
    -moz-transition: -moz-transform .2s ease-out, opacity .2s linear;
    -webkit-transition: -webkit-transform .2s ease-out, opacity .2s linear;
    -o-transition: -o-transform .2s ease-out, opacity .2s linear;
    -ms-transition: -ms-transform .2s ease-out, opacity .2s linear;
}
.PC #MainMenu a:hover img,
.PC #MainMenu a:active img {
    opacity: .7;
    transform:scale(1.1);
    -moz-transform:scale(1.1);
    -webkit-transform:scale(1.1);
    -o-transform:scale(1.1);
    -ms-transform:scale(1.1);
}

#MainMenu strong {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    color: #fff;

}

#MainMenu span {
    position: absolute;
    display: block;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 10px 15px;
    font-weight: normal;
    line-height: 140%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
}



/* Recommend
=========================================================================================== */

#Recommend {padding: 20px 0 0;}
.JS #Recommend {
    position: relative;
    z-index: 3;
    margin: -110px 0 0;
    padding: 50px 0 0;
}

.JS #Recommend .Loading .Grid4 {

    background-repeat: no-repeat;
    background-position: center 120px;
    background-size: 60px 60px;
    -moz-background-size: 60px 60px;
    -webkit-background-size: 60px 60px;
    -o-background-size: 60px 60px;
    -ms-background-size: 60px 60px;
}

.JS #Recommend .ColumnSet {padding: 0 0 40px;}

#Recommend .Title {display: none;}

#Recommend .Column1,
#Recommend .Column2 {
    position: relative;
    margin: 0;
    height: 18.125em;
    min-height: 290px;
    color: #fff;
    background-color: #000;
    overflow: hidden;
}
#Recommend .Column1 {width: 25%;}
#Recommend .Column2 {width: 50%;}

#Recommend .Stock {
    color: #333;
    background-color: #fff;
}
#Recommend .FacebookWidget {
    color: #333;
    background-color: #f6f7f8;
}
#Recommend .Facebook {background-color: #363636;}
#Recommend .Twitter {background-color: #2a2a2a;}
#Recommend .Red1 {background-color: #e60027;}
#Recommend .Red2 {background-color: #b1000e;}
#Recommend .Red3 {background-color: #9a000c;}
#Recommend .Red4 {background-color: #86000a;}
#Recommend .Gray1 {background-color: #2a2a2a;}
#Recommend .Gray2 {background-color: #363636;}
#Recommend .Gray3 {background-color: #424242;}
#Recommend .Gray4 {background-color: #4e4e4e;}

#Recommend .Column1 a,
#Recommend .Column2 a {
    display: block;
    height: 100%;
}
#Recommend .Column1 a:link,
#Recommend .Column1 a:visited,
#Recommend .Column1 a:hover,
#Recommend .Column1 a:active,
#Recommend .Column2 a:link,
#Recommend .Column2 a:visited,
#Recommend .Column2 a:hover,
#Recommend .Column2 a:active {
    color: #fff;
    text-decoration: none;
}
#Recommend .Stock a:link,
#Recommend .Stock a:visited,
#Recommend .Stock a:hover,
#Recommend .Stock a:active {color: #333;}

#Recommend .Tweet a:link,
#Recommend .Tweet a:visited {text-decoration: underline;}
#Recommend .Tweet a:hover,
#Recommend .Tweet a:active {text-decoration: none;}

#Recommend .FacebookWidget a:link,
#Recommend .FacebookWidget a:visited {
    text-decoration: underline;
    color: #c02;
}
#Recommend .FacebookWidget a:hover,
#Recommend .FacebookWidget a:active {
    text-decoration: none;
    color: #b1000e;
}

.PC #Recommend .Red1 a:after,
.PC #Recommend .Red2 a:after,
.PC #Recommend .Red3 a:after,
.PC #Recommend .Red4 a:after,
.PC #Recommend .Stock a:after,
.PC #Recommend .Facebook a:after {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #000;
    opacity: 0;
    transition: opacity .2s linear;
    -moz-transition: opacity .2s linear;
    -webkit-transition: opacity .2s linear;
    -o-transition: opacity .2s linear;
    -ms-transition: opacity .2s linear;
}
.PC #Recommend .Red1 a:hover:after,
.PC #Recommend .Red1 a:active:after,
.PC #Recommend .Red2 a:hover:after,
.PC #Recommend .Red2 a:active:after,
.PC #Recommend .Red3 a:hover:after,
.PC #Recommend .Red3 a:active:after,
.PC #Recommend .Red4 a:hover:after,
.PC #Recommend .Red4 a:active:after,
.PC #Recommend .Stock a:hover:after,
.PC #Recommend .Stock a:active:after,
.PC #Recommend .Facebook a:hover:after,
.PC #Recommend .Facebook a:active:after {opacity: .3;}

.PC #Recommend .Column1 a .Img img,
.PC #Recommend .Column2 a .Img img {
    transition: transform .2s ease-out, opacity .2s linear;
    -moz-transition: -moz-transform .2s ease-out, opacity .2s linear;
    -webkit-transition: -webkit-transform .2s ease-out, opacity .2s linear;
    -o-transition: -o-transform .2s ease-out, opacity .2s linear;
    -ms-transition: -ms-transform .2s ease-out, opacity .2s linear;
}
#Recommend .Column1 a .Thumb img,
#Recommend .Column1 a .Thumb img {vertical-align: middle;}
.PC #Recommend .Column1 a .Thumb img,
.PC #Recommend .Column1 a .Thumb img {
    width: 110px;
    height: auto;
    transition: width .2s ease-out;
    -moz-transition: width .2s ease-out;
    -webkit-transition: width .2s ease-out;
    -o-transition: width .2s ease-out;
    -ms-transition: width .2s ease-out;
}
.PC #Recommend .Column1 a:hover .Img img,
.PC #Recommend .Column1 a:active .Img img,
.PC #Recommend .Column2 a:hover .Img img,
.PC #Recommend .Column2 a:active .Img img {
    opacity: .7;
    transform:scale(1.1);
    -moz-transform:scale(1.1);
    -webkit-transform:scale(1.1);
    -o-transform:scale(1.1);
    -ms-transform:scale(1.1);
}
.PC #Recommend .Column1 a:hover .Thumb img,
.PC #Recommend .Column1 a:active .Thumb img,
.PC #Recommend .Column2 a:hover .Thumb img,
.PC #Recommend .Column2 a:active .Thumb img {width: 121px;}

#Recommend .StockImg {
    padding: 30px 0 0;
    text-align: center;
}

#Recommend .Tweet {padding: 15px 5px 0;}

#Recommend .Tweet a {margin: 0 10px;}

#Recommend .Twitter .TextArea {
    padding-top: 10px;
    background-color: #2a2a2a;
}

#Recommend .Twitter .TextArea:before {
    content: "";
    position: absolute;
    top: -40px;
    left: 0;
    width: 100%;
    height: 40px;

}

#Recommend .FacebookWidget .FbBox {margin: -70px 0 0;}

#Recommend .Facebook .FbBox {
    position: relative;
    z-index: 1;
    max-height: 9em;
    padding: 65px 15px 0;
    overflow: hidden;

    background-repeat: no-repeat;
    background-position: center 25px;
    background-size: 30px 30px;
    -moz-background-size: 30px 30px;
    -webkit-background-size: 30px 30px;
    -o-background-size: 30px 30px;
    -ms-background-size: 30px 30px;
}

#Recommend .Facebook .FbBox p {
    font-size: 83%;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

#Recommend .Tweet a,
#Recommend .FacebookWidget .FbBox a {font-size: 90%;}

#Recommend .Thumb {
    position: relative;
    width: 110px;
    height: 110px;
    top: 2em;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}

#Recommend .Thumb span {
    display: block;
    width: 220px;
    height: 220px;
    margin: -55px 0 0 -55px;
    text-align: center;
}
#Recommend .Thumb span:after {
    content: "";
    display: inline-block;
    width: 0;
    height: 220px;
    vertical-align: middle;
}

#Recommend .TextArea {
    position: absolute;
    z-index: 1;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 60px 0 0;
}

#Recommend .Img + .TextArea {}
#Recommend .Stock .Img + .TextArea {background: none;}

#Recommend .TextArea p {
    padding: 0 15px 10px 15px;
    font-size: 90%;
    line-height: 140%;
}

#Recommend .Column1 .Tag,
#Recommend .Column2 .Tag {
    min-height: 30px;
    margin: 0 15px;
    padding: 5px 0;
    border-top: solid 1px rgba(255, 255, 255, .2);
}
#Recommend .Stock .Tag,
#Recommend .FacebookWidget .Tag {border-top: solid 1px rgba(0, 0, 0, .1);}
#Recommend .Red1 .Tag,
#Recommend .Red2 .Tag,
#Recommend .Red3 .Tag,
#Recommend .Red4 .Tag {border-top: solid 1px rgba(255, 255, 255, .3);}
#Recommend .Facebook .Tag,
#Recommend .Twitter .Tag,
#Recommend .Gray1 .Tag,
#Recommend .Gray2 .Tag,
#Recommend .Gray3 .Tag,
#Recommend .Gray4 .Tag {border-top: solid 1px rgba(255, 255, 255, .15);}

#Recommend .Column1 .Tag:before,
#Recommend .Column2 .Tag:before {
    content: "";
    display: inline-block;
    width: 0;
    height: 30px;
    margin: 0 0 0 -.36em;
    background-color: #c00;
    vertical-align: middle;
}

#Recommend .Column1 .Tag ul,
#Recommend .Column2 .Tag ul {
    display: inline-block;
    margin: 0 0 0 2px;
    vertical-align: middle;
}

#Recommend .Column1 .Tag li,
#Recommend .Column2 .Tag li {
    float: left;
    font-size: 67%;
    padding: 0 10px;
    border-left: solid 1px rgba(255, 255, 255, .2);
}
#Recommend .Stock .Tag li,
#Recommend .FacebookWidget .Tag li {border-left: solid 1px rgba(0, 0, 0, .1);}
#Recommend .Red1 .Tag li,
#Recommend .Red2 .Tag li,
#Recommend .Red3 .Tag li,
#Recommend .Red4 .Tag li {border-left: solid 1px rgba(255, 255, 255, .3);}
#Recommend .Facebook .Tag li,
#Recommend .Twitter .Tag li,
#Recommend .Gray1 .Tag li,
#Recommend .Gray2 .Tag li,
#Recommend .Gray3 .Tag li,
#Recommend .Gray4 .Tag li {border-left: solid 1px rgba(255, 255, 255, .15);}

#Recommend .Column1 .Tag li:first-child,
#Recommend .Column2 .Tag li:first-child {
    padding: 0 10px 0 0;
    border-left: 0 none;
}

#Recommend .Column1 .Img,
#Recommend .Column2 .Img {
    position: absolute;
    width: 300%;
    height: 300%;
    top: -100%;
    left: -100%;
    text-align: center;
}
#Recommend .Column1 .Img:before,
#Recommend .Column2 .Img:before {
    content: "";
    display: inline-block;
    width: 0;
    height: 100%;
    vertical-align: middle;
}

#Recommend .Column1 .Img img,
#Recommend .Column2 .Img img {
    display: inline-block;
    height: auto;
    vertical-align: middle;
}
#Recommend .Column1 .Img img {
    width: 15.125em;
    min-width: 33.33333333%;
}
#Recommend .Column2 .Img img {
    width: 30.1875em;
    min-width: 33.33333333%;
}

.PC #Recommend a img {
    transition: transform .2s ease-out, opacity .2s linear;
    -moz-transition: -moz-transform .2s ease-out, opacity .2s linear;
    -webkit-transition: -webkit-transform .2s ease-out, opacity .2s linear;
    -o-transition: -o-transform .2s ease-out, opacity .2s linear;
    -ms-transition: -ms-transform .2s ease-out, opacity .2s linear;
}
.PC #Recommend a:hover img,
.PC #Recommend a:active img  {
    opacity: .7;
    transform:scale(1.1);
    -moz-transform:scale(1.1);
    -webkit-transform:scale(1.1);
    -o-transform:scale(1.1);
    -ms-transform:scale(1.1);
}

#Category {display: none;}
.JS #Category {
    display: block;
    position: relative;
    padding: 0 0 10px;
    background-color: rgba(0, 0, 0, .3);
}
#Category:after {
    content: "";
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    top: -15px;
    left: 50%;
    margin: 0 0 0 -15px;
    border-bottom: solid 15px rgba(0, 0, 0, .3);
    border-left: solid 15px transparent;
    border-right: solid 15px transparent;
}

#Category h2,
#Category h3 {
    width: 965px;
    margin: 0 auto;
    padding: 20px 0 15px;
    font-size: 76%;
    font-weight: normal;
    text-align: center;
    color: #fff;
    background-image: none;
}

#Category ul {
    width: 965px;
    margin: 0 auto;
    overflow: hidden;
}

#Category li {
    float: left;
    width: 25%;
    font-size: 76%;
}
#Category li:nth-child(4n+1) {clear: both;}

#Category li a {
    position: relative;
    display: inline-block;
    margin: 0 15px 13px 0;
    padding: 0 0 0 25px;
}
#Category li a:link,
#Category li a:visited,
#Category li a:hover,
#Category li a:active {
    color: #fff;
    text-decoration: none;
}
#Category li a:after {
    content: "";
    position: absolute;
    display: block;
    width: 17px;
    height: 17px;
    top: 0;
    left: 0;
    border: solid 1px #fff;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.PC #Category li a:hover:after,
.PC #Category li a:active:after,
#Category li.Current a:after {
    width: 15px;
    height: 15px;
    border: solid 2px #e60027;
}

#Category li a:before {
    content: "";
    position: absolute;
    display: none;
    width: 7px;
    height: 7px;
    top: 6px;
    left: 6px;
    background-color: #e60027;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
}
.PC #Category li a:hover:before,
.PC #Category li a:active:before,
#Category li.Current a:before {display: block;}



/* Contents
=========================================================================================== */

#Contents {
    position: relative;
    z-index: 3;
    padding: 40px 0 0;
}


/* --- Information --- */

#Contents .Column2 {position: relative;}

#Contents .ImportantInfo {
    position: absolute;
    top: 10px;
    right: 10px;
}

#Contents .ImportantInfo li {
    float: left;
    white-space: nowrap;
}

#Contents .ImportantInfo li img {
    margin-right: 10px;
    vertical-align: middle;
}

#Contents .ImportantInfo li a:link,
#Contents .ImportantInfo li a:visited {color: #333;}
#Contents .ImportantInfo li a:hover,
#Contents .ImportantInfo li a:active {color: #b1000e;}



/* Page Top Link
=========================================================================================== */

.PageTop {padding-top: 20px;}



/* Footer
=========================================================================================== */

/* --- Fat Banner --- */

.FatBanner {
    position: relative;
    z-index: 3;
}

.FatBanner .SmallTextStyle {
    height: 3.6em;
    font-size: 83%;
    line-height: 110%;
}


/* --- Footer List --- */

.FooterList {
    position: relative;
    z-index: 3;
    min-width: 965px;
    background-color: #f2f2f2;
    border-top: solid 1px #fff;
}

.FooterListSet {
    width: 965px;
    margin: 0 auto;
    padding: 10px 0 15px;
    overflow: hidden;
}

.FooterList ul {margin: 0;}


/* --- Fat Menu --- */

.FatMenuWide {
    position: relative;
    z-index: 3;
}


/* --- Footer --- */

#Footer {
    position: relative;
    z-index: 3;
}

#Footer ~ noscript div {
    height: 0;
    overflow: hidden;
}



/* Share Buttons
=========================================================================================== */

ul#ShareButtons {
    margin: 0 0 -15px;
    text-align: right;
}

ul#ShareButtons li {
    display: inline-block;
    overflow: hidden;
}

ul#ShareButtons li#SbGplusone {
    width: 53px;
    height: 28px;
    padding-right:20px;
}

ul#ShareButtons li#SbFacebook {
    width: 124px;
    height: 28px;
}

ul#ShareButtons li#SbTwitter {
    width: 90px;
    height: 28px;
    font-size: 90%;
    text-align: left;
}

ul#ShareButtons li iframe.twitter-share-button {width: 118px !important;}

ul#ShareButtons li#SbHatena {padding: 0 1px 0 0;}   /* for iOS8 */



/* SocialAccountBottom
=========================================================================================== */
#SocialAccountBottom {
  position:relative;
  z-index:10;
}



/* for - 994px
=========================================================================================== */

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

    .JS #top,
    .JS #TopImg,
    .JS #TopImg .Inner,
    .JS #TopMovie {min-width: 320px;}

    .JS .NoticeArea {width: auto;}

    .JS #Main {
        width: auto;
        min-width: 320px;
        padding-left: 15px;
        padding-right: 15px;
    }

    .JS #StatementArea .Statement .Copy img {
        max-width: 100%;
        height: auto;
    }

    .JS #StatementArea .Statement .Img img {
        width: 100%;
        height: auto;
    }

    .JS #News {width: auto;}

    .JS #MainMenuSet {
        left: 0;
        padding: 0 15px;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
    }

    .JS #MainMenu {width: auto;}

    .JS #MainMenu img {
        width: 100%;
        height: auto;
    }

    .JS #Recommend {min-width: 320px;}

    .JS #Recommend .GridSet {
        margin: 0;
        padding: 0;
    }

    .JS #Recommend .Grid4 {padding: 0 15px;}

    .JS #Recommend .ColumnSet {margin: 0;}

    .JS #Recommend .Column1,
    .JS #Recommend .Column2 {padding: 0;}

    .JS #Category h2,
    .JS #Category h3 {width: auto;}

    .JS #Category ul {
        width: auto;
        padding: 0 15px
    }

    .JS #Contents {padding: 40px 15px 0;}

    .JS .FooterList {min-width: 320px;}

    .JS .FooterListSet {
        width: auto;
        padding: 10px 15px 15px;
    }

    .JS #Footer {padding-bottom: 25px;}

    .JS #Footer ul {
        width: 60%;
        margin-left: 0;
        margin-right: 0;
    }

    .JS #Footer ul li {margin: 0 0 5px;}

}



/* for - 767px
=========================================================================================== */

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

    .JS #top {position: relative;}

    .JS #HeaderArea {
        position: relative;
        top: 0;
    }
    .MenuOpen #HeaderArea:before {display: block;}

    .JS #HeaderSet {line-height: 0em;}

   /* #TopImgCover {display: none;}*/

    .JS #TopImg,
    .JS #TopMovie {
        position: relative;
        height: 0;
        padding: 0 0 110%;
        overflow: visible;
    }

    .JS #TopImg .Inner,
    .JS #TopMovie .Inner {
        position: absolute;
        width: 100% !important;
        height: 100% !important;
        min-height: 352px;
        top: 0 !important;
        left: 0 !important;
        overflow: hidden;
    }

    .JS #TopImg .Inner div,
    .JS #TopMovie .Inner video {
        position: absolute;
        width: 195.55555555%;
        height: 100%;
        top: 0;
        left: -47.7777774%;
    }

    .JS #ModalYouTube {padding: 50px 0;}

    .JS #ModalYouTube .Title p {font-size: 83%;}

    .JS .NoticeArea {
        margin: 0;
        text-align: left;
    }
    .JS .NoticeArea + .NoticeArea {border-top: solid 1px #ddd;}

    .JS #Main {
        height: auto;
        min-height: 0 !important;
        top: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .JS #StatementArea {
        position: relative;
        height: 0 !important;
        padding: 0 0 110%;
    }

    .JS #StatementArea .Inner {
        position: absolute;
        height: 100%;
        top: 0;
        left: 0;
        padding: 0 0 18.24%;
        text-align: left;
        background-color: rgba(0, 0, 0, .3);
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
    }
    .JS #StatementArea .Inner:before {display: none;}

    .JS #StatementArea .Statement {
        width: 100%;
        height: 100%;
    }
    .JS #StatementArea .Statement.RightAdjust {padding-left: 0;}
    .JS #StatementArea .Statement:before {
        content: "";
        display: inline-block;
        width: 0;
        height: 100%;
        margin: 0 0 0 -.36em;
        vertical-align: middle;
    }

    .JS #StatementArea .Statement .Copy {
        display: inline-block;
        width: 100%;
        margin: 0;
        padding: 0 12px;
        vertical-align: middle;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        -o-box-sizing: border-box;
        -ms-box-sizing: border-box; }

    .JS #StatementArea .Banner {width: 66.66666666%;}

    .JS #VideoControl {
        position: absolute;
        height: auto;
        bottom: 15px;
        padding: 0 15px 18.24%;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
    }
    .JS #VideoControl.WithNote {bottom: 46px;}

    .JS #StatementArea .Banner {
        position: absolute;
        z-index: 1;
        bottom: 0;
    }

    .JS #StatementArea .Note {
        position: static;
        margin: -38px 15px 0;
    }

    .JS #News {
        margin: 0;
        background-color: #fff;
    }

    .JS #News h2 {float: none;}

    .JS #News h2 span {
        display: block;
        background-color: #e60027;
        overflow: hidden;
    }

    .JS #News h2 a {
        position: relative;
        min-width: 116px;
        padding: 1px 25px 0px 15px;
    }
    .JS #News h2 a:after {
        content: "";
        position: absolute;
        top: 13px;
        right: 5px;
        background-image: url(../../../image/en/r1/icon/icon_link_right_l_white_hd.gif);
    }

    .JS #NewsControl {
        position: absolute;
        float: none;
        width: 120px;
        top: 0;
        right: 0;
    }

    .JS #NewsControl li {width: 40px;}

    .JS #NewsControl li a {width: 40px;}

    .JS #News #NewsBody {
        position: static;
        display: table-cell;
        height: 40px;
        vertical-align: middle;
    }

    .JS #News #NewsBodyInner {
        padding-left: 15px;
        color: #333;
    }

    .JS #News #NewsBodyInner a:link,
    .JS #News #NewsBodyInner a:visited,
    .JS #News #NewsBodyInner a:hover,
    .JS #News #NewsBodyInner a:active {color: #c02;}

    .JS #MainMenuSet {
        position: static;
        padding: 0;
        bottom: 0;
    }

    .JS #MainMenu {background-color: #111;}

    .JS #MainMenu li {width: 33.33333333%;}

    .JS #Recommend {
        margin: 0;
        padding: 0;
    }

    .JS #Recommend .Inner {background-color: #111;}

    .JS #Recommend .ColumnSet {padding: 0;}

    .JS #Recommend .Grid4 {padding: 0;}

    .JS #Recommend .Column1 {
        float: left;
        width: 33.33333333%;
    }

    .JS #Recommend .Column2 {
        float: left;
        width: 66.66666666%;
    }

    .JS #Category {
        margin: 0;
        background-color: #222;
    }
    .JS #Category:after {
        z-index: 1;
        border-bottom: solid 15px #222;
    }

    .JS #Category h2,
    .JS #Category h3 {font-size: 83%;}

    .JS #Category ul {padding: 0;}

    .JS #Category li {width: 33.33333333%;}
    .JS #Category li:nth-child(4n+1) {clear: none;}
    .JS #Category li:nth-child(3n+1) {clear: both;}

    .JS #Category li a {margin-left: 15px;}

    .JS #Contents {padding: 30px 15px 0;}

    .JS #Contents .Column2 .Section,
    .JS #Contents .Column2.FirstItem .Section {padding: 0;}

    .JS #Contents .Column2.FirstItem h2 {margin-top: -30px;}
    .JS #Contents .Section + .ColumnSet .Column2.FirstItem h2,
    .JS #Contents .BoxPatternA + .ColumnSet .Column2.FirstItem h2,
    .JS #Contents .BoxPatternB + .ColumnSet .Column2.FirstItem h2,
    .JS #Contents .BoxPatternC + .ColumnSet .Column2.FirstItem h2 {margin-top: 0;}

    .JS #Contents .ImportantInfo {right: -5px;}

    .JS #Contents .LinkListStyle1 dt a {font-weight: normal;}

    .JS #Contents .LinkListStyle1 dd {color: #777;}

    .JS .FooterList {border-top: 0 none;}

    .JS .FooterListSet {padding: 0;}

    .JS .FooterListSet .LinkListStyle6 {
        margin: 0;
        border-bottom: solid 1px #fff;
    }

    .JS .FooterListSet .LinkListStyle6 li {
        width: 50%;
        margin: 0;
        padding: 0;
        border-top: solid 1px #fff;
    }
    .JS .FooterListSet .LinkListStyle6 li:nth-child(3) {clear: both;}

    .JS .FooterListSet .LinkListStyle6 li a {
        position: relative;
        display: block;
        padding: 12px 25px 12px 15px;
        background-image: none;
        text-align: center;
    }
    .JS .FooterListSet .LinkListStyle6 li:nth-child(2n+1) a {border-right: solid 1px #fff;}

    .JS .FooterListSet .LinkListStyle6 li a:link,
    .JS .FooterListSet .LinkListStyle6 li a:visited {
        color: #333;
    }
    .JS .FooterListSet .LinkListStyle6 li a:hover,
    .JS .FooterListSet .LinkListStyle6 li a:active {
        color: #333;
        text-decoration: none;
        background-color: #e5e5e5;
    }

    .JS .FooterListSet .LinkListStyle6 li a:after {
        content: "";
        position: absolute;
        display: block;
        width: 16px;
        height: 16px;
        top: 50%;
        margin: -8px 0 0;
        background-image: url(../../../image/en/r1/icon/icon_link_right_l_hd.gif);
        background-repeat: no-repeat;
        background-size: 16px 16px;
        -moz-background-size: 16px 16px;
        -webkit-background-size: 16px 16px;
        -o-background-size: 16px 16px;
        -ms-background-size: 16px 16px;
    }
    .JS .FooterListSet .LinkListStyle6 li a:link:after,
    .JS .FooterListSet .LinkListStyle6 li a:visited:after {right: 7px;}
    .JS .FooterListSet .LinkListStyle6 li a:hover:after,
    .JS .FooterListSet .LinkListStyle6 li a:active:after {right: 5px;}

    .JS #Footer {padding-bottom: 30px;}

    .JS #Footer ul {
        width: auto;
        padding-right: 0;
    }

    .JS ul#ShareButtons {
        padding: 10px 0 0;
        text-align: center;
    }

    .JS ul#ShareButtons li {padding: 0;}

}



/* for - 579px
=========================================================================================== */

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

    .JS #ModalYouTube .Title p {
        font-size: 83%;
        line-height: 120%;
    }

    .JS #StatementArea .Inner {padding: 0 0 28.151261%;}

    .JS #VideoControl {padding: 0 15px 28.151261%;}

    .JS #StatementArea .Banner {width: 100%;}

    .JS #MainMenu li {width: 50%;}

    .JS #Recommend .Column1 {width: 50%;}
    .JS #Recommend .Column2 {
        float: none;
        width: 100%;
    }

    .JS #Category li {width: 50%;}
    .JS #Category li:nth-child(3n+1) {clear: none;}
    .JS #Category li:nth-child(2n+1) {clear: both;}

}



/* for - 399px
=========================================================================================== */

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

    .JS #StatementArea .Note {margin: -28px 15px 0;}

    .JS #VideoControl.WithNote {bottom: 33px;}

    .JS #Recommend .Column1 {
        float: none;
        width: 100%;
    }

}
