@charset "utf-8";
/***********************************************
制作：ロゴスウェア株式会社
Copyright (c) LOGOSWARE, Inc
------------------------------------
全デバイス共通CSS
------------------------------------
*カスタマイズはcustomize-phone-tablet.css, customize-pc.cssにて行うこと
***********************************************/

html {
    font-size: 62.5%;
    font-family: "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    /* height 100%にしてしまうと本棚／リスト表示の下部コンテンツサムネイル画像の遅延ロードが完了しなくなる */
    /*height: 100%;*/
}

body {
    margin: 0;
    padding: 0;
    background: #FFF;
    color: #333;
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.75;
    height: 100%;
}

p {
    margin: 8px 0 10px 0;
}

label, button, a {
    cursor: pointer;
}


main {
    height: 100%;
}


/*******************************************
 Base Layout
*****************************************************/

/* clearfix */
.clearfix {
    zoom: 1;
}

.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

img.thumbnail {
    border: 1px solid #CCC \9; /* hack for IE8-6 */
    box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -webkit-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -moz-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -o-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -ms-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    appearance: none;
    -webkit-appearance: none;
}

/*---------------------*/
/* メインボタンカラー */
.theme-btn-color-main {
    background: #555 !important;
    color: #FFF !important;
}

.theme-btn-color-main.hover {
    background: #777 !important;
}

/*---------------------*/
/* 選択ボタンカラー */
.theme-btn-color-select {
    background: #CCC !important;
    color: #333 !important;
}

.theme-btn-color-select.active {
    background: #555 !important;
    color: #FFF !important;
}

.theme-btn-color-select.hover {
    background: #777 !important;
    color: #FFF !important;
}

/*---------------------*/
/* サブボタンカラー１（メインより薄い色） */
.theme-btn-color-sub1 {
    background: #CCC !important;
    color: #333 !important;
}

.theme-btn-color-sub1.hover {
    background: #DDD !important;
}

/*---------------------*/
/* サブボタンカラー２ （メインより少し薄い色）*/
.theme-btn-color-sub2 {
    background: #888 !important;
    color: #fff !important;
}

.theme-btn-color-sub2.hover {
    background: #666 !important;
}

/*---------------------*/
/* フロートボタンカラー （通常時透過）*/
.theme-btn-color-float {
    background: #555 !important;
    color: #fff !important;
    opacity: 0.7 !important;
}

.theme-btn-color-float.hover {
    background: #555 !important;
    opacity: 1.0 !important;
}

/*---------------------*/
/* ヘッダーメニューボタンカラー */
.theme-btn-color-header {
    background: #444 !important;
    color: #FFF !important;
}

.theme-btn-color-header.hover {
    background: #555 !important;
}

/*---------------------*/
/* ツリー選択ボタンカラー */
.theme-btn-color-tree {
}

.theme-btn-color-tree.active {
    background: #888 !important;
    color: #FFF !important;
}

.theme-btn-color-tree.uncheck {
    background: #EEE !important;
    color: #666 !important;
}

.theme-btn-color-tree.hover {
    background: #555 !important;
    color: #FFF !important;
}

/*---------------------*/
/* モバイル用サブメニューボタンカラー */
.theme-btn-color-mobile-menu {
    color: #aaa !important;
}

.theme-btn-color-mobile-menu.active {
    color: #555 !important;
}

.btn {
    display: inline-block;
    box-sizing: border-box;
    border-radius: 5px;
    margin: 0;
    padding: 6px 12px;
    /*background:#04C;
    color:#FFF;*/
    text-decoration: none;
    font-size: 13px;
    font-size: 1.3rem;
}

button.btn {
    vertical-align: baseline;
    outline: none;
    border-style: none;
    cursor: pointer;
    text-align: center;
    padding: 10px 15px;
}

a.btn .glyphicon {
    margin-right: 5px;
}

a.link-btn {
    display: inline-block;
    border-radius: 5px;
    margin: 0;
    text-decoration: none;
    font-size: 12px;
    font-size: 1.2rem;
}

.word-wrap-break-word {
    word-break: break-all;
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: normal;
    /*display: block;*/
}

.line-break-possible {
    white-space: pre-wrap;
}

/*******************************************
 Header
*****************************************************/
header {
    background: #333;
    color: #FFF;
}

/* clearfix */
header {
    zoom: 1;
}

header:after {
    content: "";
    display: block;
    clear: both;
}

header h1 {
    margin: 0px;
    box-sizing: border-box;
}

/*
header h1{
    float: left;
    box-sizing: border-box;
    max-width: -webkit-calc(100% - 112px - 40px) ;
    max-width : calc(100% - 112px - 40px) ;
    font-size:0;
    line-height: 1.0;
}
*/
header h1 img {
    vertical-align: bottom;
}

header h1 a {
    color: #FFF;
    text-decoration: none;
}

/*
header h1 img{
    width: 100%;
}
*/
header .header-block {
    position: relative;
    min-height: 70px;
    margin: 0px;
    padding: 0px;
}

header .header-block .headerContent {
    margin: 0px;
    padding: 0px;
}

header .header-block .right-top {
    position: absolute;
    top: 5px;
    right: 7px;
}

header .header-block .right-bottom {
    position: absolute;
    bottom: 5px;
    right: 7px;
}

/***
 ユーザー用メニュー(モバイル用：.edit.minimum／パソコン用：.edit.maximum)
 *************/
header div.edit {
    /*
    float: right;
    margin: 5px 5px 5px 0;
    */
}

header div.edit a {
    font-size: 12px;
    font-size: 1.2rem;
}

header div.edit ul {
    margin: 0;
    padding: 0;
}

header div.edit ul:after {
    content: "";
    display: block;
    clear: both;
}

header div.edit li {
    float: left;
    list-style: none;
    margin: 0 0 0 7px;
}

header div.edit a {
    display: block;
    border-radius: 4px;
    margin: 0;
    /*
    padding: 0.25em 1em;
    */
    padding: 3px 7px;
    /*background: #444;
    color: #FFF;*/
    text-decoration: none;
}

