@charset "UTF-8";
@layer assets {

  /*____________________________________________________________________________

  SITE TITLE: BOEM - BOEM下層CMS共通
  TITLE: PC 下層ベース

  (1) 全体
  (2) テキストリンクスタイル

  UPDATED:2018.12

  ____________________________________________________________________________*/
  #cms-contents{
    width: 1024px;
    margin: 0 auto;
    padding:0;
  }
  #cms-contents .aligncenter,
  #cms-contents .ql-align-center{
    text-align: center;
  }
  #cms-contents .alignright,
  #cms-contents .ql-align-right,
  #cms-contents .ql-direction-rtl{
    text-align: right;
  }
  #cms-contents .ql-align-justify{
    text-align: justify;
  }
  #cms-contents .floatleft{
    float: left;
    margin: 0 30px 30px 0;
  }
  #cms-contents .floatright{
    float: right;
    margin: 0 0 30px 30px;
  }
  #cms-contents .clear{
    clear: both;
  }
  #cms-contents .display-table{
    display: table;
  }
  #cms-contents .display-table-cell{
    display: table-cell;
    vertical-align:middle;
    border: none;
  }
  #cms-contents:after {
    content: "";
    clear: both;
    display: block;
  }
  /*----------------------------------------------------------------------------
  　(1) 全体・カラム　幅設定／共通設定
  ----------------------------------------------------------------------------*/
  #cms-contents{} 
  #cms-contents h1{
    font-size:36px;
    font-weight: normal;
    text-align: center;
    margin:60px 0 60px 0;
    padding: 0;
    line-height: 1em;
  }
  #cms-contents h1 small{    
    display: block;
    font-size: 16px;
  }
  #cms-contents h2{
    font-size:28px;
    font-weight: normal;
    text-align: left;
    margin:60px 0 30px 0;
    padding: 0 0 15px 0;
    line-height: 1em;
        border-bottom: 1px solid #dddd;
  }
    #cms-contents h2 small{
      display: block;
      font-size: 14px;
      padding-top: 16px;
    }
  #cms-contents h3{
    font-size:24px;
    margin:60px 0 30px 0;
    padding:0 0 30px 0;
  }
  #cms-contents h4{
  font-size:20px;
    padding: 20px;
    margin:60px 0 30px 0;
    background: #eee;
    border-radius:3px;

  }
  #cms-contents h5{
    font-size:18px;
    margin:60px 0 30px 0;
  }
  #cms-contents h6{
    font-size: 16px;
    margin:60px 0 30px 0;
  }

  #cms-contents p{
    font-size:12x;
    line-height:185%;
    color:#555;
    margin:0 0 1em 0;
  }
  #cms-contents p small{
    font-size:11px;
    line-height:165%;
    color:#999;
  }
  #cms-contents img{
    max-width:1024px;
    height: auto;
    display:unset;
  }
  #cms-contents ul{
    margin: 0 0 20px 0;
  }
  #cms-contents ul li{
    margin: 0.5em 2em;
    list-style-type: disc;
    font-size:13px;
    color:#444;
  }

  #cms-contents ol{
    margin: 0 0 20px 0;
  }
  #cms-contents ol li{
      margin: 0.5em 2em;
    list-style-type: decimal;
      font-size:13px;
    color:#444;
  }

  #cms-contents table.table-normal {
    box-sizing: border-box;
    width: 100%;
    border: 1px solid #eee;
    border-right: 1px solid #eee;
    margin: 30px auto;
    border-collapse: collapse;
    font-size: 13px;
  }
  #cms-contents table.table-normal th {
    color: #333;
    border-bottom: 1px solid #eee;
    border-left: 1px solid #eee;
    padding: 16px;
    text-align: center;
    white-space: nowrap;
  }
  #cms-contents table.table-normal p {
    margin: 0;
    padding: 0;
  }
  #cms-contents table.table-normal thead th {
    color: #fff;
    text-align: center;
    background: #999;
  }
  #cms-contents table.table-normal tbody th {
    text-align: left;
    background: #f8f8f8;
  }
  #cms-contents table.table-normal td {
    border-bottom: 1px solid #eee;
    border-left: 1px solid #eee;
    padding: 10px;
    text-align: left;
    background: #ffffff;
    color: #666;

  }
  #cms-contents .bordered{
      padding: 20px 20px 0px 20px;
      background: #f6fbff;
      margin: 30px 0;
      border: 1px solid #a0cef3;
  }
  #cms-contents blockquote{
    padding: 20px;
    background: #f6fbff;
    margin: 30px 0;
    border: 1px solid #a0cef3;
    color: #577aa2;
  }
  #cms-contents .bordered *{
    color: #577aa2;
  }

  #cms-contents figure{
    margin:30px 0;
  }
  #cms-contents figure figcaption{
    margin:10px 0;
    color:#666;
    font-size:11px;
  }

  #cms-contents strong{
    font-weight: bold;
  }

  #cms-contents em{
    color: #ee0000;
  }
  #cms-contents a:hover{
    opacity: 0.75;;
  }
  #cms-contents .ql-indent-1{
    border-left:4px solid #2b2b2b;
    padding-left: 16px; 
  }

  #cms-contents .ql-indent-2{
    margin-left: 2em;
    border-left:4px solid #2b2b2b;
    padding-left: 16px; 
  }

  #cms-contents .ql-size-small{
    font-size: 10px;
  }

  #cms-contents .ql-size-large{
    font-size: 16px;
  }

  #cms-contents .ql-size-huge{
    font-size: 24px;
  }

  #cms-contents .ql-syntax{
    background: #2b2b2b;
    color: #eee;
    padding: 16px;
    display: block;
    margin: 30px 0;
    overflow-x: scroll;
  }

  /*---------
  カラー
  ---------*/

  #cms-contents .ql-bg-black {
    background-color: #000;
  }
  #cms-contents .ql-bg-red {
    background-color: #e60000;
  }
  #cms-contents .ql-bg-orange {
    background-color: #f90;
  }
  #cms-contents .ql-bg-yellow {
    background-color: #ff0;
  }
  #cms-contents .ql-bg-green {
    background-color: #008a00;
  }
  #cms-contents .ql-bg-blue {
    background-color: #06c;
  }
  #cms-contents .ql-bg-purple {
    background-color: #93f;
  }
  #cms-contents .ql-color-white {
    color: #fff;
  }
  #cms-contents .ql-color-red {
    color: #e60000;
  }
  #cms-contents .ql-color-orange {
    color: #f90;
  }
  #cms-contents .ql-color-yellow {
    color: #ff0;
  }
  #cms-contents .ql-color-green {
    color: #008a00;
  }
  #cms-contents .ql-color-blue {
    color: #06c;
  }
  #cms-contents .ql-color-purple {
    color: #93f;
  }
  /*---------
  youtube埋め込み
  ---------*/
  #cms-contents .ql-video{
    position:relative;
    width:100%;
    min-height:500px;
  }
  #cms-contents .ql-video iframe{
    position:absolute;
    top:0;
    right:0;
    width:100%;
    height:100%;
  }
  /*----------------------------------------------------------------------------
  　ルックブックとかコーデとか
  ----------------------------------------------------------------------------*/

  #cms-contents ul.cms-coordinate{
    list-style:none;
    margin: 0;
    padding: 0;
    width: 100%;
    letter-spacing: -1em;
  }

  #cms-contents ul.cms-coordinate li{
    letter-spacing: normal;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 33.33%;
    display: inline-block;
    overflow: hidden;
    vertical-align: top;
    padding: 0 8px 32px 8px;
    box-sizing: border-box;
  }

  #cms-contents ul.cms-coordinate li img{
    width: 100%;
    height: auto;
  }
  #cms-contents ul.cms-coordinate li a{
    display: block;
    overflow: hidden;
  }

  #cms-contents ul.cms-coordinate li h6{
    font-size: 13px;
    color: #2b2b2b;
    margin: 1em 0 0.5em;
  }

  #cms-contents ul.cms-coordinate li p{
    font-size: 11px;
    line-height: 135%;
    color: #666;
    margin: 0 0 4px 0;
  }
  #cms-contents ul.cms-coordinate.pc-col-2 li{
    width: 50%;
  }
  #cms-contents ul.cms-coordinate.pc-col-4 li{
    width: 25%;
  }
  #cms-contents ul.cms-coordinate.pc-col-5 li{
    width: 20%;
  }
  /*----------------------------------------------------------------------------
  　NEWS記事一覧とか
  ----------------------------------------------------------------------------*/
  /* 【contents/cms-index】特集一覧 */

  #cms-contents.news-archive .news-archive-tabs {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-bottom: 60px;
  }
  #cms-contents.news-archive .news-archive-tabs li {
    width: 300px;
    text-align: center;
    padding: 12px;
    margin: 0;
    border-radius: 100px;
    list-style: none;
    border: 1px solid #ddd;
    font-size: 16px;
    color: #999;
    cursor: pointer;
    transition: opacity .2s;
  }
  #cms-contents.news-archive .news-archive-tabs li:hover {
    opacity: .7;
  }
  #cms-contents.news-archive .news-archive-tabs li.active {
    background: #333;
    color: #fff;
    border-color: #333;
  }
  #cms-contents.news-archive #arc-news {
    display: flex;
    justify-content: flex-start;
    gap: 40px 20px;
    flex-wrap: wrap;
  }
  #cms-contents.news-archive #arc-news li {
    width: calc((100% - 60px) / 4);
    margin: 0;
    padding: 0;
    border: none;
    list-style: none;
  }
  #cms-contents.news-archive #arc-news li a{
    display:block;
  }
  #cms-contents.news-archive #arc-news li .news-thumbnail{
    margin-bottom: 10px;
    border-radius: 6px;
    overflow: hidden;
  }
  #cms-contents.news-archive #arc-news li .news-thumbnail figure {
    margin: 0;
  }
  #cms-contents.news-archive #arc-news li .news-thumbnail img {
    width: 100%;
    height: auto;
  }
  #cms-contents.news-archive #arc-news li .news-title {
    margin: 0;
    padding: 0;
    font-size: 12px;
    border: none;
    line-height: 1.41;
    color: #333;
  }

  /*----------------------------------------------------------------------------
    パスワード保護
  ----------------------------------------------------------------------------*/

  #edit{
    display: block;
    width: 800px;
    margin: 60px auto;
    text-align: center;
    background:#f5f5f5;
    padding:40px;
    border:1px solid #ddd
    
  }
  #edit p{
    display: inline-block;
  }
  #edit p input{
    padding:2px
  }

  /*----------------------------------------------------------------------------
    個別対応
  ----------------------------------------------------------------------------*/

  #cms-contents.mango-cms-contents ul.cms-coordinate li img{
    width: 150%;
    margin-left:-25%; 
  }

  /*----------------------------------------------------------------------------
    ページネーション用
  ----------------------------------------------------------------------------*/

  #arc-news:after {
    clear: both;
    content: "";
    display: block;
  }

  #cms-contents .paginationjs-pages ul {
    margin: 0;
  }

  #cms-contents .paginationjs-pages ul li {
    margin: 0;
    list-style-type: none;
    font-size: 13px;
    color: #444;
  }

  .paginationjs {
    display: flex;
    text-align: center;
    margin: 40px auto 0;
  }

  .paginationjs-pages {
    display: block;
    margin: 0 auto;
  }

  /* ロード中 */
  .display-table--loading .news-thumbnail {
    display: block;
  }

  .display-table--loading .display-table-container {
    border: 1px solid #eee;
  }

  .display-table--loading .news-title--date {
    display: block;
    width: 80px;
    height: 12px;
    margin: 0 0 8px !important;
  }

  .display-table--loading .news-title--title {
    display: block;
    width: 120px;
    height: 20px;
    margin: 0 0 8px !important;
  }

  .display-table--loading .news-title--excerpt {
    display: block;
    width: 160px;
    height: 60px;
  }

  .css-bg-gradiation,
  #cms-contents.news-archive .display-table--loading .news-thumbnail figure {
    background: linear-gradient(270deg, #eeeeee, #dddddd);
    background-size: 800% 800%;
    -webkit-animation: LoadingBgGradient 2s ease infinite;
    -moz-animation: LoadingBgGradient 2s ease infinite;
    animation: LoadingBgGradient 2s ease infinite;
  }

  @-webkit-keyframes LoadingBgGradient {
    0% {
      background-position: 0% 50%
    }

    50% {
      background-position: 100% 50%
    }

    100% {
      background-position: 0% 50%
    }
  }

  @-moz-keyframes LoadingBgGradient {
    0% {
      background-position: 0% 50%
    }

    50% {
      background-position: 100% 50%
    }

    100% {
      background-position: 0% 50%
    }
  }

  @keyframes LoadingBgGradient {
    0% {
      background-position: 0% 50%
    }

    50% {
      background-position: 100% 50%
    }

    100% {
      background-position: 0% 50%
    }
  } 
  /*----------------------------------------------------------------------------
    auth パスワード入力画面
  ----------------------------------------------------------------------------*/
  .auth_contents{
    width: 1024px;
    margin:30px auto;
  }
  .auth_contents .auth_pass_text input{
    display: block;
    margin-top: 15px;
    margin-bottom :10px;
    height:30px;
    width: 100%;
  }
  .auth_pass_btn button{
    background:#000;
    color: #fff;
    font-weight: bold;
    height: 30px;
    width: 60px;
    border:none; 
  }

}