@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+Serif+JP&display=swap');
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@400;500;600;700;800&display=swap');
@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=Montserrat:wght@100;300;400;500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@300;400;500;600;700&display=swap');

body {
    font-family: 'Comfortaa', 'Noto Sans JP' !important;
    letter-spacing: 0.1em !important;
}

/*-------------------------------------------
            基本設定
-------------------------------------------*/
.l-content {
    margin: 0 auto;
}

.post_content>* {
    margin-bottom: 0;
}

.u-mb-90 {
    margin-bottom: 9em;
}

@media(min-width: 600px) {
    .center {
        text-align: center !important;
    }
}

.top #content {
    padding-top: 0 !important;
}

@media(max-width:767px) {
    .c-pageTitle {
        font-size: 2em;
        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-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';
}

/*------------投稿にタグを表示-----------*/
.tags-wrapper {
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
    flex-wrap: wrap;
}

.c-postThumb__cat.icon-tag {
    position: relative;
}

/*-------------------------------------------
        メニューの文字の大きさ
--------------------------------------------*/
@media(min-width: 1280px) {
    .c-gnav>.menu-item>a .ttl {
        display: block;
        font-size: 1.05rem;
    }
}

/*------------------------------------------
            ブロークンテキスト
-------------------------------------------*/
.is-style-broken.wp-block-media-text {
    --swl-mediatext--lap: -12em;
}

/*-------------SVGボタン--------------------*/
.centering {
    text-align: center;
}

.svg-btn-wrap {
    position: relative;
    max-width: 407px;
    width: 100%;
    height: 86px;
    display: inline-block;
    cursor: pointer;
}

.svg-btn-svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: opacity 0.2s;
    pointer-events: none;
}

.svg-btn-before {
    opacity: 1;
    z-index: 1;
    pointer-events: auto;
}

.svg-btn-after {
    opacity: 0;
    z-index: 2;
}

.svg-btn-wrap:active .svg-btn-before {
    opacity: 0;
    pointer-events: none;
}

.svg-btn-wrap:active .svg-btn-after {
    opacity: 1;
    pointer-events: auto;
}

.svg-btn-before .st0 {
    fill: #CDCDCD;
}

.svg-btn-before .st0,
.svg-btn-before .st1,
.svg-btn-before .st2,
.svg-btn-before .st3 {
    stroke: #083156;
}

.svg-btn-before .st0,
.svg-btn-before .st1,
.svg-btn-before .st3 {
    stroke-linejoin: round;
    stroke-width: .5px;
}

.svg-btn-before .st1 {
    fill: #fff;
}

.svg-btn-before .st4,
.svg-btn-before .st3 {
    fill: #083156;
}

.svg-btn-before .st2 {
    fill: none;
    stroke-width: 2px;
}

.svg-btn-after .st0 {
    fill: #CDCDCD;
}

.svg-btn-after .st0,
.svg-btn-after .st1,
.svg-btn-after .st2,
.svg-btn-after .st3 {
    stroke: #083156;
}

.svg-btn-after .st0,
.svg-btn-after .st1,
.svg-btn-after .st3 {
    stroke-linejoin: round;
    stroke-width: .5px;
}

.svg-btn-after .st1 {
    fill: #fff;
}

.svg-btn-after .st4,
.svg-btn-after .st3 {
    fill: #083156;
}

.svg-btn-after .st2 {
    fill: none;
    stroke-width: 2px;
}


/*-------------------------------------------
            固定ページヘッダー
-------------------------------------------*/
@media (min-width: 600px) {
    .l-topTitleArea {
        min-height: 500px;
    }

    .c-pageTitle {
        font-size: 3em;
        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;
    }
}

/*------------------------------------------
        SP開閉メニュー
------------------------------------------*/
.c-widget__title.-spmenu {
    display: none;
}

.p-spMenu__nav {
    margin-top: 2em;
}

/*------------------------------------------
        タブ切り替えの背景色
------------------------------------------*/
.ark-block-tab.is-style-box>.arkb-tabList .arkb-tabList__button[aria-selected=true] {
    background-color: var(--color_main);
}

/*-------------------------------------------
            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;

    }
}

.top_about {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg), url(https://niiza-tst.work/wp-content/uploads/2025/05/illust_top_about.svg);
    background-repeat: no-repeat, no-repeat;
    background-size: 100%, 95%;
    background-position: 0px 55% 55%, 59% 1%;
}

.top_about2 {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg), url(https://niiza-tst.work/wp-content/uploads/2025/05/illust_top_service1.svg);
    background-repeat: no-repeat, no-repeat;
    background-size: 100%, 100%;
    background-position: 0 -35%, 0 110%;
}

@media(min-width:768px) {
    .top_about {
        background-size: 55%, 70%;
        background-position: 0 85%, 100% 10%;
    }

    .top_about2 {
        background-size: 55%, 35%;
        background-position: 100% 40%, 0 123%;
    }
}

/*-----投稿4列------*/
.cw-1700 {
    max-width: 1700px !important;
    margin: 0 auto !important;
}

