﻿@charset "utf-8";

/*
 * media.css — site-wide responsive overrides (single file).
 * Load after main.css (index) or sub.css (sub pages).
 * Breakpoints: 1680, 1440, 1280 (+ max-height 800), 1024, 768, 480.
 * Covers: header / fullPage, main visual, sec02–sec04, sec03 Swiper, greeting, privacy, quick menu, overlays.
 */

/* ===== Sub visual CSS custom properties (moved from sub.css) ===== */
@media (max-width: 1600px) {
    #wrap.sub-page {
        --sv-pad-x: 40px;
    }
    :root {
        --sv-min-height: 480px;
        --sv-title-size: 48px;
        --sv-crumb-text-size: 16px;
        --sv-crumb-bar-h: 52px;
        --sv-crumb-list-px: 24px;
        --sv-stack-pb: 32px;
    }
}

@media (max-width: 1300px) {
    #wrap.sub-page {
        --sv-pad-x: 30px;
    }
    :root {
        --sv-min-height: 400px;
        --sv-title-size: 40px;
        --sv-title-lh: 1.25;
        --sv-crumb-text-size: 15px;
        --sv-crumb-bar-h: 48px;
        --sv-crumb-list-px: 20px;
        --sv-crumb-gap: 12px;
        --sv-stack-pb: 28px;
    }
}

@media (max-width: 1150px) {
    #wrap.sub-page {
        --sv-pad-x: 0px;
        --sv-radius-max: 0px;
    }
    :root {
        --sv-min-height: 340px;
        --sv-title-size: 34px;
        --sv-crumb-text-size: 14px;
        --sv-crumb-bar-h: 44px;
        --sv-crumb-list-px: 18px;
        --sv-crumb-gap: 10px;
        --sv-stack-pb: 24px;
    }
}

/* Desktop / large tablet (below 1280px) */
@media screen and (max-width: 1280px) {
    .main-visual .text-wrap {
        left: 40px;
        bottom: 60px;
    }
    .main-visual .text-wrap .title {
        font-size: 40px;
    }
    .main-visual .text-wrap .desc {
        font-size: 20px;
    }
    .main-visual .swiper-pagination {
        left: 40px !important;
        bottom: 30px !important;
    }
}

/* fullPage off: below 1280px width or short viewport height */
@media screen and (max-width: 1280px), screen and (max-height: 800px) {
    header {
        background: var(--color-white) !important;
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
    }
    /* Force dark logo */
    .header__logo .logo--dark,
    .header__partner .logo--dark {
        display: block !important;
    }
    .header__logo .logo--white,
    .header__partner .logo--white {
        display: none !important;
    }
    .header__search {
        color: var(--color-black) !important;
    }
    .header__mobile-toggle span {
        background-color: var(--color-black) !important;
    }
    /* For PC Intermediate GNB links */
    .gnb__link {
        color: var(--color-black) !important;
    }

    #fullpage {
        padding-top: 100px;
    }

    #fullpage .section {
        height: auto !important;
    }
    .main-visual {
        height: auto;
        aspect-ratio: 1920 / 875;
    }
    .main-visual .bg-video {
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        transform: none;
    }
}

/* 1024px — header height 60px */
@media screen and (max-width: 1024px) {
    #fullpage {
        padding-top: 60px;
    }
    .main-visual .text-wrap {
        bottom: 40px;
    }
    .main-visual .text-wrap .title {
        font-size: 32px;
    }
    .main-visual .text-wrap .desc {
        font-size: 18px;
    }
    .main-visual .swiper-pagination {
        bottom: 20px !important;
    }
    .gnb__item--has-sub::before {
        display: none;
    }
}

/* Tablet / mobile (below 768px) */
@media screen and (max-width: 768px) {
    .main-visual .text-wrap {
        left: 20px;
        bottom: 40px;
        right: 20px;
        gap: 8px;
    }
    .main-visual .swiper-pagination {
        left: 20px !important;
        bottom: 20px !important;
    }
    .main-visual .text-wrap .title {
        font-size: 26px;
        word-break: keep-all;
    }
    .main-visual .text-wrap .desc {
        font-size: 15px;
        word-break: keep-all;
    }
    .main-visual .bg-video {
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        transform: none;
    }
}

/* ===== Sec04 — ≤1280: hero flex + cards in flow; ≥1281: unchanged (main.css) ===== */
@media screen and (max-width: 1280px) {
    .sec04__main {
        margin-top: 0;
        height: auto;
    }

    .sec04__hero {
        display: flex;
        flex-direction: column;
        height: auto;
        min-height: 520px;
    }

    .sec04__hero-fill {
        display: block;
        flex: 1 1 auto;
        min-height: min(220px, 30vw);
        width: 100%;
        pointer-events: none;
    }

    .sec04__hero-title {
        font-size: clamp(56px, 11vw, 120px);
        line-height: 1.05;
        white-space: normal;
        text-align: right;
        max-width: calc(100% - 32px);
    }

    .sec04__cards {
        position: relative;
        bottom: auto;
        left: 0;
        right: 0;
        width: 100%;
        padding: 0 16px 24px;
        gap: 14px;
        align-content: flex-end;
    }

    .sec04 .dl-card {
        flex: 1 1 220px;
        max-width: 360px;
        height: auto;
        min-height: 220px;
        padding: 0 20px 22px;
        border-radius: 16px;
    }

    .sec04 .dl-card__icon {
        top: 14px;
        right: 14px;
        width: 40px;
        height: 40px;
    }

    .sec04 .dl-card__label {
        font-size: 26px;
    }

    .sec04 .dl-card__desc {
        font-size: 14px;
        padding-top: 10px;
        line-height: 1.65;
    }

    /* Tablet / narrow: copy always visible */
    .sec04 .dl-card__stack {
        transform: translateY(0);
    }

    .sec04 .dl-card__desc-clip {
        max-height: none;
        overflow: visible;
    }

    .sec04 .dl-card__desc {
        opacity: 1;
    }

    .sec04 {
        padding-bottom: 40px;
    }

    .sec04__logos {
        height: 88px;
        margin-top: 32px;
    }

    .sec04__logos-track,
    .sec04__logos-set {
        gap: 56px;
    }

    .sec04__logos-track {
        animation-duration: 22s;
    }

    .sec04__logos-set img {
        height: auto;
        max-height: 56px;
        object-fit: contain;
    }

    /* Narrow: hide trailing logos (keep marquee clone sets aligned for infinite scroll) */
    .sec04__logos-set img:nth-child(n + 9) {
        display: none;
    }
}

@media screen and (max-width: 1024px) {
    .sec04__hero {
        min-height: 480px;
    }

    .sec04__cards {
        padding: 0 12px 20px;
    }

    .sec04__logos-track,
    .sec04__logos-set {
        gap: 44px;
    }

    .sec04__logos-set img:nth-child(n + 7) {
        display: none;
    }

    .sec04__logos-set img {
        max-height: 54px;
    }
}

@media screen and (max-width: 768px) {
    .sec04__main {
        margin: auto 0;
    }

    .sec04__hero {
        min-height: 0;
        border-radius: 0;
    }

    .sec04__hero-fill {
        min-height: min(100px, 26vw);
    }

    .sec04__hero-title {
        font-size: clamp(40px, 12vw, 64px);
        line-height: 1.1;
        top: 16px;
        right: 12px;
    }

    .sec04__cards {
        padding: 0 12px 18px;
        flex-direction: column;
        flex-wrap: nowrap;
        align-items: stretch;
        justify-content: flex-start;
        gap: 12px;
    }

    .dl-card {
        flex: none;
        width: 100%;
        max-width: none;
        height: auto;
        min-height: 168px;
        padding: 20px 20px 22px;
    }

    .sec04__logos {
        margin-top: 24px;
        height: auto;
        min-height: 64px;
    }

    .sec04__logos-track,
    .sec04__logos-set {
        gap: 32px;
    }

    .sec04__logos-set img:nth-child(n + 6) {
        display: none;
    }

    .sec04__logos-set img {
        max-height: 48px;
    }
    /* Lift dl-card max-width cap on stacked layout (was 520px in main) */
    .sec04 .dl-card {
        max-width: 9999px;
    }
}

