/* Option style */
div.panel_default {
    width: 100%;
    font-size: 16px;
}
.panel_default a {
    text-decoration: underline;
}
h3.title span {
    display: inline-block;
}
h3.title small {
    display: inline-block;
    margin-left: 10px;
    font-weight: normal;
    white-space: nowrap;
    color: #333333;
}
h3.title small i {
    position: relative;
    top: -1px;
}
.cl_ticke {
    color: #cf7c2a !important;
}
.bg_ticke {
    background-color: #cf7c2a !important;
}
.cl_red {
    color: #CC0000 !important;
}
.kansai table thead th,
.kansai2 table th {
    background-color: #cf7c2a;
    color: #FFF;
    font-weight: bold;
}
.kansai2 table thead td {
	font-weight: bold;
}

/*<--- End OPTION --->*/

.txt_indent li {
    text-indent: -20px;
    padding-left: 20px;
    margin-bottom: 6px;
}

.banner {
    position: relative;
    width: 980px;
    margin: 40px auto 0;
}
.banner a {
    display: block;
    background-color: #F66800;
    position: absolute;
    color: #FFF !important;
    font-size: 18px;
    right: 15px;
    bottom: 15px;
    padding: 8px 32px 8px 35px;
    border-radius: 2px;
    -webkit-box-shadow: 0 2px 0px 0px rgba(0,0,0,0.15);
    -moz-box-shadow: 0 2px 0px 0px rgba(0,0,0,0.15);
    box-shadow: 0 2px 0px 0px rgba(0,0,0,0.15);
    zoom: 1;
    filter: progid:DXImageTransform.Microsoft.DropShadow(OffX=0, OffY=2, Color=#CCCCCC), progid:DXImageTransform.Microsoft.Chroma(Color='#FFFFFF');
}
.banner a span {
    display: block;
    background: url(../images/arrow01.png) no-repeat 0 center;
    padding-left: 27px;
    letter-spacing: 0.02em;
}

.social {
    padding: 10px 0;
}
.social ul li {
    display: inline-block;
    margin-left: 1px;
}

.nav_top {
    background: #cf7c2a;
    padding: 8px 20px;
    margin-bottom: 27px;
}
.nav_top ul li {
    display: inline-block;
    background: url(../images/arrow_down.png) no-repeat 0 center;
    padding-left: 16px;
    margin-right: 28px;
    margin-bottom: 2px;
}
.nav_top ul li a {
    display: block;
    color: #FFF;
    text-decoration: underline;
    font-size: 16px;
}
#routes.panel_default {
    margin-bottom: 25px;
}
#routes h3.heading {
    padding: 8px 10px 7px;
}
.panel_default .panel_heading .panel_title:after {
    width: 20.8%
}
.img_map {
    margin-bottom: 15px;
    margin-top: 20px;
}
.about .cl_ticke {
    border-bottom: 1px solid #CCC;
    padding-bottom: 15px;
    margin-bottom: 15px;
}
.about .txt_indent ul {
    margin-top: 5px;
}
.about .txt_indent ul li {
    text-indent: -10px;
    padding-left: 10px;
    margin-bottom: 6px;
}
.about .txt_indent > li:first-child {
    margin-bottom: 2px;
}
/* ボタン */
#routes.panel_default ul.btn {
	margin: 10px -1px 0 0;
}
#routes.panel_default ul.btn li {
    vertical-align: middle;
    display: inline-block;
    box-sizing: border-box;
    text-align: center;
    background-color: #0473bd;
	-moz-border-radius: 2px;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    -webkit-box-shadow: 0px 2px 0 0px rgba(0,0,0,0.15);
    box-shadow: 0px 2px 0 0px rgba(0,0,0,0.15);
    zoom: 1;
    filter: progid:DXImageTransform.Microsoft.DropShadow(OffX=0, OffY=2, Color=#CCCCCC), progid:DXImageTransform.Microsoft.Chroma(Color='#FFFFFF');
}
#routes.panel_default ul.btn li + li {
	margin-left: 9px;
}
#routes.panel_default ul.btn li a {
    background: url(../images/arrow07.png) no-repeat 21px center;
    display: table-cell;
    height: 60px;
    width: 307px;
    color: #fff;
    text-decoration: none;
    vertical-align: middle;
}
#routes.panel_default ul.btn li a i {
	margin-left: 4px;
    display: inline-block;
}
/* ボタン終わり */

