@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/************************************
** 固定ページの修正
************************************/

.post-7579 .header-container-in,
.post-7572 .header-container-in {
display: none!important;
}

.post-7579 .breadcrumb,
.post-7572 .breadcrumb {
display: none!important;
}

.post-7579 .entry-title,
.post-7572 .entry-title,
.post-14 .entry-title {
display: none;
}

.post-14 .date-tags,
.post-5584 .date-tags,
.post-5596 .date-tags,
.post-4253 .date-tags,
.post-2136 .date-tags,
.post-5608 .date-tags,
.post-5610 .date-tags,
.post-5965 .date-tags,
.post-5599 .date-tags,
.post-2134 .date-tags,
.post-6015 .date-tags,
.post-2130 .date-tags,
.post-6422 .date-tags,
.post-6618 .date-tags,
.post-5114 .date-tags,
.post-7817 .date-tags,
.post-5482 .date-tags,
.post-7984 .date-tags,
.post-7011 .date-tags,
.post-6531 .date-tags,
.post-7110 .date-tags,
.post-3 .date-tags,
.post-7579 .date-tags,
.post-7572 .date-tags,
.post-2127 .date-tags {
display: none;
}

.post-2127 .article-header {
display: none;
}

.post-5584 .entry-title,
.post-5596 .entry-title,
.post-4253 .entry-title,
.post-2136 .entry-title,
.post-5608 .entry-title,
.post-5610 .entry-title,
.post-5965 .entry-title,
.post-2134 .entry-title,
.post-6015 .entry-title,
.post-2130 .entry-title,
.post-7984 .entry-title,
.post-5482 .entry-title,
.post-6422 .entry-title,
.post-6618 .entry-title,
.post-7817 .entry-title,
.post-6531 .entry-title,
.post-5114 .entry-title,
.post-7011 .entry-title,
.post-7110 .entry-title,
.post-3 .entry-title,
.post-5599 .entry-title {
text-align: center;
}

/*非表示タイトル*/
.post-7110 .entry-title {
display: none;
}


/*非表示カテゴリー*/
.cat-item.cat-item-1,
.cat-item.cat-item-47,
.cat-item.cat-item-35,
.cat-item-36{
display:none;
}

/* 固定ページだけ：作成者リンク・作者名を非表示 */
.page .post-author,
.page .entry-meta .author,
.page .byline .author,
.page .author,
.page .posted-by,
.page .entry-author,
.page .vcard,
.page .author-link,
.page .byline {
  display: none !important;
}

/* FontAwesome の鉛筆アイコンを隙間なく消す（汎用） */
.fa-pencil,
.fas.fa-pencil,
.far.fa-pencil,
.fab.fa-pencil,
.fa.fa-pencil,
i.fa-pencil,
span.fa-pencil {
  display: none !important;
}

/* :before で描画される場合も確実に消す */
.fa-pencil:before,
.fas.fa-pencil:before,
.far.fa-pencil:before,
.fa.fa-pencil:before {
  display: none !important;
  content: none !important;
}

/* ページID 14 のみ目次を非表示 */
body.page-id-14 .toc,
body.page-id-14 .toc_wrap,
body.page-id-14 #toc,
body.page-id-14 .table-of-contents,
body.page-id-14 .toc-box {
  display: none !important;
}


/************************************
** トップページデザイン
************************************/
/* 岡BASE ピーシーラボ専用スタイル 20250908 親テーマの変更を加えている。 */
.wrap {
    width: auto!important;
}

.main {
    padding: 0!important;
	border: unset!important;
}

.article h2 {
    background-color: unset!important;
}

.article h3 {
    background-color: unset!important;
	border: unset!important;
	padding: 12px 0px!important;
}


.article h4 {
    background-color: unset!important;
}

    /* 岡BASE ピーシーラボ専用スタイル 20250908 */
    .okabase_section_20250908 {
        padding: 80px 20px !important;
    }
    .okabase_container_20250908 {
        max-width: 1200px !important;
        margin: 0 auto !important;
    }
    .okabase_h2_20250908 {
        font-size: 36px !important;
        color: #4e6ca8 !important;
        text-align: center !important;
        margin-bottom: 50px !important;
        position: relative !important;
        font-weight: bold !important;
    }
    .okabase_h2_20250908::after {
        content: '' !important;
        position: absolute !important;
        bottom: -10px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 60px !important;
        height: 4px !important;
        background: #4e6ca8 !important;
        border-radius: 2px !important;
    }
    
