/* universal */

@mixin box_sizing {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  
  /* header */
  .navbar{
    box-shadow: rgba(0, 0, 0, 0.1) 0 1px 6px;
    position: fixed;
    top: 0px;
    z-index: 100;
    height: 65px;
    width: 100%;
    background-color: rgba(255, 255, 255, 0.93);
    opacity: 0.9;
    border-bottom: solid 1px #3394CC;
  }
  
  /* ヘッダーMENU */
  .headerMenu{
    text-align:right;
    /* line-height:65px; */
    color:#DF5D53;
    font-size:14px;
  }
  
  .head-btn
  {
    font-weight:bold;
    padding:3px;
    margin-top:5px;
    margin-left:10px;
    box-shadow: 0px 1px 2px rgba(0,0,0,0.4);
  }
  
  p{font-size:13px;}
  
  body{
    min-width:1000px;
    background:#f3f3f3;
    color:#424242;
  }
  
  #chart{
    margin:0 auto;
    background:#fff;
    min-width:1010px;
    width:95%;
    margin-top:30px;
  }
  #chart .inner{
    padding:2px;
  }
  
  .student-top{
    width:100%;margin:0 auto;
  }
  
  /* TOP画面小講座枠組 */
  .sheetGroupTitleFrame{
    width:450px;
    height:70px;
    line-height:55px;
    position:relative;
    box-shadow: 0px 1px 2px rgba(0,0,0,0.4);
    background: linear-gradient(white, silver);
  }
  
  .sheetGroupTitle1{
    width:60px;
    height:60px;
    border:solid 1px;
    border-radius:5px;
    position:absolute;
    top:4px;
    left:7px;
    text-align:center;
    background:#DB3B48;
    color:white;
    font-weight:bold;
  }
  
  .sheetGroupTitle2{
    position:absolute;
    top:6px;
    left:85px;
  }
  
  .topTitleFrameRed{
    /* background:#CA4545; */
    background:rgb(188,26,32);
    padding:5px;
    box-shadow: 0px 5px 10px rgba(0,0,0,0.4);
    border-radius:4px;
    min-width:1010px;
    width:80%;
    margin:0 auto;
  }
  
  .topTitleFrameNavy{
    background:#3A3D56;
    margin-top:-15px;
    padding-top:5px;
    box-shadow: 0px 5px 10px rgba(0,0,0,0.4);
    border-radius:4px;
  }
  
  .topTitleFrameGreen{
    background:#3BAB6C;
    margin-top:-15px;
    padding-top:5px;
    box-shadow: 0px 5px 10px rgba(0,0,0,0.4);
  }
  
  .topTitleFrame{
    position:absolute;
    top:-5px;
    left:0;
    font-size:20px;
    height:70px;
    line-height:65px;
    background:#BD1C2B;
    border:none;
  }
  
  .topTitleFrameAdmin{
    background:#0063AA;
    margin-top:-15px;
    padding-top:5px;
    box-shadow: 0px 5px 10px rgba(0,0,0,0.4);
  }
  
  
  .topTitle{
    font-size:17px;
    color:white;
    font-weight:bold;
  }
  
  .topButtonFrame{
    margin-top:10px;
  }
  
  .topButton{
    width:450px;
    text-align:left;
    font-size:16px;
    margin-bottom:7px;
  }
  
  *.logbox
  {
    height: 180px;
    overflow: auto;
  }
  
  .newsTitleFrame{
    box-shadow: 0px 1px 2px rgba(0,0,0,0.4);
    margin-top:-20px;
  }
  
  .newsTitle{
    background:#DF5D53;
    border-left: solid 4px #DF212C;
    color:white;
    opacity:0.8;
    font-size:14px;
    height:35px;
    padding-left:10px;
    line-height:35px;
  }
  
  .newsText{
    text-align:left;
    color:#54483D;
    font-size:12px;
    padding:10px;
  }
  
  /* 解答欄 */
  .kaitoColumn{
    position:fixed;
    bottom:0px;
    left:0px;
    width:100%;
    padding:4pt;
    background:#DBDBDB;
    text-align:center;
  }
  
  .kaitoTable{
    margin:0 auto;
    width:990px;
  }
  
  .resize{
    font-size:10px;
    position:fixed;
    bottom:178px;
    left:0;
    padding:1px 10px 1px 10px;
    width:100%;
    height:10px;
  }
  
  /* 大問一覧 */
  .relativeCell{
    position:relative;
  }
  
  .btn-kaito{
    position:absolute;
    bottom:0;
    right:0;
  }
  
  .btn-shadow{
    box-shadow: 0px 1px 2px rgba(0,0,0,0.4);
  }
  
  .btn-small{
    font-size:11px;
    padding:3px;
  }
  
  /* 大問のバツ位置（テキスト） */
  .daiAbsolute{
    position:absolute;
    top:8px;
    left:-30px;
  }
  
  /* 大問のバツ位置（ラジオ、チェックボックス） */
  .daiAbsoluteButton{
    position:absolute;
    top:20px;
    left:-30px;
  }
  
  /* 小問のバツ位置 */
  .shouAbsolute{
    position:absolute;
    top:5px;
  }
  
  /* テーブル */
  th{
    text-align:center;
  }
  .aaa{
    background: #ECECEC;
    /* color: white; */
    /* opacity: 0.9; */
    font-size: 15px;
  }
  
  .topTable{
    width:435px;
    font-size:17px;
  }
  
  .topTable th{
    background:#ECECEC;
  }
  
  .topTable td{
    background:#fff;
  }
  
  .contentTable{
    font-size:13px;
    width:940px;
    margin:0 auto;
  }
  
  .contentTable th{
    text-align:center;
    font-weight:bold;
  }
  
  .contentTable td.matome{
    text-align:left;
    padding-left:10px;
  }
  
  .contentTable td.list{
    text-align:right;
    padding-right:15px;
  }
  
  td.bunya{
    background:#F2F2F2;
    text-align:left;
    padding-left:15px;
    font-size:15px;
  }
  
  tr.head{
    background:#DE3838;
    color:white;
    opacity:0.9;
    font-size:14px;
  }
  
  tr.row0{
    font-weight:bold;
    background:#595555;
    color:white;
    height:30px;
  }
  
  td.gray{
    background:#F2F2F2;
  }
  
  .tbl390{
    width:390px;
  }
  
  .grayTable th{
    background:#353232;
    color:white;
    opacity:0.9;
    font-size:14px;
  }
  
  .grayTable td{
    font-size:15px;
    padding: 40px 15px;
    border-bottom: 1px solid #84b2e0;
    border-left: 1px solid #84b2e0;
    text-align: center;
  }
  
  .redTable th{
    background:#D27272;
    color:white;
    opacity:0.9;
    font-size:14px;
  }
  
  .blueTable th{
    background:#3B7CAB;
    color:white;
    opacity:0.9;
    font-size:13px;
    padding:0px;
  }
  
  .blueTable thead tr th {
    vertical-align: middle;
  }
  
  .blueTable td{
    font-size:12px;
    border-bottom: 1px solid #84b2e0;
    border-left: 1px solid #84b2e0;
    text-align: center;
  }
  
  .blueTable td.disabled{
    background:#ccc;
  }
  
  .blueTableStudent th{
    background:#3B7CAB;
    /* background:#5D5C5C; */
    color:white;
    opacity:0.9;
    font-size:13px;
    padding:0px;
  }
  .blueTableStudent td{
    font-size:14px;
    border-bottom: 1px solid #84b2e0;
    border-left: 1px solid #84b2e0;
    text-align: center;
  }
  
  .blueTableStudent td.disabled{
    background:#ccc;
  }
  .striped tr:nth-child(odd) td {  
    background-color: #EAF9FF;
  }  
  
  
  .confirmTable th{
    background:#ccc;
    opacity:0.9;
  }
  
  table.tablesorter thead tr .header {
    background-image: url(/images/bg.gif);
    background-repeat: no-repeat;
    background-position: center right;
    cursor:pointer;
  }
  table.tablesorter thead tr .headerSortUp {
    background-image: url(/images/asc.gif);
  }
  table.tablesorter thead tr .headerSortDown {
    background-image: url(/images/desc.gif);
  }
  
  .blueTable .tdLeft{
    text-align:left;
  }
  
  .blueTableStudent .tdLeft{
    text-align:left;
  }
  
  .blueTable .tdRight{
    text-align:right;
  }
  
  .tdLeft{
    text-align:left;
  }
  
  .tdRight{
    text-align:right;
  }
  
  .tdCenter{
    text-align:center;
  }
  
  .tdLineHeight{
    line-height:30px;
  }
  .tdLineHeight40{
    line-height:40px;
  }
  
  .branch-detail{
    font-size:12px;
  }
  
  .branch-detail th{
    font-size:13px;
  }
  
  table.list-table {
    width: 960px;
    border-spacing: 0;
    font-size:15px;
  }
  table.list-table th {
    color: #fff;
    padding: 8px 15px;
    background: #258;
    background:-moz-linear-gradient(rgba(34,85,136,0.7), rgba(34,85,136,0.9) 50%);
    background:-webkit-gradient(linear, 100% 0%, 100% 50%, from(rgba(34,85,136,0.7)), to(rgba(34,85,136,0.9)));
    font-weight: bold;
    border-left:1px solid #258;
    border-top:1px solid #258;
    border-bottom:1px solid #258;
    line-height: 120%;
    text-align: center;
    text-shadow:0 -1px 0 rgba(34,85,136,0.9);
    box-shadow: 0px 1px 1px rgba(255,255,255,0.3) inset;
  }
  table.list-table th:first-child {
    border-radius: 5px 0 0 0; 
  }
  table.list-table th:last-child {
    border-radius:0 5px 0 0;
    border-right:1px solid #258;
    box-shadow: 2px 2px 1px rgba(0,0,0,0.1),0px 1px 1px rgba(255,255,255,0.3) inset;
  }
  table.list-table tr td {
    padding: 20px 15px;
    border-bottom: 1px solid #84b2e0;
    border-left: 1px solid #84b2e0;
    text-align: center;
  }
  table.list-table tr td:last-child {
    border-right: 1px solid #84b2e0;
    box-shadow: 2px 2px 1px rgba(0,0,0,0.1);
  }
  table.list-table-striped tr {
    background: #fff;
  }
  table.list-table--striped tr:nth-child(2n+1) {
    background: #f1f6fc;
  }
  table.list-table tr:last-child td {
    box-shadow: 2px 2px 1px rgba(0,0,0,0.1);
  }
  table.list-table tr:last-child td:first-child {
    border-radius: 0 0 0 5px;
  }
  table.list-table tr:last-child td:last-child {
    border-radius: 0 0 5px 0;
  }
  table.list-table tr:hover {
    background: #bbd4ee;
    cursor:pointer;
  }
  
  /* 空行 */
  .spaceRow{
    height:10px;
  }
  
  .examDate{
    cursor:pointer;
    color:#5C8EE8;
  }
  
  /* ボタン幅指定 */
  .barGraph{
    height:16px;
    background:#486DD0;
    opacity:0.9;
    box-shadow: 0px 4px 4px rgba(0,0,0,0.4);
  }
  
  /* 模試ダウンロードボタン */
  .btn-exam{
    width:150px;
    font-size:12px;
  }
  
  .btn-80{
    width:80px;
  }
  
  .btn-90{
    width:90px;
  }
  
  .btn-100{
    width:100px;
  }
  
  .btn-110{
    width:110px;
  }
  
  .btn-120{
    width:120px;
  }
  
  .btn-180{
    width:180px;
  }
  
  /* トップボタン */
  .btn-title a {
    width: 280px;
    background-color: #497BC5;
    border-radius: 3px;
    box-shadow: 0 4px 0 rgb(48, 88, 138);
    color: #ffffff;
    display: block;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    margin: 10px auto;
    padding: 10px 0;
  }
  .btn-title a:hover {
    box-shadow: 0 1px 0 rgba(136,136,136,1);
    margin: 12px auto 8px;
  }
  
  .btn-past-title a {
    width: 280px;
    background-color: #86BBEA;
    border-radius: 3px;
    box-shadow: 0 4px 0 #6D8BB1;
    color: #ffffff;
    display: block;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    margin: 10px auto;
    padding: 10px 0;
  }
  .btn-past-title a:hover {
    box-shadow: 0 1px 0 rgba(136,136,136,1);
    margin: 12px auto 8px;
  }
  
  
  /* 見出し */
  .headline{
    position:relative;
    padding-left:30px;
    border-bottom:2px solid #ccc;
    font-size: 18px;
    line-height: 38px;
  }
   
  .headline:after, .headline:before{
    content:''; 
    height:18px; 
    width:4px; 
    display:block; 
    background:#00A8FF; 
    position:absolute; 
    top:8px; 
    left:15px; 
    border-radius:10px;
    -webkit-border-radius:10px;
    -moz-border-radius:10px; 
    transform:rotate(45deg);
    -webkit-transform:rotate(45deg);
    -moz-transform:rotate(45deg);
    -o-transform:rotate(45deg);
    -ms-transform:rotate(45deg);
  }
   
  .headline:before{
    height:10px; 
    transform:rotate(-45deg);
    -webkit-transform:rotate(-45deg);
    -moz-transform:rotate(-45deg);
    -o-transform:rotate(-45deg);
    -ms-transform:rotate(-45deg); 
    top:16px; 
    left:7px
  }
  
  h3{
    position: relative;
    font-size: 18px;
    font-weight: bold;
    margin: 0 0 1.5em;
    padding: 0.5em 0.5em 0.5em 0.5em;
    border-bottom: 1px solid #B7B7B7;
    box-shadow: 0 1px 0 #fcfcfc;
  }
  /*
  h3:before{
    content: "";
    position: absolute;
    background: #878BD4;
    top: 0;
    left: 0.4em;
    height: 12px;
    width: 12px;
    transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
  }
   
  h3:after{
    content: "";
    position: absolute;
    background:#64A4D2;
    top: 1.0em;
    left: 0;
    height: 8px;
    width: 8px;
    transform: rotate(15deg);
    -moz-transform: rotate(15deg);
    -webkit-transform: rotate(15deg);
    -o-transform: rotate(15deg);
    -ms-transform: rotate(15deg);
  }
  */
  
  h4{
    margin: 0 0 1.5em;
    padding: 0.3em;
    font-size: 15px;
    font-weight: bold;
    border-top: 1px dashed #aaa;
    border-bottom: 1px dashed #aaa;
    background: #eee;
    text-shadow: 1px 1px 0 rgba(255,255,255,1);
    box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -moz-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -webkit-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -o-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -ms-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
  }
  
  h5{
    position:relative;
    padding-left:0px;
    font-weight: bold;
    font-size: 15px;
  }
   
  h5:before{
    content:''; 
    height:15px; 
    width: 100%;
    display:block; 
    position:absolute; 
    top:18px; 
    left:0px; 
    /* background-color:#ccc; */
    filter:alpha(opacity=20);
    -moz-opacity:0.20;
    -khtml-opacity: 0.20;
    opacity:0.20;
    box-shadow: 0px 3px 3px 3px rgba(255,255,255, 0.3) inset;
  }
  .rikaido{
    position:relative;
    padding-left:0px;
    font-weight: bold;
    font-size: 16px;
  }
   
  .rikaido:before{
    content:''; 
    height:8px; 
    width: 80%;
    display:block; 
    position:absolute; 
    top:25px; 
    left:0px; 
    background-color:#ccc;
    filter:alpha(opacity=20);
    -moz-opacity:0.20;
    -khtml-opacity: 0.20;
    opacity:0.20;
    box-shadow: 0px 3px 3px 3px rgba(255,255,255, 0.3) inset;
  }
  
  .box {
    box-shadow: 0px 2px 10px rgba(0,0,0,0.4);
  }
  
  
  .btn{
    color:#fff;
  }
  
  /* footer */
  
  footer {
    margin-top: 45px;
    padding-top: 5px;
    small {
      float: left;
    }
    ul {
      float: right;
      list-style: none;
      li {
        float: left;
        margin-left: 10px;
      }
    }
  }
  
  /* forms */
  
  /*　羅線状のフォーム */
  .form-lines{
    padding: 19px;
    margin-bottom: 20px;
    border: 2px dotted #999;
    border-radius:10px;
    background: white;
  }
  input, textarea, select, .uneditable-input {
    width: 100%;
  }
  
  .editDate{
    width:85px;
    font-size:14px;
    line-height:14px;
    cursor:pointer;
  }
  
  /* radiobutton , checkbox*/
  .radio,
  .checkbox {
    margin-top: 10px;
  }
  
  .form-search .radio,
  .form-search .checkbox,
  .form-inline .radio,
  .form-inline .checkbox {
    min-height: 20px;
    padding-left: 32px;
    margin-left:24px;
  }
  
  //.button-radio input[type="radio"], input[type="checkbox"]{
  //  display:none;
  //}
  
  .button-radio label {
    display:inline-block;
    background-color:#fff;
    padding:5px 20px;
    border:solid 1px #4E575B;
    border-radius:2px;
    cursor:pointer;
  }
  
  .button-radio input[type="radio"]:checked + label, input[type="checkbox"]:checked + label{ 
    background-color:#767676;
    color:#fff;
  }
  
  /* メニューテーブル */
  .menuTable{
    margin:0 auto;
    font-size:14px;
  }
  
  .menuTable th{
    background:#817A7A;
    color:white;
  }
  
  /* 学習Naviテーブル */
  table.list{
    border:1px solid #CCCCCC;
    width:950px;
    margin-top:20px;
  }
  
  table.list th{
    background:#999999;
    border:1px solid #CCCCCC;
    text-align:center;
    font-size:12px;
    color:#FFF;
  }
  
  table.list tr.whiteBg{
    background:#FFF;
  }
  
  table.list tr.grayBg{
    background:#EEEEEE;
  }
  
  table.list td{
    border:1px solid #CCCCCC;
    font-size:14px;
    padding:5px;
  }
  
  /* 中央揃え */
  .content {
  min-width: 1010px;
  width:80%;
  margin: 0 auto;
  margin-bottom: 30px;
  }
  
  .content_admin {
  min-width: 1050px;
  margin: 0 auto;
  margin-bottom: 30px;
  }
  
  .content_student {
  width: 980px;
  margin: 0 auto;
  margin-bottom: 30px;
  }
  
  
  /* Fyt */
  
  /* Fyt画面高さ */
  .fytContent{
    height:100%;
    position:relative;
  }
  
  /* Fyt右上表示 */
  .title{
    font-size: 16px;
    line-height: 38px;
    color:#DF5D53;
  }
  
  /* Fyt右下MENU */
  .subContents {
    border: 1px solid #e1e1e1;
    width: 130px;
    background:rgba(255, 255, 255, 0.5);
    z-index: 20;
    box-shadow: 0px 2px 10px rgba(0,0,0,0.4);
    /* position:fixed; top:150px; left:0;  padding:2pt;*/
    position:absolute; top:0; left:0;
    border-radius:5px;
    padding:8px 5px 2px 5px;
  }
  
  /* Fytチェックボックス */
  .nigate input[type='checkbox']{
    filter: alpha(opacity=0); -moz-opacity:0; opacity:0;
  }
  .weak_checkbox{
    background:url(/images/check.png) no-repeat left top;
    height: 28px;
    line-height: 28px;
    display: block;
    padding: 0 0 0 15px;
    cursor: pointer;
    overflow: hidden;
    background-position:left bottom;
  }
  .weak_checkbox.c_on{
      background-position:left top;
  }
  .weak_checkbox input{
    display:none
  }
  .enable_checkbox{
    background:url(/images/check.png) no-repeat left top;
    height: 28px;
    line-height: 28px;
    display: block;
    padding: 0 0 0 15px;
    cursor: pointer;
    overflow: hidden;
    background-position:left bottom;
  }
  .enable_checkbox.c_on{
      background-position:left top;
  }
  
  /* Fyt理解度グラフ */
  .graphValue{
    font-size:14px;
    font-weight:bold;
  }
  .progress {
    /*background: url(/images/bg_progress.gif) top repeat-x;*/
    border: 1px solid #d3d3d3;
    line-height: 0;
    border-radius:0px;
    position:relative;
    box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -moz-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -webkit-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -o-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -ms-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
  }
  .graph{
    height:20px;
    opacity:0.9;
    box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
  }
  /*
  .graph-green{
    background: rgba(48, 165, 95, 0.8);
    border: dashed 1px #4A8258;
    height: 100%;
  }
  .graph-blue{
    background: #618BF7;
    border: dashed 1px #FFFFFF;
    height:100%;
  }
  .graph-red{
    background: #F40F4A;
    border: dashed 1px #FFFFFF;
    height:100%;
  }
  .graph-purple{
    background:rgba(179,81,182,0.5);
    border:dashed 1px #B351B6;
    height:100%;
  }
  .graph-pink{
    background:rgba(210,59,156,0.5);
    border:dashed 1px #D23B9C;
    height:100%;
  }
  .graph-yellow{
    background: #FB9B34;
    border: dashed 1px #FFFFFF;
    height:100%;
  }
  .graph-water{
    background:rgba(75,181,186,0.5);
    border:dashed 1px #4BB5BA;
    height:100%;
  }
  .graph-list{
    background: rgb(62, 210, 59);
    border: solid 1px rgb(255, 255, 255);
    height: 100%;
  }
  */
  .graph-green{
    background:rgba(87,177,115,0.5);
    border:dashed 1px #3B8051;
    height:100%;
  }
  .graph-blue{
    background: rgba(14, 111, 224, 0.5);
    border: dashed 1px #346FB3;
    height:100%;
  }
  .graph-red{
    background:rgba(219,70,70,0.5);
    border:dashed 1px #DB4646;
    height:100%;
  }
  .graph-purple{
    background:rgba(179,81,182,0.5);
    border:dashed 1px #B351B6;
    height:100%;
  }
  .graph-pink{
    background:rgba(210,59,156,0.5);
    border:dashed 1px #D23B9C;
    height:100%;
  }
  .graph-yellow{
    background:rgba(229,220,54,0.2);
    border:dashed 1px #F4D500;
    height:100%;
  }
  .graph-water{
    background:rgba(75,181,186,0.5);
    border:dashed 1px #4BB5BA;
    height:100%;
  }
  
  .bunyaSelect{
    cursor:pointer;
    color: #000;
    width:350px;
    height: 35px;
    font-size: 13px;
    padding: 3px 3px 3px 5px;
    border: 1px solid #B3B3B3;
    border-radius: 4px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    text-indent: .01px;
    text-overflow: "";
    background: #FFF url(/images/select_arrow.jpg) no-repeat right;
  }
  
  .bunyaSelect:hover{
    background:#f2f2f2 url(/images/select_arrow.jpg) no-repeat right;
  }
  
  /* FYT受講カウント */
  .juko_count{
    position:absolute;
    right:0;
    top:-35px;
  }
  
  /* コメント欄 */
  p.dot {
    background-image: url(/images/dot.gif);
    line-height: 28px;
    margin: 0px;
    font-size:16px;
  }
  
  /* お知らせ */
  span.news {
     margin: 0px 0px 5px 0px;
     padding: 1px 0px;
     border-bottom: 1px dotted rgba(32, 27, 29, 0.26);
     font-size:13px;
     display:inline-block;
     width:100%;
  }
  .new{
    padding:1px 2px 1px 2px;
    border: solid 1px #a90013;
    color: #a90013;
    background: #fff;
    font-weight: bold;
    border-radius:3px;
  }
  .news-admin{
    padding:1px 2px 1px 2px;
    border: solid 1px #0AAC2F;
    color: #0AAC2F;
    background: #fff;
    font-weight: bold;
    border-radius:3px;
  }
  
  /* 管理ページ */
  .dragarea{
    background:#E7E7E7;
    border:2px dashed #B6B6B6;
    width:930px;
    height:100px;
    line-height:100px;
    text-align:center;
    font-size:13px;
    font-weight:bold;
    margin:0 auto;
    display:block;
  }
  .dragarea:hover{
    background:#E7E7E7;
    border:2px dashed #363939;
    width:930px;
    height:100px;
    line-height:100px;
    text-align:center;
    font-size:13px;
    font-weight:bold;
    margin:0 auto;
    display:block;
  }
  .upload{
    z-index:122222;
    background:#E7E7E7;
    height:60px;
    line-height:60px;
    text-align:center;
    font-size:13px;
    font-weight:bold;
    margin:0 auto;
  }
  .upload:hover{
    background:rgba(244, 146, 95, 0.46);
    color:white;
    height:60px;
    line-height:60px;
    text-align:center;
    font-size:13px;
    font-weight:bold;
    margin:0 auto;
  }
  
  /* パンくず */
  .breadarea {
    padding: 7px;
    border-radius: 2px;
    background-color: rgba(213, 213, 213, 0.42);
    color: #3F3F3F;
    font-size:12px;
  }
  
  /* 解説映像ページ */
  .moviearea{
    background:#f2f2f2;
    text-align:center;
    padding:3px;
  }
  
  .my-filter{
    font-weight:bold;
    input{
      border-radius:5px;
    }
  }
  
  .loginframe{
    text-align:center;
    margin:0 auto;
    background:rgba(255, 255, 255, 0.52);
    width:500px;
    padding:10px;
    margin-top:50px;
    /* border: 1px solid #D2A8A8; */
    border-radius:3px;
    height:190px;
    padding:40px;
    margin-top:100px;
  }
  
  /*　ログインフォーム */
  .loginform{
    margin-top:10px;
    input{
      width:400px;
      border-radius:4px;
      border: 1px inset;
      font-size:15px;
      padding:3px;
    }
    hr{
      border-top: 1px solid #B7B7B7;
      box-shadow: 0 1px 0 #fcfcfc;
    }
  }
  
  /* 得点欄 */
  .score-form{
    border-top: 1px dashed #aaa;
    border-bottom: 1px dashed #aaa;
    background:#eee;
    text-shadow: 1px 1px 0 rgba(255,255,255,1);
    box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -moz-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -webkit-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -ms-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    position:relative;
  }
  .score-input{
    border-top: 1px dashed #aaa;
    border-bottom: 1px dashed #aaa;
    background:#eee;
    text-shadow: 1px 1px 0 rgba(255,255,255,1);
    box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -moz-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -webkit-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -o-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    -ms-box-shadow: 0 5px 4px -4px rgba(0,0,0,0.3) inset;
    position:relative;
    width:100px;
    height:40px;
    text-align:center;
    font-size:18px;
    border-radius:5px;
  }
  
  .box {
    background: none repeat scroll 0 0 #fff;
    border-radius: 2px 2px 2px 2px;
    margin: 0 auto;
    /*width: 100%;*/
    /*height: 120px;*/
    padding: 10px;
  }
  .top-box {
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3), 0 0 5px rgba(0, 0, 0, 0.1) inset;
    position: relative;
  }
  .top-box:before, .top-box:after {
    border-radius: 100px 100px 100px 100px / 10px 10px 10px 10px;
    bottom: 10px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
    content: "";
    left: 0;
    position: absolute;
    right: 0;
    top: 10px;
    z-index: -1;
  }
  .top-box:after {
    left: auto;
    right: 10px;
    transform: skew(8deg) rotate(3deg);
    -webkit-transform: skew(8deg)  rotate(3deg);
    -moz-transform: skew(8deg)  rotate(3deg);
    -ms-transform: skew(8deg)  rotate(3deg);
    -o-transform: skew(8deg)  rotate(3deg);
  }
  strong {
  }
  /* 非表示開始 */
  .ng-hide-add {
    transition: 1s;
    opacity: 1;
  }
  /* 非表示終了 */
  .ng-hide-add-active {
    opacity: 0;
  }
  /* 表示開始 */
  .ng-hide-remove {
    transition: 1s;
    opacity: 0;
  }
  /* 表示終了 */
  .ng-hide-remove-active {
    opacity: 1;
  }
  
  /* テキストボックス */
  .list-text{
    border-radius:4px;
    border: 1px inset;
    font-size:11px;
    padding:3px;
  }
  
  /* 注意書き */
  .red-caution{
    color:red;
    font-size:15px;
    text-shadow:
    0px -1px #fff,
    1px 0px #fff,
    0px 1px #fff,
    -1px 1px #fff;
  }
  .notes{
    font-size:11px;
    margin-left:10px;
  }
  
  /* ページネーション */
  .tablePagination {
    padding-left: 0;
    margin-top: 1em;
  }
  .tablePagination:before {
    content:"Page: ";
  }
  .tablePagination li {
    cursor: pointer;
    display: inline-block;
    list-style: none;
    padding: 2px 9px;
  }
  .tablePagination li:hover {
    background: #eee;
    border-radius:4px;
  }
  .tablePagination .current {
    background: #26b;
    color: #fff;
    border-radius:4px;
  }
  
  /* 上へボタン */
  #page-top{
    width:50px;
    height:50px;
    display:none;
    position:fixed;
    right:16px;
    bottom:16px;
  }
   
  #page-top p{
    margin:0;
    padding:0;
    text-align:center;
    background:#3b3b3b;
    -webkit-transition:all 0.3s;
    -moz-transition:all 0.3s;
    transition:all 0.3s;
  }
   
  #page-top p:hover{
    background:#8b8b8b;
  }
   
  #move-page-top{
    color:#fff;
    line-height:50px;
    text-decoration:none;
    display:block;
    cursor:pointer;
  }
  
  /* 完了ボタンドロップメニュー */
  #dropmenu{
    list-style-type: none;
    padding: 0;
    border-radius: 3px 3px 0 0;
  }
  #dropmenu li{
    position: relative;
    width: 100%;
    float: left;
    margin: 0;
    padding: 0;
    text-align: center;
  }
  #dropmenu li a{
    display: block;
    margin: 0;
    padding: 15px 0 11px;
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    line-height: 1;
    text-decoration: none;
  }
  #dropmenu li ul{
    list-style: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin: 0;
    padding: 0;
    border-radius: 0 0 3px 3px;
  }
  #dropmenu li:last-child ul{
    left: 0%;
    width: 100%
  }
  #dropmenu li ul li{
    overflow: hidden;
    z-index:10000000000;
    width: 100%;
    height: 0;
    color: #fff;
    -moz-transition: .2s;
    -webkit-transition: .2s;
    -o-transition: .2s;
    -ms-transition: .2s;
    transition: .2s;
  }
  #dropmenu li ul li a{
    padding: 5px;
    background: white;
    border-radius:2px;
    border: solid 1px rgba(51, 51, 51, 0.75);
    text-align: center;
    font-size: 12px;
    font-weight: normal;
    color:black;
    margin-left:-20px;
  }
  #dropmenu li:hover > a{
    background: rgba(224, 224, 224, 0.73);
    color: #424242;
  }
  #dropmenu > li:hover > a{
    border-radius: 3px 3px 0 0;
  }
  #dropmenu li:hover ul li{
    overflow: visible;
    height: 38px;
  }
  #dropmenu li:hover ul li:first-child{
    border-top: 0;
  }
  #dropmenu li:hover ul li:last-child{
    border-bottom: 0;
  }
  #dropmenu li:hover ul li:last-child a{
    border-radius: 0 0 3px 3px;
  }
  
  /* 入力エラー */
  form td.validate_error{
    background:#e94b3b;
  }
  
  /* 入力必須 */
  form td.is_requreid{
    background:rgba(255, 227, 242, 0.5);
  }
  
  /* ラジオボタンは非表示にする */
  input[type=radio].ent-btn {
    display: none; 
  }
  /* チェックされた時のスタイル */
  input[type="radio"]:checked + .label1 {
    background: #4E8BB7;
    color: #FFF; 
  }
  input[type="radio"]:checked + .label2 {
    background: #D65B5B;
    color: #FFF; 
  }
  /* マウスオーバーしたときのスタイル */
  .label1:hover {
    background-color: #346990; 
  }
  .label2:hover {
    background-color: #C13F3F; 
  }
  /* lableのスタイル */
  .label {
    background:#95a5a6;
    width:90px;
    color: white;
    border-radius:2px;
    display: inline-block;
    height: 33px;
    line-height: 18px;
    padding-left: 20px;
    padding-right: 20px;
    cursor: pointer;
    font-size:14px;
    font-weight:bold;
    box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.4);
  }
  
  .printResultIcon{
    width:44px;
    height:28px;
  }
  
  /* buttonをテキストリンクと同様のレイアウトに */
  .to-a {
    color: #3C85C1;
    text-decoration: none;
    border-style:none;
    background:none;
    color:#3C85C1;
    width:45px;
  }
  .to-a:hover, .to-a:focus {
    color: #27ae60;
    text-decoration: none;
  }
  .to-a:focus {
    outline: thin dotted;
    outline: 5px auto -webkit-focus-ring-color;
    outline-offset: -2px;
  }
  
  /*生徒教材メニュー サブメニューボタン */
  .btn-pale-red {
    color: white;
    background-color: #D63C3C;
    border-color: #D05353;
    opacity: 0.65;
  }
  .btn-pale-red:hover, .btn-pale-red:focus, .btn-pale-red:active, .btn-pale-red.active, .open > .btn-pale-red.dropdown-toggle {
    color: white;
    background-color: #D85B5B;
    border-color: #D05353;
    opacity: 1;
  }
  
  /*カレンダー入力フォーム*/
  .editable-horizontal {
    display: inline;
  }
  
  .datetimepicker + .editable-popup .popover-content {
    min-width: 416px;
  }
  
  .pagination > li > a {
    color: #3C85C1;
  }
  
  .pagination {
    padding-left: 0;
    margin-top: 1em;
  }
  
  .pagination {
    display: inline-block;
    padding-left: 0;
    margin: 0;
    border-radius: 2px;
  }
  
  .page, .first, .prev, .next, .last {
    cursor: pointer;
    display: inline-block;
    list-style: none;
    padding: 2px 9px;
  }
  .page:hover, .first:hover, .prev:hover, .next:hover, .last:hover{
    background: #eee;
    border-radius:4px;
  }
  .page.current {
    background: #26b;
    color: #fff;
    border-radius:4px;
  }
  
  .page a:hover, .page a:focus, .first a:hover, .first a:focus, .prev a:hover, .prev a:focus, .next a:hover, .next a:focus, .last a:hover, .last a:focus {
    color: #3C85C1;
    text-decoration: none;
  }
  
  /* スクロールできるtableを入れるためのdiv */
  .tablebox {
    width:100%;
    overflow-x: scroll;
  }
  
  .item {
      display: block;
      border:solid 1px #ccc;
      color: #333;
      text-decoration: none;
      margin-top:20px;
      background: rgba(255, 255, 255, 1);
      padding:0;
      box-shadow: 1px 1px 1px rgba(0,0,0,0.1); 
  }
  .item-header{
      padding:12px;
      background: -moz-linear-gradient(top,  #e03939 0%, #e03939 100%);
      background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#e03939), color-stop(100%,#e03939));
      background: -webkit-linear-gradient(top,  #e03939 0%,#e03939 100%);
      background: -o-linear-gradient(top,  #e03939 0%,#e03939 100%);
      background: -ms-linear-gradient(top,  #e03939 0%,#e03939 100%);
      background: linear-gradient(to bottom,  #e03939 0%,#e03939 100%);
      background: linear-gradient(#e03939, #e03939);
      border-bottom: 1px solid rgba(0,0,0,0.1);
      box-shadow: 0 1px 0 rgba(255,255,255,1);
      border-radius:4px 4px 0 0;
      color:white;
  }
  .item-bottom{
      padding:5px;
      border-top: 1px solid rgba(0,0,0,0.1);
      background: linear-gradient(#45bc91, #059e6a);
      background: linear-gradient(#808080, #696969);
      color:#fff;
  }
  .item-body {
    padding: 10px 3px 5px 3px;
  }
  
  .daimon p {
    margin-bottom: 0;
    font-size: 15px;
  }
  
  .mondai-area {
    margin-top: 20px;
  }
  
  .sentaku label {
    box-sizing: border-box;
    display: inline-block;
    cursor: pointer;
    width: 100%;
    border-radius: 3px;
    border: 1px solid #ddd;
    margin: 3px;
    padding: 10px;
    background: #fff;
    color: #222;
    text-align: center;
    line-height: 1.6;
    transition: .2s;
  }
  
  .sentaku input[type="radio"]:checked + .switch-on {
    background-color: #5fb2f6;
    color: #fff;
  }
  
  .sentaku input {
    display: none;
  }
  
  table.with-noteTable {
  }
  
  table.table.blueTable.noteTable, table.table.blueTable.noteTable tr, table.table.blueTable.noteTable th, table.table.blueTable.noteTable td {
    border:none;
  }
  
  th.tdNote, td.tdNote {
    border:none;
    background:white;
    color:black;
  }
  
  th.tdNote input, td.tdNote input {
    width:200px;
  }
  
  .greenTable{
  }
  .greenTable th{
    background:#3BAB6C;
    color:white;
    opacity:0.9;
    font-size:13px;
    padding:0px;
  }
  
  .greenTable td{
    font-size:12px;
    border-bottom: 1px solid #84b2e0;
    border-left: 1px solid #84b2e0;
    text-align: center;
  }
  
  .greenTable thead tr th {
    vertical-align: middle;
  }
  
  .greenStriped tr:nth-child(odd) td {  
    background-color: #EEFFEA;
  }  
  
  .My-breadcrumb {
    padding: 8px 15px;
    margin-bottom: 20px;
    list-style: none;
    border-radius: 4px;
  }
  
  .My-breadcrumb > li {
    display: inline-block;
    font-size: 14px;
  }
  
  .My-breadcrumb > li + li:before {
    padding: 0 5px;
    color: #ccc;
    content: ">";
  }
  
  span.day {
    font-size: 21px;
    font-weight: 900;
    line-height: 1em;
  }
  .breadcrumb-custom {
    margin-left:0;
    background: #7d7d7d;
    padding: 2px 5px 5px 10px;
    overflow: hidden;
    font-size:13px;
  }
  
  .breadcrumb-custom li{
    display:inline;/*横に並ぶように*/
    list-style: none;
    font-weight: bold;/*太字*/
  }
  
  .breadcrumb-custom li:after{/* >を表示*/
    content: '>';
    padding: 0 3px;
    color: rgba(255, 255, 255, 0.4);
  }
  
  .breadcrumb-custom li:last-child:after{
    content: '';
  }
  
  .breadcrumb-custom li a {
      text-decoration: none;
      color: rgba(255, 255, 255, 1);
  }
  
  .breadcrumb-custom li:first-child a:before{/*家アイコンに*/
    font-family: FontAwesome;
    content: '\f015';
    font-weight: normal;
    font-size: 1.1em;
  }
  
  .breadcrumb-custom li a:hover {
      text-decoration: underline;
  }
  
  .adjust-box {
    position: relative;
    width: 100%;
    height: auto;
    background: #fff;
  }
  .box-1x1:before {
    content: "";
    display: block;
    padding-top: 100%;
  }
  .adjust-box-inner img {
    position: absolute;
    top: 0; 
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }
  
  .back-box{
    background:white;
    padding:20px 20px;
    border:solid 1px #ccc;
  }
  
  .modal-dialog{
    /* height: 100%; */
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  .editable-submit{
    height:34px;
  }
  
  .editable-buttons{
    margin: 0 !important;
  }
