/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/

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, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
    font-weight: inherit;
    color:#42210b;
}

body {
    line-height:1;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}

nav ul {
    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;
}

/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}

/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    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;
}

/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}

img{
    vertical-align: top;
}
/*---------------------------------------------------------------------------------*/
.clearfix::after{
    content: "";
    display: block;
    clear: both;
}

a{
    text-decoration: none;
    color: inherit;
}

b{
    font-weight: bold;
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

/*PC・SPでの非表示の切り替え--------------------------------------------------------*/
.pc{
    display: inherit;
}

.sp{
    display:none;
}
br.pc{
    display: inline;
}
br.sp{
    display: none;
}

.sp_block{
    display: inline;
}






/*画像だけを表示させるボックス*/
.imagebox_c{
    text-align: center;
}

/* .lastのマージン解除*/
.last{
    margin: 0 !important;
}

*{
    font-family: Meryo,"メイリオ",sans-serif;
}
body{
}


body{
    position: relative;
}

img{
    width: 100%;
    height: auto;
}

a{
    color: inherit;
    text-decoration: none;
}

.text-center{
    text-align: center !important;
}

.text-indent{
    text-indent: -1em;
    padding-left: 1em;
    display: block;
}



/*共通マージン設定*/
.mb1x1 {
    margin-bottom: 38px !important;
}

.mb1x025 {
    margin-bottom: 9px !important;
}

.mb1x05 {
    margin-bottom: 19px !important;
}

.mb1x2 {
    margin-bottom: 76px !important;
}
.mb1x3 {
    margin-bottom: 114px !important;
}
.mb1x4 {
    margin-bottom: 152px !important;
}

.pb1x1 {
    padding-bottom: 38px !important;
}
.pb1x2 {
    padding-bottom: 76px !important;
}
.pb1x4 {
    padding-bottom: 152px !important;
}


.pt1x1 {
    padding-top: 38px !important;
}
.pt1x2 {
    padding-top: 76px !important;
}

/* 共通 width 設定*/
.widthsize01{
    width: 1152px;
    margin: 0 auto;
}
.widthsize02{
    width: 900px;
    margin: 0 auto;
}
.widthsize03{
    width: 1124px;
    margin: 0 auto;
}
.widthsize04{
    width: 924px;
    margin: 0 auto;
}

/* 共通文字サイズ設定*/
html{
    font-size: 17px;
    
    color: #404040;
    overflow-x: auto;
    width: 100%;
}
body{
    overflow-x: hidden;
    width: 100%;
    min-width: 1200px;
}

.text{
    margin: 0 auto;
    text-align: justify;
    line-height: 1.5rem;
    letter-spacing: -0.025rem;
}
.text p,
.comment p{
    margin-bottom: 0.7rem;
}
.text p:last-of-type,
.comment p:last-of-type{
    margin-bottom: 0;
}

.copyright{
    padding: 1.2em 0 1em;
    background: #00afcc;
    color: #fff;
    text-align: center;
    font-size: 1rem;
 }


/*----------------------------------------------------------------------------*/

.header {
    height: auto;
}

/*----------------------------------------------------------------------------*/

.info{
    background: #fff;;
    width: 100%;
    position: relative;
}
.info .text{
    font-size: 1.2rem;
    line-height: 2em;
    padding: 0 60px;
}

/*----------------------------------------------------------------------------*/
.circle_size {
	width: 12px;
	margin-right: 5px;
    margin-top: 5px;
}

.map_copy {
	font-weight: 600;
}

#tech_map_area{
	position: static;
	margin-top: 0px;
	background-image: url(../img/asn_map.jpg);
	background-size: auto 100%;
	background-position: 100% 50%;
	background-repeat: no-repeat;
}

.tech_map_ttl{
	font-size: 1.4rem;
	line-height: 1.65em;
    font-weight: bold;
}
.tech_map_about{
	font-size: 1rem;
	line-height: 1.4em;
    text-align: justify;
}
.map_title {
	margin-bottom: 10px;
}

.map_ind {
	margin-left: 20px;
	margin-bottom: 20px;
}

.map_etc {
	width: 100%;
	margin-top: 0px;
	text-align: left;
}


.fs_m {
	margin-top: -5px;
	font-size: 1rem;
	line-height: 1.5;
}