/* Small phone (below 480px) */
@media screen and (max-width: 480px) {
    .main-visual .text-wrap {
        bottom: 30px;
    }
    .main-visual .text-wrap .title {
        font-size: 22px;
    }
    .main-visual .text-wrap .desc {
        font-size: 14px;
    }
    .main-visual .swiper-pagination-bullet {
        width: 8px;
        height: 8px;
    }
    .main-visual .swiper-pagination-bullet-active {
        width: 30px;
    }

    .sec04__logos-track,
    .sec04__logos-set {
        gap: 26px;
    }

    .sec04__logos-set img:nth-child(n + 5) {
        display: none;
    }

    .sec04__logos-set img {
        max-height: 44px;
    }
}

/* ===== Sec03 Swiper (≤1280 only; desktop uses .sec03__slider) ===== */
.sec03__swiper {
    display: none;
}

.sec03__swiper-inner {
    position: relative;
    height: 420px;
    overflow: hidden;
    border-radius: 24px;
}

.sec03__swiper-inner img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sec03__swiper-overlay {
    display: none;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    flex-direction: column;
    gap: 6px;
    padding: 40px 20px 24px;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.6));
    pointer-events: none;
}

.sec03__swiper-name {
    color: var(--color-white);
    font-size: 20px;
    font-weight: 600;
    line-height: 1.3;
}

.sec03__swiper-desc {
    color: rgba(255, 255, 255, 0.85);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.6;
}

.sec03__swiper .swiper-pagination {
    position: relative !important;
    bottom: auto !important;
    margin-top: 20px;
    text-align: center;
}

.sec03__swiper .swiper-pagination-bullet {
    background: #bbb;
    opacity: 1;
}

.sec03__swiper .swiper-pagination-bullet-active {
    width: 24px;
    background: var(--color-gnb-sub-bg);
    border-radius: 4px;
}

/* sec02 / sec03 bg type: wider max-width first, narrower blocks follow (cascade) */
@media screen and (max-width: 1680px) {
    .sec02__bg-text {
        font-size: 140px;
    }
    .sec03__bg-text {
        font-size: 140px;
        line-height: 1.1;
        left: 4%;
    }
    .sec03__inner {
        width: 93.75%;
        padding-left: 0;
    }
    .sec04__inner {
        width: 93.75%;
    }
    .inquiry__row--tel-email {
        flex-wrap: wrap;
        gap: 30px;
    }
    .inquiry__row--tel-email .inquiry__col {
        width: 100%;
        flex: none;
    }
}

@media screen and (max-width: 1440px) {
    .sec02__bg-text {
        font-size: 112px;
    }
    .sec03__bg-text {
        font-size: 112px;
        line-height: 1.1;
    }
}

/* Section 02 — below 1280px */
@media screen and (max-width: 1280px) {
    /* sec02 bottom padding → sec03; sec03 bottom → sec04 (no double vertical padding) */
    .sec02.sec02-inner {
        padding: 72px 0 48px;
        height: auto !important;
        overflow: visible !important;
    }

    .sec03 {
        height: auto !important;
        padding: 0 0 56px;
        overflow: visible;
    }

    .sec02__head {
        flex-direction: column;
        gap: 30px;
        margin-bottom: 50px;
    }
    .sec02__head-right {
        align-items: flex-start;
        gap: 20px;
    }
    .sec02__title {
        font-size: 36px;
    }
    .sec02__grid {
        gap: 30px;
    }
    .sec02__col {
        gap: 30px;
    }
    .sec02__col--right {
        padding-top: 0;
    }
    .prod-card__img-wrap {
        height: 360px;
    }
    .prod-card__name {
        font-size: 26px;
    }
    .sec02__bg-text {
        font-size: 80px;
        line-height: 1;
        top: 120px;
    }

    /* sec03: keep 2-col accordion; scale down only */
    .sec03__inner {
        height: auto;
    }
    .sec03__panel--text {
        flex: 0 0 360px;
        width: 360px;
        height: 500px;
    }
    .sec03__title {
        font-size: 40px;
    }
    .sec03__sub {
        font-size: 16px;
    }
    .sec03__slider {
        height: 500px;
    }
    .sec03__acc-inner {
        width: 130px;
        height: 500px;
        border-radius: 32px;
    }
    .sec03__acc-slide.active .sec03__acc-inner {
        width: 420px;
        height: 500px;
    }
    .sec03__acc-slide.next .sec03__acc-inner {
        width: 230px;
        height: 500px;
    }
    .sec03__bg-text {
        font-size: 80px;
        line-height: 1;
        bottom: 100px;
    }
    .sec03__bottom {
        margin-top: 40px;
    }
    .sec03__more {
        margin-top: 28px;
    }
    .qm-nav {
        display: none;
    }
}

@media screen and (max-width: 1024px) {
    .sec02.sec02-inner {
        padding: 64px 0 40px;
    }

    .sec03 {
        padding: 0 0 48px;
    }
    .sec02__title, .sec03__title {
        font-size: 32px;
    }
    .prod-card__img-wrap {
        height: 300px;
    }
    .prod-card__name {
        font-size: 22px;
    }
    .sec02__more {
        width: 220px;
        height: 60px;
        padding: 0 8px 0 24px;
    }
    .sec02__more-label {
        font-size: 16px;
    }
    .sec02__more-icon {
        width: 48px;
        height: 48px;
    }

    .sec02__bg-text {
        font-size: 72px;
        line-height: 1;
    }

    .sec03__bg-text {
        font-size: 72px;
        line-height: 1;
    }
}