header div.edit a i {
    margin-right: 3px;
}
/*******************************************
 Home画面
*****************************************************/
#home-page{
    height: 100%;
}
/*******************************************
 Main Menu ( Search / Display Style / Sort )
*****************************************************/
#mainMenu {
    position: relative;
    z-index: 1000;
    box-sizing: border-box;
    margin: 0;
    padding: 10px;
    width: 100%;
    background: #EFEFEF;
    vertical-align: middle;
    box-shadow: 0px 0px 5px #999;
    -webkit-box-shadow: 0px 0px 5px #999;
    -moz-box-shadow: 0px 0px 5px #999;
}

/* clearfix */
#mainMenu {
    zoom: 1;
}

#mainMenu:after {
    content: "";
    display: block;
    clear: both;
}

/***
 Search Area
 *************/
/* clearfix */
/*
#mainMenu .search .minimum{
    zoom:1;
}
*/
/*
#mainMenu .search .searchBox:after{
    content:"";
    display:block;
    clear:both;
}
*/
#mainMenu .search .searchBox #searchForm {
    float: left;
    box-sizing: border-box;
    margin: 0;
    position: relative;
}

#mainMenu .search .searchBox input.keyword {
    /*float: left;*/
    box-sizing: border-box;
    margin: 0;
    padding: 3px 5px;
}

#mainMenu .search .searchBox input.keyword::-ms-clear {
    visibility: hidden
}

#mainMenu .search .searchBox #searchForm #searchClear {
    position: absolute;
    box-sizing: border-box;
    right: 0px;
    top: 0px;
    color: #bbb;
}

/***
検索ボタン
***/
#mainMenu .search .searchBox .searchBtn {
    display: block;
    float: left;
    box-sizing: border-box;
    /*background: #666;
    color:#FFF;*/
    text-align: center;

    display: block;
    border-radius: 4px;
    box-sizing: border-box;
    margin: 0 5px;
    padding: 0px 10px;
    text-decoration: none;

    height: 30px;
    line-height: 30px;
    vertical-align: middle;
    font-size: 12px;
    font-size: 1.2rem;

}

#mainMenu .search .searchBox .searchBtn i {
    display: table-cell;
    padding: 0 3px 0 0;
}

#mainMenu .search .searchBox .searchBtn .label {
    display: table-cell;
}

/***
検索対象ボタン
********************/
#mainMenu .search .switchSearchFilterBtn {
    display: inline-block;
    margin: 0;
    padding: 0;
}

#mainMenu .switchSearchFilterBtn {
    display: inline-block;
    margin: 0;
    padding: 0;
    cursor: pointer;
    border-radius: 4px;
    box-sizing: border-box;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;

    width: 30px;
    height: 30px;
    line-height: 30px;

    /*background: #CCC;
    color: #333;*/
    font-size: 12px;
    font-size: 1.2rem;

}

#mainMenu .switchSearchFilterBtn.active {
    /*background: #177FBF;
    color: #FFF;*/
}

#mainMenu .switchSearchFilterBtn i {
    display: table-cell;
    font-size: 16px;
    font-size: 1.6rem;
    padding: 0;
    width: 30px;
    height: 30px;
    line-height: 30px;
}

/***
検索対象設定
********************/
#mainMenu .search .searchFilter {
    display: block;
    border-radius: 4px;
    background: #DDD;
}

/* clearfix */
#mainMenu .search .searchFilter {
    zoom: 1;
}

#mainMenu .search .searchFilter:after {
    content: "";
    display: block;
    clear: both;
}

#mainMenu .search .searchFilter ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

#mainMenu .search .searchFilter li {
    float: left;
}

#mainMenu .search .searchFilter input {
    vertical-align: middle;
}

#mainMenu .search .searchFilter input:before {
    clear: both;
}

#mainMenu .search .searchFilter .label {
    margin: 0 0 0 0.25em;
    padding: 0.5em 0;
}

/*******************************************
 container
*****************************************************/
/*#shelf .container{*/
.container {
    margin: 0;
    padding: 0;
    width: 100%;
}

/*******************************************
 Primary Area ( Contents - bookshelf and list )
*****************************************************/

/*******************************************
 Secondary Area (Category Menu)
*****************************************************/

/*******************************************
 Tertiary Area (Banner, etc)
*****************************************************/
#tertiary {
    display: none; /* デフォルト非表示化 */
    box-sizing: border-box;
    background: #f7f6f5;
}

#tertiary p,
#tertiary li {
    font-size: 12px;
    font-size: 1.2rem;
}

/*******************************************
 Footer
*****************************************************/
footer {
    display: block;
    clear: both;
    box-sizing: border-box;
    padding: 0;
    width: 100%;
    background: #DDD;
    color: #333;
    font-size: 12px;
    font-size: 1.2rem;
}

footer ul {
    margin: 0;
}

footer p {
    margin: 0px;
    padding: 3px 5px;
}

footer .footerLink {
    box-sizing: border-box;
    padding: 3px 5px;
}

footer .copyright {
    box-sizing: border-box;
    margin: 5px 0 0 0;
    padding: 3px;
    background: #333;
    color: #FFF;
    text-align: center;
}

footer .copyright p {
    margin: 3px;
    padding: 0px;
}

/*******************************************
 Shelf Index
*****************************************************/
#home-page .shelfBackground {
    background: url(../img/bg.png) repeat 0 0;
}
#homeBackground{
    display: none;
    position: absolute;
    top:0;
    left: 0;
    width: 100%;
    height:100%;
    z-index: -10;
}
#home-page.unvisible-footer #homeBackground{
    display: block;
}

#home-page .vertical-box{
    display: flex;
    flex-direction: column;

}