/* Benefits */
#benefits p {
	margin: 26px 0 50px;
	text-align: center;
}

/* Price */
.box_price {
    margin-bottom: 20px;
}
.box_price.row {
}
.box_price.row:after,
.box_price .row:after {
    content: "";
    display: table;
    clear: both;
}
.box_price [class*="col-"] {
    float: left;
    padding-left: 3px;
    padding-right: 3px;
}
.col-2 {
    width: 22%;
}
.col-5 {
    width: 39%;
}
.col-6 {
    width: 50%;
}
.col-12 {
    width: 100%;
}
.box_price .period {
	float: left;
	width: 61%;
	border-collapse:separate;
	background: #cf7c2a;
}
.box_price .period [class*="col-"] {
    padding-left: 2px;
    padding-right: 2px;
}
.box_price .price {
    padding: 0 3px;
}
.box_price .price_head {
    padding: 10px;
    text-align: center;
    color: #FFF;
}
.box_price .oversea .price {
    padding-left: 0;
    padding-right: 5px
}
.box_price .oversea [class*="col-"] {
    padding-left: 5px;
    padding-right: 0;
}
.box_price .oversea .price_head {
    font-size: 12px;
}
.box_price .oversea .price_head span {
    display: block;
    margin-top: 2px;
}
.box_price.row .period tr{
	background: ##cf7c2a;	
}
.box_price.row .period .price_head .btn{
    background-color: #FF9900;
    padding: 1px 0;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
}
.box_price .period .price_head{
    font-size: 16px;
    padding: 14px 13px 13px;
    line-height: 1.25em;
	vertical-align: middle;
}
.box_price.row .period tr .price_head.oversea{
	font-size:12px;
}
.box_price.row .period tr .price_head.oversea span{
	display: block;
    margin-top: 2px;
    letter-spacing: -0.3px;	
}
.box_price.row .period tr .price_item{
    text-align: center;
    font-size: 14px;
    font-weight: bold;
}
.box_price.row tr .price_item .price_itemBox{
	background-color:#fff;
	-webkit-border-radius: 2px;
    -ms-border-radius: 2px;
    border-radius: 2px;
	padding: 7px 0;
	margin:0 5px 5px 5px;
}
.box_price.row .period tr .price_item.oversea{
	width: 33%;
}
.box_price.row .period tr .price_item.blank{
	background-color:#72af2d;
    -webkit-border-radius: 0;
    -ms-border-radius: 0;
    border-radius: 0;	
}
.box_price .purchase_station {
	float: left;
	width: 39%;
	color: #999;
	background-color: #999;
	border-collapse: separate;
}
.box_price .purchase_station .price {
    color: #999;
}
.box_price .purchase_station .price_head {
    font-size: 16px;
    padding: 13px 13px 10px;
    line-height: 1.25em;
}
.box_price .purchase_station .price {
    padding-left: 0;
    padding-right: 5px
}
.box_price.row .purchase_station tr .price_item{
    text-align: center;
    font-size: 14px;
    font-weight: bold;
}
.box_price .blank {
	width: 5px;
	background-color: #fff;
	empty-cells : show;
}
.box_price .purchase_station [class*="col-"] {
    padding-left: 5px;
    padding-right: 0;
}
.cautiona {
    color: #CC0000;
    text-indent: -52px;
    display: inline-block;
    padding-left: 52px;
}
.box_price .price_item .num {
    font-size: 32px;
}
.box_price .price_item .num sub {
    font-size: 14px;
}
.period .price_item .num,
.period .price_item .num sub {
    color: #cf7c2a;
    -webkit-mask-image: url("../../images/gradation.png");
    mask-image: url("../../images/gradation.png");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%
}
.period tr .price_item.oversea .num,
.period tr .price_item.oversea .num sub  {
	color: #FF9900;
	-webkit-mask-image: url("../../images/gradation.png");
    mask-image: url("../../images/gradation.png");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
}
.discount {
    background: #FAF8BB;
    text-align: center;
    font-weight: bold;
    padding: 9px 0 10px;
    margin-bottom: 15px;
}
.discount a {
    display: inline-block;
    color: #CC0000;
	text-decoration: none !important;
}
.discount a i {
    display: inline-block;
    margin-left: 10px;
}

