@import url("/common/css/keyvisual.css?20250108");

img {
    max-width: 100%;
}

.garage_top {}

.garage_general {
    color: #000;
    margin-top: 4vw;
}

.hero-section {
    position: relative;
    height: 42vw;
}

.hero-title {
    position: absolute;
    left: 6vw;
    top: 7.1vw;
    font-size: 2.5vw;
    width: 25vw;
    font-weight: 700;
    line-height: 1.7;
}

.hero-text {
    position: absolute;
    left: 6vw;
    top: 25.4vw;
    font-size: 0.9vw;
    width: 24.7vw;
    line-height: 1.6;
}

.hero-text:before {
    content: "";
    display: block;
    position: absolute;
    background-image: url(/common/img/common/garuxgarage_logo.svg);
    left: 0.8vw;
    top: -8.5vw;
    width: 26.3vw;
    height: 4.14vw;
    background-repeat: no-repeat;
    background-size: contain;
}

.hero-image {
    position: absolute;
    right: 0;
    top: 0;
    width: 63vw;
}

.points-section {
    margin-left: auto;
    margin-right: auto;
    width: 71vw;
    padding-top: 4.2vw;
}

.points-title {
    text-align: center;
    font-size: 2vw;
    width: 100%;
    font-weight: 700;
    line-height: 1.6;
}

.points {}

.points-container {
    display: flex;
    gap: 4.5vw;
    margin-top: 3.6vw;
}

.point-item {
    width: 21vw;
}

.point-image {
    width: 21vw;
    display: block;
}

.point-headline {
    text-align: center;
    font-size: 1.5vw;
    font-weight: 500;
    line-height: 1.6;
    margin-top: 1vw;
    margin-bottom: 1vw;
}

.point-description {
    font-size: 0.9vw;
    /*    margin-top: 2vw;*/
    font-weight: 400;
}

.lifestyle-section {
    position: relative;
    margin-left: auto;
    margin-right: auto;
    width: 70vw;
    padding-top: 6.7vw;
}

.lifestyle-title {
    font-size: 2vw;
    font-weight: 700;
    line-height: 1.6;
    margin-left: -1.3vw;
}

.lifestyle-item {
    position: relative;
    height: 56vw;
}

.lifestyle-item:before {
    content: "";
    position: absolute;
    top: 33.5vw;
    font-size: 9vw;
    left: -1.3vw;
    color: #f0f0f0;
    font-weight: 500;
}

.lifestyle-item:nth-child(2):before {
    content: "Lifestyle";
    font-size: 8.6vw;
}

.lifestyle-item:nth-child(3):before {
    content: "Reliability";
    top: 36.4vw;
    font-size: 7.5vw;
    left: 35.7vw;
}

.lifestyle-item:nth-child(4):before {
    content: "One and Only";
    font-size: 6.2vw;
    top: 35.9vw;
}

.lifestyle-item:nth-child(5):before {
    content: "Tailor Made";
    top: 35.4vw;
    font-size: 7.1vw;
    left: 32.7vw;
    width: 43vw;
}

.lifestyle-item:nth-child(6):before {
    content: "Cozy Space";
    font-size: 7.5vw;
    top: 32.9vw;
}

.lifestyle-headline {
    width: 22vw;
    position: absolute;
    left: 10vw;
    top: 29.2vw;
    line-height: 1.6;
    font-weight: 500;
    font-size: 1.5vw;
}

.lifestyle-description {
    width: 22.6vw;
    position: absolute;
    left: 10vw;
    top: 34vw;
    /*    font-size: 0.86vw;*/
    font-size: 0.9vw;
    font-weight: 500;
    line-height: 1.9;
}

.lifestyle-image-01 {
    width: 62.2vw;
    position: absolute;
    left: -15vw;
    top: 2vw;
}

.lifestyle-image-02 {
    width: 22vw;
    position: absolute;
    right: -0.6vw;
    top: 22.5vw;
}

.lifestyle-image-03 {
    width: 22vw;
    position: absolute;
    right: 9.5vw;
    top: 34vw;
}

.lifestyle-item:nth-child(3),
.lifestyle-item:nth-child(5) {
    position: relative;
    height: 56.5vw;
}

.lifestyle-item:nth-child(3) .lifestyle-headline,
.lifestyle-item:nth-child(5) .lifestyle-headline {
    left: 32vw;
    width: 25.5vw;
    top: 30.7vw;
}

.lifestyle-item:nth-child(5) .lifestyle-headline {
    top: 30.2vw;
}

.lifestyle-item:nth-child(6) .lifestyle-headline {
    top: 28.7vw;
}