/* 最下段の影 */
#content.shelfContent:after {
    content: "";
    display: block;
    width: 100%;
    height: 40px;
    background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzNlMmYxYSIgc3RvcC1vcGFjaXR5PSIwLjUiLz4KICAgIDxzdG9wIG9mZnNldD0iMjAlIiBzdG9wLWNvbG9yPSIjM2UyZjFhIiBzdG9wLW9wYWNpdHk9IjAuMTUiLz4KICAgIDxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzNlMmYxYSIgc3RvcC1vcGFjaXR5PSIwIi8+CiAgPC9saW5lYXJHcmFkaWVudD4KICA8cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSJ1cmwoI2dyYWQtdWNnZy1nZW5lcmF0ZWQpIiAvPgo8L3N2Zz4=);
    background: -moz-linear-gradient(top, rgba(62, 47, 26, 0.5) 0%, rgba(62, 47, 26, 0.15) 20%, rgba(62, 47, 26, 0) 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(62, 47, 26, 0.5)), color-stop(20%, rgba(62, 47, 26, 0.15)), color-stop(100%, rgba(62, 47, 26, 0))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top, rgba(62, 47, 26, 0.5) 0%, rgba(62, 47, 26, 0.15) 20%, rgba(62, 47, 26, 0) 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top, rgba(62, 47, 26, 0.5) 0%, rgba(62, 47, 26, 0.15) 20%, rgba(62, 47, 26, 0) 100%); /* Opera 11.10+ */
    background: -ms-linear-gradient(top, rgba(62, 47, 26, 0.5) 0%, rgba(62, 47, 26, 0.15) 20%, rgba(62, 47, 26, 0) 100%); /* IE10+ */
    background: linear-gradient(to bottom, rgba(62, 47, 26, 0.5) 0%, rgba(62, 47, 26, 0.15) 20%, rgba(62, 47, 26, 0) 100%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#803e2f1a', endColorstr='#003e2f1a', GradientType=0); /* IE6-8 */
}

/* shelf title */
#content.shelfContent h2 {
    margin: 0;
    padding: 5px 10px;
    background: url(../img/bg_shelf_title.png) repeat 0 0;
    background-size: auto 100px;
    color: #FFF;
    font-size: 14px;
    font-size: 1.4rem;
}

/* shelf */
#content.shelfContent .shelf {
    position: relative;
}

#content.shelfContent .shelf ul {
    position: relative;
    width: auto;
    margin: 0;
    padding: 0;

    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: inline-axis;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    -ms-flex-align: center;
    -ms-flex-pack: center;
    justify-content: center;
    align-items: center;
}

#content.shelfContent .shelf ul li {
    position: relative;
    margin: 0 3px;
    padding: 0;
    list-style: none;
}

/* contents title */
#content.shelfContent .shelf .ctitleWrapper {
    margin: 17px auto 0;
    color: #333;

    height: 26px;
    font-size: 11px;
    font-size: 1.1rem;
    line-height: 1.2;
    text-align: center;
    vertical-align: bottom;
    overflow: hidden;

    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    text-overflow: ellipsis;
    /*white-space: nowrap;*/
}

#content.shelfContent .shelf .ctitleWrapper a {
    color: #333;
    text-decoration: none;
}

/* contents thumbnail */
#content.shelfContent .shelf .cimageWrapper {
    position: absolute;
}

#content.shelfContent .shelf img.thumbnail {
    display: block;
    margin: 0 auto;
}

/*
 おすすめコンテンツ用本棚
***********************/
#content.shelfContent .recommendation h2 {
    margin: 0;
    padding: 5px 10px;
    background: url(../img/bg_shelf_title_recommendation.png) repeat 0 0;
    background-size: auto 100px;
    color: #FFF;
}

/*******************************************
 List Index
*****************************************************/
/* category (same as shelf title) */
#content.listContent .list {
    min-height: 130px;
}

#content.listContent h2 {
    border-top: 1px solid #000;
    border-bottom: 1px dotted #000;
    margin: 40px 20px 0 20px;
    padding: 8px 5px;
    color: #333;
    font-size: 18px;
    font-size: 1.8rem;
}

#content.listContent ul.list {
    margin: 0;
    padding: 0;
}

#content.listContent ul.list li {
    list-style: none;
    border-bottom: 1px solid #CCC;
    margin: 0px 20px;
    padding: 20px 0;
}

/* clearfix */
#content.listContent ul.list > li {
    zoom: 1;
}

#content.listContent ul.list > li:after {
    content: "";
    display: block;
    clear: both;
}

/* 最後のli */
#content.listContent ul.list > li:last-child {
    border: none;
    /*margin-bottom:25px;*/
}

#content.listContent ul.list li .ctitleWrapper a {
    color: #333;
    text-decoration: none;
}

/* contents thumbnail */
/*
#content.listContent ul.list img.thumbnail {
    display: block;
    margin: 0 auto;
}
*/

/* ------------------------------------------- */
.content-list-item .content-list-item-body {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex; /* safari */
    display: -ms-flexbox; /* IE */
    display: flex;
    -webkit-box-orient: inline-axis;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;

}

.content-list-item .content-list-item-body .cimageWrapper {
    display: block;
    margin: 0 15px 10px 0;
    box-sizing: border-box;
    width: 140px;
    flex: 0 0 140px;
    -ms-flex: 0 0 140px;
    text-align: center;
}

.content-list-item .content-list-item-body .box {
    display: block;
    margin: 0;
    box-sizing: border-box;
    width: 100%;
    flex: 1 1 100%;
    -ms-flex: 1 1 100%;
}

/* ------------------------------------------- */
#content.listContent ul.list .cimageWrapper a.cimageLink {
    width: 140px;
    text-align: center;
}

#content.listContent ul.list .cimageWrapper img.thumbnail {
    max-width: 140px;
    max-height: 140px;
}

#content.listContent ul.lis .content-thumbnail .content-update-icon {
    left: 0px;
}

#content.listContent ul.lis .content-thumbnail .content-type-icon {
    right: 0px;
}

#content.listContent ul.list .box {
    /*float:right;*/
    width: 100%;
}

#content.listContent ul.list .basicinfo h3 {
    margin: 0 0 5px 0;
}

/* 説明文部分のリスト */
#content.listContent ul.list li ul {
    margin: 10px 20px;
    padding: 0;
}

