@charset "UTF-8";

body {
    font-family: 'メイリオ', 'Hiragino Kaku Gothic Pro', sans-serif;
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box
}

p {
    font-size: 14px;
}

h1 {
    font-size: 25px;
    margin: 0 0 10px 0;
    padding: 2px 8px;
    border-width: 0 0 0 5px;
    border-color: darkgrey;
    border-style: solid;
    color: #fff;
    background-color: rgb(0, 0, 139);
    line-height: 140%;
    font-weight: normal;
}

h2 {
    border-bottom: solid 3px rgb(0, 0, 139);
    color: rgb(0, 0, 139);
    font-size: 20px;
    font-weight: normal;
    margin-bottom: 20px;
    padding-top: 30px;
}


.l_main:after {
    content: "";
}

.l_main {
    margin-top: 20px;
    margin-bottom: 20px;
    display: flex;
}

.l_main_left {
    flex: 1 0 20%;
}

.l_main_right {
    flex: 2 0 80%;
    padding-left: 30px;
}

.sidemenu {
    position: -webkit-sticky;
    position: sticky;
    top: 5%;
}

/*  ++++++++++++++ パンくずリスト start +++++++++++++++++  */

.bread {
    margin-bottom: 5px;
}

.bread ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.bread li a {
    display: inline-block;
    padding: 5px;
    color: #000000;
    font-size: 12px;
    text-decoration: none;
}

.bread li a:hover {
    color: cornflowerblue;
    text-decoration: underline royalblue;

}

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

.bread li {
    float: left;
    width: auto;
}

.bread li:after {
    content: '\003e';
    color: black;
    margin-left: 10px;
    margin-right: 10px;
}

/*  ++++++++++++++ パンくずリスト end +++++++++++++++++  */

/*  ++++++++++++++ 装飾用クラス ++++++++++++++++++++++++ */

/* 文字色変更やセンタリング用のクラス */

/* グレー文字用 */

.pub_grey {
    font-size: 14px;
    color: darkgray;
}

.pub_grey1 {
    color: darkgray;
}

.pub_grey1 span {
    font-size: 12px;
}

/* テキストなどのセンタリング用 */

.pub_center {
    text-align: center;
}

/* fontサイズを大きくする */

.pub_big {
    display: block;
    font-size: 30px;
}

/* big内spanにアンダーラインを引く */

.pub_big span {
    /*    border-bottom: double 10px rgb(171, 233, 255);*/
    background: linear-gradient(transparent 60%, rgb(171, 233, 255) 60%);
}

/* 文字色が茶色 */

.pub_brown {
    color: brown;
}

/* スペース取るためのクラス */

.pub_top {
    margin-top: 10%;
    margin-bottom: 5%;
}

.pub_bottom {
    padding-top: 3%;
    padding-bottom: 7%;
}

/*  ++++++++++++++ 右メニュー ++++++++++++++++++++++++ */

/* 大メニュー 出版社様・書店様・個人のお客様*/

