@charset "utf-8";


/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {border: 0;font-family: inherit;font-size: 100%;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;}
:focus {outline: 0;}

ol, ul {list-style: none;}
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
blockquote, q {quotes: "" "";}
a img{border: 0;}
figure{margin:0}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}
/* -------------------------------------------------------------- */

body{
color:#555;
font:13px "ヒラギノ角ゴ Pro W3",‘Hiragino Kaku Gothic Pro’,メイリオ,Meiryo,Osaka,Arial,Verdana,"ＭＳ Ｐゴシック",sans-serif;
line-height:2.0em;
background:#fff;
-webkit-text-size-adjust: none;
}

html{background:#fff;}


/* リンク設定
------------------------------------------------------------*/
a{color:#006699;text-decoration:none;}
a:hover{color:#0066ff;}
a:active, a:focus{outline:0;}
.table_0 a{
text-decoration:none;
color:#006699;
}
.table_0 a:visited{
color:#0099CC;
}
.table_0 a:hover{
color:#0066FF;
text-decoration:underline;
}
.table_0 a:active{
color:#006699;
}

/*=============================================== 
	pc/sp
===============================================*/
/*-- PC版表示CSS  --*/
.pc {
  display:block;
}
.sp {
  display:none;
}
.clearbox{
	clear: both;
}

/*-- スマホ版表示CSS  --*/
@media screen and (max-width: 640px) {
  .pc{
    display:none;
  }
  .sp{
    display:block;
  }
}

/* 全体
------------------------------------------------------------*/
#wrapper{
margin:0 auto;
padding:0;
width:640px;
position:relative;
}

/*
.abstract{
position: absolute;
padding-top: 1px;
padding-left: 2px;
padding-right: 2px;
padding-bottom: 1px;
margin: auto;
width: 640px;
height: 500px;
}
*/

/* #main_abs の修正 - 幅の重複指定を解消 */
#main_abs {
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    width: 90%; /* 幅を1つに統一 */
    height: auto; /* 固定高さより自動調整の方が安全 */
    max-width: 1200px; /* 必要に応じて最大幅を設定 */
}

@media screen and (max-width: 640px) {
  /* テーブル全体のリセット */
  .table_abs {
    border-collapse: separate !important;
    border-spacing: 0 !important;
    border: none !important;
    width: 100%;
  }
  
  /* 行の調整 */
  .table_abs tr {
    display: block;
    margin-bottom: 15px;
    border: none !important;
  }
  
  /* セルの共通スタイル */
  .table_abs th,
  .table_abs td {
    display: block;
    width: 100%;
    border: none !important;
    box-sizing: border-box;
  }
  
  /* 見出しセルのスタイル */
  .table_abs th {
    background: transparent;
    padding: 10px 0 5px 10px;
    font-weight: bold;
    color: #28676b;
    position: relative;
    border-left: 4px solid #28676b !important;
    margin-bottom: 5px;
  }
  
  /* 内容セルのスタイル */
  .table_abs td {
    padding: 0 0 15px 10px;
    border-bottom: 1px solid #eaeaea !important;
  }
  
  /* 最後のセルの下線を消す */
  .table_abs tr:last-child td {
    border-bottom: none !important;
  }
  
  /* セッション概要を一行に */
  th:contains('セッション概要') {
    white-space: nowrap;
  }
  
  /* または、特定のクラスを追加 */
  .nowrap {
    white-space: nowrap !important;
  }
  
  /* 画像調整 */
  .table_abs td img.sp {
    max-width: 120px;
    float: left;
    margin: 0 15px 10px 0;
  }
  
  /* 矢印アイコン非表示 */
  .table_abs th img {
    display: none;
  }
}


/*************
テーブル
*************/
table.table{
border-collapse:collapse;
width:100%;
margin:10px auto;
}

table.table th,table.table td{
padding:6px;
border:1px solid #b0c257;
}

table.table th{
text-align:right;
vertical-align:top;
font-weight:bold;
letter-spacing:1px;
white-space:nowrap;
color:#fff;
background:#789632;
border-left:#b0c257 5px solid
}

table.table td{border-left:#b0c257 3px double}

.table_0 { 
width:100%;
margin:10px auto;
border:none; 
background:#FFFFFF;
}

.table_0 th { 
border-collapse:collapse;
border-top:#fff 1px solid;
background:#046C94;
color:#FFFFFF;
padding:3px 6px 3px;
text-align:right;
font-weight:bold;
width:14%;
}

.table_0 td { 
background:#FFFFFF;
padding:3px 6px 3px;
text-align:left;
}

.table_lec { 
width:100%;
margin:1px auto;
table-layout:fixed
border:none; 
background:#FFFFFF;
}

.table_lec th { 
background:#fff;
padding:3px 6px 3px;
text-align:left;
width:125px;
}

.table_lec td { 
background:#fff;
padding:3px 6px 3px;
text-align:left;
vertical-align:top;
font-weight:bold;
}

.table_abs_tl { 
width:96%;
margin:1px auto;
border:none; 
background:#28676b;
}

.table_abs_tl td.head1 { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#70c170;
color:#fff;
font-weight: bold;
padding:3px 6px 3px;
text-align:center;
}

.table_abs_tl td.head2 { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#009dbf;
color:#fff;
font-weight: bold;
padding:3px 6px 3px;
text-align:center;
}

.table_abs_tl td.head_v { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#925995;
color:#fff;
font-weight: bold;
padding:3px 6px 3px;
text-align:center;
}

.table_abs_tl th { 
padding:3px 6px 3px;
color:#fff;
font-weight:bold;
text-align:center;
}

.table_gry { 
width:96%;
border-collapse:collapse;
margin:1px auto;
border:none;
background:#FFFFFF;
}

.table_gry th { 
background:#CCCCCC;
font-weight:bold;
color:#993300;
padding-left:15px;
}

.table_gry td { 
background:#CCCCCC;
font-weight:bold;
color:#993300;
padding-right:15px;
text-align:right;
}

.table_gry td.ski { 
background:#CCCCCC;
font-weight:bold;
color:#28676b;
padding-right:15px;
text-align:right;
}

.table_abs { 
width:96%;
margin:1px auto;
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#FFFFFF;
}

.table_abs th { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#fff;
padding:3px 6px 3px;
text-align:left;
vertical-align:top;
width:20%;
}

.table_abs td { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#fff;
padding:3px 6px 3px;
vertical-align:top;
line-height:1.8em;
}

.table_abs td.dd { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#fff;
padding:3px 6px 3px;
vertical-align:top;
line-height:1.6em;
}

.table_abs td.hd { 
border-collapse: collapse; /* 枠線の表示方法 */ 
border: 1px #CCCCCC solid; /* テーブル全体の枠線（太さ・色・スタイル） */ 
background:#fff;
padding:3px 6px 3px;
vertical-align:top;
line-height:1.6em;
vertical-align:top;
}

.table_normal {
width:98%;
border:none;
background-color:#fff;
}

.table_normal td.co1 { 
padding:2px 1px;
font-size:12px;
line-height:1.8em;
border:none;
width:3%;
}

.table_normal td { 
padding:2px 2px;
font-size:12px;
line-height:1.8em;
border:none;
}

.table_print { 
width:96%;
margin:1px auto;
background:#FFFFFF;
}

.table_print th { 
background:#fff;
padding:3px 6px 3px;
text-align:center;
}

span.pmp {
vertical-align: super;
}

.sup {
    height: 0;
    line-height: 1;
    vertical-align: baseline;
    _vertical-align: bottom;
    position: relative;
	bottom: 1ex;
     
}

.sup_rev {
	font-size: 98%; //お好きなサイズに
	vertical-align: top;
	position: relative;
	top: -0.6em; //お好きな位置に
}

.subsub_cfp_2 {
padding-right: 2px;
padding-left: 2px;
padding-top: 1px;
padding-bottom: 0px;
font-size: 9px;
font-weight:bold;
background-color:#fff;
border:solid 1px #CC0000;
color:#cc0000;
}

span.super {
    vertical-align: baseline;
    position: relative;
    top: -1ex;
}

span.guide {
font-style:oblique;
}

.italic{
    display:inline-block;
     -webkit-transform: skewX(-15deg);
     -ms-transform: skewX(-15deg);
     transform: skewX(-15deg);
}

ol.nashi_marunum  {
  /*margin: 0;
  padding-left: 0.6em;*/
  padding-left: 1.8em;
}
ol.nashi_marunum li  {
  list-style: none;
  /*padding-left: 1.4em;
  text-indent: -1.4em;*/
  padding-left: 0.5em;
  margin-left: 0.2em;
  text-indent: -0.2em;
}

ol.num  {
padding-left: 1.8em;

}
ol.num li  {
  list-style: decimal;
  padding-left: 0.5em;
  margin-left: 0.2em;
  text-indent: -0.2em;
}

ul.ul10 {
list-style: disc;
padding-left: 15px;
}

ul.ul20 {
list-style: disc;
padding-left: 25px;
}

.pic {
  float: right;
  margin: 0 0 15px 15px;
  width: 30%;
}
.pic img {
  max-width: 100%;
}
.float_none {
  clear: both;
}
