@charset "UTF-8";
article, aside, figure, footer, header, nav, section, main {
  display: block;
}

body, div, dl, dt, dd, ul, li, h1, h2, h3, h4, h5, pre, form, input, img,
article, aside, figure, footer, header, nav, section, main {
  margin: 0;
  padding: 0;
}

table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 100%;
}

img, object {
  border: 0;
  vertical-align: top;
}

ul {
  list-style: none;
}

ol {
  margin: 0;
  padding: 0 0 0 1.4em;
}

caption, th {
  text-align: left;
}

h1, h2, h3, h4, h5, h6, select {
  font-size: 100%;
}

em, address, i {
  font-style: normal;
}

p {
  margin: 0 0 1em;
  padding: 0;
}

/* ====== utility ====== */
.panelist li {
  font-size: 10px;
  font-size: .625rem;
}

.chkbx2 span, .agreement {
  font-size: 12px;
  font-size: .75rem;
}



body, .bd_dot, .agbox label {
  font-size: 14px;
  font-size: .875rem;
}

.time span {
  font-size: 16px;
  font-size: 1rem;
}

.catch, .panel h2 span {
  font-size: 18px;
  font-size: 1.125rem;
}

.panel h2 {
  font-size: 24px;
  font-size: 1.5rem;
}

.r {
  text-align: right;
}

.c {
  text-align: center;
}

.flo_l {
  float: left;
}

.flo_r {
  float: right;
}

.emph,
.alert {
  font-weight: bold;
}

.attention,
.alert {
  color: #d71718;
}

.disc {
  list-style-type: disc;
  margin-bottom: 1em;
  padding-left: 1.4em;
}

.hide {
  display: none;
}

.clear {
  clear: both;
}

.shrink {
  letter-spacing: -1px;
}

td, th {
  padding: 5px;
  text-align: left;
  vertical-align: top;
}

th {
  white-space: nowrap;
}

/* micro clearfix */
/* fix width or so to turn hasLayout true (instead of zoom:1) */
.cf:before, .ft_link ul:before, .section:before, .inner:before, .modaltarget:before, .session:before, .detail_list:before, .cf:after, .ft_link ul:after, .section:after, .inner:after, .modaltarget:after, .session:after, .detail_list:after {
  content: '';
  display: table;
}
.cf:after, .ft_link ul:after, .section:after, .inner:after, .modaltarget:after, .session:after, .detail_list:after {
  clear: both;
}

body {
  color: #333;
  font-family: Arial, Roboto, "Droid Sans", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 1.8;
}

body.tt {
  background: url(../images/pattern.png);
}

body.form {
  background: url(../images/pattern2.png);
}

img {
  max-width: 100%;
}

a {
  color: #333;
  text-decoration: none;
}

.wrap {
  width: 960px;
  margin: 0 auto;
}

.hd {
  background-color: #000;
}


.hd2 {
  margin-bottom: 70px;
  background-color: #000;
}

.hd3 {
  background-color: #000;
}

.ft_link {
  padding: 1.5em 0;
  background-color: #454545;
}
.ft_link a {
  color: #fff;
}
.ft_link li {
  float: left;
  margin-right: 4em;
}

.ft {
  padding-top: 30px;
  background-color: #292929;
  color: #fff;
}
.ft a {
  color: #fff;
}

.ft_logo {
  float: left;
  margin-right: 30px;
  margin-bottom: 30px;
}

.copy {
  clear: both;
  text-align: center;
}

.catch {
  color: #015e50;
  text-align: center;
  font-weight: bold;
}

.section {
  margin-bottom: 30px;
  background-color: #fff;
}

.inner {
  padding: 10px;
}

.chkbx1 {
  float: left;
  width: 98px;
  margin-right: 15px;
  text-align: center;
}

.chkbx1 .bx {
  height: 36px;
  line-height: 36px;
  margin-bottom: 10px;
  border-top: 3px solid #015e50;
  background-color: #ebebeb;
}

.chkbx1 input[type="checkbox"] {
  margin-top: 10px;
  margin-left: 10px;
  -moz-transform-origin: center;
  -moz-transform: scale( 1.5 );
  height:20px;
  width:20px;
}

.label_over {
  background-color: #00ffa7;
  font-weight: bold;
}

.opening {
  float: left;
}

.tbr {
  display: table-row;
  width: 400px;
}
.tbr span, .tbr p {
  display: table-cell;
}
.tbr p {
  padding-left: 10px;
  vertical-align: bottom;
}

.greeting {
  float: left;
  width: 6em;
}
.greeting + .flo_l {
  width: 500px;
}
.greeting + .flo_l img {
  margin-right: 10px;
}

.panel {
  clear: both;
  line-height: 1.4;
  margin-top: 15px;
}
.panel h2 {
  color: #015e50;
  font-weight: normal;
}

.panelist {
  clear: both;
}
.panelist li {
  float: left;
  width: 150px;
  margin-left: 8px;
}
.panelist li:first-child {
  margin-left: 0;
}

.modal {
  position: relative;
  display: block;
  height: 100%;
}
.modal:hover:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/green.png);
  content: '';
}
.modal:hover:after {
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -30px;
  content: url(../images/more.png);
}