@media screen and (max-width: 768px) {
    .sec03 {
        padding: 0 0 36px;
    }

    .sec02.sec02-inner {
        padding: 30px 0 60px;
    }
    .sec02__title, .sec03__title {
        font-size: 28px;
    }
    .sec02__sub, .sec03__sub {
        font-size: 16px;
    }

    .sec03__sub br {
        display: none;
    }
    .sec02__head {
        margin-bottom: 10px;
        gap: 0;
    }
    .sec02__head-right {
        gap: 16px;
    }
    .sec02__grid {
        flex-direction: column;
        gap: 20px;
    }
    .sec02__col {
        flex-direction: row;
        gap: 16px;
    }
    .prod-card {
        flex: 1;
        min-width: 0;
        gap: 14px;
    }
    .prod-card__img-wrap {
        height: auto;
        aspect-ratio: 1/1;
        border-radius: 24px;
    }
    .prod-card__info {
        gap: 14px;
        flex-wrap: wrap;
    }
    .prod-card__text {
        flex: 1;
    }
    .prod-card__name {
        font-size: 18px;
    }
    .prod-card__desc {
        font-size: 13px;
        line-height: 1.6;
    }
    .prod-card__btn {
        width: 34px;
        height: 34px;
        align-self: flex-start;
    }
    /* sec03 ≤768: switch to Swiper */
    .sec03__slider {
        display: none;
    }

    .sec03__swiper {
        display: block;
        width: 100%;
    }

    .sec04__inner {
        width: 100%;
    }

    /* sec03 mobile: top row + full-width slide */
    .sec03__inner {
        width: 91.67%;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding-bottom: 80px;
    }
    .sec03__panel--text {
        width: 100%;
        height: auto;
        flex: none;
    }
    .sec03__content {
        flex-direction: column;
        align-items: flex-start;
        justify-content: space-between;
        gap: 16px;
        max-width: 100%;
        padding-top: 0;
    }
    .sec03__head {
        flex: 1;
        min-width: 0;
        gap: 0;
    }

    /* Match sec02__head mobile title ↔ sub rhythm (gap: 0) */
    .sec03__title-br {
        display: none;
    }
    .sec03__more {
        margin-top: 0;
        align-self: flex-start;
        flex-shrink: 0;
    }
    .sec03__bottom {
        display: none;
    }
    .sec03__panel--media {
        width: 100%;
        height: auto;
        flex: none;
        margin-top: 32px;
        overflow: visible;
    }
    /* Hide per-slide overlay (replaced by cloneNode overlay) */
    .sec03__swiper-overlay {
        display: none !important;
    }
    /* Swiper slide height */
    .sec03__swiper-inner {
        height: 360px;
        border-radius: 0px;
    }
    /* Injected sec03__bottom clone (cloneNode) */
    .sec03__bottom--swiper {
        display: flex !important;
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
        position: absolute;
        z-index: 10;
        bottom: 0;
        left: 0;
        right: 0;
        margin-top: 0;
        padding: 80px 20px 40px;
        background: linear-gradient(transparent, rgba(0, 0, 0, 0.65));
        pointer-events: none;
    }
    .sec03__bottom--swiper .sec03__progress {
        width: 100%;
        max-width: 100%;
        background: rgba(255, 255, 255, 0.3);
    }
    .sec03__bottom--swiper .sec03__progress-bar {
        background: var(--color-white);
    }
    .sec03__bottom--swiper .sec03__info {
        margin-top: 12px;
        max-width: 100%;
    }
    .sec03__bottom--swiper .sec03__industry-name {
        color: var(--color-white);
        font-size: 20px;
    }
    .sec03__bottom--swiper .sec03__industry-desc {
        color: rgba(255, 255, 255, 0.85);
        font-size: 13px;
        line-height: 1.6;
    }
    /* Swiper pagination: absolute on card, light bullets */
    .sec03__swiper .swiper-pagination {
        position: absolute !important;
        z-index: 20;
        bottom: 16px !important;
        margin-top: 0;
    }
    .sec03__swiper .swiper-pagination-bullet {
        background: rgba(255, 255, 255, 0.6);
    }
    .sec03__swiper .swiper-pagination-bullet-active {
        background: var(--color-white);
    }
    .sec03__bg-text {
        font-size: 52px;
        line-height: 1;
        bottom: 60px;
    }
    .sec02__bg-text {
        font-size: 52px;
        line-height: 1;
    }
    #sec03DragCursor {
        display: none !important;
    }
    .sec02__more {
        width: 200px;
        height: 50px;
    }
    .sec02__more-icon {
        width: 32px;
        height: 32px;
    }
    .auto-mobile-card__img-wrap{background-color: transparent;}
}

@media screen and (max-width: 480px) {
    .sec02__title, .sec03__title {
        font-size: 24px;
    }
    .sec02__sub, .sec03__sub {
        font-size: 14px;
    }
    .sec02__col {
        flex-direction: column;
    }
    .prod-card__img-wrap {
        height: auto;
        border-radius: 16px;
    }
    .prod-card__name {
        font-size: 18px;
    }
    .sec02__more {
        width: 100%;
        max-width: 175px;
    }

    .sec02__more-icon {
        width: 26px;
        height: 26px;
    }

    /* Swiper inner height at 480 */
    .sec03__swiper-inner {
        height: 400px;
    }
    .sec03__swiper-name {
        font-size: 17px;
    }
    .sec03__swiper-desc {
        font-size: 12px;
    }

    .sec02__bg-text {
        right: 0;
        top: 275px;
        font-size: 32px;
        line-height: 1;
    }

    .sec03__bg-text {
        bottom: 80px;
        font-size: 28px;
        line-height: 1;
    }
}


@media screen and (max-width: 1280px) {
    .greeting {
        padding: 100px 0 120px;
    }
    .greeting__bg-text {
        font-size: 110px;
        bottom: 80px;
    }
    .greeting__title {
        font-size: 44px;
    }
    .greeting__body {
        gap: 60px;
        align-items: flex-start;
    }
    .greeting__img-wrap {
        width: 440px;
        height: 540px;
    }
    .greeting__text-wrap {
        padding: 0 40px;
    }
    .greeting__lead {
        font-size: 28px;
    }
    .greeting__para-group p {
        font-size: 18px;
    }
}

@media screen and (max-width: 1024px) {
    .greeting {
        padding: 80px 0 100px;
    }
    .greeting__bg-text {
        font-size: 80px;
        bottom: 60px;
    }
    .greeting__content {
        gap: 40px;
    }
    .greeting__body {
        flex-direction: column;
        align-items: stretch;
        gap: 40px;
    }
    .greeting__img-wrap {
        width: 100%;
        height: auto;
        aspect-ratio: 4 / 3;
    }
    .greeting__text-wrap {
        padding: 0;
    }
    .greeting__title {
        font-size: 38px;
    }
}

@media screen and (max-width: 768px) {
    .greeting {
        padding: 60px 0 80px;
    }
    .greeting__bg-text {
        font-size: 56px;
        bottom: 40px;
    }
    .greeting__content {
        gap: 32px;
    }
    .greeting__body {
        gap: 32px;
    }
    .greeting__img-wrap {
        border-radius: 20px;
        aspect-ratio: 4 / 3;
    }
    .greeting__title {
        font-size: 32px;
    }
    .greeting__lead {
        font-size: 22px;
    }
    .greeting__text-inner {
        gap: 28px;
    }
    .greeting__head-group {
        gap: 20px;
    }
    .greeting__para-group {
        gap: 20px;
    }
    .greeting__para-group p {
        font-size: 16px;
    }
}

@media screen and (max-width: 480px) {
    .greeting {
        padding: 40px 0 60px;
    }
    .greeting__bg-text {
        font-size: 40px;
        bottom: 24px;
    }
    .greeting__title {
        font-size: 28px;
    }
    .greeting__lead {
        font-size: 20px;
    }
    .greeting__para-group p {
        font-size: 15px;
    }
}

/* ===== Privacy (responsive; same breakpoint steps as .greeting) ===== */
@media screen and (max-width: 1280px) {
    .privacy {
        padding: 100px 24px 120px;
        box-sizing: border-box;
    }

    .privacy--compact {
        padding: 64px 24px 96px;
    }

    .privacy__bg-text {
        font-size: 110px;
        bottom: 80px;
    }

    .privacy__content {
        gap: 48px;
    }

    .privacy__title {
        font-size: 44px;
    }

    .privacy__head {
        gap: 24px;
    }

    .privacy__body {
        gap: 32px;
        max-width: 100%;
    }

    .privacy__lead,
    .privacy__body > dl > dd,
    .privacy__body > p:not(.privacy__lead):not(.privacy__meta) {
        font-size: 18px;
    }

    .privacy__body > dl > dt {
        font-size: 17px;
    }

    .privacy__body > dl > dd ul li,
    .privacy__body > dl > dd ul li p {
        font-size: 17px;
    }

    .privacy .sTxt p {
        font-size: 17px;
    }
}