#content.listContent ul.list li li {
    border: none;
    margin: 0;
    padding: 0;
}

#content.listContent ul.list li ul li {
    list-style: disc;
}

#content.listContent ul.list .basicinfo .ctitleWrapper {
    margin: 0px 0 5px;
}

/* ブックのメタ情報 */
#content.listContent ul.list .basicinfo ul.metadata {
    margin: 5px 0 5px;
}

#content.listContent ul.list .basicinfo ul.metadata li {
    list-style: none;
    /*float: left;*/
    display: inline-block;
    margin-right: 1em;
    font-size: 11px;
    font-size: 1.1rem;
}

#content.listContent ul.list .basicinfo ul.metadata li i {
    margin-right: 3px;
}

/* ブックのタグ情報 */
#content.listContent ul.list .basicinfo .meta-tags {
    margin: 5px 0;
}

/* ボタン（開く・ダウンロード） */
#content.listContent ul.list .basicinfo ul.action {
    margin: 5px 0 0 0;
}

#content.listContent ul.list .basicinfo ul.action li {
    display: inline-block;
    list-style: none;
    margin: 7px 5px 0 0;
}

#content.listContent ul.list .basicinfo ul.action li a {
    margin: 0px;
}

/***********************************************************
　検索ヒット箇所情報表示　Add Itoh
***/
#content.listContent ul.list .ctitle em,
#content.listContent ul.list .content-number em,
#content.listContent ul.list .content-memo em {
    color: #ff0000;
    font-style: normal;
    font-weight: bold;
}

#content.listContent ul.list .searchHit {
    clear: both;
    padding: 10px 10px 0 10px;
}

#content.listContent ul.list .searchHit ul.searchHitList {
    list-style: none;
    margin: 0;
    padding: 0;
}

#content.listContent ul.list .searchHit .searchHitBody {
    border-top: 1px dashed #cccccc;
    margin-top: 10px;
    padding-top: 5px;
}

#content.listContent ul.list .searchHit .searchHitBody .content-body-label {
    margin: 5px 0px;
}

#content.listContent ul.list .searchHit ul.searchHitList li {
    list-style-type: none;
    background-color: #ede9e7;
    border: 1px solid #ede9e7;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    margin-bottom: 5px;
}

#content.listContent ul.list .searchHit ul.searchHitList li a {
    color: #333333;
    text-decoration: none;
    vertical-align: baseline;
    display: block;
    padding: 5px 7px 5px 7px;
    cursor: pointer;
}

#content.listContent ul.list .searchHit ul.searchHitList li a:visited,
#content.listContent ul.list .searchHit ul.searchHitList li a:link {
    color: #333333;
}

#content.listContent ul.list .searchHit ul.searchHitList li em {
    color: #ff0000;
    font-style: normal;
    font-weight: bold;
}

#content.listContent ul.list .searchHit ul.searchHitList li .positionInfo {
    text-align: left;
}

#content.listContent ul.list .searchHit ul.searchHitList li .position {
    font-size: 12px;
    font-size: 1.2rem;
}

#content.listContent ul.list .searchHit .scope-type,
#content.listContent ul.list .searchHit ul.searchHitList li .subtype {
    font-size: 12px;
    font-size: 1.2rem;
    background-color: #666666;
    padding: 2px 5px;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    color: #ffffff;
    margin-right: 5px;
}

#content.listContent ul.list .searchHit ul.searchHitList li .subtype {
    background-color: #999999;
}

#content.listContent ul.list .searchHit .searchResultMore {
    width: 100%;
    text-align: center;
}

#content.listContent ul.list .searchHit .searchResultMore span {
    margin: 0 5px;
}

#content.listContent ul.list .searchHit .searchResultMore a {
    display: inline-block;

    color: #333333;
    text-decoration: none;
    padding: 2px 7px;
    margin: 0 5px;

    background-color: #ede9e7;
    border: 1px solid #ede9e7;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;

}

#content.listContent ul.list .searchHit .searchResultMore a:visited,
#content.listContent ul.list .searchHit .searchResultMore a:link {
    color: #333333;
}

/*******************************************
Banner Area
*****************************************************/
/* #tertiary内 */
#tertiary .banner ul {
    margin: 0;
    padding: 0;
}

#tertiary .banner li {
    list-style: none;
}

/*********************************************
モーダルウィンドウ表示用
**********************************************/
.modal-body {
    background-color: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0;
    z-index: 10001;
    overflow-x: hidden;
    overflow-y: auto;
    box-sizing: border-box;

    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    -ms-flex-align: center;
    -ms-flex-pack: center;
    justify-content: center;
    align-items: center;
}

.modal-body.overWindow {
    -ms-flex-align: start;
    align-items: flex-start;
}

.modal-container {
    position: relative;
    width: auto;
    margin: 10px;
    box-sizing: border-box;
    flex: 0 1 680px;
    -ms-flex: 0 1 680px;

    display: block;
    background-color: #fff;
    border-radius: 5px;
    border: 1px solid #ddd;
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
    padding: 10px 15px;
}

/* ------------------------------------------ */
.modal-container div.action-close {
    position: relative;
    text-align: center;

    border-top: 1px dotted #dddddd;
    padding-top: 10px;
}

.modal-container div.action-close a {
    margin: 0 auto;
    text-align: center;
}

.modal-container p.closeBtn {
    position: absolute;
    top: 0px;
    right: 10px;
    text-align: right;
    flex-basis: 30px;
    font-size: 1.5em;
    /*font-width:bold;*/
    color: #999999;
    cursor: pointer;
}

/* ------------------------------------------ */

/***
 コンテンツ詳細ウィンドウ（オーバーレイ）
*/
.content-detail-modal {
    /*position: relative;*/
    padding: 0px 10px;
}

.content-detail-modal ul li {
    list-style: none;
}

.content-detail-modal .content-detail-body {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex; /* safari */
    display: -ms-flexbox; /* IE */
    display: flex;
    -webkit-box-orient: inline-axis;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;

}