.pub_title1 {
    display: inline-block;
    width: 100%;
    text-decoration: none;
    margin-left: 0;
    padding: 0.2em 0.5em;
    background: -webkit-linear-gradient(left, rgb(67, 82, 195), #6495ed);
    background: -o-linear-gradient(left, rgb(67, 82, 195), #6495ed);
    background: linear-gradient(to right, rgb(67, 82, 195), #6495ed);
    color: white;
    font-weight: lighter;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.56);
    font-size: 35px;
    margin-top: 15px;
}

/*アコーディオンメニュー全体 オンデマンド出版サービス等 */

.pub_service {
    margin: 2em 0;
    padding: 0;
    max-width: 100%;
}

/* アコーディオンメニュー　ラベル部分*/

.pub_service label {
    display: block;
    margin: 1.5px 0;
    padding: 13px 12px;
    color: rgb(66, 103, 208);
    font-weight: bold;
    cursor: pointer;
    transition: all 0.5s;
    font-size: 20px;
    border: 2.5px solid rgb(66, 103, 208);
}

/*　アコーディオンメニュー*/

.pub_show {
    display: none;
    overflow: hidden;
    padding: 5px;
}

.pub_show p {
    margin: 15px 10px;
}

.pub_plass:before {
    content: '\f067';
    font-family: 'Font Awesome 5 Free';
    padding-right: 8px;
    font-weight: bold;
}

.pub_plass.pub_active:before {
    content: '\f068';
}

/* メリットタイトル */

.pub_title2 {
    display: inline-block;
    padding: 5px 5px;
    color: #fff;
    text-decoration: none;
    background: rgb(240, 144, 185);
    box-shadow: -20px 14px rgb(244, 180, 208);
    width: 50%;
    font-size: 25px;
    text-align: center;
    bottom: 5%;
}

/* メリット直下のテーブル*/

.pub_table_merit {
    font-size: 18px;
    margin-top: 2%;
    margin-bottom: 5%;
}

.pub_table_merit th {
    font-size: 25px;
    color: rgb(240, 144, 185);
    line-height: 70%;
    width: 7%;
    vertical-align: top;
}

/* 青囲い枠　サービスのご利用方法など */

.pub_service_border {
    position: relative;
    margin: 2em 0;
    border: solid 3px #95ccff;
    border-radius: 40px;
    width: 95%;
    padding: 5%;
    top: 20px;
    height: auto;
}

/*　青ストライプのタイトル */

.pub_title3 {
    width: 50%;
    font-size: 20px;

    text-decoration: none;
    color: #6cb4e4;
    text-align: center;
    padding: 0.5em;
    border-top: solid 2px #6cb4e4 !important;
    border-bottom: solid 2px #6cb4e4 !important;
    background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px, #e9f4ff 3px, #e9f4ff 7px);
    background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px, #e9f4ff 3px, #e9f4ff 7px);

    position: absolute;
    display: inline-block;
    top: -20px;
    left: 20px;
    line-height: 1;
    font-weight: bold;
}

/* 青枠内のテーブル */

.pub_table_kaiin {
    font-size: 16px;
    line-height: 200%;
    display: block;
}

.pub_table_kaiin th {
    color: #6cb4e4;
    width: 8%;
    font-size: 20px;
    vertical-align: top;
}

.pub_table_kaiin span {
    font-size: 13px;
}

.pub_fax span {
    font-style: italic;
    font-size: 16px;
    font-weight: 600;
}

/*　問い合わせボタン */

.pub_contact {
    display: inline-block;
    padding: 0.6em 2em;
    text-decoration: none;
    background: rgb(250, 156, 130);
    color: #FFF;
    box-shadow: 0px 0px 0px 5px rgb(250, 156, 130);
    border: dashed 2px #FFF;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    margin: 3% 0px;
}

.pub_contact:hover {
    border: dotted 2px #FFF;
}

/*　青囲い枠　四角 */

.pub_border {
    display: block;
    position: relative;
    margin: 2em 0;
    border: solid 3px #95ccff;
    border-radius: 5px;
    width: 95%;
    padding: 20px;
    z-index: auto;
}

/* 青囲い枠　四角用　幅広タイトル title4とwidthのみ異なる*/

.pub_title5 {
    width: 60%;
    font-size: 20px;
    position: absolute;
    display: inline-block;
    top: -10px;
    left: 20px;
    line-height: 1;
    font-weight: bold;
    background-color: #fff;
    text-align: center;
}

.pub_table_zaiko {
    line-height: 200%;
    margin: 15px;
    padding-left: 5%;
}

/* ポイント用ライン */

.pub_line {
    position: absolute;
    color: gray;
    width: 100%;
    top: -5px;
}

/* ポイントタイトル PUB_POINT_BOXからのabsolute*/

.pub_point {
    font-size: 20px;
    position: absolute;
    top: -10px;
    left: 20%;
    background-color: #fff;
    font-weight: bold;
}

/*　ポイントタイトルの親要素 */

.pub_point_box {
    position: relative;
    margin-top: 5%;
    margin-bottom: 7%;
}

.pub_point_box1 {
    position: relative;
    margin-top: 5%;
    margin-bottom: 7%;
}

.pub_pointp {
    position: relative;
    top: 20px;
}

/* ラインナップ箇所 クラス */

.pub_lineup {
    display: block;
    background-color: rgb(222, 235, 254);
    padding: 10px 0;
    width: 85%;
    margin: 3% auto;
}

.pub_lineup_bold {
    color: darkblue;
    font-weight: bold;
    font-style: italic;
    font-size: 20px;
}

/* ふきだし */

.pub_huki {
    position: relative;
    display: inline-block;
    min-width: 120px;
    max-width: 100%;
    color: #fff;
    background: rgb(240, 144, 185);
    border: solid 3px rgb(240, 144, 185);
    box-sizing: border-box;
}

.pub_huki:after {
    content: "";
    position: absolute;
    bottom: -30px;
    left: 50%;
    margin-left: -17px;
    border: 14px solid transparent;
    border-top: 14px solid rgb(240, 144, 185);
    z-index: 1;
}

.pub_huki p {
    margin: 0;
    padding: 0;
}

/* 個人のお客様　自費出版 */

.pub_pad {}

.pub_table_self {
    line-height: 200%;
    margin: 0 auto;
}

.pub_big2 {
    display: block;
    font-size: 20px;
}

/* 外部リンク用ボタン　お取り扱い商品一覧・万能書店で確認する・復刊リクエスト*/

.flat_ss {
    color: #fff;
    display: inline-block;
    height: 50px;
    font-size: 14px;
    line-height: 50px;
    vertical-align: middle;
    background: rgb(240, 144, 185);
    text-decoration: none;
    margin: 1em;

    width: 350px;
    content: "";
    clear: both;
}

.flat_ss .iconback {
    display: inline-block;
    width: 50px;
    height: 50px;
    text-align: center;
    color: rgb(240, 144, 185);

    float: left;
    width: 15%;
}

.flat_ss .iconback .fas {
    font-size: 25px;
    line-height: 50px;
}

.flat_ss .btnttl {
    display: inline-block;
    width: 520px;
    text-align: center;
    vertical-align: middle;

    float: left;
    width: 85%;
}

.flat_ss .tw {
    background: rgb(235, 216, 236);
}

.pub_center2 {
    margin-left: 10%;
}

.pub_serkijib {
    color: rgb(0, 112, 192);
    font-size: 18px;
}

.pub_pdf {
    text-align: right;
}

/*  ++++++++++++++ 右メニュー end ++++++++++++++++++++ */

/* ++++++++  サイドメニュー +++++++++++  */

/* サイドメニュー */

.sidemenu h3 {
    font-size: 16px;
    /*    font-weight: normal;*/
    color: rgb(0, 0, 139);
    position: relative;
    padding-left: 10px;
    /*	text-shadow: 1px 2px 5px skyblue;*/
}

.sidemenu ul {
    border-top: solid rgb(0, 0, 139) 2px;
    /*上のボーダー*/
    border-bottom: solid rgb(0, 0, 139) 2px;
    /*下のボーダー*/
    color: deepskyblue;
    font-size: 14px;
    margin: 0;
    padding: 0.5em 0 0.5em 1.5em;
}

.sidemenu ul li {
    color: rgb(0, 0, 139);
    line-height: 1.5;
    padding: 0.5em 0;
}

.sidemenu li a {
    color: rgb(0, 0, 139);
    display: block;
    padding: 5px;
    text-decoration: none;

}

.sidemenu li a:hover {
    background-color: rgb(0, 0, 139);
    color: white;
}

.sidemenu h4 {
    background-color: rgb(0, 0, 139);
    color: white;
    padding-left: 10px;
}


/*電話番号*/

.con_telno {
    font-size: 14px;
    color: rgb(0, 0, 139);
    margin-bottom: 0;
}

.con_telno i {
    margin-right: 10px;
}

/*受付時間*/

.con_working-day {
    font-size: 14px;
    color: rgb(0, 0, 139);
    margin-bottom: 0;
}

.con_working-day i {
    margin-right: 10px;
}



/*メールアドレス*/

.con_mail {
    font-size: 14px;
    color: rgb(0, 0, 139);
    margin-bottom: 0;
    padding-bottom: 5px;
    vertical-align: middle;
}

.con_mail i {
    margin-right: 10px;
}

/*　問い合わせボタン　*/

.sidemenu button {
    margin: 0 auto;
    padding: 1em 2em;
    border: solid rgb(0, 0, 139) 2px;
    box-sizing: border-box;
    width: 170px;
    display: inline-block;
    font-size: 13px;
    position: relative;
    cursor: pointer;
    background-color: transparent;
    border-radius: 10px;
    color: rgb(0, 0, 139);
}

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

/*-------------------------メデイアクエリ-----------------------------*/

/* ############ 1281px 以上 ############ */

@media (min-width: 1281px) {

    .l_main {
        width: 1140px;
        margin-left: auto;
        margin-right: auto;
    }

}

/* ############ 960px 以上 & 1280px以下 ############ */

@media (min-width: 960px) and (max-width: 1280px) {}

/* ############ 768px 以上 ############ */

@media (min-width: 768px) {

    /*	 モーダルウィンドウ 非表示 */
    .modal {
        display: none;
    }

    /* レスポンシブ時だけ改行タグ入れる　*/
    .pub_rp_br {
        display: none;
    }
}

/* ############ 1081px 以下 ############ */

@media (max-width: 1081px) {

    .pub_center2 {
        margin-left: 5%;
    }

}

/* ############ 836px 以下 ############ */

@media (max-width: 836px) {

    .pub_big {
        font-size: 20px;
    }

    .pub_lineup_bold {
        font-size: 15px;
    }

    .flat_ss {
        width: 80%;
        height: 80%;
    }


}

/* ############ 767px 以下 ############ */

@media (max-width: 768px) {

    .pub_title2 {
        font-size: 20px;
        width: 80%;
    }

    .pub_title3 {
        width: 70%;
    }

    .pub_title5 {
        width: 80%;
        font-size: 16px;
    }

    .pub_point_box1 {
        margin-bottom: 10%;
    }

}

/* ############ 630px以下 ############ */

@media (max-width: 630px) {

    .flat_ss .iconback {
        display: none;
    }

    .flat_ss .iconback .fas {
        display: none;
    }

    .flat_ss .btnttl {
        width: 100%;
    }

    .flat_ss {
        width: 90%;
    }

    .pub_table_merit {
        font-size: 14px;
    }

    .pub_table_zaiko {
        font-size: 14px;
    }

    .pub_table_kaiin {
        font-size: 14px;
    }

    .pub_title5 {
        width: 90%;
    }

}

/* ############ 599px以下 ############ */

@media (max-width: 599px) {

    /* ｻｲﾄﾞﾒﾆｭｰ 非表示*/
    .l_main_left {
        display: none;
    }

    .sidemenu {
        display: none;
    }

    .l_main_right {
        width: 100%;
        padding: 0;
    }

    .pub_workflow {
        margin: 0;
    }

    /*モーダルウィンドウ  開始　　*/
    .modal .modal-check {
        display: none;
    }

    .modal .modal-window {
        /*
		display: flex;
		justify-content: flex-end;
*/
        /*position: relative;*/
        position: fixed;
        top: 330px;
        right: 18px;

        z-index: 100001;
        animation: fadein .3s 1, zoomin .3s 1;
    }

    /*バッテン modal-window が親要素なので位置はそれに依存する　*/
    .modal .modal-label {

        position: absolute;
        /*		position: fixed;*/
        top: -5px;
        right: -10px;
        /*	left:180px;*/
        display: flex;

        align-items: center;
        justify-content: center;
        line-height: 1;
        background: #099;
        border-radius: 50%;
        width: 20px;
        height: 20px;
        cursor: pointer;
        transition: all .2s ease;
    }

    /*
.modal .modal-label:hover {
	background: #00cccc;
}
*/
    .modal .modal-label:active {
        background: cyan;
    }

    .modal .modal-label svg {
        display: flex;
        align-items: center;
        fill: #fff;
    }

    .modal .modal-inner {
        /*
	width: 80vw;
	max-width: 500px;
*/
        max-width: 200px;
        background: rgb(204, 204, 255);
        /*背景透過*/
        /*background-color: rgba(0, 0, 139, 0.1);*/
        /*  背景文字透過*/
        /*
		background-color: rgb(0, 0, 139);
		opacity: 0.5;
*/
        /*  文字透過しない。背景透過*/
        /*		background-color: transparent;*/
        border-radius: 3px;
        box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.2);
    }

    .modal .modal-content {
        color: #099;
    }

    .modal .modal-content p {
        padding: 0;
        margin: 0;
    }

    .modal .modal-check:checked + .modal-body {
        animation: fadeout .2s 1 forwards, hide .1s .2s 1 forwards;
    }

    .modal .modal-check:checked + .modal-body .modal-window {
        animation: zoomout .2s 1 forwards;
    }

    @keyframes fadein {
        0% {
            opacity: 0;
        }

        100% {
            opacity: 1;
        }
    }

    @keyframes fadeout {
        0% {
            opacity: 1;
        }

        100% {
            opacity: 0;
        }
    }

    @keyframes zoomin {
        0% {
            transform: scale(0.9);
        }

        100% {
            transform: scale(1);
        }
    }

    @keyframes zoomout {
        0% {
            transform: scale(1);
        }

        100% {
            transform: scale(0.9);
        }
    }

    @keyframes hide {
        0% {
            visibility: visible;
        }

        100% {
            visibility: hidden;
        }
    }

    /*モーダルウィンドウ 終了　　*/
    .pub_sertable th,
    .pub_sertable td {
        font-size: 14px;
    }

    .pub_serkiji4,
    .pub_serkiji8,
    .pub_serkiji5 {
        font-size: 16px;
    }

    .pub_table_self {
        font-size: 12px;
    }
}