@media (min-width: 960px) {

    .-col4 .-type-card.-pc-col3 .p-postList__item,
    .-col4 .-type-thumb.-pc-col3 .p-postList__item {
        width: calc(100% / 4);
    }
}

.width-1600 {
    max-width: 1600px;
    width: 90%;
    margin: 0 auto;
}

/*------------------------------------------
            私たちについて
-------------------------------------------*/
.about_greet {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/illust_top_about.svg);
    background-repeat: no-repeat, no-repeat;
    background-size: 100%;
    background-position: 0 0;
}

.about_boss {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: 100% 90%;
}

@media(min-width:768px) {
    .about_greet {
        background-size: 35%;
        background-position: 0 85%;
    }

    .about_boss {
        background-size: 65%;
        background-position: 100% 50%;
    }
}

/*------------------------------------------
            パーツの強み
-------------------------------------------*/
.st_col_01 {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg), url(https://niiza-tst.work/wp-content/uploads/2025/06/illust_top_service_3.svg);
    background-repeat: no-repeat, no-repeat;
    background-size: 190%, 70%;
    background-position: 0 85%, 100% -8%;
}

.st_col_02 {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg), url(https://niiza-tst.work/wp-content/uploads/2025/06/illust_top_service_4.svg);
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-size: 190%, 109%;
    background-position: 0 41%, 0 115%;
}

.st_col_03 {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg);
    background-repeat: no-repeat;
    background-size: 270%;
    background-position: 0 90%;
}

.st_col_04 {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/05/bg_about_1200ｘ900.svg);
    background-repeat: no-repeat, no-repeat;
    background-size: 240%;
    background-position: 0 80%;
}

.st_col_01 .is-style-broken.wp-block-media-text,
.st_col_02 .is-style-broken.wp-block-media-text,
.st_col_03 .is-style-broken.wp-block-media-text,
.st_col_04 .is-style-broken.wp-block-media-text {
    --swl-mediatext--lap: -15em;
}

@media(min-width:768px) {
    .st_col_01 {
        background-size: 55%, 64%;
        background-position: 0 30%, 100% 50%;
    }

    .st_col_02 {
        background-size: 55%, 45%;
        background-position: 100% 20%, 0 230%;
    }

    .st_col_03 {
        background-size: 55%;
        background-position: 0 50%;
    }

    .st_col_04 {
        background-size: 55%;
        background-position: 100% 20%;
    }
}

/*------------------------------------------
            制作事例
-------------------------------------------*/

.sliderloop {
    display: flex;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
    height: 200px;
    overflow: hidden;
}

.sliderloop ul {
    display: flex;
    padding: 0;
    margin: 0;
}

.sliderloop li {
    width: 300px;
    list-style: none;
}

.sliderloop ul:first-child {
    animation: slideloop 50s -75s linear infinite;
}

.sliderloop ul:last-child {
    animation: slide2 50s linear infinite;
}

@keyframes slideloop {
    0% {
        transform: translateX(100%);
    }

    to {
        transform: translateX(-100%);
    }
}

@keyframes slide2 {
    0% {
        transform: translateX(0);
    }

    to {
        transform: translateX(-200%);
    }
}

/*------------------------------------------
            制作事例
-------------------------------------------*/
.jirei_invite {
    background-size: 65%;
    background-position: 100% 10%;
}

@media(min-width:768px) {
    .jirei_invite {
        background: url(https://niiza-tst.work/wp-content/uploads/2025/06/jirei_bg.svg) no-repeat;
        background-size: 100%;
        background-position: 100% 15%;
    }
}

/*------------------------------------------
            会社概要
-------------------------------------------*/
.googlemap {
    filter: grayscale(67%) hue-rotate(172deg);
}

/*------------------------------------------
            faq
-------------------------------------------*/
.ark-block-tab>.arkb-tabList {
    padding: 0;
    margin-bottom: 3em;
}

/*------------------------------------------
            投稿ページ
-------------------------------------------*/
.l-topTitleArea__body {}

/*------------------------------------------
            お問い合わせ
-------------------------------------------*/
.contact-bg {
    background: url(https://niiza-tst.work/wp-content/uploads/2025/06/contact_illust1.svg) no-repeat;
    background-size: 50%;
    background-position: 100% 7%;
}

@media(min-width:768px) {
    .contact-bg {
        background-size: 40%;
        background-position: 95% -5%;
    }
}

/*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
------------------------------------------------*/
/*-----footerロゴ-----------
.footlogo {
    width: 10%;
    margin: 0 45%;
}

@media(max-width: 767px) {
    .footlogo {
        width: 20%;
        margin: 0 40%;
    }
}
--*/
/*-----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;
}