/*! HTML5 Boilerplate v9.0.1 | MIT License | https://html5boilerplate.com/ */

/* main.css 3.0.0 | MIT License | https://github.com/h5bp/main.css#readme */
/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Abril+Fatface&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

html {
    color: #222;
    font-size: 1em;
    line-height: 1.4;
    --hero-reveal-delay: 120ms;
    --sub-head-reveal-delay: 120ms;
    --reveal-delay: 0ms;
}

/*
 * Remove text-shadow in selection highlight:
 * https://twitter.com/miketaylr/status/12228805301
 *
 * Customize the background color to match your design.
 */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}


a {
    text-decoration: none;
}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers:
 * https://github.com/h5bp/html5-boilerplate/issues/440
 */

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}

/* ==========================================================================
   Author's custom styles
   ========================================================================== */

/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Hide visually and from screen readers
 */

.hidden,
[hidden] {
    display: none !important;
}

/*
 * Hide only visually, but have it available for screen readers:
 * https://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 *
 * 1. For long content, line feeds are not interpreted as spaces and small width
 *    causes content to wrap 1 word per line:
 *    https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe
 */

.visually-hidden {
    border: 0;
    clip: rect(0, 0, 0, 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 1px;
    /* 1 */
}

/*
 * Extends the .visually-hidden class to allow the element
 * to be focusable when navigated to via the keyboard:
 * https://www.drupal.org/node/897638
 */

.visually-hidden.focusable:active,
.visually-hidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    white-space: inherit;
    width: auto;
}

/*
 * Hide visually and from screen readers, but maintain layout
 */