@media screen and (max-width: 1024px) {
    .privacy {
        padding: 80px 20px 100px;
    }

    .privacy--compact {
        padding: 48px 20px 80px;
    }

    .privacy__bg-text {
        font-size: 80px;
        bottom: 60px;
    }

    .privacy__content {
        gap: 40px;
    }

    .privacy__title {
        font-size: 38px;
    }

    .privacy__head {
        gap: 22px;
    }

    .privacy__body {
        gap: 28px;
    }

    .privacy .sTxt {
        padding: 24px 22px 26px;
        border-radius: 16px;
    }
}

@media screen and (max-width: 768px) {
    .privacy {
        padding: 60px 16px 80px;
    }

    .privacy--compact {
        padding: 40px 16px 64px;
    }
    .privacy__bg-text {
        font-size: 56px;
        bottom: 40px;
    }

    .privacy__content {
        gap: 32px;
    }

    .privacy__title {
        font-size: 32px;
        line-height: 1.25;
    }

    .privacy__head {
        gap: 20px;
    }

    .privacy__body {
        gap: 28px;
    }

    .privacy__lead,
    .privacy__body > dl > dd,
    .privacy__body > p:not(.privacy__lead):not(.privacy__meta) {
        font-size: 16px;
        line-height: 1.65;
    }

    .privacy__meta {
        font-size: 15px;
    }

    .privacy__body > dl > dt {
        font-size: 16px;
    }

    .privacy__body > dl > dd ul li,
    .privacy__body > dl > dd ul li p,
    .privacy .sTxt p,
    .privacy .sTxt dd {
        font-size: 16px;
    }

    .privacy .sTxt {
        padding: 22px 18px 24px;
    }

    .privacy .sTxt h3 {
        font-size: 16px;
    }
}

@media screen and (max-width: 480px) {
    .privacy {
        padding: 40px 12px 60px;
    }

    .privacy--compact {
        padding: 32px 12px 48px;
    }

    .privacy__bg-text {
        font-size: 40px;
        bottom: 24px;
    }

    .privacy__content {
        gap: 28px;
    }

    .privacy__title {
        font-size: 24px;
        line-height: 1.2;
    }

    .privacy__bar {
        width: 48px;
    }

    .privacy__lead,
    .privacy__body > dl > dd,
    .privacy__body > p:not(.privacy__lead):not(.privacy__meta) {
        font-size: 15px;
    }

    .privacy__meta {
        font-size: 14px;
    }

    .privacy__body > dl > dt {
        font-size: 15px;
    }

    .privacy__body > dl > dd ul li,
    .privacy__body > dl > dd ul li p {
        font-size: 14px;
    }

    .privacy .sTxt {
        padding: 18px 14px 20px;
        border-radius: 14px;
    }
}

/* ===== Sec03 slide text overlay (injected via cloneNode; mobile only) ===== */
.sec03__info--overlay {
    display: none;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    padding: 40px 20px 24px;
    margin-top: 0;
    max-width: 100%;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.6));
    pointer-events: none;
}

.sec03__info--overlay .sec03__industry-name {
    color: var(--color-white);
    font-size: 20px;
    font-weight: 600;
    line-height: 1.3;
}

.sec03__info--overlay .sec03__industry-desc {
    color: rgba(255, 255, 255, 0.85);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.6;
    text-align: left;
}

/* Quick menu — chat / scroll (fixed + sec04/footer clones, same scale) */
@media screen and (max-width: 1280px) {
    .qm-btns {
        right: 16px;
        bottom: 28px;
        gap: 8px;
    }

    .qm-btns-sec04-wrap {
        right: 16px;
        bottom: 28px;
    }

    .qm-btns-foot-wrap {
        right: 16px;
        bottom: calc(28px + var(--qm-foot-clone-lift, 0px));
    }

    .qm-chat {
        width: 68px;
        height: 68px;
    }

    .qm-chat img {
        width: 34px;
        height: 34px;
    }

    .qm-scroll {
        width: 52px;
        height: 52px;
    }

    .qm-scroll__icon svg {
        width: 20px;
        height: 20px;
    }
}

@media screen and (max-width: 1024px) {
    .qm-btns {
        right: 12px;
        bottom: 22px;
        gap: 7px;
    }

    .qm-btns-sec04-wrap {
        right: 12px;
        bottom: 22px;
    }

    .qm-btns-foot-wrap {
        right: 12px;
        bottom: calc(22px + var(--qm-foot-clone-lift, 0px));
    }

    .qm-chat {
        width: 60px;
        height: 60px;
    }

    .qm-chat img {
        width: 30px;
        height: 30px;
    }

    .qm-scroll {
        width: 46px;
        height: 46px;
    }

    .qm-scroll__icon svg {
        width: 18px;
        height: 18px;
    }
}

@media (max-width: 1280px) {
    .location { padding: 100px 0 120px; }
    .location__title { font-size: 44px; }
    .location__info { width: 500px; padding: 44px 50px; }
}

@media (max-width: 1024px) {
    :root {
        --sv-min-height: min(300px, 42vh);
        --sv-title-size: 28px;
        --sv-crumb-text-size: 13px;
        --sv-crumb-bar-h: 40px;
        --sv-crumb-list-px: 16px;
        --sv-stack-pb: 20px;
    }
}

@media (max-width: 1024px) {
    .location { padding: 80px 0 100px; }
    .location__title { font-size: 38px; }
    .location__content { gap: 40px; }
    .location__body {
        flex-direction: column;
        align-items: stretch;
    }
    .location__info {
        width: 100%;
        padding: 40px;
    }
    .location__map .root_daum_roughmap { height: 400px !important; }
}

@media (max-width: 768px) {
    :root {
        --sv-min-height: min(240px, 36vh);
        --sv-title-size: 22px;
        --sv-title-lh: 1.22;
        --sv-crumb-text-size: 12px;
        --sv-crumb-lh: 1.45;
        --sv-crumb-bar-h: 40px;
        --sv-crumb-list-px: 12px;
        --sv-crumb-gap: 8px;
        --sv-stack-pb: 16px;
    }
}

@media (max-width: 768px) {
    .location { padding: 60px 0 80px; }
    .location__title { font-size: 32px; }
    .location__content { gap: 32px; }
    .location__info {
        padding: 32px 28px;
        border-radius: 20px;
    }
    .location__section-title { font-size: 22px; }
    .location__text,
    .location__transport-desc { font-size: 16px; }
    .location__transport-label { font-size: 16px; }
    .location__map { border-radius: 20px; }
    .location__map .root_daum_roughmap { height: 320px !important; }
}

@media (max-width: 480px) {
    .location { padding: 40px 0 60px; }
    .location__title { font-size: 28px; }
    .location__info { padding: 24px 20px; }
    .location__map .root_daum_roughmap { height: 260px !important; }
}

@media screen and (max-width: 768px) {
    .qm-btns {
        right: 10px;
        bottom: 16px;
        gap: 6px;
    }

    .qm-btns-sec04-wrap {
        right: 10px;
        bottom: 16px;
    }

    .qm-btns-foot-wrap {
        right: 10px;
        bottom: calc(16px + var(--qm-foot-clone-lift, 0px));
    }

    .qm-chat {
        width: 52px;
        height: 52px;
    }

    .qm-chat img {
        width: 26px;
        height: 26px;
    }

    .qm-scroll {
        width: 40px;
        height: 40px;
    }

    .qm-scroll__icon svg {
        width: 16px;
        height: 16px;
    }

    .qm-chat:focus-visible,
    .qm-scroll:focus-visible {
        outline-offset: 2px;
    }
    .privacy__inner .br-mo {
        display: block;
    }
}
@media (max-width: 1024px) {
    .location__map{min-height: 300px;}
}

@media (max-width: 1280px) {
    .cases__card {
        gap: 60px;
    }
    .cases__card-img {
        width: 420px;
        height: 290px;
    }
}

