@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/
/* WEBフォントインポート  */
/* WEBフォントインポート  */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@300;400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DotGothic16&family=Mochiy+Pop+One&display=swap');

body {
    font-family: 'Comfortaa', 'Zen Maru Gothic', 'Noto Sans JP' !important;
    letter-spacing: 0.1em !important;
}

/*-------------------------------------------
            基本設定
-------------------------------------------*/
.l-content {
    margin: 0 auto;
}

.post_content>* {
    margin-bottom: 0;
}

@media(min-width: 600px) {
    .center {
        text-align: center !important;
    }
}

.top #content {
    padding-top: 0 !important;
}

@media(max-width:767px) {
    .c-pageTitle {
        font-size: 2.5em;
        width: fit-content;
        padding: .2em;
        text-align: center;
        backdrop-filter: blur(40px);
    }
}

.swell-block-fullWide+.swell-block-fullWide {
    margin-top: 0 !important;
}

/*------------すりガラスフィルター--------*/
.bfilter {
    backdrop-filter: blur(20px);
}

/*------------スマホのみ改行--------------*/
@media(min-width:768px) {
    .spbr {
        display: none;
    }
}

/*------------ニュースの文字色------------*/

@media(min-width: 900px) {
    .sr {
        display: none;
    }
}

/*-----------見出し-----------------------*/
.post_content h2 {
    font-family: "Mochiy Pop One";
    font-weight: 300;
    font-size: 1.4em;
    letter-spacing: 0.1em !important;
    margin-bottom: 1em;
    font-weight: 400 !important;
}

@media(min-width: 768px) {
    .post_content h2 {
        font-size: 2em;
        letter-spacing: 0.4em;
    }
}

/*------------見出しの頭文字--------------*/
.first-letter::first-letter {
    font-size: 140%;
}

/*------------bottomline------------------*/
.bottomline {
    border-bottom: 1px solid #295890 !important;
}

.post_content h2::before {
    top: initial !important;
}

.bottomline:before {
    position: absolute !important;
    bottom: 0;
    left: 0 !important;
    width: 20% !important;
    height: 2px !important;
    content: '' !important;
    background: #00a0ff !important;
}

/*-------------左寄せ----------------------*/
.m-left {
    text-align: left !important;
    font-size: 1.5em !important;
}

@media(min-wdith: 768px) {
    .m-left {
        font-size: 2em !important;
    }
}

/*----------flex direction-------------*/
.flex-direction {
    flex-direction: row-reverse;
}

/*--swellボタンをhtml内に設置する際のmargin--*/
.btn-margin {
    margin: 40px auto 10px;
}

/*------padding-top----------------------*/
.padding-top {
    padding-top: 5em;
}

/*------------ボタンキラリの設定----------*/
.is-style-btn_shiny a {
    color: #FFF !important;
    font-family: 'Noto Sans Japanese';
}

/*-------------------------------------------
        メニューの文字の大きさ
--------------------------------------------*/
@media(min-width: 1280px) {
    .c-gnav>.menu-item>a .ttl {
        display: block;
        font-size: 1.05rem;
    }
}

/*-------------------------------------------
            固定ページヘッダー
-------------------------------------------*/
@media (min-width: 600px) {
    .l-topTitleArea {
        min-height: 500px;
    }

    .c-pageTitle {
        font-size: 4em;
        font-weight: 500;
        letter-spacing: 0.2em;
        background: rgba(0, 0, 0, 0.1);
        width: fit-content;
        padding: .2em;
        text-align: center;
        backdrop-filter: blur(40px);
    }
}

.c-filterLayer.-texture-dot:after {
    background-color: transparent;
    background-image: none;
}

.l-topTitleArea.c-filterLayer::before {
    background-color: transparent !important;
}

/*-------------------------------------------
            MVのテキスト
-------------------------------------------*/
.t-mainVisual_box {
    position: absolute;
    top: 35%;
    right: -5%;
    max-width: 800px;
    z-index: 10000;
}

.mv-inner_box {
    position: relative;
    padding: 5rem 6rem;
    border: 1px solid #FFF;
}

.mv-inner_box:before {
    background: rgba(0, 0, 0, 0.1);
    position: absolute;
    top: -3%;
    left: 2%;
    width: 96%;
    height: 106%;
    content: '';
    border: 1px solid #FFF;
    z-index: -1;
    backdrop-filter: blur(20px);
}

.mv-inner_box h2 {
    font-size: 3em;
    position: relative;
    color: #FFF;
    font-weight: 400;
}

.mv-inner_box h2:after {
    position: absolute;
    top: 95%;
    left: 0;
    width: 100%;
    content: "";
    border: 1px solid #FFF;
}

.mv-inner_box p {
    font-size: 2em;
    color: #FFF;
}

@media(max-width: 799px) {
    .t-mainVisual_box {
        position: absolute;
        width: 90%;
        top: 50%;
        left: 50%;
        right: 0;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
    }
}