/* メインビジュアル部分の修正 */
.okabase_hero_20250908 {
    position: relative !important;
    background: linear-gradient(135deg, #5b7bb4, #8ca3d0) !important;
    padding: 60px 20px !important;
    text-align: center !important;
    color: white !important;
    margin: -20px -20px 0 !important;
}
.okabase_hero_content_20250908 {
    max-width: 1400px !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 60px !important;
}
.okabase_hero_text_20250908 {
    flex: 0 0 45% !important;
    text-align: left !important;
    padding-left: 40px !important;
}
.okabase_hero_20250908 h1 {
    font-size: 48px !important;
    margin-bottom: 20px !important;
    font-weight: bold !important;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.2) !important;
    color: white !important;
    line-height: 1.3 !important;
}
.okabase_hero_subtitle_20250908 {
    font-size: 20px !important;
    margin-bottom: 30px !important;
    opacity: 0.95 !important;
}
.okabase_hero_image_20250908 {
    flex: 1 !important;
    position: relative !important;
    margin-right: -20px !important;
}
.okabase_hero_image_content_20250908 {
    background: linear-gradient(135deg, #a3bded, #6991c7) !important;
    height: 450px !important;
    border-radius: 20px 0 0 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    font-size: 24px !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2) !important;
}
.okabase_hero_image_content_20250908 img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 20px 0 0 20px !important;
}
    
    /* バッジ */
    .okabase_badge_20250908 {
        display: inline-block !important;
        background: #ffd54f !important;
        color: #333 !important;
        padding: 5px 15px !important;
        border-radius: 20px !important;
        font-size: 14px !important;
        font-weight: bold !important;
        margin: 5px !important;
    }
    .okabase_blue_badge_20250908 {
        background: #81a3d8 !important;
        color: white !important;
    }
    
    /* 作業内容セクション */
    .okabase_work_section_20250908 {
        background: #f0f4f8 !important;
        padding: 80px 20px !important;
    }
    .okabase_work_grid_20250908 {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 30px !important;
    }
    .okabase_work_item_20250908 {
        background: white !important;
        border-radius: 15px !important;
        overflow: hidden !important;
        box-shadow: 0 5px 20px rgba(0,0,0,0.1) !important;
        transition: transform 0.3s !important;
    }
    .okabase_work_item_20250908:hover {
        transform: translateY(-5px) !important;
    }
    .okabase_work_image_20250908 {
        height: 200px !important;
        background: #e0e7f0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 14px !important;
        color: #666 !important;
        position: relative !important;
        overflow: hidden !important;
    }
    .okabase_work_image_20250908 img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }
    .okabase_work_content_20250908 {
        padding: 25px !important;
    }
    .okabase_work_content_20250908 h3 {
        color: #4e6ca8 !important;
        font-size: 22px !important;
        margin-bottom: 10px !important;
    }
    
