/*
Theme Name: novaris theme 2025
Description: novaris
Version: 1.0
Author: maeda
*/
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Text:ital@0;1&family=Gloock&family=IBM+Plex+Sans+JP&family=Noto+Sans+JP:wght@100..900&display=swap');
:root {
    --color-black:      16 21 48;
    --color-whitegray:  244 245 247;
    --color-lightgray:  226 229 235;
    --color-gray:       107 114 128;
    --color-yellow:     255 191 0;

    --font-gray:       rgb(var(--color-gray) / 1);
    --color-note_gray:      rgb(var(--color-whitegray) / 1);
    --color-main_black:       rgb(var(--color-black) / 1);
    --color-common-yellow:      rgb(var(--color-yellow) / 1);
    --color-common-lightgray:      rgb(var(--color-lightgray) / 1);

}

/* ========================================================================
    base
 */
#wpadminbar {display: none;}
*{scroll-margin-top: 160px;}
body {
    font-family: "Noto Sans JP", 游ゴシック体, YuGothic, 游ゴシック medium, yu gothic medium, -apple-system, BlinkMacSystemFont, helvetica neue, yu gothic medium, ヒラギノ角ゴ pron w3, hiragino kaku gothic pron, Arial, メイリオ, Meiryo, sans-serif;
    font-size: 14px;
    letter-spacing: .05em;
    color: var(--color-main_black);
}
main:not(.home main) {
    padding-bottom: 2em;
}
h1, h2, h3, h4, h5 {
    font-family: "IBM Plex Sans JP", sans-serif;
    font-weight: normal;
}
h4 {
    line-height: 1.2;
}
h5 {
    font-size: .85em;
    line-height: 1;
}
a {
    color: var(--color-main_black);
}

svg {
    vertical-align: middle;
}
small {
    /* color: var(--font-gray); */
    font-size: 12px;
    font-weight: normal;
}
hr {
    border-bottom: solid 1px var(--color-common-lightgray);
}

article {
    padding: .25em;
}
@media screen and (min-width:768px) {
    article {
        padding: 1em 2em;
    }
}

form {
    display: grid!important;
    width: 100%;
    font-size: 14px!important;
}
/* Cloudflare Turnstile バッジ調整 */
.cf-turnstile,
iframe[src*="challenges.cloudflare.com"] {
    margin-top: 1em;
    text-align: center;
    order: 2;
}
.wpcf7-spinner {
    display: none !important;
}
input[type="text"], input[type="number"], input[type="tel"], input[type="email"], textarea {
    background: var(--color-note_gray);
    border: solid 1px var(--color-common-lightgray);
}

@media screen and (min-width:768px) {
    .l-wrap {
        padding: 4rem 1rem;
    }
}
.o-btn {
    background: var(--color-main_black);
    /* border-radius: 4px!important; */
}
.o-cards {
    padding: 1.5em;
}


/* ========================================================================
    共通
*/

/* タイトル英語装飾 */
.p-ttl_emphasis {
    font-family: "Gloock", serif;
    font-weight: normal;
    letter-spacing: .1em;
}
.p-sbttl_emphasis {
    font-family: "DM Serif Text", serif;
    font-weight: normal;
    letter-spacing: .1em;
}

.p-bkclr_gray {
    background: var(--color-note_gray);
    color: var(--color-main_black);
}
.p-bkclr_black {
    background: linear-gradient(to bottom, rgb(var(--color-black) / 80%) 0%, var(--color-main_black, 100%));
    /* background: var(--color-main_black); */
    color: white;
}
.p-bkclr_black h2 {
    color: var(--color-common-yellow);
}
.p-bkclr_white {
    background: white;
    color: var(--color-main_black);
}
.p-bkclr_yellow {
    background: var(--color-common-yellow);
    color: var(--color-main_black);
}
.p-fntclr_yellow {
    color: var(--color-common-yellow);
}
.p-bdclr_yellow {
    border-color: var(--color-common-yellow);
}

.p-text_icons {
    display: flex;
    align-items: center;
    gap: .5em;
}

.p-text_tag,
.p-text_category {
    padding: .5em 1em;
    font-size: xx-small;
    vertical-align: middle;
    line-height: 1;
    letter-spacing: 0;
}
h3:has(.p-text_category) {
    display: flex;
    align-items: center;
    justify-content: space-between;
} 
.p-text_tag {
    /* background: var(--color-note_gray);
    color: var(--font-gray); */
    border: solid 1px;
}
.p-text_category {
    /* background: var(--color-main_black);
    color: white; */
    background: var(--color-common-yellow);
    color: var(--color-main_black);
}