@media(max-width: 768px) {
    .mv-inner_box h2 {
        font-size: 2em;
    }

    .mv-inner_box p {
        font-size: 1.3em;
    }

    .mv-inner_box {
        padding: 2rem;
    }
}

/*------------------------------------------
        投稿ページのタイトルすりガラス
------------------------------------------*/
.l-topTitleArea__body {
    backdrop-filter: blur(40px);
    background: rgba(0, 0, 0, 0.2);
    padding: 1em;
}

/*------------------------------------------
        タブ切り替えの背景色
------------------------------------------*/
.ark-block-tab.is-style-box>.arkb-tabList .arkb-tabList__button[aria-selected=true] {
    background-color: #dd5d02;
}

/*-------------------------------------------
            TOPページ
-------------------------------------------*/
@media (min-width: 600px) {
    .p-mainVisual__slideTitle {
        font-size: 40px;
    }
}

@media(min-width:900px) {
    .pc-inbox-padding {
        /*私たちについてPC用のpadding*/
        padding-left: 18% !important;
        padding-right: 18% !important;

    }
}

.radius {
    border-radius: 50%;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    padding: 5em 0 !important;
}

@media(max-width:767px) {
    .radius {
        padding: 4.5em 0 !important;
    }
}

/*------------------------------------------
            私たちについて
-------------------------------------------*/
.bottom-bdr {
    border-bottom: 10px solid #FFF;
}

/*------------------------------------------
            ZEBについて
-------------------------------------------*/
.sec-zeb:before {
    background: rgba(0, 0, 0, 0.1) !important;
    backdrop-filter: blur(6px);
}

.value .swell-block-step__item {
    border-top: 1px solid var(--swl-step_arrow_color) !important;
    background: rgba(0, 0, 0, 0.6);
}

.is-style-big>.swell-block-step__item {
    border-bottom: 1px solid var(--swl-step_arrow_color) !important;
    border-left: 1px solid var(--swl-step_arrow_color) !important;
    border-right: 1px solid var(--swl-step_arrow_color) !important;

}

.value .arkb-tabList__button {
    padding: 1.5em;
}

/*Contact Form 7カスタマイズ*/
/*スマホContact Form 7カスタマイズ*/
input {
    width: 100%;
}

.arkb-tabBody {
    padding: 0.1em;
}

@media(max-width:500px) {
    .inquiry {
        table-layout: fixed;
        word-break: break-all;
        word-wrap: break-all;
    }

    .inquiry th,
    .inquiry td {
        display: block !important;
        width: 100% !important;
        border-top: none !important;
        -webkit-box-sizing: border-box !important;
        -moz-box-sizing: border-box !important;
        box-sizing: border-box !important;
    }

    .inquiry tr:first-child th {
        border-top: 1px solid #d7d7d7 !important;
    }

    /* 必須・任意のサイズ調整 */
    .inquiry .haveto,
    .inquiry .any {
        font-size: 10px;
    }
}

/*見出し欄*/
.inquiry th {
    text-align: left;
    font-size: 1.1rem;
    color: #444;
    padding-right: 5px;
    width: 30%;
    background: #f7f7f7;
    border: solid 1px #d7d7d7;
}

/*通常欄*/
.inquiry td {
    font-size: 1rem;
    border: solid 1px #d7d7d7;
}

/*横の行とテーブル全体*/
.entry-content .inquiry tr,
.entry-content table {
    border: solid 1px #d7d7d7;
}

/*必須の調整*/
.haveto {
    font-size: 7px;
    padding: 5px;
    background: #ff9393;
    color: #fff;
    border-radius: 2px;
    margin-right: 5px;
    position: relative;
    bottom: 1px;
}

/*任意の調整*/
.any {
    font-size: 7px;
    padding: 5px;
    background: #93c9ff;
    color: #fff;
    border-radius: 2px;
    margin-right: 5px;
    position: relative;
    bottom: 1px;
}

/*ラジオボタンを縦並び指定*/
.verticallist .wpcf7-list-item {
    display: block;
}

/*送信ボタンのデザイン変更*/
.formbtn {
    display: block;
    padding: 1em 0;
    margin-top: 30px;
    width: 100%;
    background: #ffaa56;
    color: #fff;
    font-size: 18px;
    font-weight: bold;
    border-radius: 2px;
    border: none;
}

/*送信ボタンマウスホバー時*/
.formbtn:hover {
    background: #fff;
    color: #ffaa56;
}

input .wpcf7-form-control,
select,
textarea {
    width: 100%;
}



/*------------------------------------------------
            footer contact
------------------------------------------------*/

/*-----SNSアイコンサイズ調整------*/
.u-fz-14 {
    font-size: 25px;
}


/* 問い合わせタブのカスタム*/
@media (min-width: 600px) {

    .arkb-tabList__button,
    .c-tabList__button {
        font-size: 1.5em;
    }
}

