@charset "UTF-8";
/* CSS Document */

/* @import url(/_shared/_css/reset.css); */
@import url(reset.css);

/* =========================================
タグ定義
========================================= */

body {
	background: url(../_images/bg_head.gif) repeat-x left top #efefef;
	color: #333;
	font-family: arial,helvetica,clean,sans-serif;
}

a {
	color: #3e90bd;
	text-decoration: underline;
}
a:visited {
	color: #477289;
}
a:hover {
	color: #fff;
	background-color: #3e90bd;
	text-decoration: none;
}

/* キャンセル */
.cancel {
	margin: 20px;
	border: 1px solid #ee2700;
	padding: 10px;
}
.cancel p {
	margin-bottom: 0.5em;
}

/* =========================================
ページの枠組み
========================================= */

#wrap {
	background: url(../_images/bg_contents.png) repeat-y center top;
	width: 945px;
	margin: 0 auto;
	padding: 0 60px;
	position: relative;
}

/* header */

#header {
	text-align: right;
}
#header h1 {
	float: left;
	width: 248px;
	margin: 0 0 0 -10px;
	display: inline;
}

/* areaMain */
#areaMain {
	width: 695px;
	float: right;
	margin-top: 52px;
}

/* areaSub */
#areaSub {
	width: 230px;
	float: left;
	position: relative;
}

/* areaBanner */
#areaBanner {
	clear: both;
	background: url(../_images/bg_banner.gif) repeat-x top left #eee;
	margin: 0 -17px 0 -18px;
	padding: 20px;
}

/* footer */
#footer {
	background: url(../_images/bg_footer.gif) no-repeat center top;
	width: 945px;
	margin: 0 auto;
	padding: 0 60px;
	min-height: 100px;
}


/* =========================================
lead
========================================= */

.lead {
	margin-bottom: 30px;
}
.lead h3 {
	margin-bottom: 10px;
	font-size: 110%;
	color: #ee2700;
}
.lead p {
	font-size: 93%;
	color: #254098;
	margin-bottom: 0.7em;
	line-height: 1.6;
}


/* =========================================
gNavi
========================================= */

#gNavi {
	background: url(../_images/bg_gn.gif) no-repeat left top;
	padding: 10px;
	position: absolute;
	top: 0;
	left: 0;
}
#gNavi li {
	margin: 0;
	line-height: 0;
}
#gNavi li img {
	vertical-align: top;
}
#gNavi a:hover {
	background-color: transparent;
}
#gNavi li#btnContact {
	margin-top: 10px;
}

/* =========================================
panel
========================================= */

.panel {
	margin-bottom: 50px;
	clear: both;
}
.panel h3 {
	margin-bottom: 30px;
}

/* withRight */
.withRight {
	float: left;
	width: 434px;
}

/* normalList */
.panel .normalList dt {
	font-size: 93%;
	font-weight: bold;
	line-height: 1.3;
	margin-bottom: 0.5em;
	letter-spacing: 0.3em;
}
.panel .normalList dd {
	margin-bottom: 2.5em;
	line-height: 1.4;
}
.panel .normalList .sessionList dt {
	font-size: 100%;
	letter-spacing: 0;
	font-weight: normal;
}
.panel .normalList .sessionList dd {
	margin-bottom: 1.2em;
}

/* areaBtn */

.areaBtn {
	text-align: center;
	margin-top: 30px;
}
.areaBtn a:hover {
	background-color: transparent;
}

/* agenda */
#agenda h4 {
	font-weight: bold;
	margin-bottom: 2em;
}
#agenda .name {
	font-size: 84%;
	/*display: block;*/
}
#agenda .handle {
	font-size: 80%;
}
#agenda .job {
	font-size: 64%;
	display: block;
	color: #8b8b8b;
}
#agenda .link {
	font-size: 84%;
	display: block;
}
#agenda .note {
	color: #8c8b8b;
	font-size: 64%;
	margin-top: 0.5em;
	line-height: 1.5;
}