.p-icon_cycle {
    padding: .5em;
    background: var(--color-main_black);
    color: white;
    line-height: 1;
}
.p-icon_number {
    font-family: "DM Serif Text", serif;
    font-size: 1.5em;
    color: var(--color-common-lightgray);
    line-height: 1;
}
.p-number_cycle {
    display: block;
    margin: 0 0 0 auto;
    padding: .25em;
    width: 1.5em;
    height: 1.5em;
    aspect-ratio: 1;
    background: var(--color-note_gray);
    border-radius: 100%;
    line-height: 1;
    text-align: center;
}

/* 矢印　スタンダード */
.p-link_arrow {
    position: relative;
    display: inline-block;
    padding: 0 2em 0 0;
    color: var(--color-main_black);
}
.p-link_arrow::before,
.p-link_arrow::after {
    content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
}
.p-link_arrow::before{
    right: .25em;
    width: 1em;
    height: 1px;
    background: currentColor;
}
.p-link_arrow::after{
    right: .25em;
    width: .5em;
    height: .5em;
    border-top: 1px solid currentColor;
    border-right: 1px solid currentColor;
    transform: rotate(45deg);
}

/* 矢印　くの字 */
.p-list_arrow {
    position: relative;
    display: flex;
    align-items: center;
    padding: 0 0 0 1em;
}
.p-list_arrow::before {
    content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
.p-list_arrow::before{
    width: .5em;
    height: .5em;
    border-top: 1px solid var(--color-common-lightgray);
    border-right: 1px solid var(--color-common-lightgray);
    transform: rotate(45deg);
}

/* イベント フォントカラー */
    .is-hover__parent:hover .is-hover__color {
        color: var(--color-common-yellow)!important;
    }
/* イベント 背景カラー */
    .is-hover__shadow:hover .is-hover__bkcolor {
        background: var(--color-common-lightgray)!important;
    }

    
/* ========================================================================
    ヘッダーフッター
*/
.home #headerArea {
    position: absolute;
}
#headerArea {
    top: 0;
    left: 0;
    right: 0;
    z-index: 1;
    /* border-bottom: solid 1px; */
}
#headerArea,
#footerArea {
    font-family: "DM Serif Text", serif;
    font-size: medium;
    padding: 1em;
    background: white;
}
#headerArea > nav,
#footerArea > nav {
    margin: 0 auto;
    max-width: 1600px;
    width: 100%;
}
#headerArea > nav ul,
#footerArea > nav ul {
    display: flex;
    flex-direction: column;
    gap: 1em;
    width: 100%;
}
@media screen and (min-width:768px) {
    #headerArea > nav ul,
    #footerArea > nav ul {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}
#headerArea > nav ul > li h1,
#footerArea > nav ul > li h1  {
    font-family: "Gloock", serif;
    font-weight: 400;
}
#headerArea li:has(h1) {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
#footerArea:not(.home #footerArea) {
    border-top: solid 1px;
}
/* レスポンシブ */
#headerArea .p-menu_global {
    display: none;
}
@media screen and (min-width:768px) {
    #headerArea .p-menu_global {
        display: block;
    }
}
#headerArea.is-active .p-menu_global {
    display: block;
}
#headerArea.is-active .p-menu_global ul > li {
    padding: .5em;
}
#headerArea.is-active .p-menu_global ul > li:not(#headerArea .p-menu_global ul > li:last-of-type) {
    border-bottom: solid 1px;
}


/* ハンバーガーメニュー */
.p-btn_hamburger {
    position: relative;
    display: block;
    width: 2em;
    height: 1.5em;
}
.p-btn_hamburger span,
.p-btn_hamburger::before,
.p-btn_hamburger::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    display: block;
    width: 100%;
    height: 1px;
    margin: auto;
    background: var(--color-main_black);
    transition-duration: 300ms;
}
.p-btn_hamburger span {
    top: 0;
    bottom: 0;
}
.is-active .p-btn_hamburger span {
    opacity: 0;
    width: 100%;
}
.p-btn_hamburger::before {
    top: 0;
}
.is-active .p-btn_hamburger::before {
    transform: rotate(45deg);
}
.p-btn_hamburger::after {
    bottom: 0;
}
.is-active .p-btn_hamburger::after {
    top: 0;
    bottom: auto;
    transform: rotate(-45deg);
}
@media screen and (min-width:768px) {
    .p-btn_hamburger {
        display: none;
    }
}