.attention {
    margin-bottom: 30px;
}
.attention h3 {
    margin-bottom: 5px;
    font-weight: bold;
}
.attention_list li span {
    text-decoration: underline;
}
.attention_list li {
    margin-bottom: 7px;
}
.attention .age > li > ul {
    padding-left: 15px;
    margin-top: 3px;
}
.attention .age ul li {
    font-weight: normal;
    padding-left: 10px;
    text-indent: -10px;
}
.attention .age ul li ul {
    padding-left: 2px;
}
.attention .age > li {
    font-weight: bold;
    margin-bottom: 4px;
}
.attention .age {
	margin-top: 12px;
}
#eligibility {
    margin-top: -10px;
}
.eligibility p.cl_red {
    margin-bottom: 12px;
}
.eligibility p {
    margin-bottom: 5px;
}
.eligibility .right_ct {
    margin-top: 5px
}

#purchasing {
    margin-top: -20px
}
.purchasing .col_l {
    float: left;
    width: 53%;
    padding-right: 2%;
}
.purchasing .col_r {
    float: right;
    width: 47%;
}
.purchasing .row {
	padding-bottom: 20px;
}
.purchasing .row:last-child {
    border-bottom: 0 none;
}
.purchasing .row h4 {
    font-weight: bold;
    margin-bottom: 13px;
    color: #CC0000;
}
.purchasing .step div.table{
    margin-top: 2px
}
.step > ul > li {
    padding-left: 60px;
    position: relative;
    margin-bottom: 13px;
}
ul.mt6 li {
    margin-top: 8px;
}
p.rong {
    padding-top: 7px;
}
.step ul li .lbl {
    font-weight: bold;
    position: absolute;
    top: 0;
    left: 0;
}
.step div.table {
    font-weight: bold;
    display: table;
}
.step .table .th,
.step .table .td {
    display: table-cell;
}
.step .table .th {
    white-space: nowrap;
}
.data_reservation h5 span {
    position: relative;
    background: #FFF;
    display: inline-block;
    z-index: 99;
    padding-right: 10px;
}
.data_reservation h5:after {
    content: "";
    width: 100%;
    height: 0;
    position: absolute;
    top: 50%;
    left: 0;
    border-bottom: 1px solid;
}
.data_reservation h5 {
    position: relative;
    font-weight: bold;
    margin-bottom: 7px;
}
.data_reservation table thead th {
    font-weight: bold;
    color: #FFF;
}
.data_reservation table tr:nth-child(even),
.train table tbody tr:nth-child(odd) {
    background-color: #F2F3F5;
}
.data_reservation table tbody th {
    font-weight: bold;
}
.data_reservation table th, 
.data_reservation table td {
    width: 33.3333%;
    border: 1px solid #CCC;
    text-align: center;
    padding: 10px 5px;
}
.data_reservation table i {
    position: relative;
    top: -2px;
    display: inline-block;
    margin-right: 5px;
}
.row .note {
    padding-left: 20px;
    margin: 5px 0 20px;
}
.reservation {
    margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom:solid 1px #ccc;
}
.reservation .application {
    background: #FAFBBB;
    padding: 20px;
    margin-bottom: 10px;
}
.application .caution {
    color: #CC0000;
    margin-bottom: 15px;
}
.application .kansai_area {
    width: 68.88889%;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 20px;
}
.application .kansai_area a {
    background-color: #F66800;
    font-size: 20px;
    padding: 8px 0;
    line-height: 1.2;
    color: #FFF;
    display: block;
    text-decoration: none;
}
.application .kansai_area a,
.application .btn_app li,
.btn_primary a {
    -moz-border-radius: 2px;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    -webkit-box-shadow: 0px 2px 0 0px rgba(0,0,0,0.15);
    box-shadow: 0px 2px 0 0px rgba(0,0,0,0.15);
    zoom: 1;
    filter: progid:DXImageTransform.Microsoft.DropShadow(OffX=0, OffY=2, Color=#CCCCCC), progid:DXImageTransform.Microsoft.Chroma(Color='#FFFFFF');
}
.application .btn_app {
    background-color: #F2F3F5;
    padding: 10px 0;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    text-align: center;
}
.application .btn_app ul li {
    display: inline-block;
    margin: 0 3px 5px;
    width: 200px;
    padding: 0 20px;
    background-color: #B8B8B8;
}
.application .btn_app ul li a {
    background: url(../images/arrow07.png) no-repeat 0 center;
    padding: 10px 0;
    display: block;
    color: #FFF;
    text-decoration: none;
}
.btn_primary a {
    width: 49.5%;
    display: block;
    text-decoration: none !important;
    font-size: 20px;
    padding: 6px 20px;
    text-align: center;
}

.btn_primary a span {
    color: #FFF;
    display: block;
    background: url(../images/arrow07.png) no-repeat 0 center;
}
.btn_primary .process {
    float: left;
}
.btn_primary .pickup {
    float: right;
}
h3.heading.style2 span {
    border-color: #333;
    line-height: 1.2;
}
h3.heading.style2 {
    background-color: #F2F3F5;
    margin-bottom: 0 !important;
}
.payment .card {
    border-left: 5px solid #F2F3F5;
    border-right: 5px solid #F2F3F5;
    border-bottom: 5px solid #F2F3F5;
    padding: 20px;
    border-top: 1px solid #F2F3F5;
}
.card ul ul {
    padding-left: 14px;
}
.card > p {
    margin-top: 15px;
}
.pdl {
    padding-left: 20px;
    margin: 5px 0 20px;
}
.train table {
    margin-bottom: 12px;
}
.train table thead td {
    background-color: #FAF8BB;
}
.train table thead .bg_train {
    background-color: #f8d6d6;
}
.train table tbody td {
    line-height: 18px;
    padding: 12px 10px;
}
.train table th, 
.train table td {
    text-align: center;
    padding: 10px 5px;
    border: 1px solid #CCC;
    vertical-align: middle;
}
.train.kansai2.md table tr th {
	width:100px;
}
.mb5 ul {
    margin-top: 10px;
}
.pl3 {
	padding-left: 8px;
}
#information {
    margin-bottom: 60px;
    margin-top: -3px
}
#use.panel_default {
    margin-bottom: 26px;
    margin-top: -11px
}
#use .txt_indent ul {
    margin-top: 4px;
}
#use .txt_indent li {
    text-indent: -16px
}
.payment {
    margin-bottom: 30px;
    margin-top: -3px
}
.step > ul > li.mb5 {
	margin-bottom: 5px;
	margin-top: 20px;
}
#eligibility .panel_heading .panel_title,
#purchasing .panel_heading .panel_title,
#use .panel_heading .panel_title,
#accommodations .panel_heading .panel_title,
#changes .panel_heading .panel_title,
#refunds .panel_heading .panel_title,
#information .panel_heading .panel_title {
    margin-bottom: 15px;
}
#changes {
    margin-bottom: 28px;
    margin-top: -18px
}
#refunds {
    margin-bottom: 30px;
}
#refunds .mb5 li ul li {
    margin-bottom: 1px;
}
#accommodations .pdl {
    margin-bottom: 18px;
}