/* スケジュールセクション - 縦型タイムライン */
.okabase_schedule_section_20250908 {
    background: linear-gradient(180deg, #ffffff 0%, #f8f9fa 100%) !important;
    padding: 80px 20px !important;
}
.okabase_schedule_timeline_20250908 {
    max-width: 800px !important;
    margin: 0 auto !important;
    position: relative !important;
    padding: 20px 0 !important;
}
.okabase_schedule_timeline_20250908::before {
    content: '' !important;
    position: absolute !important;
    left: 60px !important;
    top: 20px !important;
    bottom: 20px !important;
    width: 3px !important;
    background: linear-gradient(180deg, #4e6ca8, #6b84c0) !important;
}
.okabase_schedule_item_20250908 {
    position: relative !important;
    padding-left: 100px !important;
    margin-bottom: 40px !important;
    display: flex !important;
    align-items: center !important;
    min-height: 80px !important;
}
.okabase_schedule_number_20250908 {
    position: absolute !important;
    left: 30px !important;
    width: 60px !important;
    height: 60px !important;
    background: #4e6ca8 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    font-weight: bold !important;
    font-size: 18px !important;
    box-shadow: 0 4px 10px rgba(78,108,168,0.3) !important;
    z-index: 2 !important;
}
.okabase_schedule_content_20250908 {
    background: white !important;
    border-radius: 15px !important;
    padding: 25px 30px !important;
    box-shadow: 0 5px 20px rgba(0,0,0,0.08) !important;
    width: 100% !important;
}
.okabase_schedule_title_20250908 {
    font-size: 20px !important;
    color: #333 !important;
    font-weight: bold !important;
    margin-bottom: 8px !important;
}
.okabase_schedule_description_20250908 {
    color: #666 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
}
.okabase_schedule_description_20250908 span {
    color: #4e6ca8 !important;
    font-weight: 500 !important;
}
   
    /* 特徴セクション */
    .okabase_features_grid_20250908 {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 30px !important;
    }
    .okabase_feature_card_20250908 {
        text-align: center !important;
        background: white !important;
        padding: 30px !important;
        border-radius: 15px !important;
        box-shadow: 0 5px 20px rgba(0,0,0,0.1) !important;
        transition: transform 0.3s !important;
    }
    .okabase_feature_card_20250908:hover {
        transform: translateY(-10px) !important;
    }
    .okabase_feature_icon_20250908 {
        width: 80px !important;
        height: 80px !important;
        margin: 0 auto 20px !important;
        background: linear-gradient(135deg, #4e6ca8, #6b84c0) !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 36px !important;
        color: white !important;
    }
    .okabase_feature_title_20250908 {
        font-size: 18px !important;
        color: #333 !important;
        margin-bottom: 10px !important;
        font-weight: bold !important;
    }
    
/* ギャラリーセクション - 画像対応版 */
.okabase_gallery_section_20250908 {
    background: #f5f8fb !important;
    padding: 80px 20px !important;
    margin-bottom: 0 !important;
}
.okabase_gallery_grid_20250908 {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
}
.okabase_gallery_item_20250908 {
    position: relative !important;
    border-radius: 15px !important;
    overflow: hidden !important;
    box-shadow: 0 5px 20px rgba(0,0,0,0.1) !important;
    aspect-ratio: 16/9 !important;
    background: linear-gradient(135deg, #a3bded, #6991c7) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 18px !important;
    color: white !important;
}
.okabase_gallery_item_20250908 img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}
    
    /* アクセスセクション */
    .okabase_access_section_20250908 {
        background: linear-gradient(180deg, #e3ecf5 0%, #ffffff 100%) !important;
        padding: 80px 20px !important;
    }
    .okabase_access_container_20250908 {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 40px !important;
        align-items: center !important;
    }
    .okabase_access_info_20250908 {
        background: white !important;
        padding: 40px !important;
        border-radius: 15px !important;
        box-shadow: 0 5px 20px rgba(0,0,0,0.1) !important;
    }
    .okabase_access_info_20250908 h3 {
        color: #4e6ca8 !important;
        font-size: 24px !important;
        margin-bottom: 20px !important;
    }
    .okabase_access_item_20250908 {
        display: flex !important;
        align-items: start !important;
        margin-bottom: 20px !important;
    }
    .okabase_access_icon_20250908 {
        width: 40px !important;
        height: 40px !important;
        background: #4e6ca8 !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: white !important;
        margin-right: 15px !important;
        flex-shrink: 0 !important;
    }
    .okabase_map_container_20250908 {
        height: 400px !important;
        border-radius: 15px !important;
        overflow: hidden !important;
        box-shadow: 0 5px 20px rgba(0,0,0,0.1) !important;
    }
    .okabase_map_container_20250908 iframe {
        width: 100% !important;
        height: 100% !important;
        border: none !important;
    }
    
    /* コンタクトセクション */
    .okabase_contact_section_20250908 {
        background: linear-gradient(135deg, #ff69b4, #ff1493) !important;
        padding: 0 !important;
        position: relative !important;
        overflow: visible !important;
        margin: 0 -20px !important;
    }
    .okabase_contact_wrapper_20250908 {
        position: relative !important;
        padding: 100px 20px !important;
    }
    .okabase_contact_card_20250908 {
        position: relative !important;
        background: white !important;
        border-radius: 30px !important;
        padding: 60px 40px !important;
        max-width: 800px !important;
        margin: 0 auto !important;
        box-shadow: 0 10px 40px rgba(0,0,0,0.1) !important;
        text-align: center !important;
    }
    .okabase_contact_character_20250908 {
        position: absolute !important;
        top: -40px !important;
        right: 40px !important;
        width: 80px !important;
        height: 80px !important;
        background: #8b6331 !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 40px !important;
    }
    .okabase_contact_title_20250908 {
        font-size: 28px !important;
        color: #333 !important;
        margin-bottom: 10px !important;
        font-weight: bold !important;
    }
    .okabase_contact_subtitle_20250908 {
        margin-bottom: 0px !important;
        /*color: #ff69b4 !important;
        font-size: 14px !important;
        text-transform: uppercase !important;
        letter-spacing: 2px !important; */
    }
    .okabase_contact_description_20250908 {
        font-size: 16px !important;
        color: #666 !important;
        margin-bottom: 40px !important;
        line-height: 1.8 !important;
    }
    .okabase_contact_buttons_20250908 {
        display: flex !important;
        justify-content: center !important;
        gap: 30px !important;
    }
    .okabase_contact_btn_20250908 {
        display: inline-block !important;
        padding: 15px 60px !important;
        border-radius: 30px !important;
        text-decoration: none !important;
        font-size: 1.2em !important;
        font-weight: bold !important;
        transition: transform 0.3s, box-shadow 0.3s !important;
        background: #ff69b4 !important;
        color: white !important;
        box-shadow: 0 5px 20px rgba(255,105,180,0.3) !important;
    }
    .okabase_contact_btn_20250908:hover {
        transform: translateY(-3px) !important;
        box-shadow: 0 8px 30px rgba(255,105,180,0.4) !important;
    }
    .okabase_contact_note_20250908 {
        margin-top: 30px !important;
        padding: 15px !important;
        background: rgba(255,105,180,0.1) !important;
        border-radius: 10px !important;
        color: #666 !important;
        font-size: 14px !important;
    }
    
    /* グループ一覧セクション */
    .okabase_group_section_20250908 {
        background: #fff !important;
        padding: 80px 20px !important;
    }
    .okabase_group_logos_20250908 {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 40px !important;
        flex-wrap: wrap !important;
        max-width: 1000px !important;
        margin: 0 auto !important;
    }
    .okabase_group_logo_item_20250908 {
        flex: 0 1 150px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: transform 0.3s !important;
    }
    .okabase_group_logo_item_20250908:hover {
        transform: scale(1.1) !important;
    }
    .okabase_group_logo_item_20250908 img {
        max-width: 100% !important;
        height: auto !important;
        max-height: 60px !important;
        object-fit: contain !important;
    }
    
    /* レスポンシブ対応 */
    @media (max-width: 768px) {
        .okabase_hero_content_20250908 {
        flex-direction: column !important;
        gap: 30px !important;
        }
        .okabase_hero_20250908 h1 {
        font-size: 32px !important;
        text-align: center !important;
        }
        .okabase_hero_text_20250908 {
        text-align: center !important;
        padding-left: 0 !important;
        flex: 1 !important;
        }
    .okabase_hero_image_20250908 {
        margin-right: 0 !important;
        width: 100% !important;
    }
    .okabase_hero_image_content_20250908 {
        height: 300px !important;
        border-radius: 20px !important;
        margin: 0 20px !important;
    }
		
        .okabase_work_grid_20250908 {
            grid-template-columns: 1fr !important;
        }
        .okabase_features_grid_20250908 {
            grid-template-columns: 1fr !important;
        }
        .okabase_gallery_grid_20250908 {
            grid-template-columns: repeat(2, 1fr) !important;
        }
        .okabase_access_container_20250908 {
            grid-template-columns: 1fr !important;
        }
        .okabase_contact_buttons_20250908 {
            flex-direction: column !important;
            gap: 20px !important;
        }
        .okabase_contact_btn_20250908 {
            width: 100% !important;
        }
        .okabase_contact_character_20250908 {
            right: 20px !important;
            width: 60px !important;
            height: 60px !important;
            font-size: 30px !important;
        }
        .okabase_group_logos_20250908 {
            gap: 20px !important;
        }
        .okabase_group_logo_item_20250908 {
            flex: 0 1 100px !important;
        }
        /* スケジュールのレスポンシブ */
        .okabase_schedule_timeline_20250908::before {
            left: 40px !important;
        }
        .okabase_schedule_item_20250908 {
            padding-left: 80px !important;
        }
        .okabase_schedule_number_20250908 {
            left: 15px !important;
            width: 50px !important;
            height: 50px !important;
            font-size: 16px !important;
        }
        .okabase_schedule_content_20250908 {
            padding: 20px !important;
        }
    }
    @media (max-width: 480px) {
        .okabase_hero_20250908 h1 {
            font-size: 26px !important;
        }
    .okabase_hero_image_content_20250908 {
        height: 250px !important;
    }
        .okabase_h2_20250908 {
            font-size: 28px !important;
        }
        .okabase_gallery_grid_20250908 {
            grid-template-columns: 1fr !important;
        }
        .okabase_contact_card_20250908 {
            padding: 40px 20px !important;
        }
        .okabase_contact_title_20250908 {
            font-size: 24px !important;
        }
        /* スケジュールのさらに小さい画面用 */
        .okabase_schedule_timeline_20250908::before {
            left: 30px !important;
        }
        .okabase_schedule_item_20250908 {
            padding-left: 65px !important;
        }
        .okabase_schedule_number_20250908 {
            left: 10px !important;
            width: 40px !important;
            height: 40px !important;
            font-size: 14px !important;
        }
        .okabase_schedule_title_20250908 {
            font-size: 18px !important;
        }
    }


/************************************
** トップページデザイン終了
************************************/

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}
