@charset "utf-8";
#bread { margin: 0 auto; }
/* ------------------------------------------------------------ fv */
#fv { margin: 92px auto 0; background: url(../images/service/fv.jpg) no-repeat center center; background-size: cover; }
/* ------------------------------------------------------------ anywhere */
#anywhere { position: relative; margin: 80px auto 0; }
#anywhere:after { position: absolute; content: ""; bottom: 0; width: 100%; height: 85px; background: #f8fafc; z-index: -1; }
#anywhere .box { max-width: 1400px; background: url(../images/service/bg_01.png) no-repeat left top; padding: 140px 0; margin: 0 auto; }
#anywhere .textbox { float: right; width: 430px; }
#anywhere .textbox h3 { font-size: 54px; font-weight: 600; padding: 0 0 30px; }
#anywhere .textbox h3 span { background: url(../images/service/dot.png) no-repeat center top; padding: 15px 0 0; font-weight: 600; }
#anywhere .textbox p { font-size: 18px; font-weight: 600; line-height: 42px; }
#anywhere .textbox p span { border-bottom: solid 3px #d60603; font-weight: 600; }
#anywhere .textbox p strong { color: #d60603; font-weight: 600; }
/* ------------------------------------------------------------ scene */
#scene { background: #f8fafc; padding: 110px 0; }
#scene ul { padding: 45px 0 0; }
#scene ul li { float: left; width: 340px; padding: 0 0 40px 40px; }
#scene ul li:nth-child(3n+1) { clear: both; padding: 0; }
#scene ul li h4 { text-align: center; font-weight: 600; font-size: 22px; line-height: 34px; padding: 20px 0 0; }
#scene ul li h4 strong { font-size: 32px; color: #d70000; font-weight: 600; } 
#scene .birth { font-size: 34px; text-align: center; letter-spacing: 2px; font-weight: 600; line-height: 50px; }
#scene .birth span { font-size: 60px; color: #d70000; font-family: 'Lato', sans-serif; }
#scene .birth strong { font-weight: 600; }
#scene p { text-align: center; font-size: 20px; line-height: 38px; padding: 20px 0 0; }
/* ------------------------------------------------------------ merit */
#merit { background: url(../images/service/pattern_01.gif) repeat; padding: 80px 0 140px; }
#merit .inner { width: 880px; }
#merit h3 { font-size: 40px; font-weight: 600; text-align: center; }
#merit h3 small { font-size: 24px; font-weight: 600; color: #d70000; display: block; line-height: 110px; }
#merit h3 strong { font-size: 130px; font-family: 'Lato', sans-serif; font-weight: 700; font-style: italic; color: #d70000; }
#merit h3 span { font-size: 70px; font-weight: 600; }
#merit ol li { width: 100%; background: #fff; border: 1px solid #ccc; text-align: center; border-radius: 10px; -moz-border-radius: 10px; -webkit-border-radius: 10px; padding: 60px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; margin: 45px auto 0; }
#merit ol li img { display: block; margin: 0 auto; padding: 0 0 25px; }
#merit ol li h4 { font-size: 36px; color: #d70000; font-weight: 600; display: inline-block; *display: inline; *zoom: 1; letter-spacing: 1px; }
#merit ol li:nth-child(1) h4 { background: url(../images/service/number_01.gif) no-repeat 10px center; padding: 40px 0 0 65px; }
#merit ol li:nth-child(2) h4 { background: url(../images/service/number_02.gif) no-repeat left center; padding: 40px 0 0 75px; }
#merit ol li:nth-child(3) h4 { background: url(../images/service/number_03.gif) no-repeat left center; padding: 40px 0 0 75px; }
#merit ol li p { font-size: 20px; font-weight: 600; line-height: 42px; padding: 15px 0 0; }
/* ------------------------------------------------------------ function */
#function { padding: 100px 0 140px; }
#function .inner { width: 985px; }
#function ul { padding: 60px 0 0; }
#function ul li { width: 470px; border: 1px solid #ccc; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; border-radius: 10px; -moz-border-radius: 10px; -webkit-border-radius: 10px; position: relative; text-align: center; padding: 75px 0 0; float: left; }
#function ul li:first-child { margin: 0 45px 0 0; }
#function ul li .icn { position: absolute; left: 0; right: 0; margin: 0 auto; top: -30px; }
#function ul li h4 { font-size: 30px; color: #d70000; font-weight: 600; padding: 0 0 12px; }
#function ul li p { font-size: 24px; font-weight: 600; line-height: 36px; padding: 0 0 30px; }
/* ------------------------------------------------------------ security */
#security { background: url(../images/service/bg_02.gif) no-repeat center center; padding: 160px 0 110px; }
#security .inner { width: 985px; }
#security .box { padding: 0 0 70px; }
#security .box .textbox { float: left; }
#security .box h3 { font-size: 60px; font-weight: 600; letter-spacing: 2px; }
#security .box h3 span { font-size: 40px; font-family: 'Lato', sans-serif; font-weight: 700; color: #d70000; display: block; padding: 0 0 20px; }
#security .box h4 { font-size: 18px; color: #d60603; font-weight: 600; padding: 55px 0 20px; }
#security .box p { font-size: 14px; line-height: 34px; }
#security .box p span { border-bottom: solid 2px #d60603; line-height: 34px; }
#security .box img { float: right; }
#security .vpn { background: #fff; border-radius: 78.5px; -moz-border-radius: 78.5px; -webkit-border-radius: 78.5px; padding: 12px 15px; }
#security .vpn img { float: left; }
#security .vpn .textbox { float: left; padding: 20px 0 0 40px; }
#security .vpn h4 { font-size: 18px; color: #d70000; font-weight: 600; line-height: 38px; }
#security .vpn p { font-size: 14px; line-height: 26px; }
#security .vpn p span { border-bottom: solid 2px #d60603; }
/* ------------------------------------------------------------ plan */
#plan { padding: 90px 0 120px; }
#plan .table_wrap.PC table { border-collapse: separate; border-spacing: 6px 0; padding: 30px 0 20px; margin: 0 auto;}
#plan .table_wrap.PC th { font-size: 22px; font-weight: 600; text-align: center; color: #d50403; border-bottom: solid 1px #eaedee; border-top: solid 4px #d50a03; box-shadow: -3px 0 3px rgba(0,0,0,0.1); padding: 30px 5px; width: 220px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
#plan .table_wrap.PC th:first-child { border: none; box-shadow: inherit; }
#plan .table_wrap.PC th:last-child { border-right: solid 1px #e7e6e7; }
#plan .table_wrap.PC th span { display: block; font-size: 12px; color: #000; padding: 8px 0 0; }