/* ========================================================================
    MV
*/
#MV {
    position: relative;
    height: 100vh;
    /* width: 100vw; */
    background: linear-gradient(to bottom, rgb(0 0 0 / 0%) 0%, var(--color-note_gray) 100%);
    /* overflow: hidden; */
}
.p-top_mv {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2em;
    padding-top: 80px;
    margin: 0 auto;
    height: 100%;
    width: 100%;
    max-width: 1560px;
}
@media screen and (min-width:768px) {
    .p-top_mv {
        flex-direction: row;
        justify-content: space-between;
    }
}
.p-top_mv .p-top_MVimg {
    display: block;
    width: 100%;
    max-height: 240px;
    height: 100%;
    /* background: var(--color-common-lightgray); */
    background-image: url('/wp-content/themes/novaris_2025/assets/img/mv_01.jpg');
    background-size: cover;
}
@media screen and (min-width:768px) {
    .p-top_mv .p-top_MVimg {
        width: 50%;
        max-height: 640px;
        order: 1;
    }
}
.p-top_mv .p-top_MVtext {
    display: grid;
    gap: 2em;
    padding: 0 2em;
}
.p-top_mv .p-top_MVtext h1 {
    font-size: 1.5rem;
}
.p-top_mv .p-top_MVornament {
    font-family: "Gloock", sans-serif;
    font-weight: 400;
    font-size: 2em;
    letter-spacing: .15em;
    line-height: 1;
}

.p-top_mv .p-top_btnContact {
    position: absolute;
    bottom: 2em;
    right: 2em;
    padding-left: .5em;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 12px;
}
.p-top_mv .p-top_btnContact:hover {
    text-decoration-color: transparent;
    transform: translateY(1em);
}
.p-top_mv .p-top_btnContact::before,
.p-top_mv .p-top_btnContact::after {
    content: '';
    position: absolute;
    bottom: -2px;
    display: block;
    width: 2px;
    background: var(--color-main_black);
}
.p-top_mv .p-top_btnContact::before {
    right: calc(2em - 2px);
    height: 100%;
}
.p-top_mv .p-top_btnContact::after {
    right: calc(2em + 3px);
    height: 1em;
    transform: rotate(-45deg);
}


/* ========================================================================
    TOP：contents-head
*/
.p-top_headTtl {
    display: grid;
    align-content: start;
    gap: .5em;
    text-align: left;
}
.p-top_headTtl > dt::after {
    content: '';
    display: block;
    margin: 1em 0;
    width: 2em;
    height: 2px;
    background: currentColor;
}
.p-top_headTtl > dt small::before {
    content: '';
    display: inline-block;
    margin: 0 .5em 0 0;
    width: .5em;
    height: 1px;
    background: currentColor;
    vertical-align: middle;
}


/* ========================================================================
    TOP：contents
*/
.p-top_contItem dt {
    display: grid;
    gap: .5em;
    font-size: 1.2em;
}

/* ========================================================================
    TOP：contact
*/
.p-top_table {
    padding: 2em;
    overflow: hidden;
}
.p-top_table tbody {
    display: grid;
    gap: 1em;
}
.p-top_table :is(tr, th, td) {
    display: block;
    padding: 0;
    width: 100%;
    border: none;
}
.p-top_table th {
    padding-bottom: .5em;
}
.p-top_table th label {
    color: red;
}
.p-top_table .o-btn {
    margin: 0 auto;
    width: 100%;
}
.wpcf7 form .wpcf7-response-output {
    background: var(--color-note_gray);
    border: none;
    color: var(--color-main_black);
    text-align: center;
}

/* ========================================================================
    company
*/
.p-table_company :is(tr, th) {
    border: none;
}
.p-table_company tr {
    border-bottom: solid 1px var(--color-common-lightgray);
}

/* ========================================================================
    seach
*/

.p-form_layout {
    position: relative;
    width: 100%;
}
.p-form_input {
    padding-right: 1em;
}
.p-form_submit {
    position: absolute;
    top: 0;
    bottom: 0;
    right: .5em;
    margin: auto;
    width: 1em;
    background: none;
    cursor: pointer;
    z-index: 1;
    
}

/* ========================================================================
    blog
*/