/*Contact Form 7カスタマイズ*/
/*スマホContact Form 7カスタマイズ*/
.inquiry table,
.inquiry tbody,
.inquiry tr,
.inquiry th,
.inquiry td,
.inquiry td:last-child,
.inquiry th:last-child {
    border: 0;
}

button,
input,
select,
textarea {
    padding: 0.5em 0.75em;
}

.border-bottom {
    border-bottom: 1px solid #eee !important;
}

@media (max-width: 500px) {

    .inquiry th,
    .inquiry td {
        display: block !important;
        width: 100% !important;
        -webkit-box-sizing: border-box !important;
        -moz-box-sizing: border-box !important;
        box-sizing: border-box !important;
    }

    /* 必須・任意のサイズ調整 */
}

.require {
    color: #a40000;
    font-size: 2em;
}

input,
select,
textarea {
    background: #fff;
}

.wpcf7-list-item {
    display: inline-block;
    margin: 0em 2em 0.5em 2em;
}

.wpcf7-list-item .radio2 {
    margin-bottom: 0.5em;
}

.wpcf7-acceptance .wpcf7-list-item {
    margin-left: 0.5em !important;
}

.inquiry-width100 {
    width: 100%;
}

.inquiry tr {
    padding: 1em 0;
}

/*見出し欄*/
.inquiry th {
    text-align: left;
    font-size: 1.1em;
    font-weight: 400 !important;
    color: #444;
    padding: 1em 0.3em 0 1em !important;
    width: 30%;
    background: none !important;
}

.inquiry th:before {
    background: none !important;
}

/*通常欄*/
.inquiry td {
    font-size: 1.1em;
    padding: 1em 0 1em 1em !important;
}

.daythree {
    margin: 1em 0;
}

.daythree span,
.jusho {
    margin: 0.25em;
    display: block;
}

.dayhour {
    padding: 0.25em 0.5em;
    background: var(--color_main);
    color: #fff;
}

.width100 {
    width: 100% !important;
}

.width100 a {
    width: 100% !important;
    padding: 0.42em 0;
}

@media(min-width: 600px) {

    .daythree span,
    .jusho {
        margin: 0.25em;
        display: inline-block;
    }

    .p-postal-code {
        width: 20% !important;
    }
}

@media (min-width: 960px) {
    .width100 a {
        padding: 0.67795138624em 0;
    }
}

@media(min-width: 1285px) {
    .width100 a {
        padding: 0.7em 0;
    }
}

.width100 a:before {
    content: "";
    border-top: 1px solid #19274a;
    position: absolute;
    right: 90%;
    top: 50%;
    width: 20%;
    transition: 0.4s ease;
}

.width100 a:hover::before {
    width: 24%;
    right: 86%;
}

/*ラジオボタンを縦並び指定*/
.verticallist .wpcf7-list-item {
    display: block;
}

.wpcf7 input[type="submit"] {
    width: 300px;
    padding: 10px;
    margin-top: 30px;
    margin-left: 35%;
    color: #000;
    -moz-border-radius: 0px;
    border: 1px solid var(--color_main);
    background: #fff;
    position: relative;
}

.wpcf7-submit:hover {
    background: var(--color_main);
    color: #fff;
}

.submitbtm {
    position: relative;
}

.submitbtm:after {
    content: "";
    border-top: 1px solid var(--color_main);
    position: absolute;
    right: 61.5%;
    top: 50%;
    width: 7%;
    transition: 0.4s ease;
}

.submitbtm:hover::after {
    right: 60%;
    width: 7%;
}

@media (max-width: 800px) {
    .wpcf7 input[type="submit"] {
        width: 34%;
        margin-left: 33%;
    }

    .submitbtm:after {
        right: 62%;
    }
}

@media (max-width: 599px) {
    .wpcf7 input[type="submit"] {
        width: 60%;
        margin-left: 20%;
    }

    .submitbtm:after {
        right: 71%;
        width: 20%;
    }

    input,
    select,
    textarea {
        background: #fff;
        max-width: 300px;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
    }

    input .spam1 {
        width: auto !important;
    }

    .inquiry td {
        font-size: 1.1em;
        padding: 0.5em 0 !important;
    }
}

@media (max-width: 391px) {
    .submitbtm:after {
        top: 30%;
    }
}

/*-------------------------------------------
           contact 個人情報保護
-------------------------------------------*/
.personalinfo {
    margin: 2em auto;
}

.personal-head {
    padding: 0.5em 0;
    background: var(--color_main);
    text-align: center;
    color: #fff;
    font-size: 1.5em;
}

.personalinfo-inner {
    height: 250px;
    overflow-y: scroll;
    border: 1px solid #ccc;
    padding: 1em 2em;
    background: #fff;
    font-size: 14px;
}

.personalinfo-inner dl {
    display: flex;
    justify-content: flex-start;
    padding: 0.75em 0 0;
    border-bottom: 1px solid #eee;
}

.personalinfo-inner dt {
    font-size: 1.1em;
    font-weight: 400;
    padding-right: 2em;
}

.personalinfo-inner dd {
    font-size: 1em;
}