.lifestyle-item:nth-child(3) .lifestyle-description,
.lifestyle-item:nth-child(5) .lifestyle-description {
    left: 32vw;
    width: 22.5vw;
    top: 35.5vw;
}

.lifestyle-item:nth-child(3) .lifestyle-description {
    line-height: 2;
}

.lifestyle-item:nth-child(4) .lifestyle-description {
    top: 33.2vw;
    line-height: 1.8;
}

.lifestyle-item:nth-child(5) .lifestyle-description {
    top: 35.2vw;
    line-height: 1.7;
}

.lifestyle-item:nth-child(6) .lifestyle-description {
    top: 33.7vw;
    line-height: 1.7;
}

.lifestyle-item:nth-child(3) .lifestyle-image-01,
.lifestyle-item:nth-child(5) .lifestyle-image-01 {
    width: 62.5vw;
    left: 23vw;
}

.lifestyle-item:nth-child(3) .lifestyle-image-02,
.lifestyle-item:nth-child(5) .lifestyle-image-02 {
    left: -1.5vw;
}

.lifestyle-item:nth-child(3) .lifestyle-image-03,
.lifestyle-item:nth-child(5) .lifestyle-image-03 {
    left: 8.5vw;
}

.lifestyle-description-list {
    display: block;
    padding-left: 0.5vw;
    line-height: 2;
}

.lifestyle-item:nth-child(1) .lifestyle-description-list {}

.lifestyle-item:nth-child(2) .lifestyle-description-list {}

.lifestyle-item:nth-child(3) .lifestyle-description-list {
    padding-top: .6vw;
    line-height: 2.1;
}

.lifestyle-item:nth-child(4) .lifestyle-description-list {
    padding-top: 0.7vw;
    line-height: 1.7;
    width: 24vw;
}

.lifestyle-item:nth-child(5) .lifestyle-description-list {
    padding-top: 1vw;
    line-height: 1.7;
}

.lifestyle-item:nth-child(6) .lifestyle-description-list {
    padding-top: 3vw;
    line-height: 1.7;
}

.needs-section {
    position: relative;
    margin-left: auto;
    margin-right: auto;
    width: 73vw;
    margin-top: 0.2vw;
}

.needs-section:after {
    content: "";
    width: 80vw;
    position: absolute;
    bottom: 0;
    left: -3vw;
    border-bottom: solid 1px #dddddd;
}

.needs-title {
    font-size: 2vw;
    font-weight: 700;
    line-height: 1.4;
    margin-top: 2vw;
}

.cases {}

.needs-container {}

.case-item {
    position: relative;
    height: 71.2vw;
}

.case-item:nth-child(2) {
    height: 66.5vw;
}

.case-header {
    width: 20.6vw;
    border: 1px solid #000;
    left: 0;
    position: absolute;
    /*    top: 4.5vw;*/
    top: 6vw;
    height: 23vw;
}

.case-header:before {
    content: "";
    border-top: solid 1px #000;
    width: 16.5vw;
    height: 1px;
    position: absolute;
    left: 2vw;
    top: 11.5vw;
}

.case-headline {
    text-align: center;
    font-weight: 700;
    font-size: 1.6vw;
    padding-top: 2vw;
    line-height: 1.8;
}

.case-icon {
    position: absolute;
    width: 6.5vw;
    left: 3.5vw;
    top: 13.5vw;
    border-radius: 4vw;
}

.case-customer {
    position: absolute;
    top: 16vw;
    left: 11.5vw;
}

.case-image-01 {
    width: 48vw;
    position: absolute;
    right: 1vw;
    top: 6vw;
}

.case-description {
    position: absolute;
    top: 43.5vw;
    left: 50vw;
    line-height: 1.65;
    width: 22vw;
    top: unset !important;
    bottom: 9vw;
    border: 1px solid #000;
    padding: 1vw;
    left: unset;
    right: 3vw;
    height: unset;
    margin-bottom: 0;
    font-size: 0.9vw;
}

.case-description:before,
.case-description:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    background-color: transparent;
    position: absolute;
}

.case-description:before {
    border-left: 1vw solid transparent;
    border-right: 1vw solid white;
    border-bottom: 1vw solid transparent;
    border-top: .7vw solid white;
    left: calc(-2vw + 1px);
    top: 2.5vw;
    z-index: 3;
}

.case-description:after {
    border-left: 1vw solid transparent;
    border-right: 1vw solid #000;
    border-bottom: 1vw solid transparent;
    border-top: .7vw solid #000;
    left: calc(-2vw + 0.5px);
    top: calc(2.5vw + 0.5px);
    z-index: 2;
}