.invisible {
    visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * The use of `table` rather than `block` is only necessary if using
 * `::before` to contain the top-margins of child elements.
 */

.clearfix::before,
.clearfix::after {
    content: "";
    display: table;
}

.clearfix::after {
    clear: both;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {
    /* Style adjustments for viewports that meet the condition */
}

@media print,
(-webkit-min-device-pixel-ratio: 1.25),
(min-resolution: 1.25dppx),
(min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   https://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print {
    *,
    *::before,
    *::after {
        background: #fff !important;
        color: #000 !important;
        /* Black prints faster */
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]::after {
        content: " (" attr(href) ")";
    }

    abbr[title]::after {
        content: " (" attr(title) ")";
    }

    /*
     * Don't show links that are fragment identifiers,
     * or use the `javascript:` pseudo protocol
     */
    a[href^="#"]::after,
    a[href^="javascript:"]::after {
        content: "";
    }

    pre {
        white-space: pre-wrap !important;
    }

    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}

html, body {
    margin:0;
    background: #fafafa;
}

body * {
    font-family: 'Montserrat', Sans-serif;
    letter-spacing: -0.03em;
}
body.popup-open {
    overflow: hidden;
}

.contents-body {
    height:auto;
    .fix-box {
        position: sticky;
        bottom:0;
        background: #101725;
        z-index: 99;
        .container {
            height:100px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            p {
                margin:0;
                color:#fff;
            }
            a {
                cursor: pointer;
                font-size:14px;
                font-weight:500;
                color:rgba(255,255,255,0.6);
                padding:16px 20px;
                border:1px rgba(255,255,255,0.2) solid;
                transition-duration: .3s;
                &:hover {
                    border-color:#2d93ff;
                    color:#2d93ff;
                    transition-duration: .3s;
                }
            }
        }
    }
}

.key-section {
    background: #fafafa;
    .icon-list {
        display: flex;
        align-items: center;
        list-style-type: none;
        padding:0;
        margin:0;
        li {
            padding:0 30px;
            flex:1;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            .icon {
                width:60px;
                height:60px;
                margin-bottom:20px;
                img {
                    width:100%;
                    height:100%;
                    object-fit: contain;
                    opacity: 0.2;
                }
            }
            p {
                text-align: center;
                margin:0;
                font-weight:600;
                font-size:16px;
                word-break: keep-all;
            }
        }
        li+li {
            border-left:1px #e2e4e7 solid;
        }
    }
}

.visual-area {
    height:100vh;
    background:#000;
    padding:0;
    overflow-x: hidden;
    --visual-parallax-x: 0px;
    --visual-parallax-y: 0px;
    .txt-box {
        z-index: 2;
        position: absolute;
        top:50%;
        box-sizing: border-box;
        transform: translate(-50%,-50%);
        width:1440px;
        left:50%;
        display: flex;
        flex-direction: column;
        p { font-size:18px; font-weight:300; line-height:1.6; color:#fff; letter-spacing: -0.01em; margin:0 0 15px; }
        h1 { font-family: 'Montserrat', sans-serif; font-weight:700; color:#2d93ff; opacity: 0.8; letter-spacing: 0; font-size:70px; line-height:1; margin:20px 0 40px;  }
        span { color:#fff; opacity: 0.5; font-size:16px; line-height:1.8; letter-spacing: -0.01em; }
    }
    .bg-img {
        position: absolute;
        z-index: 1;
        width: 100%;
        height: 100%;
        overflow: hidden;
        .cover {
            position: absolute;
            top:0;
            left:0;
            right:0;
            bottom:0;
            background: rgba(14,17,28,0.6);
        }
        img {
            width:100%;
            height:100%;
            object-fit: cover;
            transform: scale(1.2) translate3d(var(--visual-parallax-x), var(--visual-parallax-y), 0);
            transition: transform 0.18s ease-out;
            will-change: transform;
        }
    }
    .wrapper {
        max-width:1440px;
        margin:0 auto;
        z-index:2;
        position: relative;
        height:100%;
        display: flex;
        align-items: center;
        gap:120px;
    }
}

.container {
    max-width:1440px;
    width:100%;
    margin:0 auto;
    box-sizing: border-box;
}

header {
    position: fixed;
    height:80px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    top:0;
    left:0;
    right:0;
    z-index: 3;
    transition-duration: .3s;
    .logo-wrap {
        height:28px;
        display: flex;
        align-items: center;
        .logo-img {
            display: flex;
            align-items: center;
            position: relative;
            height:28px;
            line-height:0;
            .color {
                position: absolute;
                z-index: 2;
                opacity: 0;
                height:100%;
                top:1px;
            }
            .white {
                height:100%;
                line-height:0;
            }
        }
        span {
            line-height:1;
            color:#fff;
            font-size:16px;
            font-weight:500;
            padding-left:12px;
        }
    }
    .container {
        display: flex;
        justify-content: space-between;
        max-width:100%;
        padding:0 80px;
        box-sizing: border-box;
        align-items: center;
    }
    .gnb {
        margin:0;
        padding:0;
        display: flex;
        align-items: center;
        list-style-type: none;
        flex:1;
        justify-content: flex-end;
        li {
            display: flex;
            flex-direction: column;
            align-items: center;
            position: relative;
            &:hover {
                .sub-item {
                    opacity: 1;
                    transform: translateY(0);
                }
            }
        }
        .main-item {
            font-family: 'Montserrat';
            display: flex;
            height:50px;
            align-items: center;
            justify-content: center;
            width:160px;
            font-size:16px;
            color:#ddd;
            font-weight:600;
            text-transform: uppercase;
            transition-duration: .3s;
            cursor: pointer;
            &:hover,
            &:focus {
                color:#fff;
                transition-duration: .3s;
            }
        }
        .sub-item {
            position: absolute;
            display: flex;
            flex-direction: column;
            gap:15px;
            opacity:0;
            top:60px;
            transition-duration: .3s;
            transform: translateY(-20px);
            background: #fff;
            border-radius: 5px;
            padding:15px 0;
            width:100%;
            box-sizing: border-box;
            align-items: center;
            a {
                font-size:14px;
                text-align: center;
                font-weight:400;
                height:28px;
                line-height:28px;
                color:#aaa;
                transition-duration: .3s;
                cursor: pointer;
                display: block;
                &:hover {
                    color:#111;
                    transition-duration: .3s;
                }
            }
        }
    }
    &.fixed {
        height:70px;
        background: #fafafa;
        transition-duration: .3s;
        border-bottom:1px rgba(0,0,0,0.1) solid;
        .mobile-menu-button {
            span {
                background: #111;
                transition-duration: .3s;
            }
        }
        .logo-wrap {
            .logo-img {
                .color {
                    opacity: 1;
                }
                .white {
                    opacity: 0;
                }
            }
            span {
                color:#555;
                font-weight:500;
                transition-duration: .3s;
            }

        }
        .gnb li .main-item {
            color:#111;
            &:hover,
            &:focus {
                color:#203763;
                transition-duration: .3s;
            }
        }
    }
}
header.sub {
    transition-duration: .3s;
    .logo-wrap {
        .color {
            opacity: 1;
        }
        .white {
            opacity: 0;
        }
        span {
            color:#333;
        }
    }
    .gnb li .main-item {
        color:#111;
        &:hover,
        &:focus {
            color:#203763;
            transition-duration: .3s;
        }
    }
    .tools .lang {
        a {
            color:rgba(0,0,0,0.5);
            &:hover,
            &.active {
                color:rgba(0,0,0,1);
                transition-duration: .3s;
            }}
        a+a {
            border-left:1px rgba(0,0,0,0.2) solid;
        }
    }
}
.sections-wrapper {
    position: relative;
}

section {
    padding:80px 0;
}
.center-section {
    display: flex;
    align-items: center;
}
.section-title {
    display: flex;
    align-items: center;
    h2 { color:#fff; text-transform: uppercase; font-size:60px; margin:0; }
    p { color:#333; margin:0 30px; }
}

.slider-area {
    background:#f0f0f0;
    padding:0;
    height:100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    .slider-wrapper {
        .slider-title {
            color:#fff;
            font-size:36px;
            font-weight:400;
            margin-bottom:60px;
            b {
                font-weight:700;
                display: block;
            }
        }
    }
    .swiper-slide {
        border-top: 1px #111 solid;
        padding-top:30px;
        h4 {
            text-transform: uppercase;
            font-weight:800;
            color:#111;
            margin:0 0 10px;
        }
        p {
            color:#333;
            font-size:16px;
        }
    }
    .swiper {
        width: 100%;
        box-sizing: border-box;
        padding-left:240px;
        margin-top:40px;
        .swiper-button-next {
            color:#fff;
            right:120px;
        }
        .swiper-button-prev {
            color:#fff;
            left:120px;
        }
        .swiper-pagination-bullet-active {
            background: #fff;
        }
    }
    .swiper-slide img {
        width:100%;
        display:block;
        cursor: zoom-in;
    }
}

.image-popup-dialog {
    position: relative;
}

.image-popup-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    border: 0;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.45);
    cursor: pointer;
    z-index: 2;
}

.image-popup-prev {
    left: 24px;
}

.image-popup-next {
    right: 24px;
}

.image-popup-nav::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 14px;
    height: 14px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}

.image-popup-prev::before {
    transform: translate(-35%, -50%) rotate(-135deg);
}

.image-popup-next::before {
    transform: translate(-65%, -50%) rotate(45deg);
}

.image-popup-nav.is-disabled {
    opacity: 0.35;
    pointer-events: none;
}

@media (max-width: 767px) {
    .image-popup-nav {
        width: 44px;
        height: 44px;
    }

    .image-popup-prev {
        left: 12px;
    }

    .image-popup-next {
        right: 12px;
    }
}

.image-popup {
    position: fixed;
    inset: 0;
    z-index: 20;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .25s ease, visibility .25s ease;
    .image-popup-dim {
        position: absolute;
        inset: 0;
        background: rgba(0,0,0,0.88);
    }
    .image-popup-dialog {
        position: relative;
        z-index: 1;
        width: calc(100% - 80px);
        height: calc(100% - 80px);
        margin: 40px auto;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: center;
    }
    .image-popup-close {
        position: absolute;
        top: 0;
        right: 0;
        width: 52px;
        height: 52px;
        border: 0;
        border-radius: 50%;
        background: rgba(255,255,255,0.14);
        cursor: pointer;
        z-index: 2;
        &::before,
        &::after {
            content: "";
            position: absolute;
            top: 14px;
            left: 25px;
            width: 2px;
            height: 24px;
            background: #fff;
        }
        &::before {
            transform: rotate(45deg);
        }
        &::after {
            transform: rotate(-45deg);
        }
    }
    .image-popup-toolbar {
        display: flex;
        justify-content: flex-end;
        gap: 10px;
        margin-bottom: 16px;
        padding-right: 64px;
        button {
            height: 52px;
            min-width: 52px;
            padding: 0 18px;
            border: 0;
            border-radius: 26px;
            background: rgba(255,255,255,0.14);
            color: #fff;
            font-size: 18px;
            font-weight: 700;
            cursor: pointer;
        }
        .zoom-reset {
            font-size: 14px;
            font-family: 'Montserrat', sans-serif;
        }
    }
    .image-popup-view {
        flex: 1;
        overflow: auto;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 40px;
        box-sizing: border-box;
    }
    .image-popup-target {
        max-width: min(1200px, 100%);
        max-height: 100%;
        object-fit: contain;
        transform: scale(1);
        transform-origin: center center;
        transition: transform .2s ease;
        will-change: transform;
        user-select: none;
    }
    &.active {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }
}

.quick-area {
    background: #1e233b;
    background-size:cover;
    padding:100px 0;
    .title {
        h2 {
            font-size: 46px;
            color:#fff;
            font-weight:700;
            margin:0 0 10px;
        }
        p {
            color:rgba(255,255,255,0.8);
            font-size:16px;
            line-height:1.7;
        }
    }
}

.section-list-style {
    display: flex;
    list-style-type: none;
    padding:0;
    margin:40px -10px 0;
    li {
        padding:0 10px;
        width:25%;
        max-width:25%;
        min-width:25%;
        box-sizing: border-box;
    }
    .item {
        background: #fff;
        transition-duration: .3s;
        display: flex;
        justify-content: flex-end;
        flex-direction: column;
        border-radius: 15px;
        overflow: hidden;
        position: relative;
        box-shadow: 0 0 10px rgba(0,0,0,0.2);
        .thumb {
            height:240px;
            img {
                width:100%;
                height:100%;
                object-fit: cover;
            }
        }
        .contents {
            padding:20px 25px 30px;
        }
        h4 {
            margin:0 0 5px;
            font-size:18px;
            position: relative;
            z-index: 2;
            color:#111;
        }
        p {
            font-size:14px;
            margin:0;
            position: relative;
            z-index: 2;
            color:#111;
        }
        .cate {
            display: flex;
            flex-wrap: wrap;
            z-index: 2;
            position: relative;
            margin-top:15px;
            span {
                font-size:12px;
                color:#111;
                font-weight:600;
            }
            span+span {
                padding-left:5px;
                margin-left:5px;
            }
        }
        &:hover {
            transition-duration: .3s;
            transform:translateY(-5px);
            box-shadow: 0 0 20px rgba(0,0,0,0.5);
        }
    }
}

.copy-area {
    padding:40px 0;
    background: #272b3d;
    p {
        color:#fff;
        font-size:15px;
        line-height:2;
        margin:0;
    }
    p+p {
        margin-top:15px;
    }

}

footer {
    padding:40px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #101725;
    .info-line {
        display: flex;
        align-items: flex-start;
        margin-bottom:5px;
        p {
            opacity: 0.7;
            line-height:1.6;
            font-size:14px;
            margin:0;
            color:#fff;
            a { color:#fff; }
            span { font-size:16px; font-weight:600; }
        }
    }
    .footer-logo {
        padding-top:5px;
        opacity: 0.5;
        margin-right:20px;
        display: flex;
        align-items: center;
        img {
            width:26px;
        }
    }
    .container > span {
        padding-left:45px;
        font-family: Montserrat, sans-serif;
        font-size:13px;
        text-transform: uppercase;
        color:#fff;
        opacity: 0.3;
    }
}

/* sub layout common */

.rows-section {
    display: flex;
    align-items: center;
    min-height:100%;
    padding:140px 0;
}

@keyframes pageTitleReveal {
    from {
        opacity: 0;
        transform: translate3d(0, 30px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes pageTitleInnerReveal {
    from {
        opacity: 0;
        transform: translate3d(0, 18px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.page-title {
    padding-top:40px;
    opacity: 0;
    transform: translate3d(0, 30px, 0);
    animation: pageTitleReveal 0.8s cubic-bezier(0.22, 1, 0.36, 1) forwards;
    will-change: opacity, transform;
    span {
        display: block;
        color:#203763;
        font-size:16px;
        font-weight:700;
        letter-spacing: 0.4em;
        opacity: 0;
        transform: translate3d(0, 18px, 0);
        animation: pageTitleInnerReveal 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.08s forwards;
        will-change: opacity, transform;
    }
    h2 {
        margin-top:10px;
        line-height:1.2;
        font-size:38px;
        font-weight:400;
        opacity: 0;
        transform: translate3d(0, 22px, 0);
        animation: pageTitleInnerReveal 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.16s forwards;
        will-change: opacity, transform;
        b {
            font-weight:700;
        }
    }
}

@media (prefers-reduced-motion: reduce) {
    .page-title,
    .page-title span,
    .page-title h2 {
        opacity: 1;
        transform: none;
        animation: none;
    }
}
.contents-list {
    ul {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        list-style-type: none;
        padding:0;
        margin:0 -12px;
    }
    li {
        padding:12px;
        box-sizing: border-box;
        flex:1;
        max-width:25%;
        min-width:25%;
        overflow: hidden;
        .thumb {
            background: #e2e4e7;
            width:100%;
            aspect-ratio: 5 / 4;
            img {
                width:100%;
                height:100%;
                object-fit: cover;
            }
        }
        p {
            font-size:18px;
            color:#111;
            font-weight:700;
            margin:15px 0 5px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        span {
            font-family: Montserrat, sans-serif;
            font-size:14px;
            color:#999;
        }
    }
    &.photo {
        p {
            font-size:16px;
            font-weight:400;
            margin-bottom:0;
        }
    }
}
.popup-layer {
    width:100%;
    height:100%;
    top:0;
    left:0;
    right:0;
    bottom:0;
    position: fixed;
    background: rgba(0,0,0,0.5);
    display: none;
    z-index: 10;
    overflow-y:auto;
}
.popup-layer.active {
    display: block;
}

.popup-contents {
    max-width:1440px;
    width:100%;
    background: #fff;
    margin:0 auto;
    min-height:100vh;
    position: relative;

    .close {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top:30px;
        right:30px;
        width:50px;
        height:50px;
        background: rgba(0,0,0,0.5);
        border-radius: 50%;
        span {
            width:2px;
            height:24px;
            background: #fff;
            position: absolute;
            transform: rotate(45deg);
        }
        span:nth-child(2) {
            transform: rotate(-45deg);
        }
    }
}
.popup-head {
    height:360px;
    padding:30px;
    background: #333;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
    label {
        display: flex;
        align-self: flex-start;
        height:46px;
        text-transform: uppercase;
        border-radius: 25px;
        background: #203763;
        color:#fff;
        font-family: Montserrat,sans-serif;
        font-weight:700;
        font-size:14px;
        align-items: center;
        justify-content: center;
        padding:0 20px;
    }
    .title-contents {
        h3 { font-size:36px; font-weight:800; margin:15px 0; font-family: Pretendard, sans-serif; color:#fff; }
        span { color:#999; font-weight:400; font-family: Montserrat,sans-serif; }
    }
}
.popup-container {
    padding:60px 30px 30px;
    .box {
        h4 {
            font-size:32px;
            color:#111;
            font-weight:400;
            margin:0 0 10px;
            line-height:1.2;
            b {
                font-weight:700;
            }
        }
        h5 { font-size:18px; color:#111; font-weight:700; margin:0 0 10px; }
        p { font-size:18px; color:#666; line-height:1.6; text-align: justify; }
    }
    .box+.box {
        margin-top:40px;
    }
}

.contents-title {
    margin-bottom:60px;
    h3 {
        font-size:20px;
        font-weight:700;
        color:#111;
    }
    p {
        font-size:16px;
        line-height:1.6;
    }
}

.color-box {
    background: #203763;
    display: flex;
    padding:40px;
    margin-top:20px;
    margin-bottom:60px;
    .title {
        flex:1;
        h4 {
            color:#fff;
            font-size:22px;
            font-weight:700;
            line-height:1.5;
            margin:0 0 10px;
        }
        span {
            color:#fff;
            opacity: 0.8;
            font-size:14px;
            line-height:1.2;
        }
    }
    .contents {
        padding-left:80px;
        flex:4.5;
        p {
            margin-top:0;
            color:#fff;
            font-size:16px;
            text-align: justify;
            font-weight:300;
            opacity: 0.9;
            line-height:1.6;
        }
    }
}
.white-box {
    border: 1px solid #203763;
    display: flex;
    padding:40px;
    margin-top:40px;
    margin-bottom:40px;
    .title {
        flex:1;
        h4 {
            color:#203763;
            font-size:18px;
            font-weight:700;
            line-height:1.5;
            margin:0 0 10px;
        }
        span {
            color:#666;
            font-size:14px;
            line-height:1.2;
        }
    }
    .contents {
        padding-left:80px;
        flex:4.5;
        h5 {
            font-size:16px;
            color:#111;
            font-weight:700;
            margin:0 0 10px;
            line-height:1.6;
            span {
                display: block;
                font-size:14px;
                color:#666;
                margin-top:3px;
                font-weight:400;
            }
        }
        p {
            margin-top:0;
            color:#111;
            font-size:16px;
            text-align: justify;
            font-weight:300;
            opacity: 0.9;
            line-height:1.6;
        }
        p+h5 {
            margin-top:30px;
        }
    }
}
.sep-layout {
    padding-top:60px;
    .sep-block {
        display: flex;
        align-items: flex-start;
        height:auto;
        position: relative;
        .title {
            flex:1;
            margin-right:50px;
            position: sticky;
            top:120px;
            h4 {
                color:#203763;
                font-size:28px;
                font-family: Montserrat, sans-serif;
                font-weight:800;
                margin:0;
            }
            p {
                word-break: keep-all;
                color:#203763;
                font-size:16px;
                font-family: Pretendard, sans-serif;
                font-weight:700;
                margin:0;
            }
        }
        .contents {
            position: relative;
            padding-left:80px;
            flex:5;
            p {
                margin:0;
                font-size:16px;
                color:#333;
                line-height:1.6;
            }
            .columns {
                margin-top:20px;
                display: flex;
                flex-direction: column;
                .row {
                    flex:1;
                    display: flex;
                    align-items: flex-start;
                    padding:20px 0;
                    label {
                        font-weight:700;
                        color:#111;
                        min-width:220px;
                    }
                    .row-contents {
                        flex:1;
                        h5 {
                            margin:0 0 10px;
                            font-size:16px;
                        }
                        .unit {
                            margin-bottom:20px;
                        }
                        table {
                            width:100%;
                            border-top:1px #111 solid;
                            border-bottom:1px #111 solid;
                            th, td {
                                text-align: left;
                                padding:0;
                                height:54px;
                                font-size:14px;
                            }
                            th {
                                border-bottom:1px #111 solid;
                            }
                            td {
                                color:#666;
                                border-bottom:1px #e2e4e7 solid;
                            }
                            tr:last-child td {
                                border-bottom:0;
                            }
                            .lb {
                                padding-left:30px;
                                border-left:1px #e2e4e7 solid;
                            }
                        }
                    }
                }
            }
            .rows {
                margin-top:20px;
                display: flex;
                .row {
                    flex:1;
                    display: flex;
                    align-items: center;
                    label {
                        font-weight:700;
                        color:#111;
                        margin-right:15px;
                    }
                }
            }
            .incom-product-list {
                list-style-type: none;
                display: flex;
                flex-wrap: wrap;
                padding:0;
                margin-left:-20px;
                margin-right:-20px;
                .thumb {
                    border:1px #e2e4e7 solid;
                    aspect-ratio: 4 / 3;
                    overflow: hidden;
                    img {
                        width:100%;
                        height:100%;
                        object-fit: cover;
                    }
                }
                li {
                    flex:1;
                    min-width:33.3%;
                    max-width:33.3%;
                    box-sizing: border-box;
                    padding:20px;
                    b {
                        color:#111;
                        display: block;
                        margin:20px 0 5px;
                    }
                    p {
                        font-size:14px;
                    }
                }
            }
            .photo-box {
                margin:40px 0;
                .img-wrapper {
                    display: flex;
                    margin-bottom:10px;
                    gap:1px;
                    .img {
                        flex:1;
                        img {
                            width:100%;
                        }
                    }
                }
                span {
                    color:#999;
                    font-size:14px;
                }
            }
            .question {
                display: flex;
                margin-bottom:20px;
                align-items: center;
                span {
                    display: flex;
                    width:32px;
                    min-width:32px;
                    height:32px;
                    background: #203763;
                    color:#fff;
                    font-family: Montserrat, sans-serif;
                    font-weight:700;
                    font-size:14px;
                    align-items: center;
                    justify-content: center;
                    border-radius: 50%;
                    margin-right:15px;
                }
                p {
                    font-weight:600;
                    margin:0;
                }
            }
            .answer {
                display: flex;
                margin-bottom:20px;
                align-items: flex-start;
                span {
                    display: flex;
                    min-width:32px;
                    width:32px;
                    height:32px;
                    background: #333;
                    color:#fff;
                    font-family: Montserrat, sans-serif;
                    font-weight:700;
                    font-size:14px;
                    align-items: center;
                    justify-content: center;
                    border-radius: 50%;
                    margin-right:15px;
                }
                p {
                    margin:0;
                    text-align: justify;
                }
            }

        }
        &+.sep-block {
            margin-top:60px;
            border-top:1px #e2e4e7 solid;
            padding-top:60px;
        }
    }
    &.reverse {
        margin-top:60px;
        .sep-block {
            flex-direction: row-reverse;
        }
        .photo {
            border:1px #e2e4e7 solid;
        }
        .contents {
            padding-left:0;
            padding-right:80px;
            h3 {
                font-size:24px;
                margin:0 0 8px;
            }
            span {
                display: block;
                margin-bottom:30px;
                color:#888;
                font-size:16px;
            }
            p {
                font-size:16px;
                text-align: justify;
            }
            p+p {
                margin-top:15px;
            }
        }
    }
}
.count-layout {
    .count-block {
        padding:80px 0;
        border-bottom:1px #e2e4e7 solid;
        .container {
            display: flex;
            align-items: flex-start;
            height:auto;
            position: relative;
        }
        .item {
            display: flex;
            align-items: center;
            flex-direction: column;
            .icon {
                width:48px;
                height:48px;
                margin-bottom:20px;
                background: #111;
                border-radius: 50%;
                display: flex;
                align-items: center;
                justify-content: center;
                img {
                    width:100%;
                    height:100%;
                    object-fit: cover;
                }
            }
            p {
                text-align: center;
                font-family: Montserrat, sans-serif;
                color:#333;
                font-size:40px;
                font-weight:800;
                margin:0 0 5px;
                span { padding-left:10px; display: inline-block; }
            }
            label {
                text-align: center;
                font-size:18px;
                font-weight:700;
            }
            label+span {
                margin-top:10px;
            }
            span {
                display: block;
                margin:3px 0;
                text-align: center;
                font-size:16px; color:#888; font-family: Pretendard, sans-serif;
            }
            .addict ul {
                display: flex;
                flex-direction: column;
                gap:10px;
                padding:0;
                li {
                    padding:0 40px;
                    background: #203763;
                    color:#fff;
                    font-size:14px;
                    font-weight:400;
                    font-family: Pretendard, sans-serif;
                    height:36px;
                    border-radius: 18px;
                    display: flex;
                    align-items: center;
                    justify-content: center;
                }
            }
        }
        .title {
            flex:1;
            margin-right:50px;
            position: sticky;
            top:120px;
            .item {
                p {
                    color:#203763;
                }
                label {
                    color:#203763;
                }
            }
        }
        .contents {
            flex:3;
            display: flex;
            flex-direction: row;
            align-items: flex-start;
            flex-wrap: wrap;
            row-gap: 60px;
            .item {
                flex:1;
                min-width:33%;
            }
        }
        &+.sep-block {
            margin-top:60px;
            border-top:1px #e2e4e7 solid;
            padding-top:60px;
        }
        &+.fill {
            background: #203763;
            .item {
                label,p,span { color:#fff; }
            }
        }
        .sm-wrap {
            gap:40px;
        }
        .sm-item {
            display: flex;
            align-items: center;
            label {
                margin-right:20px;
                text-align: center;
                font-size:16px;
                font-weight:700;
            }
            p {
                text-align: center;
                font-family: Montserrat, sans-serif;
                color:#333;
                font-size:20px;
                font-weight:800;
                margin:0 0 5px;
                span { padding-left:10px; font-weight:400; font-size:16px; display: inline-block; }
            }
        }
        &:first-child {
            padding-top:40px;
        }
        &:last-child {
            border:0;
            padding-bottom:0;
        }
    }
    &.reverse {
        margin-top:60px;
        .sep-block {
            flex-direction: row-reverse;
        }
        .title {}
        .contents {
            padding-left:0;
            padding-right:80px;
            h3 {
                font-size:24px;
                margin:0 0 8px;
            }
            span {
                display: block;
                margin-bottom:30px;
                color:#888;
                font-size:16px;
            }
            p {
                font-size:16px;
                text-align: justify;
            }
            p+p {
                margin-top:15px;
            }
        }
    }
}

.mobile-menu-btn {
    position: absolute;
    right:30px;
    top:15px;
    width:42px;
    height:42px;
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap:4px;
    span {
        width:18px;
        height:2px;
        background: #111;
        display: block;
    }
}
.mobile-menu-close-btn-wrapper {
    margin:15px 30px;
    display: flex;
    justify-content: flex-end;
}
.mobile-menu-close-btn {
    width:42px;
    height:42px;
    display: flex;
    align-self: flex-end;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    background: #111;
    border-radius: 50%;
    span {
        width:18px;
        height:1px;
        background: #fff;
        display: block;
        position: absolute;
        transform: rotate(45deg);
    }
    span:last-child {
        transform: rotate(-45deg);
    }
}
.map-area {
    background: #f0f0f0;
    height:480px;
}
.contact-info {
    margin-top:60px;
    padding-bottom:120px;
    display: flex;
    gap:60px;
    .unit {
        flex:1;
        .icon {
            margin-bottom:20px;
            width:30px;
            height:30px;
            img {
                width:100%;
                height:100%;
            }
        }
        label {
            font-size:16px;
            font-family: 'Montserrat','Pretendard',sans-serif;
            font-weight:700;
            color:#111;
        }
        p {
            margin:5px 0;
            font-weight:400;
            font-family: 'Montserrat','Pretendard',sans-serif;
            font-size:20px;
            b {
                font-weight:700;
            }
        }
        span {
            font-size:14px;
            font-family: 'Montserrat','Pretendard',sans-serif;
            color:#999;
        }
    }
}
.sub-head {
    height:680px;
    box-sizing: border-box;
    padding:60px 0;
    position: relative;
    .cover {
        position: absolute;
        top:0;
        left:0;
        right:0;
        bottom:0;
    }
    .container {
        position: relative;
        z-index:2;
        display: flex;
        height:100%;
        flex-direction: column;
        justify-content: flex-end;
        h2 {
            font-size:40px;
            margin:0 0 10px;
            color:#fff;
        }
        p {
            color:#fff;
            font-size:16px;
            line-height:1.8;
            margin:0;
        }
        .cate {
            margin:15px 0 0;
            display: flex;
            flex-wrap: wrap;
            row-gap: 10px;
            span {
                font-size:14px;
                color:#fff;
                opacity: 0.7;
                position: relative;
                padding-right:30px;
                &:before {
                    content:'·';
                    position: absolute;
                    right:14px;
                }
            }
            span:last-child {
                padding-right:0;
            }
        }
    }
}
.sub-head.contacts {
    background: #000 url('../img/bg-top-contacts.jpg') right no-repeat;
    background-size:cover;
}
.sub-head.about {
    background: #000 url('../img/bg-top-about.jpg') right no-repeat;
    background-size:cover;
}
.sub-head.products {
    background: #000 url('../img/bg-top-products.jpg') no-repeat;
    background-size:cover;
}
.sub-head.details01 {
    background: #000 url('../img/bg-top-details01.jpg') no-repeat;
    background-size:cover;
}
.sub-head.details02 {
    background: #000 url('../img/bg-top-details02.jpg') no-repeat;
    background-size:cover;
}
.sub-head.details03 {
    background: #000 url('../img/bg-top-details03.jpg') no-repeat;
    background-size:cover;
}
.sub-head.details04 {
    background: #000 url('../img/bg-top-details04.jpg') no-repeat;
    background-size:cover;
}

.fixed-list-section {
    .container {
        height:100%;
        display: flex;
        align-items: flex-start;
    }
    .title {
        position: sticky;
        top:80px;
        flex:1;
        h4 {
            font-size:40px;
            margin:0;
        }
    }
    .contents {
        flex:1;
        ul {
            list-style-type: none;
            padding:0;
            margin:0;
            display: flex;
            flex-direction: column;
            gap:30px;
            li {
                font-size:18px;
                position: relative;
                padding-left:40px;
                &:before {
                    left:0;
                    width:12px;
                    height:12px;
                    border-radius: 50%;
                    border:4px #2d93ff solid;
                    display: block;
                    content:'';
                    position: absolute;
                    top:3px;
                }
            }
        }
        form {
            display: flex;
            flex-direction: column;
            gap:40px;
            .rows {
                display: flex;
                gap:40px;
            }
            .input-item {
                display: flex;
                flex-direction: column;
                flex:1;
                label {
                    font-weight:600;
                    font-size:14px;
                    margin-bottom:10px;
                }
                label+p {
                    margin-top:-5px;
                }
                p {
                    margin-bottom:10px;
                }
                input { border:1px #e2e4e7 solid; height:46px; line-height:46px; padding:0 10px; }
                select {
                    border:1px #e2e4e7 solid; height:46px; line-height:46px; padding:0 10px;
                    -webkit-appearance: none;
                }
                textarea { border:1px #e2e4e7 solid; resize:none; line-height:1.6; padding:10px; }
            }
            p {
                margin:0;
                flex:1;
                font-size:14px;
            }
            button {
                width:auto;
                font-size:16px;
                font-weight:600;
                color:#111;
                background: none;
                border:0;
                text-align: right;
                cursor: pointer;
            }
        }
    }
}
.fixed-list-section.history {
    .contents {
        ul {
            li {
                padding-left:50px;
                display: flex;
                p {
                    margin:0;
                }
                p+p {
                    margin-top:20px;
                }
                label {
                    font-weight:600;
                    color:#111;
                    width:100px;
                }
                .unit {
                    margin-left:20px;
                }
                &:before {
                    left:0;
                    width:24px;
                    height:24px;
                    border-radius: 50%;
                    border:1px #2d93ff solid;
                    display: block;
                    content:'';
                    position: absolute;
                    top:-2px;
                }
                &:after {
                    left:9px;
                    width:8px;
                    height:8px;
                    border-radius: 50%;
                    background: #203763;
                    display: block;
                    content:'';
                    position: absolute;
                    top:7px;
                }
            }
        }
    }
}
.map-area {
    padding:0;
    overflow: hidden;
    line-height:1;
    height:auto;
}

.cert {
    .container {
        display: flex;
        flex-direction: row;
        align-items: center;
        .contents {
            flex:1;
            padding-bottom:40px;
            .icon {
                width:40px;
            }
            h4 {
                font-size:28px;
                margin:20px 0;
            }
            p {
                font-size:18px;
                line-height:1.6;
            }
        }
        .thumb {
            flex:0.8; border:1px #e2e4e7 solid; box-shadow: 0 5px 10px rgba(0,0,0,0.05);
            img { width:100%; }
        }

        .thumb-area {
        }

    }
}
.network {
    padding:0 0 40px;
    background:#f0f0f0 url('../img/bg-global-focus.jpg') no-repeat top center;
    background-size:cover;
    min-height:800px;
    display: flex;
    align-items: stretch;
    position: relative;
    .container {
        display: flex;
        flex-direction: row-reverse;
        align-items: flex-end;
        .contents {
            flex:1;
            max-width:50%;
            padding-bottom:40px;
            h4 {
                font-size:28px;
                margin:20px 0;
            }
            p {
                font-size:18px;
                line-height:1.6;
            }
        }
    }
}
.product-list {
    ul {
        display: flex; flex-direction: column; list-style-type: none; padding:0; margin:0;
        li {
            padding:40px 0;
            .item {
                cursor: pointer;
                display: flex;
                align-items: center;
                gap:80px;
            }
            .thumb {
                flex:1;
                border:1px #e2e4e7 solid;
                background: #f0f0f0;
                height:360px;
                img {
                    width:100%;
                    height:100%;
                    object-fit: cover;
                    object-position: top;
                }
            }
            .contents {
                flex:1;
            }
            h4 {
                font-size:32px;
                font-weight:700;
                color:#111;
                margin:0 0 20px;
            }
            p {
                font-size:18px;
                color:#666;
                line-height:1.6;
                margin:0;
            }
            .cate {
                margin:10px 0;
                display: flex;
                span {
                    font-size:14px;
                    color:#111;
                    position: relative;
                    padding-right:30px;
                    &:before {
                        content:'·';
                        position: absolute;
                        right:14px;
                    }
                }
                span:last-child {
                    padding-right:0;

                }
            }
        }
        li:nth-child(2n) {
            .item {
                flex-direction: row-reverse;
                h4, p {text-align: right}
                .cate { justify-content: flex-end }
            }
        }
    }
}

.product-details-list {
    display: flex;
    flex-direction: column;
    list-style-type: none;
    padding:0;
    margin:0;
    li {
        display: flex;
        padding:40px 0;
        border-bottom:1px #e2e4e7 solid;
        .thumb {
            flex:1;
            background: #f0f0f0;
            height:270px;
            img {
                height:100%;
            }
        }
        .contents {
            flex:2.5;
            padding:15px 40px;
            display: flex;
            flex-direction: column;
        }
        h4 {
            font-size:28px;
            font-weight:700;
            color:#111;
            margin:0 0 10px;
        }
        .cate {
            margin:10px 0;
            display: flex;
            flex:1;
            align-items: flex-start;
            flex-wrap: wrap;
            span {
                font-size:14px;
                color:#111;
                position: relative;
                padding-right:30px;
                font-weight:600;
                &:before {
                    content:'·';
                    position: absolute;
                    right:14px;
                }
            }
            span:last-child {
                padding-right:0px;
                &:before {
                    display: none;
                }
            }
        }
        .adv-line {
            display: flex;
            margin:10px 0;
            label {
                width:200px;
                color:#111;
                font-weight:500;
            }
            p { margin:0; }
        }
        &:last-child { border:0; }
    }
}
.capa {
    background: #f5f5f5;
}
.bottom-line {
    background: #f5f5f5;
    padding:40px 0;
    p {
        font-size:14px;
        text-align: center;
        color:#666;
    }
}

@media screen and ( max-width:1440px ) {
    header {
        .container {
            padding:0 40px;
        }
        .gnb {
            .main-item {
                width:140px;
                font-size:16px;
            }
        }
    }
    .container {
        padding:0 40px;
        box-sizing: border-box;
    }
    .visual-area {
        .txt-box {
            width:100%;
            left:0;
            right:0;
            padding:0 40px;
            transform: translateY(-50%);
            h1 {
                font-size:56px;
                line-height:1.2;
            }
            p { font-size:16px; }
            span { font-size:14px; }
        }
    }
}
@media screen and ( max-width:1024px ){
    .key-section {
        .icon-list {
            li {
                p {
                    font-size:16px;
                }
            }
        }
    }
    .quick-area {
        .title {
            h2 {
                font-size:36px;
            }
            p {
                font-size:14px;
            }
        }
    }
    .section-list-style {
        flex-wrap: wrap;
        row-gap: 20px;
        li { max-width:50%; min-width:50%; }
    }
    .cert {
        .container {
            .thumb {
                flex:1;
                min-width:380px;
            }
            .contents {
                h4 { font-size:24px; }
                p { font-size:16px; }
            }
        }
    }
    .network {
        height:90vh;
        min-height:90vh;
        .container {
            .contents {
                h4 { font-size:24px; }
                p { font-size:16px; }
            }
        }
    }
    .fixed-list-section.history {
        .contents {
            ul {
                li {
                    label { font-size:16px; width:80px; }
                    p {
                        font-size:16px;
                    }
                }
            }
        }
    }
    .fixed-list-section {
        .title {
            flex:1;
            h4 { font-size:28px; }
        }
        .contents {
            flex:2;
            form {
                margin-left:40px;
                display: flex;
                flex-direction: column;
                gap:20px;
                .rows {
                    display: flex;
                    flex-direction: column;
                    gap:20px;
                }
                .input-item {
                    display: flex;
                    flex-direction: column;
                    flex:1;
                    label {
                        font-weight:600;
                        font-size:14px;
                        margin-bottom:10px;
                    }
                    input { border:1px #e2e4e7 solid; height:46px; line-height:46px; padding:0 10px; }
                    select {
                        border:1px #e2e4e7 solid; height:46px; line-height:46px; padding:0 10px;
                        -webkit-appearance: none;
                    }
                    textarea { border:1px #e2e4e7 solid; resize:none; line-height:1.6; padding:10px; }
                }
                button {
                    width:auto;
                    font-size:16px;
                    font-weight:600;
                    color:#111;
                    background: none;
                    border:0;
                    text-align: right;
                    cursor: pointer;
                }
            }
        }
    }
}
@media screen and ( max-width:768px ) {
    header {
        .gnb-wrapper {
            display: none;
        }
    }
    footer {
        .footer-logo {

            span {
                font-size:13px;
                padding-bottom:1px;
            }
        }
        padding:30px;
        span {text-align: center;}
    }
    .container {
        padding:0 40px;
        box-sizing: border-box;
    }
    .visual-area {
        .txt-box {
            h1 {
                font-size:40px;
            }
            p { font-size:14px; }
            span { font-size:14px; }
        }
        #bg-video {
            pointer-events: none;
        }
    }
    .product-details-list {
        li {
            .thumb {

            }
            .contents {
                flex:1;
                padding:0 0 0 40px;
            }
            .adv-line {
                flex-direction: column;
                margin:5px 0;
            }
        }
    }
    .product-list {
        padding:40px 0;
        ul {
            li {
                .item {
                    gap:40px;
                }
                h4 { font-size:24px; }
                p { font-size:14px; }
                .cate {
                    span {font-size:13px; }
                }
            }
        }
    }
    .key-section {
        padding:40px 0;
        .icon-list {
            flex-direction: column;
            align-items: stretch;
            gap:20px;
            li {
                display: flex;
                flex-direction: row;
                .icon {
                    border:1px #e2e4e7 solid;
                    border-radius: 50%;
                    display: flex;
                    background: #fff;
                    align-items: center;
                    justify-content: center;
                    width:80px;
                    height:80px;
                    margin-right:40px;
                    margin-bottom:0;
                    img {
                        width:60%;
                        height:60%;
                    }
                }
                p {
                    font-size:14px;
                }
            }
            li+li {
                border-width:0;
            }
        }
    }
    .cert {
        .container {
            flex-direction: column;
            align-items: center;
            .thumb {
                flex:1;
                min-width:300px;
            }
            .contents {
                margin-top:40px;
                display: flex;
                flex-direction: column;
                align-items: center;
                h4 { font-size:24px; text-align: center; margin-bottom:0; }
                p { font-size:16px; text-align: center; }
            }
        }
    }
    .network {
        height:90vh;
        min-height:90vh;
        .container {
            .contents {
                h4 { font-size:24px; }
                p { font-size:16px; }
            }
        }
    }
    .fixed-list-section.history {
        .contents {
            ul {
                li {
                    flex-direction: column;
                    label { font-size:16px; width:80px; }
                    .unit { margin:10px 0 0; }
                    p {
                        font-size:16px;
                    }
                }
            }
        }
    }
    .fixed-list-section {
        .title {
            flex:1;
            h4 { font-size:28px; }
        }
        .contents {
            flex:2;
        }

    }
}
@media screen and ( max-width:500px ) {
    .cert {
        .container {
            .contents {
                margin-top:30px;
                h4 { font-size:20px; text-align: center; margin-bottom:0; }
                p { font-size:14px; text-align: center; }
            }
        }
    }
    .network {
        height:68vh;
        min-height:0;
        .container {
            .contents {
                max-width:100%;
                h4 { font-size:20px; }
                p { font-size:14px; }
            }
        }
    }
    .visual-area {
        .txt-box {
            h1 {
                font-size:32px;
            }
            p { font-size:14px; }
            span { font-size:14px; }
        }
    }
    .key-section {
        padding:40px 0;
        .icon-list {
            flex-direction: column;
            align-items: center;
            gap:40px;
            li {
                display: flex;
                flex-direction: column;
                .icon {
                    border:1px #e2e4e7 solid;
                    border-radius: 50%;
                    display: flex;
                    background: #fff;
                    align-items: center;
                    justify-content: center;
                    width:60px;
                    height:60px;
                    margin-right:0;
                    margin-bottom:20px;
                    img {
                        width:60%;
                        height:60%;
                    }
                }
                p {
                    font-size:14px;
                }
            }
        }
    }
    header {
        height:60px;
        & .logo-wrap {
            margin-top:-10px;
            .logo-img {
                height:22px;
            }
            span { font-size:12px; padding-bottom:3px; }
        }
        .container {
            padding:0 30px;
        }
    }
    footer {
        padding:20px 0;
        .info-line {
            flex-direction: column;
            .footer-logo {
                margin-right:0;
                margin-bottom:8px;
            }
            p { opacity: 0.8; }
        }
        .container > span {
            padding:0;
            opacity: 0.8;
            font-size:13px;
            text-align: center;
        }
        span {text-align: center; }
    }
    .container {
        padding:0 30px;
    }
    section {
        padding:40px 0;
    }
    .product-details-list {
        margin-top:-40px;
        li {
            flex-direction: column;
            .thumb {
                min-height:240px;
            }
            .contents {
                flex:auto;
                padding:20px 0 0;
            }
            h4 {
                font-size:24px;
                margin-bottom:0;
            }
            .cate {
                row-gap:5px;
            }
            .adv-line {
                flex-direction: column;
                margin:8px 0;
                gap:5px;
            }
        }
    }
    .fixed-list-section {
        .container {
            flex-direction: column;
        }
        .title {
            position: static;
            top:auto;
            margin-bottom:20px;
            h4 {
                font-size:20px;
            }
        }
        .contents {
            ul {
                gap:20px;
                li {
                    font-size:14px;
                    padding-left:30px;
                    &:before {
                        width:8px;
                        height:8px;
                        border-width:3px;
                    }
                }
            }
        }
        &.history .contents ul li {
            p {
                font-size:14px;
            }
            p+p { margin-top:10px; }
        }
    }
    .bottom-line {
        padding:0 20px 20px;
    }
    .contents-body {
        .fix-box {
            position: initial;
            padding:30px 0;
            .container {
                flex-direction: column;
            }
        }
    }
    .sub-head {
        height:480px;
        padding:40px 0;
        .container {
            h2 {
                font-size:24px;
            }
            p { font-size:14px; }
        }
    }
    .copy-area p {
        font-size:13px;
    }
    .product-list {
        padding:0;
        ul {
            li {
                .item {
                    align-items: stretch;
                    flex-direction: column;
                    gap:40px;
                }
                h4 { font-size:24px; }
                p { font-size:14px; }
                .cate {
                    span {font-size:13px; }
                }
            }
            li:nth-child(2n) {
                .item {
                    align-items: stretch;
                    flex-direction: column;
                    gap:40px;
                    h4, p { text-align: left; }
                    .cate {
                        justify-content: flex-start;
                    }
                }

            }
        }
    }
    .quick-area {
        .title {
            h2 {
                font-size:24px;
            }
            p {
                font-size:14px;
            }
        }
    }
    .section-list-style {
        flex-wrap: wrap;
        row-gap: 20px;
        li { max-width:100%; min-width:100%; }
    }
}

.visual-area .txt-box .hero-motion-item {
    opacity: 0;
    transform: translate3d(0, 46px, 0);
    transition:
        opacity 0.8s ease,
        transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--hero-reveal-delay, 0ms);
    will-change: opacity, transform;
}

body.hero-motion-start .visual-area .txt-box .hero-motion-item {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce) {
    .visual-area .txt-box .hero-motion-item {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

body.motion-ready .motion-item {
    opacity: 0;
    transform: translate3d(0, 42px, 0);
    transition:
        opacity 0.7s ease,
        transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
}

body.motion-ready .motion-item.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce) {
    body.motion-ready .motion-item {
        opacity: 1;
        transform: none;
        transition: none;
    }
}
/* Mobile menu */
.mobile-menu-button,
.mobile-menu,
.mobile-menu-overlay {
    display: none;
}

@media (max-width: 768px) {
    body.mobile-menu-open {
        overflow: hidden;
    }

    #header .container {
        position: relative;
    }

    .gnb-wrapper {
        display: none;
    }

    .mobile-menu-button {
        display: inline-flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 6px;
        width: 44px;
        height: 44px;
        margin-left: auto;
        border: 0;
        background: transparent;
        cursor: pointer;
        padding: 0;
        z-index: 1002;
    }

    .mobile-menu-button span {
        display: block;
        width: 24px;
        height: 2px;
        background: #fff;
        border-radius: 999px;
    }

    .mobile-menu {
        display: block;
        position: fixed;
        top: 0;
        right: 0;
        width: min(82vw, 340px);
        height: 100vh;
        background: #fff;
        z-index: 1003;
        transform: translateX(100%);
        transition: transform 0.28s ease;
        box-shadow: -12px 0 30px rgba(0, 0, 0, 0.16);
        padding: 24px;
    }

    body.mobile-menu-open .mobile-menu {
        transform: translateX(0);
    }

    .mobile-menu-overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.45);
        z-index: 1001;
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.28s ease, visibility 0.28s ease;
    }

    body.mobile-menu-open .mobile-menu-overlay {
        opacity: 1;
        visibility: visible;
    }

    .mobile-menu-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding-bottom: 20px;
        border-bottom: 1px solid #e5e5e5;
        color: #111;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 0.08em;
    }

    .mobile-menu-close {
        width: 36px;
        height: 36px;
        border: 0;
        background: transparent;
        color: #111;
        font-size: 32px;
        line-height: 1;
        cursor: pointer;
    }

    .mobile-menu-nav {
        display: flex;
        flex-direction: column;
        padding-top: 20px;
    }

    .mobile-menu-nav > a,
    .mobile-submenu-button {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 18px 0;
        border: 0;
        border-bottom: 1px solid #ececec;
        background: transparent;
        color: #111;
        font-size: 20px;
        font-weight: 600;
        text-align: left;
        text-decoration: none;
        cursor: pointer;
    }

    .mobile-submenu-button span {
        font-size: 24px;
        font-weight: 300;
        transition: transform 0.2s ease;
    }

    .mobile-submenu-button[aria-expanded="true"] span {
        transform: rotate(45deg);
    }

    .mobile-submenu {
        display: none;
        flex-direction: column;
        padding: 8px 0 12px 16px;
        border-bottom: 1px solid #ececec;
    }

    .mobile-submenu.is-open {
        display: flex;
    }

    .mobile-submenu a {
        padding: 10px 0;
        color: #555;
        font-size: 16px;
        text-decoration: none;
    }
}