@media (max-width: 1024px) {
    .cases {
        padding: 80px 0 120px;
    }
    .cases__title {
        font-size: 40px;
    }
    .cases__tab-btn {
        width: 180px;
        padding: 12px 30px;
        font-size: 16px;
    }
    .cases__card {
        gap: 40px;
        padding: 40px;
    }
    .cases__card-img {
        width: 340px;
        height: 240px;
    }
    .cases__card-title {
        font-size: 26px;
    }
    .cases__card-desc {
        font-size: 16px;
    }
}

@media (max-width: 768px) {
    .cases {
        padding: 60px 0 100px;
    }
    .cases__head {
        gap: 28px;
        margin-bottom: 40px;
    }
    .cases__title {
        font-size: 30px;
    }
    .cases__tab {
        justify-content: center;
    }
    .cases__tab-btn {
        width: 140px;
        padding: 12px 20px;
        font-size: 15px;
    }
    .cases__card {
        flex-direction: column;
        gap: 30px;
        padding: 30px;
        border-radius: 20px;
    }
    .cases__card-img {
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
        flex-shrink: unset;
    }
    .cases__card-body {
        gap: 20px;
    }
    .cases__card-title-wrap {
        gap: 20px;
    }
    .cases__card-title {
        font-size: 22px;
    }
    .cases__card-desc {
        font-size: 15px;
    }
    .cases__card-recommend-label {
        font-size: 17px;
    }
    .cases__card-tag {
        font-size: 14px;
        padding: 8px 16px;
    }
}

@media (max-width: 480px) {
    .cases__title {
        font-size: 24px;
    }
    .cases__card {
        padding: 24px;
        border-radius: 16px;
    }
    .cases__card-img {
        height: auto;
    }
    .cases__card-title {
        font-size: 19px;
    }
}

/* ── cases--auto 반응형 ── */
@media screen and (max-width: 768px) {
    /* 포인트: 숫자 표시, 중심점 숨김, pulse 제거 */
    .auto-point {
        width: 28px;
        height: 28px;
        margin-left: -14px;
        margin-top: -14px;
        background: #DA291C;
        border-radius: 9999px;
    }
    .auto-point::before {
        display: none;
    }
    .auto-point::after {
        display: none;
    }
    .auto-point__num {
        display: block;
    }
    .auto-point.is-active {
        background: #9e1b12;
        outline: 2px solid #DA291C;
        outline-offset: 2px;
    }

    /* 클릭 팝업 카드 숨김 (모바일에서는 나열 카드 사용) */
    .auto-card {
        display: none !important;
    }
    .auto-point-line {
        display: none;
    }

    .auto-tab-btn {
        padding: 12px 36px;
        font-size: 16px;
    }
    .auto-viewer__note {
        font-size: 14px;
    }

    /* 탭: JS로 이미지 아래로 이동 후 position 리셋 */
    .auto-viewer__tab-wrap--mobile {
        position: static;
        justify-content: center;
        margin-top: 20px;
    }

    /* 모바일 나열 카드 표시 */
    .auto-mobile-list {
        display: flex;
    }
}

/* =====================================================
   제품소개 — 제품 목록 반응형
   ===================================================== */

@media (max-width: 1280px) {
    .prod-list__tab-btn {
        width: 220px;
        padding: 14px 40px;
        font-size: 17px;
    }
    .prod-list__title {
        font-size: 44px;
    }
}

@media (max-width: 1024px) {
    .prod-list {
        padding: 80px 0 120px;
    }
    .prod-list__title {
        font-size: 38px;
    }
    .prod-list__tab-btn {
        width: 180px;
        padding: 12px 30px;
        font-size: 16px;
    }
    /* 3열 */
    .prod-list__grid .pcard {
        flex: none;
        width: calc((100% - 40px) / 3);
    }
}

@media (max-width: 768px) {
    .prod-list {
        padding: 60px 0 100px;
    }
    .prod-list__head {
        gap: 28px;
        margin-bottom: 40px;
    }
    .prod-list__title {
        font-size: 30px;
    }
    .prod-list__tab-btn {
        width: 140px;
        padding: 12px 20px;
        font-size: 15px;
    }
    /* 2열 */
    .prod-list__grid .pcard {
        flex: none;
        width: calc((100% - 20px) / 2);
    }
    .pcard__img {
        height: 180px;
    }
    .pcard__features li {
        font-size: 14px;
    }
    .prod-list__panel {
        gap: 40px;
    }
}

@media (max-width: 480px) {
    .prod-list__title {
        font-size: 26px;
    }
    .prod-list__tab-btn {
        width: 120px;
        font-size: 14px;
    }
    /* 1열 */
    .prod-list__grid .pcard {
        flex: none;
        width: 100%;
    }
    .pcard__img {
        height: 200px;
    }
    .prod-pagination__btn,
    .prod-pagination__arrow {
        width: 38px;
        height: 38px;
        font-size: 14px;
    }
}

/* ===== 검색결과 반응형 ===== */
@media (max-width: 1280px) {
    .search-result {
        padding: 80px 0 120px;
    }
    .search-result__count {
        font-size: 28px;
    }
}

@media (max-width: 1024px) {
    /* 3열 */
    .search-result__grid .pcard {
        flex: none;
        width: calc((100% - 40px) / 3);
    }
}

@media (max-width: 768px) {
    .search-result {
        padding: 60px 0 100px;
    }
    .search-result__bar {
        max-width: 100%;
        margin-bottom: 40px;
    }
    .search-result__input {
        flex: 1;
        width: auto;
        font-size: 16px;
    }
    .search-result__count {
        font-size: 22px;
        margin-bottom: 40px;
    }
    /* 2열 */
    .search-result__grid .pcard {
        flex: none;
        width: calc((100% - 20px) / 2);
    }
    .search-result__grid {
        margin-bottom: 40px;
    }
}

@media (max-width: 480px) {
    .search-result__count {
        font-size: 18px;
    }
}

/* =====================================================
   다운로드 — 매뉴얼 (.manual)
   ===================================================== */
@media (max-width: 1280px) {
    .manual__card {
        flex: 0 0 calc((100% - 60px) / 4);
        width: calc((100% - 60px) / 4);
    }
}

@media (max-width: 1024px) {
    .manual {
        padding: 80px 0 100px;
    }
    .manual__inner {
        gap: 40px;
    }
    .manual__head {
        gap: 40px;
        width: 100%;
    }
    .manual__title {
        font-size: 40px;
    }
    /* 2열 */
    .manual__card {
        flex: 0 0 calc((100% - 20px) / 2);
        width: calc((100% - 20px) / 2);
    }
}