.case-item:nth-child(2) .case-description {
    top: 42.9vw;
}

.case-item:nth-child(3) .case-description {
    top: 42.9vw;
    line-height: 1.67;
}

.case-image-02 {
    width: 22vw;
    position: absolute;
    top: 34.5vw;
    top: 33vw !important;
    left: 0;
}

.case-item:nth-child(3) .case-image-02 {
    top: 36.5vw;
}

.case-image-03 {
    width: 25.5vw;
    position: absolute;
    left: 18vw;
    top: 44.5vw;
    top: unset !important;
    bottom: 9vw;
}

.case-item:nth-child(1) .case-image-03 {
    top: 44.9vw;
}

.case-item:nth-child(3) .case-image-03 {
    top: 46.5vw;
}

.fadein {
    opacity: 0;
    transform: translateY(20px);
    animation: fadein 1s ease-out forwards;
}

.fadein_up {
    opacity: 0;
    transform: translateY(30px);
    animation: fadeup 1s ease-out forwards;
}

.fadein_right {
    opacity: 0;
    transform: translateX(-30px);
    animation: faderight 1s ease-out forwards;
}

.fadein_left {
    opacity: 0;
    transform: translateX(30px);
    animation: fadeleft 1s ease-out forwards;
}

.fadein2 {
    opacity: 0;
    animation: fadein2 1.2s ease-out forwards;
}

@keyframes fadein {
    to {
        opacity: 1;
        transform: none;
    }
}

@keyframes fadeup {
    to {
        opacity: 1;
        transform: none;
    }
}

@keyframes faderight {
    to {
        opacity: 1;
        transform: none;
    }
}

@keyframes fadeleft {
    to {
        opacity: 1;
        transform: none;
    }
}

@keyframes fadein2 {
    to {
        opacity: 1;
    }
}

.anime-fadein,
.anime-fadein2,
.anime-fadein_up,
.anime-fadein_right,
.anime-fadein_left {
    visibility: hidden;
}

.fadein,
.fadein2,
.fadein_up,
.fadein_right,
.fadein_left {
    visibility: visible;
}


/******************************************/
.txt_type_01 {
    border-bottom: 3px dotted #0d5899;
    width: 73vw;
    margin-left: auto !important;
    margin-right: auto !important;
    display: block;
}

.garage_farmer_faq h2 {
    font-size: 2vw;
}

.garage_farmer_flow p {
    background-color: #97bad8;
    font-size: 1vw;
    width: 36vw;
}

.garage_farmer_flow .garage_farmer_flow_boxs {
    background-color: #d2e4f3;
    width: 100vw;
    padding-left: 13.5vw;
    padding-right: 13.5vw;
    padding-top: 2vw;
    padding-bottom: 2vw;
}

.garage_farmer_flow li:before {
    background-color: #72a2cb;
    font-size: 1vw;
    width: 2.4vw;
    height: 2.4vw;
    line-height: 2.4vw;
    margin-left: -1.2vw;
}

.garage_farmer_faq dl {
    margin-bottom: 1vw;
}

.garage_farmer_flow dl dd {
    width: 8vw;
    height: 8vw;
}

.garage_farmer_flow dl dd img {
    width: 4vw;
    margin-top: 2vw;
}

.garage_farmer_flow dl dt {
    font-size: 0.9vw;
}

.garage_farmer_faq dt h4:before,
.garage_farmer_faq dd p:before {
    width: 2.4vw;
    height: 2.4vw;
    line-height: 2.4vw;
    font-size: 1vw;
    left: -4vw;
}

.garage_farmer_faq dt h4,
.garage_farmer_faq dd p {
    font-size: 1vw;
    font-size: 0.9vw;
}

.garage_farmer_faq dd p {
    padding-top: 0.3vw;
}

.garage_farmer_faq dd ul li {
    margin-bottom: 0.3vw;
    font-size: 0.9vw;
}

.garage_farmer_faq dd ul li span {
    font-size: 1vw;
    margin-bottom: 0.3vw;
}

.garage_farmer_faq div {
    background-color: #d2e4f3;
    width: 100vw;
    padding-left: 13.5vw;
    padding-right: 13.5vw;
}

.garage_farmer_faq div div {
    width: 73vw;
    padding: 2vw;
}

.garage_farmer_faq dt {}

.garage_farmer_faq dt h4:before {
    background-color: #72a2cb;
}


.garage_farmer_faq dd ul li:before {
    background-color: #4380b5;
}

.garage_farmer_flow h2 {
    font-size: 2vw;
}