.content-detail-modal .content-detail-body .cimageWrapper {
    display: block;
    margin: 0 10px 10px 0;
    box-sizing: border-box;
    flex: 0 0 auto;
    -ms-flex: 0 0 auto;
}

.content-detail-modal .content-detail-body .cimageWrapper a.cimageLink {
    max-width: 200px;
}

.content-detail-modal .content-detail-body .cimageWrapper img.thumbnail {
    max-width: 200px;
    max-height: 200px;
}

.content-detail-modal .content-detail-body .content-thumbnail .content-update-icon {
    left: 0px;
}

.content-detail-modal .content-detail-body .content-thumbnail .content-type-icon {
    right: 0px;
}

.content-detail-modal .content-detail-body .cinfo-wrapper {
    display: block;
    margin: 0 10px 10px 10px;
    box-sizing: border-box;
    flex: 1 1 auto;
    -ms-flex: 1 1 auto;
    width: 100%;
}

.content-detail-modal .content-detail-body .cinfo-wrapper {
    font-size: 13px;
    font-size: 1.3rem;
}

/* ------------------------------------------ */
.content-detail-modal .content-detail-body .cimageWrapper div.action-open {
    width: 100%;
    text-align: center;
    margin-top: 10px;
}

/* ------------------------------------------ */
.content-detail-modal .ctitleWrapper a {
    color: #333;
    text-decoration: none;
}

.content-detail-modal div.title {
    margin: 10px 0px;
    font-weight: bold;
    font-size: 1.5em;
}

/* ------------------------------------------ */
.content-detail-modal ul.metadata {
    margin: 0px;
    padding: 0px;
}

.content-detail-modal ul.metadata li {
    display: inline-block;
    margin-right: 1em;

}

.content-detail-modal ul.metadata li i {
    margin-right: 3px;
}

/* ブックのタグ情報 */
.content-detail-modal .meta-tags {
    margin: 5px 0;
    font-size: 12px;
    font-size: 1.2rem;
}

.content-detail-modal .meta-content-number i,
.content-detail-modal .meta-memo i {
    margin-right: 3px;
}

.content-detail-modal .meta-content-number {
    margin: 0px;
}

.content-detail-modal .meta-memo {
    margin: 5px 0px;
}

.content-detail-modal .meta-memo p {
    margin: 0px;
}

.content-detail-modal .basicinfo ul.action {
    padding: 0px;
    margin: 10px 0 5px 0;
}

.content-detail-modal .basicinfo ul.action li {
    display: inline-block;
    list-style: none;
    margin: 0 5px 5px 0;
}

.content-detail-modal .basicinfo ul.action li a {
    display: block;
    border-radius: 4px;
    box-sizing: border-box;
    padding: 4px 10px 3px;
    /*background: #CCC;
    color: #333;*/
    text-decoration: none;
}

.content-detail-modal .basicinfo ul.action li a.active {
    /*background: #177FBF;
    color: #FFF;*/
}

/* ------------------------------------------ */
.content-detail-modal .optioninfo .share-url-area,
.content-detail-modal .optioninfo .version-list-area,
.content-detail-modal .optioninfo .file-list-area {
    display: inline-block;
    width: 100%;
    box-sizing: border-box;
    border-radius: 5px;
    border: 1px solid #ddd;
    background-color: #eeeeee;
    padding: 5px 10px;
    margin: 0 0 10px 0;
}

.content-detail-modal .share-url-area .share-url-title,
.content-detail-modal .version-list-area .version-list-title,
.content-detail-modal .file-list-area .file-list-title {
    font-weight: bold;
    color: #555;
    font-size: 1.2em;
    margin: 0px;
}

.content-detail-modal .optioninfo .share-url-area .share-url-action {
    line-height: 25px;
    vertical-align: middle;
    margin: 5px 0 5px 0;
    word-break: break-all;
}

.content-detail-modal .optioninfo .share-url-area .share-url-action a.link-btn {
    height: 25px;
    line-height: 25px;
    text-align: center;
    vertical-align: middle;
    padding: 0 5px;
}

.content-detail-modal .optioninfo .share-url-area .share-url-action a.link-btn i {
    margin-right: 3px;
}

.content-detail-modal .optioninfo .share-url-area .share-detail-info-url-area{
    margin-top: 12px;
    padding-top: 6px;
    border-top:1px dotted #999999;
}

.content-detail-modal .share-url-message,
.content-detail-modal .share-detail-info-url-message{
    font-size: 10px;
    color: #666666;
    line-height: 12px;
}
.content-detail-modal .share-detail-info-url-message{
    margin-bottom: 6px;
}

.content-detail-modal .version-list-area ul,
.content-detail-modal .file-list-area ul {
    margin: 0px 10px;
    padding: 0px;
}

.content-detail-modal .version-list-area ul li,
.content-detail-modal .file-list-area ul li {
    margin: 5px 0px;

}

.content-detail-modal ul.version-list li i,
.content-detail-modal ul.file-list li i {
    margin: 0 3px 0 0;
}

.content-detail-modal ul.version-list li a,
.content-detail-modal ul.file-list li a {
    color: #555;
    text-decoration: underline;
    margin: 0 10px 0 0;
}

.content-detail-modal ul.version-list li .version-comment {
    display: inline-block;
}

/***
/ コンテンツサムネイル画像の設定
**/
.content-thumbnail {
    position: relative;
}

.content-thumbnail .content-update-icon {
    position: absolute;
    top: 0;
    left: 1px;
}

.content-thumbnail .content-type-icon {
    position: absolute;
    top: 0;
    right: 1px;
}

.content-thumbnail .content-public-type {
    position: absolute;
    bottom: 0px;
    width: 100%;
    text-align: center;
}