/* =========================================
sessionsAndSpeakers
========================================= */

/* session */
#sessionsAndSpeakers .session {
	margin-bottom: 30px;
	padding-top: 10px;
}
#sessionsAndSpeakers .session h4 {
	background: url(../_images/line_white_and_black.gif) repeat-x left bottom;
	font-weight: bold;
	padding-bottom: 10px;
	line-height: 1.2;
	font-size: 122%;
	margin-bottom: 10px;
}
#sessionsAndSpeakers .session h4 .ssnNo {
	font-weight: normal;
	letter-spacing: 0.3em;
	font-size: 70%;
	text-transform: capitalize;
	background-color: #334b97;
	text-shadow: none;
	color: #fff;
	border-color: #334b97;
	border-style: solid;
	border-width: 2px 2px 2px 10px;
	margin-right: 1em;
}
#sessionsAndSpeakers .session .summary {
	line-height: 1.6;
	margin-bottom: 1em;
}

/* profile */
#sessionsAndSpeakers .session .profile {
	background-color: #e8e8e8;
	border: 1px solid #e2e2e2;
	margin-left: 27px;
	padding: 15px 10px;
}
#sessionsAndSpeakers .session .profile .pic {
	background: url(../_images/bg_picture.gif) no-repeat left top;
	padding: 5px 5px 5px 24px;
	float: left;
}
#sessionsAndSpeakers .session .profile .txt {
	margin-left: 165px;
}
#sessionsAndSpeakers .session .profile .name {
	font-weight: bold;
	line-height: 1.2;
	margin-bottom: 0.2em;
}
#sessionsAndSpeakers .session .profile .name .handle {
	font-weight: normal;
	font-size: 64%;
	padding-left: 0.5em;
}
#sessionsAndSpeakers .session .profile .job {
	font-size: 84%;
	line-height: 1.2;
	color: #747474;
	margin-bottom: 0.5em;
}
#sessionsAndSpeakers .session .profile .brief {
	font-size: 64%;
	line-height: 1.9;
}

/* specialSession */
#sessionsAndSpeakers .specialSession {
	background-color: #f3f3f3;
	border: 1px solid #e2e3e3;
	margin-top: 50px;
}
#sessionsAndSpeakers .specialSession .inner {
	border: 2px solid #fbfbfb;
	padding: 15px 13px;
}
#sessionsAndSpeakers .specialSession h4 {
	margin-bottom: 10px;
}
#sessionsAndSpeakers .specialSession h5 {
	color: #334b97;
	margin-bottom: 0.5em;
	line-height: 1.5;
	font-weight: bold;
	text-shadow: 1px 1px 1px #ccc;
}
#sessionsAndSpeakers .specialSession h5 .shoulder {
	display: block;
	font-weight: normal;
	font-size: 84%;
	text-shadow: none;
}
#sessionsAndSpeakers .specialSession .summary {
	font-size: 84%;
	margin-bottom: 0.8em;
	line-height: 1.6;
}
#sessionsAndSpeakers .specialSession .pic {
	background: url(../_images/bg_special_pic.gif) no-repeat left top;
	padding: 4px;
	float: left;
}
#sessionsAndSpeakers .specialSession .txt {
	margin-left: 110px;
}
#sessionsAndSpeakers .specialSession .txt .name {
	font-weight: bold;
	font-size: 84%;
	line-height: 1.2;
	margin-bottom: 0.15em;
}
#sessionsAndSpeakers .specialSession .txt .job {
	font-size: 64%;
	color: #747475;
	line-height: 1.2;
	margin-bottom: 0.5em;
}
#sessionsAndSpeakers .specialSession .txt .brief {
	font-size: 64%;
	line-height: 1.8;
}

/* =========================================
timetable
========================================= */