#plan .table_wrap.PC td { font-size: 15px; font-weight: 600; text-align: center; line-height: 24px; background: #fff; border-bottom: solid 1px #eaedee; box-shadow: -3px 0 3px rgba(0,0,0,0.1); padding: 25px 15px; }
#plan .table_wrap.PC td:first-child { background: #f3f7fa; font-size: 16px; font-weight: 600; text-align: center; border-bottom: solid 1px #eaedee; box-shadow: inherit; }
#plan .table_wrap.PC td:first-child span { display: block; font-size: 12px; }
#plan .table_wrap.PC td:last-child { border-right: solid 1px #e7e6e7; }
/* ------ 最後の行の影 始まり----- */
#plan .table_wrap.PC tr:last-child td { box-shadow: -3px 2px 3px rgba(0,0,0,0.1); }
#plan .table_wrap.PC tr:last-child td:first-child { box-shadow: inherit; }
/* ------ 最後の行の影 終わり----- */
#plan .table_wrap.PC td p { font-weight: 600; }
#plan .table_wrap.PC td strong { font-weight: 600; border-bottom: solid 3px #d50a03; }
#plan .table_wrap.PC td span.pad { display: block; padding: 5px 0 0; }
#plan .allspot { background: url(../images/service/icn_03.png) no-repeat center top; padding: 45px 0 0; }
#plan .freeonly { background: url(../images/service/icn_04.png) no-repeat center top; padding: 45px 0 0; }
#plan .highspeed { background: url(../images/service/icn_05.png) no-repeat center top; padding: 40px 0 0; }
#plan .lowspeed { background: url(../images/service/icn_06.png) no-repeat center top; padding: 40px 0 0; }
#plan .secure { background: url(../images/service/icn_07.png) no-repeat center top; padding: 40px 0 0; }
#plan .caution { line-height: 24px; font-size: 12px; padding: 0 0 0 140px; }
/* ------------------------------------------------------------ footer */
footer { margin: 150px auto 0; }