.content-thumbnail .content-public-type span {
    margin: 0 0 2px 0;
    border-radius: 3px;
    box-sizing: border-box;
    padding: 2px 5px;

    line-height: normal;
    font-size: 10px;
    font-size: 1.0rem;

    color: #333333;
    text-shadow: 0px 1px 0 #eaeaea;
    -moz-text-shadow: 0px 1px 0 #eaeaea;
    -webkit-text-shadow: 0px 1px 0 #eaeaea;
    background-color: #d2d3d3;

    border: 1px solid #CCC \9; /* hack for IE8-6 */
    box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -webkit-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -moz-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -o-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
    -ms-box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.5);
}
.content-thumbnail .lock-icon {
    position: absolute;
    bottom: 1px;
    right: 1px;
}

/* -------------------------------------------------------- */
.leaf-tag-box {
    display: inline-block;
    margin: 2px;
    padding: 2px 5px;
    vertical-align: middle;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    color: #333333;
    text-shadow: 0 1px 0 #393939;
    -moz-text-shadow: 0 1px 0 #393939;
    -webkit-text-shadow: 0 1px 0 #393939;
    background-color: rgb(196, 196, 196);
}

.leaf-tag-box .tag-link a {
    margin: 0px;
    display: inline-block;
    color: #333333;
    text-shadow: none;
    -moz-text-shadow: none;
    -webkit-text-shadow: none;
    text-decoration: none;
    vertical-align: baseline;

    border-right: 1px dotted #666666;
}

.leaf-tag-box .tag-link a:last-of-type {
    border-right: none;
}

.leaf-tag-box .tag-link a:visited,
.leaf-tag-box .tag-link a:link {
    color: #333333;
}

/* ------------------------------------------- */
.whiteChar {
    color: #ffffff;
}

.leaf-tag-box.whiteChar .tag-link a {
    color: #ffffff;
    text-shadow: 0 1px 0 #393939;
    -moz-text-shadow: 0 1px 0 #393939;
    -webkit-text-shadow: 0 1px 0 #393939;
}

.leaf-tag-box.whiteChar .tag-link a:visited,
.leaf-tag-box.whiteChar .tag-link a:link {
    color: #ffffff;
}

/* ------------------------------------------- */

.leaf-tag-box .tag-link-sep {
    /*margin: 0px 5px;*/
}

/*****/
#content {
    position: relative;
}

#content:after {
    content: "";
    display: block;
    width: 100%;
    height: 40px;
}

#content .notFoundMsg {
    position: absolute;
    top: 60px;
    z-index: 3000;
    margin: auto;
    text-align: center;
    width: 100%;
}

#content .loading {
    position: absolute;
    top: 60px;
    z-index: 3000;
    margin: auto;
    text-align: center;
    width: 100%;
}

#content .loading span {
    margin: 0 auto;
    text-align: center;
}

#init-loading {
    margin: 100px auto;
    text-align: center;
}

/*
#init-loading #init-loading-image img{
    width: 64px;
    height: 64px;
}
*/

/* ----------------------------------------- */
/* ログイン画面                              */
/* ----------------------------------------- */
#containerWrap.login {
    width: 100%;
    margin: 30px 0;
    font-size: 12px;
    font-size: 1.2rem;
}

#containerWrap.login .form {
    position: relative;
    width: 260px;
    margin: 0 auto 0 auto;
    border: 1px solid #c6c6c6;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    padding: 0 20px;
}

#containerWrap.login .form #errorBox {
    margin: 20px 0;
    background-color: #ffebe8;
    border: 1px solid #dd3c10;
    padding: 1em;
    font-weight: bold;
}

#containerWrap.login .form #errorBox p {
    margin: 5px 0;
}

#containerWrap.login .form label.formLabel {
    font-size: 14px;
    font-size: 1.4rem;
}

#containerWrap.login .form #password {
    margin-bottom: 3px;
}

#containerWrap.login .form input[type="text"],
#containerWrap.login .form input[type="password"] {
    font-size: 15px;
    font-size: 1.5rem;

    margin: 0;
    padding: 5px;
}

#containerWrap.login input[type="text"],
#containerWrap.login input[type="password"], textarea {
    width: 100%;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

#containerWrap.login .formRow {
    clear: both;
    margin-top: 20px;
}

/*
#containerWrap.login #loginSaveRow {
    margin-top: 10px;
}*/
#containerWrap.login #loginSaveRow label {
    font-size: 12px;
    font-size: 1.2rem;
    color: #676767;
}

#containerWrap.login .submitButtonWrap {
    position: relative;
    margin: 20px 0;
}

#containerWrap.login #submitButton,
#containerWrap.login #homeButton {
    width: 260px;
    font-size: 16px;
    font-size: 1.6rem;

    cursor: pointer;
    text-align: center;
    padding: 10px 15px;

}

#containerWrap.login #reminderWrap {
    margin: 30px 0 10px 0;
    text-align: right;
}

#containerWrap.login #reminder {
    display: inline;
    width: 260px;
    border-bottom: dotted 1px #7C6767;
    margin-right: 10px;
    vertical-align: bottom;
}

#containerWrap.login #reminder, #forgot a:active {
    color: #7C6767;
    font-size: 12px;
    font-size: 1.2rem;
}

#containerWrap.login a {
    text-decoration: none;
}

#containerWrap.login a:visited {
    color: #333333;
}

#containerWrap.login #versionNo {
    position: relative;
    margin: 0 auto;
    text-align: right;
    color: #eeeeee;
    font-size: 10px;
    width: 290px;
}

#containerWrap.login .loading {
    display: block;
    position: absolute;
    overflow: auto;
    text-align: center;
    height: 17px;
    width: 17px;
    top: 50%;
    left: 50%;
    margin-top: -8px;
    margin-left: -8px;
    background-image: url(../img/loading.gif);
}

/* -----------------------
ページトップへ移動ボタン
----------------------- */
#pageTop {
    position: fixed;
    bottom: 20px;
    right: 20px;
}

#pageTop a {
    display: block;
    display: table-cell; /* IE8から使用可能 */
    vertical-align: middle;
    text-align: center;

    z-index: 1000;
    /*background-color: #177FBF;
    color: #fff;*/
    width: 40px;
    height: 40px;
    font-weight: bold;
    text-decoration: none;
    border-radius: 10px;

    box-shadow: 0px 0px 5px #999;
    -webkit-box-shadow: 0px 0px 5px #999;
    -moz-box-shadow: 0px 0px 5px #999;
}