.modaltarget {
  display: none;
  position: fixed;
  background-color: #fff;
  z-index: 2;
}
.modaltarget ._close {
  position: absolute;
  top: -20px;
  right: -20px;
  cursor: pointer;
}

#_overlay {
  position: fixed;
  display: none;
  top: 0;
  left: 0;
  width: 100%;
  height: 120%;
  background: url(../images/over.png);
  z-index: 1;
}

.prof {
  width: 910px;
  padding: 15px;
}
.prof h2 {
  margin-bottom: 20px;
  border-bottom: 1px solid #ccc;
  color: #015e50;
  font-size: 30px;
}
.prof .tn {
  float: left;
  margin-right: 30px;
}

.session li {
  float: left;
  width: 460px;
  margin: 10px;
  padding-bottom: 5px;
  line-height: 1.2;
  border-bottom: 1px solid #eee;
}
.session li .flo_l {
  margin-right: 10px;
}
.session li .hook {
  position: relative;
}
.session li a {
  overflow: hidden;
}
.session li .tn {
  margin-right: 10px;
  vertical-align: bottom;
}

.tt1,
.tt4 {
  width: 243px;
}

.tt2,
.tt3 {
  width: 237px;
}

.cell {
  padding: 10px;
}
.cell p {
  margin-bottom: 0;
  overflow: hidden;
}
.cell .p2 {
  height: 5em;
}

.chkbx2 {
  height: 36px;
  margin-bottom: 10px;
  border-top: 3px solid #015e50;
  border-bottom: 1px solid #ccc;
  background-color: #ebebeb;
}
.chkbx2 span {
  float: right;
  width: 6em;
  line-height: 1.4;
  margin-top: 10px;
  margin-right: 10px;
  font-weight: bold;
  text-align: center;
}

.chkbx2 input[type="checkbox"] {
  margin-top: 10px;
  margin-left: 10px;
  -moz-transform-origin: center;
  -moz-transform: scale( 1.5 );
  height:20px;
  width:20px;
}

.rest {
  background-color: #f19ec2;
}

.over {
  background-color: #00ffa7;
}

.full {
  background-color: #e60012;
  color: #fff;
}

.note {
  color: #e30000;
  font-weight: bold;
  text-align: center;
}

.regi {
  margin: 50px;
  text-align: center;
}

.time {
  position: relative;
  height: 40px;
  border-bottom: 1px solid #ccc;
}
.time span {
  float: right;
  width: 6em;
  text-align: center;
}
.time img {
  position: absolute;
  top: -25px;
  left: -63px;
}

.detail {
  width: 834px;
  padding: 15px 53px;
}
.detail h2 {
  font-size: 30px;
}

.detail_list li {
  float: left;
  width: 33%;
}

.bd_dot {
  margin-bottom: 20px;
  border-bottom: 1px dotted #999;
  font-weight: normal;
}
.bd_dot .bd {
  display: inline-block;
  margin-bottom: -2px;
  padding-bottom: 5px;
  border-bottom: 3px solid #015e50;
}

.form_wrap {
  width: 960px;
  margin: 0 auto 100px;
  padding: 20px 38px;
  background-color: #fff;
}

.agreement {
  margin-bottom: 30px;
}

.agbox {
  padding: 25px;
  background-color: #f2f7f6;
}
.agbox label {
  display: block;
  color: #900;
  font-size:18px;
  text-align: center;
}
.agbox label input[type="checkbox"] {
  margin-right: .5em;
  -moz-transform-origin: center;
  -moz-transform: scale( 1.5 );
  height:20px;
  width:20px;
}
.agbox .term {
  height: 100px;
  padding: 20px;
  background-color: #fff;
  overflow: auto;
}
.agbox .term h3 {
  margin-bottom: 5px;
  padding-bottom: 5px;
  border-bottom: 1px dotted #999;
  font-weight: normal;
}

.req {
  display: inline-block;
  width: 3em;
  background-color: #e60012;
  color: #fff;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
}
th .req {
  float: left;
  margin-left: 10px;
}
.req.adjast {
  margin-top: 12px;
}

.ftbl th,
.ftbl td {
  height: 4em;
  border-top: 1px solid #d5d4d4;
  border-bottom: 1px solid #d5d4d4;
  vertical-align: middle;
}
.ftbl th {
  width: 240px;
  background-color: #f2f7f6;
  text-align: right;
  font-weight: normal;
}
.ftbl td label {
  display: inline-block;
  margin-right: 1em;
}
.ftbl input[type="text"],
.ftbl select {
  padding: 15px;
  border: 1px solid #d5d4d4;
}
.ftbl .name {
  width: 250px;
}
.ftbl .co {
  width: 500px;
}
.ftbl .tel {
  width: 350px;
}
.ftbl .zip {
  width: 100px;
}

.form_nav {
  margin: 30px;
  text-align: center;
}
.form_nav input[type="image"],
.form_nav a {
  margin: 0 10px;
}

.selected {
  margin: 0 100px 50px;
  padding: 10px;
  border: 1px solid #999;
}
.selected li {
  margin-top: 10px;
  padding-left: 10px;
  border-left: 3px solid #00ffa7;
}
.selected li:first-child {
  margin-top: 0;
}
.selected .session_name {
  color: #015e50;
}

p.txt{
  margin: 0;
  padding: 0;
}