.p-blog_layout {
    display: flex;
    flex-wrap: wrap;
    gap: 2em;
}
.p-blog_contents,
.p-blog_menu {
    width: 100%;
}
.p-blog_contents {
    font-size: 16px;
}
.p-blog_contents > p,
.p-blog_contents > :is(ul, ol) li {
    line-height: 1.8;
}
.p-blog_contents img {
    margin: 0 auto;
}
@media screen and (min-width:768px) {
    .p-blog_contents {
        width: calc(70% - 2em);
    }
    .p-blog_menu {
        width: 30%;
    }
}

/* 記事内容 */
.p-blog_item {
    display: flex;
    flex-wrap: wrap;
    gap: 1em;
}
.p-blog_thumbnail {
    width: 100%;
    line-height: 0;
}
@media screen and (min-width:768px) {
    .p-blog_thumbnail {
        display: grid;
        align-items: center;
        width: 40%;
    }
    .p-blog_detail {
        width: calc(60% - 1em);
    }
}

/* プロフィール画像 */
.p-blog_prof {
    align-items: center;
}
.p-blog_profImg {
    line-height: 0;
}
.p-blog_profImg img {
    width: 40px;
    aspect-ratio: 1;
    border-radius: 50%;
}
/* 筆者欄 */
.p-blog_author {
    display: grid;
    gap: 1rem;
    padding: 1.5rem;
    background: var(--color-note_gray);
}
.p-blog_author figure, .p-blog_author figcaption {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
}
.p-blog_author figcaption {
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
}
.p-blog_author figure .avatar {
    margin: 0;
    max-width: 48px;
    border-radius: 100%;
}
.p-blog_author .p-author_name {
    font-weight: bold;
}
.p-blog_author .p-author_comment {
    font-size: 14px;
}
.p-blog_author .p-author_snsList {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.p-blog_author .p-author_snsList img {
    max-width: 24px;
}

.p-blog_category {
    padding: .25em .5em;
    font-size: x-small;
    background: var(--color-note_gray);
}
.p-blog_time {
    font-size: smaller;
    color: var(--font-gray);
}
.p-blog_excerpt {
    color: var(--font-gray);
}
.p-blog_category_list {
    display: grid;
    gap: .5em;
}

.p-blog_tags {
    padding: .25em .5em;
    font-size: smaller;
    border-radius: .5em;
    background: var(--color-note_gray);
}
.p-blog_tags:hover {
    opacity: .5;
}
.p-blog_tags a:hover {
    text-decoration-color: transparent;
}
.p-blog_tags_list {
    display: flex;
    flex-wrap: wrap;
    gap: .5em;
}

/* ページネーション */
.p-blog_pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5em;
}
.p-blog_pagination .page-numbers {
    display: inline-block;
    padding: .5em;
    border: solid 1px var(--color-common-lightgray);
    color: var(--font-gray);
    text-align: center;
    line-height: 1;
}
.p-blog_pagination .page-numbers:hover {
    opacity: .5;
}
.p-blog_pagination .page-numbers:hover {
    text-decoration-color: transparent;
}
.p-blog_pagination .page-numbers.current {
    background: var(--color-common-lightgray);
    color: white;
}

/* 目次 */
div#ez-toc-container {
    padding: 1em;
    margin-bottom: 1em;
    background: var(--color-note_gray);
}
.ez-toc-title-container {
    display: flex;
    padding: .25em 1em;
    justify-content: space-between;
}
.ez-toc-title {
    vertical-align: -webkit-baseline-middle;
    font-size: 1.2em;
}
.ez-toc-title::before {
    content: '';
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-right: .25em;
    vertical-align: middle;
    background: var(--color-main_black);
}
.arrow-unsorted-368013 {
    display: none;
}
.ez-toc-list {
    padding: 1em;
}
[class^="ez-toc-list-level-"] {
    padding: 0 1em;
}
div#ez-toc-container ul li {
    padding: .5em;
}
div#ez-toc-container ul.ez-toc-list-level-1 > li:not(:last-child) {
    border-bottom: solid 1px var(--color-common-lightgray);
}
.ez-toc-list-level-3 a {
    color: var(--font-gray);
}
.ez-toc-heading-level-3 {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}
.ez-toc-heading-level-3::before {
    content: "";
    display: block;
    width: 8px;
    height: 1px;
    margin-right: .25em;
    background: var(--font-gray);
}