/* -----------------------
ページングUI
----------------------- */
#mainMenu .paginator {
}

#mainMenu .paginator .itemNumLabel {
    display: inline-block;
    margin: 0 0 0 10px;
    font-size: 15px;
    font-size: 1.5rem;
}

#mainMenu .paginator .pageController {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
}

/***
更新（リロード）ボタン
***/
#mainMenu .reloadBtn {
    display: inline-block;
    margin: 0 0 0 5px;
    padding: 0;
    cursor: pointer;
    border-radius: 4px;
    box-sizing: border-box;
    text-align: center;
    text-decoration: none;
    vertical-align: top;

    width: 30px;
    height: 30px;
    line-height: 30px;

    font-size: 12px;
    font-size: 1.2rem;
}

#mainMenu .reloadBtn i {
    display: table-cell;
    font-size: 16px;
    font-size: 1.6rem;
    padding: 0;
    width: 30px;
    height: 30px;
    line-height: 30px;
}

#contentBottom {
    position: absolute;
    width: 100%;
    text-align: center;
}

#contentBottom .paginator .itemNumLabel {
    display: inline-block;
    margin: 5px 0 0 10px;
    font-size: 15px;
    font-size: 1.5rem;
}

#contentBottom .paginator .pageController {
    display: inline-block;
    color: #333;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 5px;
}


.pageController a.deactive {
    filter: alpha(opacity=30);
    -moz-opacity: 0.3;
    opacity: 0.3;
    cursor: default;
}

.userSelectNone {
    user-select: none; /* CSS3 */
    -moz-user-select: none; /* Firefox */
    -webkit-user-select: none; /* Safari、Chromeなど */
    -ms-user-select: none; /* IE10かららしい */
}

/* -----------------------
マイアカウント画面
----------------------- */
.myaccount {
    margin: 0 auto;
    padding: 10px;
    width: 100%;
    max-width: 600px;
    box-sizing: border-box;

    font-size: 12px;
    font-size: 1.2rem;
}

.myaccount #dateBlock {
    padding: 0 10px 10px 10px;
}

.myaccount #dateBlock span {
    margin: 0 10px 0 0;
}

.myaccount #myaccountForm,
.myaccount #changePasswordForm,
.myaccount #optionInfoBlock {
    box-sizing: border-box;
    padding: 10px;
    border-top: 1px solid #666;
}

.myaccount #myaccountForm .formRow,
.myaccount #changePasswordForm .formRow {
    box-sizing: border-box;
    margin: 0 0 10px 0;
    width: 100%;
}

.myaccount #myaccountForm .submitButtonRow,
.myaccount #changePasswordForm .submitButtonRow {
    margin: 20px 0 15px 0;
}

.myaccount #myaccountForm .formRow label,
.myaccount #changePasswordForm .formRow label {
    display: block;
}

.myaccount #myaccountForm .formRow input,
.myaccount #changePasswordForm .formRow input {
    box-sizing: border-box;
    width: 100%;
    padding: 5px;
}

.myaccount #myaccountForm .formRow #usernameInput,
.myaccount #myaccountForm .formRow #usernameKanaInput {
    box-sizing: border-box;
    width: 100%;

    display: -webkit-box;
    display: -webkit-flex; /* safari */
    display: -ms-flexbox; /* IE */
    display: flex;
    -webkit-box-orient: inline-axis;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
}

.myaccount #myaccountForm .formRow #usernameInput div.col2,
.myaccount #myaccountForm .formRow #usernameKanaInput div.col2 {
    margin: 0;
    box-sizing: border-box;
    flex: 1 1 50%;
    -ms-flex: 1 1 50%;
}

.myaccount #myaccountForm .formRow #usernameInput #lastnameCol,
.myaccount #myaccountForm .formRow #usernameKanaInput #lastKananameCol {
    margin-right: 5px;
}

.myaccount #optionInfoBlock #groupBlock,
.myaccount #optionInfoBlock #communityBlock {
    margin-bottom: 20px;
}

/* -----------------------
フォーム共通設定
----------------------- */
.ng-valid.required {
    /*
    border-left: 5px solid #42A948;
    */
}

form .ng-invalid.ng-dirty {
    border: 1px solid #a94442;
    border-left: 5px solid #a94442;
}

form .manual-invalid.ng-dirty {
    border: 1px solid #a94442;
    border-left: 5px solid #a94442;
}

/*
.ng-invalid:not(form)  {
	border-left: 5px solid #a94442;
}
*/

.text-danger {
    color: red;
}

.disabled,
button:disabled {
    cursor: default;
    pointer-events: none;
    filter: alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
}

.require-astarisk {
    color: red;
}

/* -----------------------
コンテンツプレイヤー画面の設定（/content/<コンテンツID>/<バージョン>）
----------------------- */

/* ヘッダー */
#content-page header {
    background: #333;
    color: #FFF;
}

#content-page header #content-header {
    padding: 0 10px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: inline-axis;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-justify-content: center;
    -ms-flex-align: center;
    -ms-flex-pack: center;
    justify-content: center;
    align-items: center;
}

#content-page header h1 {
    font-size: 18px;
    font-size: 1.8rem;
    flex: 1 1 auto;
    -ms-flex: 1 1 auto;
}

#content-page header #content-menu {
    padding: 5px 0px;
    flex: 0 0 auto;
    -ms-flex: 0 0 auto;
}

#content-page header #content-menu div {
    display: inline-block;
    margin: 0 5px;
}

#content-page header #content-menu select {
    color: #333;
}

/* ヘッダーのホームへ移動ボタン */
#content-page #content-menu a {
    display: block;
    border-radius: 4px;
    margin: 0;
    padding: 3px 7px;
    background: #444;
    color: #FFF;
    text-decoration: none;
    text-align: center;
}

#content-page #content-menu a i {
    margin-right: 3px;
}

/* ローディング表示 */
#content-page #content-loading {
    margin: 100px auto;
    text-align: center;
}