/* ------------------------------------------------------------ mobile */
@media only screen and (max-width:640px){
#bread { margin: 0 auto; }
/* ------------------------------------------------------------ fv */
#fv { margin: 60px auto 0; }
/* ------------------------------------------------------------ anywhere */
#anywhere { margin: 50px auto 60px; }
#anywhere:after { display: none; }
#anywhere img { width: 90%; height: auto; margin: 0 auto; }
#anywhere .box { max-width: 100%; background: none; padding: 50px 0 0; margin: 0 auto; }
#anywhere .textbox { float: none; width: 100%; }
#anywhere .textbox h3 { font-size: 32px; padding: 0 0 15px; }
#anywhere .textbox h3 span { }
#anywhere .textbox p { font-size: 16px; line-height: 32px; }
#anywhere .textbox p span { }
#anywhere .textbox p strong { }
/* ------------------------------------------------------------ scene */
#scene { padding: 60px 0 50px; }
#scene ul { padding: 20px 0 0; }
#scene ul li { float: none; width: 100%; padding: 0 0 40px; }
#scene ul li:first-child { padding: 0 0 40px; }
#scene ul li img { width: 100%; height: auto; }
#scene ul li h4 { font-size: 18px; line-height: 34px; padding: 15px 0 0; }
#scene ul li h4 strong { font-size: 27px; } 
#scene .birth { font-size: 20px; line-height: 36px; }
#scene .birth span { font-size: 40px; display: none; }
#scene .birth strong { border-bottom: solid 2px #d60603; }
#scene p { text-align: left; font-size: 16px; line-height: 27px; padding: 15px 0 0; }
/* ------------------------------------------------------------ merit */
#merit { padding: 30px 0 70px; }
#merit .inner { width: 90%; }
#merit h3 { font-size: 24px; font-weight: 600; text-align: center; }
#merit h3 small { font-size: 16px; line-height: 80px; }
#merit h3 strong { font-size: 80px; }
#merit h3 span { font-size: 38px; }

#merit ol li { width: 100%; margin: 25px auto 0; padding: 30px 5%; }
#merit ol li img { width: 200px; height: auto; padding: 0 0 15px; }
#merit ol li h4 { font-size: 22px; line-height: 32px; }
#merit ol li:nth-child(1) h4 { padding: 6px 0 0 55px; background-size: auto 50px; }
#merit ol li:nth-child(2) h4 { padding: 33px 0 0 55px; background-size: auto 50px; }
#merit ol li:nth-child(3) h4 { padding: 6px 0 0 55px; background-size: auto 50px; }
#merit ol li p { font-size: 16px; line-height: 27px; padding: 15px 0 0; text-align: left; }
/* ------------------------------------------------------------ function */
#function { padding: 60px 0 70px; }
#function .inner { width: 90%; }
#function ul { padding: 50px 0 0; }
#function ul li { width: 100%; padding: 55px 0 0; float: left; }
#function ul li:first-child { margin: 0 auto 70px; }
#function ul li .icn { top: -30px; width: auto; height: 60px; }
#function ul li h4 { font-size: 24px; padding: 0 0 15px; }
#function ul li p { font-size: 18px; line-height: 27px; padding: 0 0 25px; }
/* ------------------------------------------------------------ security */
#security { background: #f3f7fa; padding: 50px 0 60px; }
#security .inner { width: 90%; }
#security .box { padding: 0 0 50px; }
#security .box .textbox { float: none; }
#security .box h3 { font-size: 30px; }
#security .box h3 span { font-size: 24px; padding: 0 0 16px; }
#security .box h4 { font-size: 18px; padding: 30px 0px 8px 1em; text-indent: -1em; line-height: 27px; }
#security .box p { font-size: 14px; line-height: 27px; }
#security .box p span { line-height: 27px; }
#security .box img { float: none; width: 270px; height: auto; display: block; margin: 0 auto; padding: 30px 0 0; }

#security .vpn { border-radius: inherit; padding: 30px 5%; text-align: center; }
#security .vpn img { float: none; }
#security .vpn .textbox { float: none; padding: 20px 0 0; }
#security .vpn h4 { font-size: 18px; line-height: 27px; text-align: left; padding: 0 0 6px; }
#security .vpn p { font-size: 14px; line-height: 27px; text-align: left; }
#security .vpn p span { line-height: 27px; }
/* ------------------------------------------------------------ plan */
#plan { padding: 50px 0 100px; }
#plan .table_wrap { padding: 0 0 50px; }
#plan h3 { padding: 0 0 25px; }
#plan h4 { font-size: 20px; color: #d50403; font-weight: 600; padding: 0 0 15px; }
#plan h4 span { font-size: 12px; color: #000; font-weight: normal; padding: 0 0 0 5px; }
#plan table,
#plan table tbody,
#plan table tr { width: 100%; }
#plan table , td, th { border: 1px solid #eaedee; border-collapse: collapse; vertical-align: middle; }
#plan .table_wrap.last { padding: 0 0 20px; }
#plan .table_wrap.SP th { font-size: 14px; width: 110px; font-weight: 600; line-height: 18px; background: #f3f7fa; padding: 15px 0; }
#plan .table_wrap.SP td { font-size: 14px; width: calc(100% - 111px); line-height: 20px; text-align: center; padding: 15px 0; font-weight: 600; }
#plan .table_wrap.SP td p { font-weight: 600; }
#plan .table_wrap.SP td img { width: auto; height: 38px; }
#plan .table_wrap.SP td img.bar { width: 20px; height: auto; }
#plan .caution { line-height: 24px; font-size: 12px; padding: 0 0 0 6px; }
/* ------------------------------------------------------------ footer */
footer { margin: 0 auto; }
}