@media (max-width: 768px) {
    .manual {
        padding: 60px 0 80px;
    }
    .manual__inner {
        gap: 32px;
    }
    .manual__head {
        gap: 32px;
    }
    .manual__title {
        font-size: 32px;
    }
    /* 검색바 → column */
    .manual__search {
        flex-direction: column;
        width: 100%;
    }
    .manual__select-wrap {
        width: 100%;
    }
    .manual__select {
        width: 100%;
        height: 56px;
        font-size: 16px;
    }
    .manual__input-wrap {
        width: 100%;
    }
    .manual__input {
        flex: 1;
        width: auto;
        height: 56px;
        font-size: 16px;
    }
    /* 2열 유지 */
    .manual__card {
        flex: 0 0 calc((100% - 20px) / 2);
        width: calc((100% - 20px) / 2);
        padding: 28px;
    }
    .manual__card-name {
        font-size: 20px;
    }
    .manual__card-category,
    .manual__card-type {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .manual {
        padding: 40px 0 60px;
    }
    .manual__title {
        font-size: 26px;
    }
    /* 1열 */
    .manual__list {
        gap: 12px;
    }
    .manual__card {
        flex: 0 0 100%;
        width: 100%;
        padding: 24px;
    }
}

/* =====================================================
   다운로드 — 프로그램 반응형 (.program)
   ===================================================== */

@media (max-width: 1280px) {
    /* 3열 */
    .program__card {
        flex: 0 0 calc((100% - 40px) / 3);
        width: calc((100% - 40px) / 3);
    }
}

@media (max-width: 1024px) {
    .program {
        padding: 80px 0 100px;
    }
    .program__inner {
        gap: 48px;
    }
    .program__head {
        gap: 40px;
    }
    .program__title {
        font-size: 40px;
    }
    /* 2열 */
    .program__list {
        gap: 16px;
    }
    .program__card {
        flex: 0 0 calc((100% - 16px) / 2);
        width: calc((100% - 16px) / 2);
        height: auto;
        min-height: 200px;
        padding: 32px;
    }
    .program__card-name {
        font-size: 20px;
    }
}

@media (max-width: 768px) {
    .program {
        padding: 60px 0 80px;
    }
    .program__inner {
        gap: 32px;
    }
    .program__head {
        gap: 32px;
    }
    .program__title {
        font-size: 32px;
    }
    /* 2열 유지 */
    .program__list {
        gap: 12px;
    }
    .program__card {
        flex: 0 0 calc((100% - 12px) / 2);
        width: calc((100% - 12px) / 2);
        padding: 24px;
        min-height: 180px;
    }
    .program__card-name {
        font-size: 18px;
    }
    .program__card-models-label {
        font-size: 15px;
    }
    .program__card-models-text {
        font-size: 14px;
    }
    .program__card-dl svg {
        width: 28px;
        height: 28px;
    }
}

@media (max-width: 480px) {
    .program {
        padding: 40px 0 60px;
    }
    .program__title {
        font-size: 26px;
    }
    /* 1열 */
    .program__list {
        gap: 12px;
    }
    .program__card {
        flex: 0 0 100%;
        width: 100%;
        padding: 24px;
    }
}

/* =====================================================
   공지사항 반응형
   ===================================================== */

@media (max-width: 1024px) {
    .notice {
        padding: 60px 0 80px;
    }
    .notice__inner {
        gap: 40px;
    }
    .notice__title {
        font-size: 40px;
    }
    /* 검색바 세로 배치 */
    .notice__head {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
        margin-bottom: 20px;
    }
    .notice__search {
        width: 100%;
    }
    .notice__search .manual__select-wrap {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: 140px;
        width: 140px;
        max-width: 140px;
    }
    .notice__search .manual__select {
        width: 140px;
        height: 54px;
        font-size: 15px;
        padding: 0 40px 0 20px;
    }
    .notice__search .manual__input-wrap {
        flex: 1 1 0;
        min-width: 0;
        overflow: hidden;
    }
    .notice__search .manual__input {
        width: 100%;
        min-width: 0;
        height: 54px;
        font-size: 15px;
        box-sizing: border-box;
    }
    .notice__search .manual__submit {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: 54px;
        width: 54px;
        height: 54px;
    }
    /* 헤더: 작성자·등록일·조회 숨김, #·제목만 */
    .notice__row--head .notice__col--writer,
    .notice__row--head .notice__col--date,
    .notice__row--head .notice__col--view {
        display: none;
    }
    .notice__row--head .notice__col {
        font-size: 17px;
    }
    /* 행: 번호 + body 가로 배치 */
    .notice__row {
        align-items: flex-start;
        padding: 16px 20px;
        height: auto;
    }
    /* 번호/핀: 고정 너비 */
    .notice__col--num {
        flex: 0 0 40px;
        width: 40px;
        height: auto;
        padding: 2px 0 0;
        font-size: 14px;
        color: var(--color-gray-pale);
        align-self: flex-start;
        line-height: 1.4;
        justify-content: center;
    }
    /* body wrapper: 세로 flex */
    .notice__col--body {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-width: 0;
        gap: 4px;
    }
    /* 제목 */
    .notice__col--title {
        flex: none;
        width: 100%;
        height: auto;
        padding: 0;
        justify-content: flex-start;
        font-size: 16px;
    }
    /* 메타 wrapper: 가로 flex */
    .notice__meta {
        display: flex;
        align-items: center;
        gap: 0;
    }
    /* writer/date/view: 작게 가로 나열 */
    .notice__col--writer,
    .notice__col--date,
    .notice__col--view {
        display: flex;
        flex: 0 0 auto;
        width: auto;
        height: auto;
        padding: 0;
        font-size: 13px;
        color: var(--color-gray-pale);
        font-family: 'SUIT', sans-serif;
        justify-content: flex-start;
    }
    .notice__col--writer::after,
    .notice__col--date::after {
        content: '·';
        margin: 0 6px;
        color: #CCCCCC;
    }
    .notice__col--view::after {
        content: none;
    }
    .notice__col {
        height: auto;
        font-size: 16px;
    }
}

@media (max-width: 768px) {
    .notice {
        padding: 50px 0 70px;
    }
    .notice__inner {
        gap: 30px;
    }
    .notice__title {
        font-size: 32px;
    }
    /* 헤더: 작성자·등록일·조회 숨김, #·제목만 노출 */
    .notice__row--head .notice__col--writer,
    .notice__row--head .notice__col--date,
    .notice__row--head .notice__col--view {
        display: none;
    }
    /* 행: 번호 + body(제목+메타) 가로 배치 */
    .notice__row {
        align-items: flex-start;
        padding: 14px 16px;
        height: auto;
    }
    /* 번호: 왼쪽 고정 — 제목 첫 줄에 맞춰 상단 정렬 */
    .notice__col--num {
        flex: 0 0 auto;
        width: auto;
        height: auto;
        padding: 2px 8px 0 0;
        font-size: 13px;
        color: var(--color-gray-pale);
        align-self: flex-start;
        line-height: 1.4;
    }
    /* body wrapper: display:contents 해제 → 세로 flex 컨테이너로 전환 */
    .notice__col--body {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-width: 0;
        gap: 4px;
    }
    /* 제목 */
    .notice__col--title {
        flex: none;
        width: 100%;
        height: auto;
        padding: 0;
        justify-content: flex-start;
        font-size: 15px;
    }
    /* 메타 wrapper: display:contents 해제 → 가로 flex */
    .notice__meta {
        display: flex;
        align-items: center;
        gap: 0;
    }
    /* writer/date/view: 작게 가로 나열 (1024px display:none 복원) */
    .notice__col--writer,
    .notice__col--date,
    .notice__col--view {
        display: flex;
        flex: 0 0 auto;
        width: auto;
        height: auto;
        padding: 0;
        font-size: 12px;
        color: var(--color-gray-pale);
        font-family: 'SUIT', sans-serif;
        justify-content: flex-start;
    }
    .notice__col--writer::after,
    .notice__col--date::after {
        content: '·';
        margin: 0 6px;
        color: #CCCCCC;
    }
    .notice__col--view::after {
        content: none;
    }
    /* notice__col 공통 height 리셋 */
    .notice__col {
        height: auto;
        font-size: 15px;
    }
    .notice__head {
        margin-bottom: 16px;
    }
}

@media (max-width: 480px) {
    .notice {
        padding: 40px 0 60px;
    }
    .notice__title {
        font-size: 26px;
    }
    .notice__col--title {
        font-size: 14px;
    }
    .notice__col--writer,
    .notice__col--date,
    .notice__col--view {
        font-size: 11px;
    }
    .notice__count {
        font-size: 15px;
    }
    .notice__head {
        gap: 12px;
        margin-bottom: 12px;
    }
}

/* =====================================================
   공지사항 뷰 반응형 (.notice-view)
   ===================================================== */

@media (max-width: 1280px) {
    .notice-view {
        padding: 70px 0 100px;
    }
    .notice-view__inner {
        gap: 50px;
    }
    .notice-view__title {
        font-size: 44px;
    }
    .notice-view__post-title {
        font-size: 28px;
    }
    .notice-view__img-wrap {
        height: 520px;
    }
    .notice-view__nav-item {
        width: 480px;
    }
}

@media (max-width: 1024px) {
    .notice-view {
        padding: 60px 0 80px;
    }
    .notice-view__inner {
        gap: 40px;
    }
    .notice-view__title {
        font-size: 38px;
    }
    .notice-view__head {
        gap: 36px;
    }
    .notice-view__post-title {
        font-size: 24px;
    }
    .notice-view__info {
        gap: 24px;
    }
    .notice-view__info-item {
        font-size: 16px;
    }
    .notice-view__img-wrap {
        height: 420px;
    }
    .notice-view__text {
        font-size: 16px;
    }
    .notice-view__file {
        gap: 40px;
        padding: 24px 40px;
    }
    .notice-view__file-label {
        font-size: 16px;
    }
    .notice-view__file-link {
        font-size: 16px;
    }
    .notice-view__nav-item {
        width: auto;
        flex: 1;
        gap: 24px;
    }
    .notice-view__nav-label {
        font-size: 14px;
    }
    .notice-view__nav-title {
        font-size: 16px;
    }
    .notice-view__list-btn {
        height: 66px;
        padding: 0 60px;
        font-size: 18px;
    }
}

@media (max-width: 768px) {
    .notice-view {
        padding: 50px 0 70px;
    }
    .notice-view__inner {
        gap: 32px;
    }
    .notice-view__title {
        font-size: 30px;
        letter-spacing: -0.6px;
    }
    .notice-view__head {
        gap: 28px;
    }
    .notice-view__tit-wrap {
        gap: 20px;
    }
    .notice-view__post-title {
        font-size: 20px;
        letter-spacing: -0.4px;
    }
    .notice-view__info {
        gap: 16px;
        flex-wrap: wrap;
        justify-content: center;
    }
    .notice-view__info-item {
        font-size: 14px;
    }
    .notice-view__body {
        gap: 50px;
    }
    .notice-view__img-wrap {
        height: 320px;
        border-radius: 14px;
    }
    .notice-view__text {
        font-size: 15px;
    }
    .notice-view__file {
        flex-direction: column;
        gap: 16px;
        padding: 20px 24px;
        width: 100%;
        border-radius: 14px;
    }
    .notice-view__file-tit {
        width: 100%;
    }
    .notice-view__file-list {
        width: 100%;
        gap: 12px;
    }
    .notice-view__file-label {
        font-size: 15px;
    }
    .notice-view__file-link {
        font-size: 14px;
    }
    /* 네비게이션: 이전/다음/목록 세로 배치 */
    .notice-view__nav {
        flex-direction: column;
        gap: 0;
    }
    .notice-view__nav-item {
        width: 100%;
        gap: 16px;
        padding: 18px 0;
        border-top: 1px solid #eeeeee;
        justify-content: flex-start;
    }
    .notice-view__nav-item--next {
        justify-content: flex-end;
        border-bottom: 1px solid #eeeeee;
    }
    .notice-view__nav-txt--right {
        align-items: flex-end;
    }
    .notice-view__nav-title {
        font-size: 15px;
    }
    .notice-view__nav-label {
        font-size: 13px;
    }
    .notice-view__list-btn {
        margin-top: 24px;
        width: 100%;
        height: 56px;
        padding: 0;
        font-size: 16px;
        border-radius: 12px;
    }
}

@media (max-width: 480px) {
    .notice-view {
        padding: 40px 0 60px;
    }
    .notice-view__inner {
        gap: 24px;
    }
    .notice-view__title {
        font-size: 24px;
        letter-spacing: -0.48px;
    }
    .notice-view__head {
        gap: 20px;
    }
    .notice-view__tit-wrap {
        gap: 16px;
    }
    .notice-view__post-title {
        font-size: 17px;
        letter-spacing: -0.34px;
    }
    .notice-view__info {
        gap: 12px;
    }
    .notice-view__info-item {
        font-size: 13px;
    }
    .notice-view__body {
        gap: 36px;
    }
    .notice-view__img-wrap {
        height: 220px;
        border-radius: 10px;
    }
    .notice-view__text {
        font-size: 14px;
    }
    .notice-view__file {
        padding: 16px 18px;
        gap: 12px;
        border-radius: 10px;
    }
    .notice-view__file-label {
        font-size: 14px;
    }
    .notice-view__file-link {
        font-size: 13px;
    }
    .notice-view__list-btn {
        height: 50px;
        padding: 0 40px;
        font-size: 15px;
    }
}

/* ===================================================
   온라인 문의 (inquiry) 반응형
=================================================== */
@media (max-width: 1024px) {
    .inquiry {
        padding: 60px 0 80px;
    }
    .inquiry__title {
        font-size: 40px;
        margin-bottom: 32px;
    }
    .inquiry__row {
        gap: 40px;
    }
    .inquiry__head-tit {
        font-size: 24px;
    }
    .inquiry__required-note {
        font-size: 16px;
    }
    .inquiry__label {
        font-size: 18px;
    }
    .inquiry__input,
    .inquiry__select,
    .inquiry__textarea {
        height: 60px;
        font-size: 16px;
    }
    .inquiry__custom-select-btn {
        height: 60px;
        font-size: 16px;
    }
    .inquiry__custom-select-list {
        top: 59px;
    }
    .inquiry__textarea {
        height: 140px;
    }
    .inquiry__agree-label {
        font-size: 18px;
    }
    .inquiry__btn {
        height: 68px;
        padding: 0 60px;
        font-size: 18px;
    }
}

@media (max-width: 768px) {
    .inquiry {
        padding: 48px 0 60px;
    }
    .inquiry__title {
        font-size: 32px;
        margin-bottom: 28px;
    }
    .inquiry__head {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }
    .inquiry__row {
        flex-direction: column;
        gap: 20px;
    }
    .inquiry__col {
        width: 100%;
        flex: none;
    }
    .inquiry__head-tit {
        font-size: 20px;
    }
    .inquiry__required-note {
        font-size: 14px;
    }
    .inquiry__label {
        font-size: 16px;
    }
    .inquiry__input,
    .inquiry__select,
    .inquiry__textarea {
        height: 54px;
        font-size: 15px;
        padding: 0 18px;
    }
    .inquiry__custom-select-btn {
        height: 54px;
        padding: 0 18px;
    }
    .inquiry__custom-select-list {
        top: 53px;
        padding: 16px 18px;
    }
    .inquiry__textarea {
        height: 120px;
        padding: 16px 18px;
    }
    .inquiry__input--tel {
        min-width: 0;
    }
    .inquiry__email-wrap {
        flex-wrap: wrap;
        gap: 8px;
    }
    .inquiry__email-wrap .inquiry__input:not(.inquiry__input--email-domain) {
        flex: 1 1 80px;
        min-width: 0;
    }
    .inquiry__input--email-domain {
        flex: 2 1 100px;
        min-width: 0;
        width: auto;
    }
    .inquiry__custom-select--email {
        flex: 0 0 100%;
        width: 100%;
    }
    .inquiry__agree-box {
        padding: 24px 20px;
        height: 200px;
    }
    .inquiry__agree-label {
        font-size: 16px;
    }
    .inquiry__agree-text {
        font-size: 14px;
    }
    .inquiry__btns {
        margin-top: 30px;
        gap: 8px;
    }
    .inquiry__btn {
        height: 56px;
        padding: 0 40px;
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .inquiry {
        padding: 36px 0 48px;
    }
    .inquiry__title {
        font-size: 26px;
        margin-bottom: 24px;
    }
    .inquiry__form {
        gap: 20px;
    }
    .inquiry__head-tit {
        font-size: 18px;
    }
    .inquiry__required-note {
        font-size: 13px;
    }
    .inquiry__label {
        font-size: 15px;
    }
    .inquiry__input,
    .inquiry__select,
    .inquiry__textarea {
        height: 50px;
        font-size: 14px;
        padding: 0 14px;
        border-radius: 8px;
    }
    .inquiry__custom-select-btn {
        height: 50px;
        padding: 0 14px;
        border-radius: 8px;
    }
    .inquiry__custom-select-list {
        top: 49px;
        padding: 14px;
        gap: 14px;
    }
    .inquiry__custom-select-item {
        font-size: 14px;
    }
    .inquiry__textarea {
        height: 100px;
        padding: 14px;
    }
    .inquiry__tel-wrap {
        gap: 6px;
    }
    .inquiry__input--tel {
        min-width: 0;
    }
    .inquiry__email-wrap {
        gap: 6px;
    }
    .inquiry__email-wrap .inquiry__input:not(.inquiry__input--email-domain) {
        flex: 1 1 60px;
        min-width: 0;
    }
    .inquiry__input--email-domain {
        flex: 2 1 80px;
        min-width: 0;
        width: auto;
    }
    .inquiry__custom-select--email {
        flex: 0 0 100%;
        width: 100%;
    }
    .inquiry__agree-box {
        padding: 18px 16px;
        height: 180px;
    }
    .inquiry__agree-label {
        font-size: 14px;
    }
    .inquiry__agree-text {
        font-size: 13px;
    }
    .inquiry__btns {
        flex-direction: column;
        margin-top: 24px;
        gap: 8px;
    }
    .inquiry__btn {
        width: 100%;
        height: 52px;
        padding: 0;
        font-size: 15px;
        border-radius: 10px;
    }
}

/* ===================================================
   제품 상세 뷰 (prod-view) 반응형
=================================================== */
@media (max-width: 1600px) {
    .prod-view__gallery {
        flex: 0 0 600px;
        width: 600px;
        min-height: 420px;
    }
    .prod-view__info {
        flex: 1;
        width: auto;
        min-height: auto;
    }
}

@media (max-width: 1280px) {
    .prod-view {
        padding: 80px 0 100px;
    }
    .prod-view__inner {
        gap: 80px;
    }
    .prod-view__gallery {
        flex: 0 0 480px;
        width: 480px;
        min-height: 360px;
    }
    .prod-view__info-inner {
        padding: 48px;
        gap: 24px;
    }
    .prod-view__section {
        gap: 80px;
    }
    .prod-view__section-title {
        font-size: 26px;
    }
}

@media (max-width: 1024px) {
    .prod-view {
        padding: 60px 0 80px;
    }
    .prod-view__inner {
        gap: 60px;
    }
    /* 상단: 갤러리+정보 세로 전환 */
    .prod-view__top {
        flex-direction: column;
        gap: 30px;
    }
    .prod-view__gallery {
        flex: none;
        width: 100%;
        min-height: 360px;
    }
    .prod-view__info {
        flex: none;
        width: 100%;
    }
    .prod-view__info-inner {
        padding: 40px;
    }
    /* 섹션: 헤드+콘텐츠 세로 전환 */
    .prod-view__section {
        flex-direction: column;
        gap: 20px;
    }
    .prod-view__section-head {
        align-items: center;
    }
    .prod-view__section-title {
        font-size: 24px;
    }
    .prod-view__section-num {
        width: 36px;
        height: 36px;
        font-size: 16px;
    }
    .prod-view__section-content {
        width: 100%;
    }
    /* 관련 제품: Swiper 슬라이드 모드 — 인디케이터 노출 */
    .prod-view__related-slider {
        overflow: visible;
    }
    .prod-view__related-grid {
        flex-wrap: nowrap;
    }
    .prod-view__related-grid .pcard {
        flex: 0 0 auto;
        width: auto;
    }
    .prod-view__related-pagination {
        display: block;
    }
    /* 스펙 테이블 th 너비 축소 */
    .prod-view__spec-table th {
        width: 200px;
    }
    .prod-view__spec-table th,
    .prod-view__spec-table td {
        font-size: 16px;
        padding: 16px;
    }
}

@media (max-width: 768px) {
    .prod-view {
        padding: 48px 0 60px;
    }
    .prod-view__inner {
        gap: 48px;
    }
    .prod-view__gallery {
        min-height: 280px;
        border-radius: 20px;
    }
    .prod-view__info {
        border-radius: 20px;
    }
    .prod-view__info-inner {
        padding: 30px;
        gap: 20px;
    }
    .prod-view__category {
        font-size: 16px;
    }
    .prod-view__name {
        font-size: 28px;
    }
    .prod-view__meta-label {
        font-size: 16px;
    }
    .prod-view__meta-list li {
        font-size: 16px;
    }
    .prod-view__btn {
        width: 140px;
        height: 58px;
        font-size: 16px;
    }
    .prod-view__body {
        gap: 48px;
    }
    .prod-view__section-content {
        padding: 24px;
    }
    .prod-view__section-content > p {
        font-size: 16px;
    }
    .prod-view__feature-title {
        font-size: 18px;
        height: auto;
    }
    .prod-view__feature > p {
        font-size: 16px;
    }
    .prod-view__feature-img img {
        height: 240px;
    }
    /* 스펙 테이블: th 50% 고정, td 나머지 */
    .prod-view__spec-table tr {
        flex-wrap: wrap;
    }
    .prod-view__spec-table th {
        width: 40%;
        flex-shrink: 0;
    }
    .prod-view__spec-table td {
        width: 60%;
        flex: 1;
        justify-content: flex-start;
        text-align: left;
    }
    .prod-view__spec-table th,
    .prod-view__spec-table td {
        font-size: 15px;
        padding: 14px 16px;
    }
    .prod-view__back-btn {
        width: 180px;
        height: 58px;
        font-size: 17px;
    }
}

@media (max-width: 480px) {
    .prod-view {
        padding: 36px 0 48px;
    }
    .prod-view__inner {
        gap: 36px;
    }
    .prod-view__gallery {
        min-height: 220px;
        border-radius: 16px;
    }
    .prod-view__info {
        border-radius: 16px;
    }
    .prod-view__info-inner {
        padding: 24px 20px;
        gap: 16px;
    }
    .prod-view__name {
        font-size: 24px;
    }
    .prod-view__btn {
        flex: 1 1 calc((100% - 10px) / 2);
        width: auto;
        height: 52px;
        font-size: 14px;
    }
    .prod-view__body {
        gap: 36px;
    }
    .prod-view__section-content {
        padding: 18px 16px;
        border-radius: 14px;
    }
    .prod-view__feature + .prod-view__feature {
        margin-top: 36px;
    }
    .prod-view__feature-img img {
        height: 180px;
    }
    .prod-view__spec-table th {
        width: 44%;
    }
    .prod-view__spec-table td {
        width: 56%;
    }
    .prod-view__spec-table th,
    .prod-view__spec-table td {
        font-size: 13px;
        padding: 12px 12px;
    }
    .prod-view__back-btn {
        width: 160px;
        height: 52px;
        font-size: 16px;
    }
}