/* ============================================================
   Mobile polish — 모바일 (≤1200px) 레이아웃 보정.
   목표: 모든 페이지가 모바일에서 자연스러운 흐름·간격·hierarchy 로
   보이도록 KR/EN 공통 base 보강.
   ============================================================ */

@media only screen and (max-width: 1200px) {

  /* ── 0. 모바일 헤더 재구성 — 로고 왼쪽, lang + 햄버거 오른쪽. tel 아이콘 제거.
        layout.css 가 cascade 마지막에 로드되어 specificity 동률 시 우리 패치가 짐.
        html 접두로 specificity ↑ (0,0,2,1 vs layout 의 0,0,2,0). ── */
  html .tel_m { display: none !important; }

  /* 헤더 컨테이너 */
  html .header {
    background: rgba(255, 255, 255, 0.96) !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-bottom: 1px solid rgba(217, 207, 194, 0.4);
  }
  html .header,
  html .header .inner {
    height: 56px !important;
  }
  html .header .inner {
    text-align: left !important;
    padding: 0 16px !important;
    position: relative;
  }

  /* 로고 — 왼쪽 정렬, 사이즈 축소, .on 상태 무관 항상 다크 (모바일 헤더는 흰 BG). */
  html .header .inner h1 {
    padding: 14px 0 0 0 !important;
    margin: 0 !important;
  }
  html .header .inner h1 a,
  html .header.on .inner h1 a,
  html .header.is-scrolled .inner h1 a {
    width: 96px !important;
    height: 26px !important;
    background: url(/img/logo_dark.svg) left center / contain no-repeat !important;
  }

  /* 우측 lang 토글 — 햄버거 왼쪽에 pill 형태로 */
  html .header .lang {
    display: inline-flex !important;
    position: absolute !important;
    top: 12px !important;
    right: 56px !important;
    height: auto !important;
    width: auto !important;
  }
  html .header .lang .tab,
  html .header.on .lang .tab,
  html .header.is-scrolled .lang .tab {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: auto !important;
    height: 32px !important;
    padding: 0 26px 0 12px !important;
    font-family: 'Pretendard Variable', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.04em !important;
    color: #393939 !important;
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid rgba(217, 207, 194, 0.7) !important;
    border-radius: 999px !important;
    cursor: pointer;
    line-height: 30px !important;
    position: relative;
    box-sizing: border-box !important;
    margin: 0 !important;
  }
  .header .lang .tab::after {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    width: 6px;
    height: 6px;
    border-right: 1.4px solid currentColor;
    border-bottom: 1.4px solid currentColor;
    /* default(closed) = ⌄ 아래 방향 — dropdown 펼침 hint */
    transform: translate(0, -65%) rotate(-135deg);
    transition: transform 0.25s ease;
  }
  .header .lang.on .tab::after {
    /* open = ⌃ 위 방향 */
    transform: translate(0, -30%) rotate(45deg);
  }
  .header .lang ul {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    right: 0 !important;
    left: auto !important;
    margin: 0 !important;
    padding: 6px 0 !important;
    min-width: 96px;
    background: #fff !important;
    border-radius: 8px !important;
    box-shadow: 0 12px 32px -8px rgba(58, 47, 38, 0.18);
    list-style: none;
    z-index: 100;
  }
  .header .lang ul li {
    margin: 0 !important;
    padding: 0 !important;
    height: auto !important;
    display: block !important;
  }
  .header .lang ul li a {
    display: block !important;
    padding: 9px 18px !important;
    font-size: 12px !important;
    text-align: center;
    color: #5d5247 !important;
    background: transparent !important;
  }
  .header .lang ul li a.on {
    color: #aa8e7d !important;
    font-weight: 500 !important;
  }

  /* 햄버거 — 우측, 모던 inline SVG (기존 PNG 누락 대응) */
  html .m_open {
    position: absolute !important;
    right: 16px !important;
    top: 12px !important;
    width: 32px !important;
    height: 32px !important;
    background: transparent !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23393939' stroke-width='1.6' stroke-linecap='round'><line x1='4' y1='8' x2='20' y2='8'/><line x1='4' y1='14' x2='20' y2='14'/><line x1='4' y1='20' x2='20' y2='20'/></svg>") !important;
    background-size: 22px 22px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
  }
  body.on .m_open {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='1.6' stroke-linecap='round'><line x1='6' y1='6' x2='18' y2='18'/><line x1='18' y1='6' x2='6' y2='18'/></svg>") !important;
  }

  /* ── Footer wordmark — 모바일에서는 너무 큼. 숨김. ── */
  .footer .fv2-wordmark { display: none !important; }

  /* ── Hero (.section1) — 모바일 텍스트 세로 중앙 + 스크롤 인디케이터 숨김. ── */
  html .section_main.section1 {
    position: relative !important;
  }
  html .section_main.section1 .slider_banner.mobile .ment {
    position: absolute !important;
    top: 50% !important;
    left: 0 !important;
    right: 0 !important;
    transform: translateY(-50%) !important;
    margin-top: 0 !important;
    z-index: 5;
  }
  /* 스크롤 다운 인디케이터 (원형 + 화살표) — 하단 quick bar 와 겹쳐서 숨김 */
  html .section_main.section1 .scroll.go_top,
  html .section_main.section1 a.scroll {
    display: none !important;
  }

  /* ── DETAIL VIEW 버튼 — 모바일에서 underline 전체 폭으로 (hover 없음 = 정적). ── */
  .section_main.section2 .left .btn_area .btn_style::before {
    width: 100% !important;
  }
  .section_main.section2 .left .btn_area .btn_style::after {
    transform: translateX(4px);
  }

  /* ── Mobile drawer (.m_menu) — 미니멀 모던 리디자인 v2.
        drawer-enhance.js 가 런타임에 .dv2-* 마크업을 inject.
        기존 .top → .dv2-header 로 교체, gnb 뒤에 .dv2-cta-block + .dv2-info-card,
        하단 언어는 .dv2-lang 으로 변형. ── */
  .m_menu {
    background: #fdfaf5 !important;
    box-shadow: -12px 0 48px -16px rgba(58, 47, 38, 0.20);
    /* 슬라이드 전환 (script.js 의 right:-100% → 0 패턴 위에 부드러움 보정) */
    transition: right 0.32s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
    /* 콘텐츠가 viewport 보다 길 때 drawer 내부 스크롤 (CTA + 미니카드 + lang 까지 닿게) */
    height: 100vh !important;
    max-height: 100vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  /* Legacy fallback — drawer-enhance.js 가 안 돌았을 때만 보이는 .top. */
  .m_menu .top {
    padding: 14px 16px 6px !important;
    border-bottom: 1px solid rgba(217, 207, 194, 0.32);
    background: transparent !important;
  }
  .m_menu .top .info_top { display: none !important; }
  .m_menu .top .m_close {
    width: 30px !important;
    height: 30px !important;
    background: transparent !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23393939' stroke-width='1.6' stroke-linecap='round'><line x1='6' y1='6' x2='18' y2='18'/><line x1='18' y1='6' x2='6' y2='18'/></svg>") !important;
    background-size: 22px 22px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    border: 0 !important;
    text-indent: -9999px;
    font-size: 0 !important;
    color: transparent !important;
  }

  /* ── drawer v2 header: 로고 좌 + 닫기 우 ── */
  .m_menu .dv2-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 18px 5% 14px !important;
    border-bottom: 1px solid rgba(58, 47, 38, 0.08);
    background: #fdfaf5 !important;
  }
  .m_menu .dv2-logo {
    display: inline-flex;
    align-items: center;
    height: 26px;
  }
  .m_menu .dv2-logo img {
    height: 22px;
    width: auto;
    display: block;
  }
  .m_menu .dv2-close {
    width: 32px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    color: #2a2521;
    cursor: pointer;
    border-radius: 999px;
    transition: background-color 0.18s ease;
    /* legacy .m_close 의 "Close" text 무력화 */
    font-size: 0 !important;
    line-height: 0 !important;
    text-indent: 0 !important;
  }
  .m_menu .dv2-close:hover,
  .m_menu .dv2-close:focus-visible {
    background: rgba(193, 169, 154, 0.16) !important;
    outline: none;
  }
  .m_menu .dv2-close svg {
    width: 20px;
    height: 20px;
    display: block;
  }
  /* 대분류 메뉴 */
  .m_menu .gnb_m {
    padding: 8px 0 12px !important;
  }
  .m_menu .gnb_m > ul > li {
    border-bottom: 1px solid rgba(58, 47, 38, 0.07);
    padding: 0 !important;
    position: relative;
  }
  .m_menu .gnb_m > ul > li > a.big {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center;
    padding: 16px 5% !important;
    font-family: 'Pretendard Variable', sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    letter-spacing: -0.005em !important;
    color: #2a2521 !important;
    background: transparent !important;
    transition: background-color 0.18s ease;
  }
  .m_menu .gnb_m > ul > li > a.big:active,
  .m_menu .gnb_m > ul > li > a.big:focus-visible {
    background: #f8f3e8 !important;
    outline: none;
  }
  .m_menu .gnb_m > ul > li > a.big::after {
    content: '';
    width: 8px;
    height: 8px;
    border-right: 1.6px solid #c1a99a;
    border-bottom: 1.6px solid #c1a99a;
    transform: rotate(-45deg);
    transition: transform 0.25s ease, border-color 0.18s ease;
    margin-right: 2px;
  }
  .m_menu .gnb_m > ul > li.on > a.big::after,
  .m_menu .gnb_m > ul > li > a.big.on::after {
    transform: rotate(45deg);
  }

  /* 활성 메뉴 강조 — taupe accent bar 좌측 + bold + taupe 색 */
  .m_menu .gnb_m > ul > li.dv2-active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px;
    bottom: 8px;
    width: 3px;
    border-radius: 0 2px 2px 0;
    background: #c1a99a;
  }
  .m_menu .gnb_m > ul > li.dv2-active > a.big,
  .m_menu .gnb_m > ul > li > a.big.dv2-active-a {
    color: #8a6f5e !important;
    font-weight: 600 !important;
  }
  .m_menu .gnb_m > ul > li.dv2-active > a.big::after {
    border-color: #8a6f5e !important;
  }

  /* 서브메뉴 */
  .m_menu .gnb_m .sub {
    background: #f8f3e8 !important;
    padding: 6px 0 12px !important;
  }
  .m_menu .gnb_m .sub li {
    border: 0 !important;
  }
  .m_menu .gnb_m .sub li a {
    display: block !important;
    padding: 11px 8% !important;
    font-size: 13.5px !important;
    color: #5d5247 !important;
    background: transparent !important;
  }

  /* ── CTA block (Quick Booking + 1:1 Consult) ── */
  .m_menu .dv2-cta-block {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 18px 5% 16px !important;
    border-top: 1px solid rgba(58, 47, 38, 0.07);
  }
  .m_menu .dv2-cta {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 14px 18px !important;
    font-family: 'Pretendard Variable', sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em;
    border-radius: 4px !important;
    cursor: pointer;
    text-decoration: none !important;
    transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
    box-sizing: border-box;
  }
  .m_menu .dv2-cta-primary {
    background: #c1a99a !important;
    color: #ffffff !important;
    border: 1px solid #c1a99a !important;
  }
  .m_menu .dv2-cta-primary:active {
    background: #ad9685 !important;
    border-color: #ad9685 !important;
  }
  .m_menu .dv2-cta-secondary {
    background: transparent !important;
    color: #8a6f5e !important;
    border: 1px solid #c1a99a !important;
  }
  .m_menu .dv2-cta-secondary:active {
    background: #f8f3e8 !important;
  }
  .m_menu .dv2-cta-arrow {
    font-family: 'Cormorant Garamond', serif;
    font-size: 16px;
    line-height: 1;
    transform: translateX(0);
    transition: transform 0.2s ease;
  }
  .m_menu .dv2-cta:active .dv2-cta-arrow {
    transform: translateX(3px);
  }

  /* ── 미니 카드 (주소 / 전화 / 진료시간) ── */
  .m_menu .dv2-info-card {
    margin: 0 5% 14px !important;
    padding: 14px 16px !important;
    background: rgba(248, 243, 232, 0.55);
    border: 1px solid rgba(58, 47, 38, 0.06);
    border-radius: 4px;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .m_menu .dv2-info-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-family: 'Pretendard Variable', sans-serif;
    font-size: 12px !important;
    line-height: 1.6 !important;
    color: #393939;
  }
  .m_menu .dv2-info-icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 18px;
    color: #c1a99a;
  }
  .m_menu .dv2-info-text {
    flex: 1 1 auto;
    word-break: keep-all;
    color: #393939;
    text-decoration: none;
  }
  .m_menu .dv2-info-link {
    color: #393939;
    border-bottom: 1px dotted rgba(193, 169, 154, 0.6);
    padding-bottom: 1px;
  }

  /* 하단 lang 토글 — 네이티브 라벨 */
  .m_menu .wrap_info_bottom {
    border-top: 1px solid rgba(58, 47, 38, 0.07);
    padding: 16px 5% !important;
    background: rgba(253, 250, 245, 0.6);
  }
  .m_menu .info_bottom {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px 10px;
    justify-content: center;
  }
  .m_menu .info_bottom a,
  .m_menu .info_bottom .dv2-lang {
    font-family: 'Pretendard Variable', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: #5d5247 !important;
    letter-spacing: 0.02em;
    text-decoration: none;
    padding-bottom: 1px;
  }
  .m_menu .info_bottom a.on,
  .m_menu .info_bottom .dv2-lang.on {
    color: #c1a99a !important;
    border-bottom: 1.5px solid #c1a99a;
    padding-bottom: 1px;
  }
  .m_menu .info_bottom i,
  .m_menu .info_bottom .dv2-lang-sep {
    color: rgba(193, 169, 154, 0.45) !important;
    font-style: normal;
    font-size: 11px;
  }

  /* ── 1. 우측 quick bar — i18n 후 버튼 4개 (Consult/WhatsApp/LINE/TOP) 만 남음.
        원본 layout.css 는 6개 가정해 16.66% 너비 → 우측에 33% 공백 발생.
        bg 없으면 fixed bar 가 투명 → 스크롤 시 아래 콘텐츠가 아이콘 사이로 비침.
        z-index: layout.css `.section_main .inner { z-index:99 }` 가 카드 stacking
        context 를 99 로 끌어올림 → 90 으로는 카드가 quick bar 위로 paint. 9999 로
        elevate (header 와 동일 레벨이나 화면상 겹치지 않음). ── */
  html .quick.mobile.rightQuick {
    background: #ffffff !important;
    backdrop-filter: saturate(1.1);
    box-shadow: 0 -1px 12px -4px rgba(58, 47, 38, 0.10);
    z-index: 9999 !important;
    border-top: 1px solid rgba(58, 47, 38, 0.06);
  }
  .quick.mobile.rightQuick > ul {
    display: flex !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .quick.mobile.rightQuick > ul > li {
    flex: 1 1 0 !important;
    width: auto !important;
    margin: 0 !important;
    float: none !important;
  }

  /* ── 2. quick bar 가 콘텐츠 가리지 않도록 footer 아래 padding 확보. ── */
  body {
    padding-bottom: 65px !important;
  }
  /* 모바일 드로어 열렸을 땐 quick bar 숨김 (메뉴와 시각 충돌) */
  body.on .quick.mobile.rightQuick {
    display: none !important;
  }

  /* ── 3. Hero 모바일 — 헤딩·서브텍스트 폭 보정 + safe padding. ── */
  .section_main.section1 .slider_banner.mobile .ment .in {
    max-width: 100% !important;
    padding: 0 4vw !important;
  }
  .section_main.section1 .ment .txt1 {
    font-size: clamp(36px, 11vw, 56px) !important;
    line-height: 0.95 !important;
    word-break: keep-all;
  }
  .section_main.section1 .ment .txt2 {
    font-size: 14px !important;
    line-height: 1.7 !important;
    word-break: keep-all;
    max-width: 92vw;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* ── 4. Sub 페이지 hero (.sub_top) — 모바일에서 헤딩 잘림 방지. ── */
  .sub_top .ment p.txt1,
  .sub_top .ment p.txt2 {
    font-size: clamp(13px, 3.6vw, 16px) !important;
    word-break: keep-all;
    padding: 0 6vw;
  }
  .sub_top .ment p.txt2 {
    font-size: clamp(28px, 7.5vw, 44px) !important;
    line-height: 1.15 !important;
  }
  .sub_top .ment p.txt3 {
    font-size: 13px !important;
  }

  /* ── 5. Sub 페이지 본문 컬럼 - 좌우 패딩 + 텍스트 wrap. ── */
  .sub_cont .ment {
    padding: 32px 5vw 0 !important;
  }
  .sub_cont .ment p.txt1,
  .sub_cont .ment p.txt3 {
    word-break: keep-all;
    line-height: 1.65;
  }
  .sub_cont .left .ment,
  .sub_cont .right .ment {
    width: 100% !important;
    float: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* ── 6. .list_icon ul li — 모바일에서 가로 5개 grid 불가능. 2열 stack.
        align-items: stretch (default) 로 카드 세로 동일. 가로 패딩 충분히. ── */
  html .list_icon ul {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    grid-auto-rows: 1fr !important;
    gap: 12px !important;
    width: 100% !important;
    padding: 0 5vw !important;
    box-sizing: border-box !important;
    align-items: stretch !important;
  }
  html .list_icon ul li {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 28px 22px !important;
    float: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
  }
  html .list_icon ul li .txt {
    flex: 1 1 auto;
  }
  html .list_icon ul li .txt strong {
    font-size: 17px !important;
    padding-bottom: 12px !important;
  }
  html .list_icon ul li .txt p {
    font-size: 14px !important;
    line-height: 1.6 !important;
    word-break: keep-all;
  }

  /* ── 7. .list_icon4 등 4-card 행 — 2열 stack. ── */
  .list_icon4 ul {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px !important;
  }
  .list_icon4 ul li {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    float: none !important;
  }

  /* ── 8. section3 그리드 — s3-grid-list 모바일에서 1열 stack (지금은 6열) ── */
  .section_main.section3 .s3-grid-list {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
    padding: 0 5vw !important;
    box-sizing: border-box;
  }
  .section_main.section3 .s3-grid-list > li {
    grid-column: auto !important;
  }
  .section_main.section3 .inner::before {
    font-size: clamp(32px, 8vw, 48px) !important;
    margin-bottom: 24px !important;
  }

  /* ── 9. section-director (3 doctor cards) — 1열 stack. ── */
  .section_main.section-director .sd-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .section_main.section-director .sd-card__portrait {
    aspect-ratio: 4 / 5;
    max-height: 60vh;
  }

  /* ── 10. section5 mosaic — 모바일 1열 stack. 자식 모두 column/row auto. ── */
  html .section_main.section5 .s5-mosaic {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    gap: 12px !important;
    margin-bottom: 20px !important;
  }
  html .section_main.section5 .s5-mosaic > .s5-case {
    grid-column: auto !important;
    grid-row: auto !important;
    aspect-ratio: 16 / 10;
  }
  /* 더 많은 사례 CTA — mosaic 와 자연스러운 간격 */
  html .section_main.section5 .s5-cta {
    margin-top: 8px !important;
    padding: 0 5vw !important;
  }

  /* ── 11. Footer v2 — 모바일 자연스러운 스택. ── */
  .footer .fv2-sitemap {
    grid-template-columns: 1fr 1fr !important;
    gap: 28px 16px !important;
  }
  .footer .fv2-contact-row {
    flex-direction: column !important;
    gap: 24px !important;
  }
  .footer .fv2-map {
    width: 100% !important;
    height: 200px !important;
  }
  .footer .fv2-wordmark {
    font-size: clamp(40px, 11vw, 72px) !important;
  }

  /* ── 12. CELLON Signature heading - section3 인트로 위 백지 줄임. ── */
  .section_main.section3 {
    padding-top: 24px !important;
  }
  .section_main.section3 .inner {
    padding: 40px 5% 24px !important;
  }

  /* ── 13. Director 카드 (intro03 등) — 이름 + 직함이 한 p.txt1 안에 inline.
        layout.css `.sub_cont .info .ment p.txt1 { font-size:40px; line-height:normal }`
        가 mobile 에서도 그대로 → 좁은 viewport 에서 wrap 시 line-height 부족으로
        이름과 "Director" 가 시각적으로 겹침. ── */
  html .sub_cont .info .ment p.txt1,
  html .sub_cont .info .ment p.txt1 strong {
    font-size: 22px !important;
    line-height: 1.35 !important;
  }
  html .sub_cont .info .ment p.txt1 strong {
    display: block;
    margin-bottom: 4px;
  }

  /* ── 14. AOS fallback — script.js 의 AOS.init({ disable:'mobile' }) 가 모바일에서
        [data-aos] 의 inline pre-state (opacity:0 + translateY(100px)) 를 정리하지
        않음 → 카드/헤딩이 영원히 안 보이는 stuck 발생. mobile 에선 reveal 애니
        무력화하고 즉시 visible 처리. ── */
  [data-aos] {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ── 13. 매우 좁은 모바일 (≤480px) — .list_icon 한 줄에 1개로 폴백. ── */
@media (max-width: 480px) {
  .list_icon ul {
    grid-template-columns: 1fr !important;
  }
  .list_icon4 ul {
    grid-template-columns: 1fr !important;
  }
  .section_main.section3 .s3-grid-list {
    grid-template-columns: 1fr !important;
  }
}