.fs_s {
	margin-top: -5px;
	font-size: 0.8rem;
	line-height: 1.5;
}
.textbig{
    font-weight: bold;
    color: #f0630b;
}
/*----------------------------------------------------------------------------*/


.couponttl{
    margin: 2em 0;
    background: #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.22);
    border-radius: 10px;/*角の丸み*/
}
.couponttl .box-title {
    font-size: 1.8em;
    background: -webkit-repeating-linear-gradient(-45deg, #f0630b, #f0630b 3px,#f05e02 3px, #f05e02 7px);
    background: repeating-linear-gradient(-45deg, #f0630b, #f0630b 3px,#f05e02 3px, #f05e02 7px);
    padding: 1.2rem 0 0.9rem;
    text-align: center;
    color: #FFF;
    font-weight: bold;
    letter-spacing: 0.05em;
    border-radius: 10px 10px 0 0;/*角の丸み*/
    font-family: "M PLUS Rounded 1c";
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
}

.couponttl p {
    padding: 1rem 0 0.7rem;
    margin: 0;
    text-align: center;
    font-size: 1.2em;
    font-family: "M PLUS Rounded 1c";
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
}
.couponkome{
    line-height: 1.3rem;
    text-align: center;
}


.kojinttl{
    background-color: #00afcc;
    width: 100%;
}
.kojinttl h3{
    font-size: 2.2rem;
    color: #fff;
    padding: 28px 0px 26px;
    text-align: center;
    margin-bottom: 40px;
    font-family: "M PLUS Rounded 1c";
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
    font-weight: 600;
}

.kojinttl h3:before {
	content:"";
	display:inline-block;
	width:1em;
	height:1em;
	background:url(../img/kojinicon.png) no-repeat;
	background-size:contain;  
    margin: 0 10px -4px;
}


.hojinttl{
    background-color: #0068b7;
    width: 100%;
}
.hojinttl h3{
    font-size: 2.2rem;
    color: #fff;
    padding: 28px 0px 26px;
    text-align: center;
    margin-bottom: 40px;
    margin-top: 80px;
    font-family: "M PLUS Rounded 1c";
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
    font-weight: 600; 
}
.hojinttl h3:before {
	content:"";
	display:inline-block;
	width:1em;
	height:1em;
	background:url(../img/hojinicon.png) no-repeat;
	background-size:contain;  
    margin: 0 10px -4px;
}




.supportlist {
    background: #e6e6e6 top center no-repeat;
}


.supportlist .conts {
    /*text-align: justify;
    text-justify: inter-ideograph;
    text-align-last: justify;
    margin-bottom: 2rem;
    text-align-last: center;*/
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
/*.supportlist .conts :last-of-type{
    margin-bottom: 0;
}*/
.supportlist .conts div {
    width: 545px;
    display: inline-block;
    transition: 0.3s;
}
/*.supportlist .conts div:last-of-type {
    margin-bottom: 0;
}*/
.supportlist .conts div:hover{
    /*border-bottom: solid 0.3rem #a71717;*/
    /*transform: translateY(-0.2rem);*/
    
}
.supportlist .conts div:active{
    /*border-bottom: solid 0rem #a71717;*/
    /*transform: translateY(0);*/
}
.supportlist a {
}

.supporturi{
    position: relative;
    padding: 0.9em 0.2em;
    background: #f08300;
    /*border: solid 6px #f08300; */
    color: #fff;
    margin-bottom: 10px;
    font-size: 1.25rem;
    font-weight: 600;
    border-radius: 10px;/*角の丸み*/
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.22);
    font-family: "M PLUS Rounded 1c";
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
}
.supporturi:after {
    position: absolute;
    content: '';
    top: 100%;
    left: 32px;
    border: 10px solid transparent;
    border-top: 16px solid #f08300;
    width: 0;
    height: 0;
}

.supportimg {
    padding: 0 0 5px;
}
.supporttext {
    padding: 5px 0 10px;
    font-size: 0.9rem;
    line-height: 1.6em;
    text-align: justify;
}
.contsbox01{
    background-color: #fff;
    padding: 20px;
    margin-bottom: 60px;
    text-align: center;
    position: relative; /* ボタンの位置を固定 */
}

.supporttable{
  margin-bottom: 4.4em; /* ボタン分空ける */
  width: 100%;
  border-collapse: collapse;
}

.supporttable tr{
    border-bottom: solid 2px #ffffff;
    font-size: 0.9rem;
    line-height: 1.4rem;
}

.supporttable tr:last-child{
  border-bottom: none;
}

.supporttable th{
  position: relative;
  width: 30%;
  color: #ffffff;
  text-align: center;
  padding: 10px 0 6px;
}


.supporttable th:after{
  display: block;
  content: "";
  width: 0px;
  height: 0px;
  position: absolute;
  top:calc(50% - 10px);
  right:-10px;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
}


.kojinth{
  background-color: #00afcc; 

}
.kojinth:after{
  border-left: 10px solid #00afcc;
}
.hojinth{
  background-color: #0068b7; 
}
.hojinth:after{
  border-left: 10px solid #0068b7;
}


.supporttable td{
  width: 70%;
  text-align: center;
  background-color: #eee;
  padding: 10px 0 6px;
  vertical-align: middle;

}

.priceplan{
    font-size: 1.2rem;
    font-weight: bold;
    color: white;
}
.pricecouponb{
    font-size: 1.6rem;
    font-weight: bold;
    color: #f0630b;
}
.pricecoupons{
    font-size: 1rem;
    color: #f0630b;
}





/*----------------------------------------------------------------------------*/
.apsystem{
    background-color: #00afcc;
    color: #fff;
    font-size: 1.7rem;
    text-align: center;
    padding: 18px 0 14px;
    font-family: "M PLUS Rounded 1c";
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
    font-weight: 600;
    border-radius:20px;
}

.support_wrap {
	background-color: #FFFFFF;
	color: #666666;
	border-bottom: 40px;
	margin-top: 0px;/*Sales地図復活時は消す*/
}


.support_containe{
    display: flex;
    width: 100%;
    flex-wrap: wrap;
    justify-content: space-between;
}

.support_box {
	width: 30%;
	text-align: center;
    margin-bottom: 0;
}
.support_box h4 {
	font-size: 1.1rem;
	font-weight: bold;
	padding: 10px 0;
    text-align: left;
}
.support_box p {
	font-size: 1rem;
	line-height: 1.4em;
    text-align: justify;
}





/*----------------------------------------------------------------------------*/






.info01{
    text-align: center;
}
.info01 .infotel{
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 0.4rem;
    color:#454545;
}
.info01 .infotel img{
    width: 2rem;
    margin-bottom: 0.4rem;
}
.info01 .infosmall{
    font-size: 1rem;
}




/*----------------------------------------------------------------------------*/
.block_logo{
    text-align: center;
}
.block_logo .logo{
    margin: auto;
    display: inline-block;
    width: 241px;
    font-size: 26px;
    text-align: justify;
}
.block_logo .logo img{
    border-bottom: 2px solid #555555;
    padding-bottom: 0.4rem;
    margin-bottom: 0.425rem;
}





/*ボタン ----------*/
.btn01{
    background: #f0630b;
    padding: 14px 18px 14px;
    border-radius: 7px;
    -moz-border-radius: 7px;
    -webkit-border-radius: 7px;
    display: inline-block;
    margin: 20px auto 0;
    border:solid 1px #f0630b; 
    
    position: absolute;/* ↓ボタンの位置固定 */
    bottom: 20px;
    left: 0;
    right: 0;
    width:65%;
}
.btn01 p{
    color: #ffffff; 
    font-size: 1.2rem;
    font-family: "M PLUS Rounded 1c"; 
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
    font-weight: 500;
}
a.btn01{
    outline: none;
    color: #fff;
    text-decoration: none;

}

.btn01:hover{
    color: #f0630b;
    background: #ffffff;
    border:solid 1px #f0630b;
}
.btn01 p:hover{
    color: #f0630b;
}



.heading04 {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.25rem;
	text-align: center;
    font-family: "M PLUS Rounded 1c"; 
    transform: rotate(0.03deg);/* シャギーを防ぐ指定 */
    color: #f0630b;
    font-weight: 600;
    margin-bottom: 0.3rem
}

.heading04::before,
.heading04::after {
	content: '';
	width: 3px;
	height: 26px;
	background-color: #f0630b;
}

.heading04::before {
	margin-right: 16px;
	transform: rotate(-35deg)
}
.heading04::after {
	margin-left: 16px;
	transform: rotate(35deg)
}



.newkoza{
    background-color: #f08300;
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold;
    padding: 0.8rem 0 0.6rem;
}


.doga iframe{
    width: 1112px;
    height: 500px;
}