#content-page #content-loading #content-loading-image img {
    width: 32px;
    height: 32px;
}

#content-page #video-player {
    width: 100vw;
    height: 100vh;
    display: flex;
    flex-direction: column;
}
/* MP4プレイヤー表示 */
#content-page #video-player #mp4-player {
    margin: 0px auto;
    flex: 1;
    /*overflow: hidden;*/
    width: 100vw;
}

/* ------------------------
問い合わせ画面
 */

.inquiry-modal div.title {
    margin: 0 10px 5px 10px;
    font-weight: bold;
    font-size: 1.5em;
}

.inquiry-modal .inquiry-detail-body {
    font-size: 14px;
    box-sizing: border-box;
    padding: 10px;
    border-top: 1px dotted #dddddd;
}

.inquiry-modal #inquiry-form {
}

.inquiry-modal #inquiry-form .description {
    margin: 10px 0 15px 0;
}

.inquiry-modal #inquiry-form .formRow {
    box-sizing: border-box;
    margin: 0 0 10px 0;
    width: 100%;
}

.inquiry-modal #inquiry-form .submit-button-row {
    margin: 20px 0 15px 0;
    text-align: center;
}

.inquiry-modal #inquiry-form .submit-button-row button {
    width: 100%;
}

.inquiry-modal #inquiry-form .formRow label {
    display: block;
}

.inquiry-modal #inquiry-form .formRow input,
.inquiry-modal #inquiry-form .formRow textarea {
    box-sizing: border-box;
    width: 100%;
    padding: 5px;
}

.inquiry-modal .confirm-area {
    padding: 10px 10px 20px 10px;
    margin: 15px 0 15px 0;
    border: 1px dashed #ccc;
    background-color: #eee;

    position: relative;
    text-align: center;
}

.inquiry-modal .confirm-area .confirm-msg {
    margin: 10px 0;
}

.inquiry-modal .confirm-area button {
    margin-right: 20px;
    /*padding: 3px 5px;*/
}

.inquiry-modal .completed-msg-area {
    margin: 15px;
    text-align: center;
}

.inquiry-modal .sending-view {
    position: absolute;
    top: 0px;
    left: 0px;
    box-sizing: border-box;
    margin: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    vertical-align: middle;
    background-color: rgba(255, 255, 255, 0.7);

    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: block-axis;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center; /* 子要素をflexboxにより中央に配置する */
}
/* --------------------
Notify設定
 */
div.notifyjs-corner{
    z-index: 20000;
}
/* ------------------------
入力モーダル画面（Survey共通）
 */

.input-modal div.title {
    margin: 0 10px 5px 10px;
    font-weight: bold;
    font-size: 1.5em;
}

.input-modal .input-detail-body {
    position: relative;
    font-size: 14px;
    box-sizing: border-box;
    padding: 12px 18px;
    border-top: 1px dotted #dddddd;
}

.input-modal .description {
    margin: 10px 0 15px 0;
}

.input-modal .formRow {
    box-sizing: border-box;
    margin: 0 0 6px 0;
    width: 100%;
}

.input-modal .submit-button-row {
    margin: 20px 0 15px 0;
    text-align: center;
}

.input-modal .submit-button-row button {
    width: 100%;
}

.input-modal .formRow label {
    display: block;
}

.input-modal .formRow input,
.input-modal .formRow textarea {
    box-sizing: border-box;
    width: 100%;
    padding: 5px;
}

.input-modal .confirm-area {
    padding: 10px 10px 20px 10px;
    margin: 15px 0 15px 0;
    border: 1px dashed #ccc;
    background-color: #eee;

    position: relative;
    text-align: center;
}

.input-modal .confirm-area .confirm-msg {
    margin: 10px 0;
}

.input-modal .confirm-area button {
    margin-right: 20px;
    /*padding: 3px 5px;*/
}

.input-modal .completed-msg-area {
    margin: 15px;
    text-align: center;
}

.input-modal .sending-view {
    position: absolute;
    top: 0px;
    left: 0px;
    box-sizing: border-box;
    margin: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    vertical-align: middle;
    background-color: rgba(255, 255, 255, 0.7);

    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: block-axis;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center; /* 子要素をflexboxにより中央に配置する */
}

.input-modal .input-privacy-area {
    margin: 12px 0;
}
.input-modal .checkbox-row input {
    vertical-align: middle;
    /*width: auto;*/
    width: 1.3em;
    height: 1.3em;
}

.input-modal .checkbox-row .label {
    display: initial;
    margin: 0 0 0 0.25em;
    padding: 0.5em 0;
}

.input-modal .link-privacy-area {
    padding: 0 0 0 2.0em;
}

.input-modal .save-input-data-area {
    margin: 24px 0;
    text-align: center;
}

.inquiry-modal  textarea,
.input-modal #input-request-catalog-form textarea
{
    resize: none;
}


/***
アンケート回答モーダル
 */
.enquete-modal .question-ope-area{
    display: flex;
    justify-content: center;
    margin: 12px 0 6px
}
.enquete-modal .question-ope-area > a{
    margin: 0 12px;
    min-width: 100px;
    text-align: center;
}
.enquete-modal .enquete-head-area{
    display: flex;
    justify-content: space-between;

}
.enquete-modal .enquete-main-area{
    margin: 6px;
}
.enquete-modal .question-area{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 12px 0 24px 0;
}
.enquete-modal .question-area .choice-freeinput{
    width: 100%;
}
.enquete-modal .question-area .choice-freeinput textarea{
    padding: 6px;
}
.enquete-modal .question-area ul.choice-list{
    margin: 0;
    padding: 0;
    list-style: none;
}
.enquete-modal .question-area ul.choice-list li {
    margin: 6px 12px;
}
.enquete-modal .question-area ul.choice-list li input {
    vertical-align: middle;
    width: 1.3em;
    height: 1.3em;
}
.enquete-modal .question-area ul.choice-list li label {
    margin: 0 0 0 0.25em;
    padding: 0.5em 0;
}
