@charset "UTF-8";

/*
Theme Name: fullhouse
Description: fullhouse original theme
Version: 1.0
Author: Takuro Maruyama
*/

/*
root
================================================ */
:root {
    --text: #1C1C1C;
    --navy: #3C475C;
    --grey: #AAAAAA;
    --light-grey: #E9E9E9;
    --white: #fff;
    --teal: #5696AA;
    --light-teal: #8AB0BA;
    --yellow: #F1ED8D;

    /* Fonts */
    --font-en: "Oswald", system-ui, -apple-system, "Segoe UI", sans-serif;
    --font-jp: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", sans-serif;

    /* Layout */
    --container: 960px;
    --radius: 16px;
}

/*
GENERAL STYLING
================================================ */
html {
    font-size: 62.5%;
    /* 1rem = 10px */
    scroll-behavior: smooth;
    margin-top: 0 !important;
}

body {
    color: var(--text);
    font-size: clamp(1.4rem, 1.2rem + .3vw, 1.6rem);
    font-family: var(--font-jp);
    line-height: 1.8;
    background: var(--white);
    overflow-x: hidden;
}

img {
    display: block;
    width: 100%;
    height: auto;
}

a {
    color: inherit;
    text-decoration: none;
}

.container {
    max-width: var(--container);
    margin-inline: auto;
    padding-inline: clamp(16px, 5vw, 40px);
}

.sp-only {
    display: none;
}

@media (max-width: 769px) {
    .sp-only {
        display: block;
    }
}

/*
TYPOGRAPHY
================================================ */
.page-title-en {
    font-family: var(--font-en);
    font-size: clamp(2.2rem, 1.6rem + 1.6vw, 3.2rem);
    text-transform: uppercase;
    color: var(--teal);
    padding-right: clamp(1.6rem, 1.4rem + 0.6vw, 2.4rem);
}

.page-title-jp {
    font-size: clamp(1.8rem, 1.6rem + 0.6vw, 2rem);
    color: var(--teal);
}

.view-more-btn {
    font-family: var(--font-en);
    font-size: 1.4rem;
    color: var(--teal);
    background: var(--white);
    padding: 2px 0;
    width: clamp(160px, 32vw, 200px);
    display: flex;
    gap: 16px;
    justify-content: center;
    align-items: center;
    border: 1px solid var(--teal);
    border-radius: 80px;
    transition: transform .25s ease, background .25s ease;
}

.view-more-btn-l {
    font-family: var(--font-en);
    font-size: 1.4rem;
    color: var(--teal);
    background: var(--white);
    padding: 8px 0;
    width: clamp(200px, 36vw, 280px);
    display: flex;
    gap: 16px;
    justify-content: center;
    align-items: center;
    border: 1px solid var(--teal);
    border-radius: 80px;
    transition: transform .25s ease, background .25s ease;
}

.btn-arrow {
    width: 1.4rem;
    transition: transform .3s ease;
}

.view-more-btn:hover,
.view-more-btn-l:hover {
    background: var(--teal);
    color: var(--white);
}

.fa-arrow-right {
    transition: transform .3s ease;
}

.view-more-btn:hover .fa-arrow-right,
.view-more-btn-l:hover .fa-arrow-right {
    transform: translateX(4px);
}

.sec-title-en {
    font-family: var(--font-en);
    font-size: 1.4rem;
    letter-spacing: .15em;
    color: var(--navy);
    position: relative;
}

.sec-title-en::after {
    content: "";
    position: absolute;
    height: 1px;
    left: 0;
    bottom: -1.6rem;
    width: 40px;
    background: var(--navy);
}

.sec-heading {
    font-size: clamp(1.6rem, 1.4rem + 0.8vw, 2rem);
    font-weight: bold;
    color: var(--navy);
    width: 100%;
}

.works-category {
    font-size: 1.4rem;
    font-weight: 500;
    color: var(--white);
    border: 1px solid var(--teal);
    background: var(--teal);
    padding: 2px 16px;
    border-radius: 64px;
}

.works-company {
    color: var(--grey);
    font-weight: 500;
}

.works-title-grid,
.news-title-grid {
    font-size: clamp(1.6rem, 1.4rem + 0.8vw, 2rem);
    font-weight: 500;
    margin-top: 4px;
}


.news-date {
    font-size: clamp(1.4rem, 1.2rem + 0.4vw, 1.6rem);
    font-family: var(--font-en);
    color: var(--grey);
    letter-spacing: .1em;
}

.member-title {
    font-size: 1.4rem;
    color: var(--grey);
}

.member-name-box {
    display: flex;
    gap: 8px;
}

.member-name {
    font-size: clamp(1.6rem, 1.4rem + 0.8vw, 2rem);
	display: flex;
	align-items: center;
}

.member-name::after {
    content: "";
    display: inline-block;
    width: 1px;
    height: 16px;
    margin-left: 8px;
    background: var(--light-grey);
}

.member-name-en {
    font-family: var(--font-en);
    font-size: clamp(1.6rem, 1.4rem + 0.8vw, 2rem);
}



.page-lead {
    font-size: clamp(2.4rem, 2.2rem + 2.4vw, 4.8rem);
    font-weight: bold;
    color: var(--navy);
}

.page-lead-sm {
    font-size: clamp(2rem, 1.8rem + 1.4vw, 4.0rem);
    font-weight: bold;
    color: var(--navy);
    display: flex;
    gap: clamp(8px, 0.8rem + 0.4vw, 16px);
}

.page-lead-sm-num {
    font-family: var(--font-en);
	display: flex;
    align-items: center;
}

.page-lead-sm-num::after {
    content: "";
    display: inline-block;
    width: 2px;
    height: clamp(2.4rem, 2.0rem + 1.6vw, 4.0rem);
    margin-left: clamp(8px, 0.8rem + 0.4vw, 16px);
    background: var(--text);
}

.page-lead-sub {
    font-size: clamp(1.6rem, 1.4rem + 0.8vw, 2.4rem);
    color: var(--navy);
}

/* フェードダウン */
.fadeDown {
    animation-name: fadeDownAnime;
    animation-duration: 0.8s;
    animation-fill-mode: forwards;
    opacity: 0;
}

@keyframes fadeDownAnime {
    from {
        opacity: 0;
        transform: translateY(-60px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fadeDownHero {
    animation-name: fadeDownHeroAnime;
    animation-duration: 1s;
    animation-delay: 0.3s;
    animation-fill-mode: forwards;
    opacity: 0;
}

@keyframes fadeDownHeroAnime {
    from {
        opacity: 0;
        transform: translateY(-100px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}