#timetable .tablewrap {
	border: 3px solid #d9d9d9;
	margin-bottom: 20px;
}
#timetable table.time {
	border: 1px solid #fff;
	background-color: #f1f1f1;
}
#timetable table.time th {
	text-align: center;
	vertical-align: middle;
	padding: 20px 30px;
	font-weight: bold;
	font-size: 140%;
	font-family: Futura, Arial, Helvetica, sans-serif;
	line-height: 1;
	white-space: nowrap;
	border-top: 2px solid #d9d9d9;
}
#timetable table.time td {
	text-align: left;
	vertical-align: middle;
	padding: 10px 15px;
	font-size: 110%;
	line-height: 1.4;
	border-top: 2px solid #d9d9d9;
	border-left: 1px solid #d9d9d9;
}
#timetable table.time .top th,
#timetable table.time .top td {
	border-top: none;
}
#timetable table.time td.speaker {
	width: 27%;
}
#timetable table.time td .job {
	display: block;
	font-size: 84%;
	color: #747474;
}

#timetable .note li,
#registration .note li {
	font-size: 84%;
	color: #626161;
	line-height: 1.2;
	margin-bottom: 0.2em;
}

/* =========================================
subpanel
========================================= */

.subpanel {
	width: 247px;
	float: left;
	display: inline;
	margin-left: 10px;
}

.subpanel #twitter {
	background-color: #fff;
	padding: 8px;
	margin-bottom: 30px;
}
.subpanel #twitter h3 {
	margin-bottom: 10px;
}
.subpanel #twitter p {
	font-size: 84%;
	margin-bottom: 0.5em;
}

.subpanel .banner {
	margin-bottom: 30px;
}
.subpanel .banner h3 {
	margin-bottom: 10px;
}
.subpanel .banner .bannerList li {
	background-color: #fff;
	padding: 7px 0;
	text-align: center;
	vertical-align: top;
	line-height: 0;
}


/* =========================================
pagetop
========================================= */

#pagetop {
	position: absolute;
	bottom: 10px;
	right: 0px;
}
#pagetop a:hover {
	background-color: transparent;
}

/* =========================================
areaBanner inner
========================================= */
#areaBanner .inner {
	border: 1px solid #f8f8f8;
	padding: 20px;
}
#areaBanner .inner h2 {
	margin-bottom: 15px;
}
#areaBanner .inner .bnr01 {
	width: 400px;
	float: left;
}
#areaBanner .inner .bnr01 .txt {
	margin-left: 130px;
}
#areaBanner .inner .bnr02 {
	margin-left: 425px;
}
#areaBanner .inner .bnr02 .txt {
	margin-left: 210px;
}
#areaBanner .inner .bnrPanel h3 {
	font-weight: bold;
	color: #909191;
	margin-bottom: 0.5em;
}
#areaBanner .inner .bnrPanel code {
	display: block;
	border: 1px solid red;
	font-size: 75%;
	padding: 5px;
	border: 1px solid #d3d3d3;
	color: #8a8a8a;
	height: 80px;
	overflow: auto;
	word-break:break-all;
	line-height: 1.3;
}
#areaBanner .inner a:hover {
	background-color: #eee;
}

/* =========================================
areaContact
========================================= */
#areaContact {
	padding: 30px 30px 0 30px;
}
#areaContact h1 {
	margin-bottom: 2em;
}
#areaContact p {
	color: #333333;
	line-height: 1.5;
	margin-bottom: 1em;
}
.areaContactBtn {
	margin-bottom: 10px;
}

/* =========================================
汎用クラス
========================================= */
.accent {
	color: #c58a18;
	text-shadow: 1px 1px 1px #ccc;
}
.imgLeft {
	float: left;
	margin: 0 10px 0 0;
}
.center {
	text-align: center;
}

strong {
	font-weight: bold;
}


/* =========================================
clearfix
========================================= */

.clearfix:after {
	content: "."; 
	display: block; 
	height: 0; 
	clear: both; 
	visibility: hidden;
}
.clearfix {
	display: inline-table;
	min-height: 1%;
}
/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
/* End hide from IE-mac */

