/* ── Reset & Variables ── */
    *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

    :root {
      --bg:         #fbfaf7;
      --bg2:        #ffffff;
      --surface:    rgba(255,255,255,0.94);
      --text:       #1d1d1f;
      --text-sub:   #6e6e73;
      --line:       rgba(0,0,0,0.06);
      --gold:       #e8be59;
      --gold-deep:  #c79a2c;
      --gold-soft:  #fff7df;
      --gold-xsoft: #fffaf0;
      --shadow:     0 24px 60px rgba(15,23,42,0.07);
      --shadow-sm:  0 8px 24px rgba(15,23,42,0.05);
      --shadow-xs:  0 4px 12px rgba(15,23,42,0.04);
      --radius-xl:  38px;
      --radius-lg:  28px;
      --radius-md:  20px;
      --radius-sm:  14px;
      --radius-xs:  10px;
      --font:       'Noto Sans KR', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', sans-serif;
      --t-ease:     cubic-bezier(.4,0,.2,1);
    }

    html { scroll-behavior: smooth; }
    
    /* ── PC 125% 확대 적용 (모바일 제외) ── */
    /* @media (min-width: 769px) {
      header, footer, section {
        zoom: 1.25;
      }
    } */

    body {
      font-family: var(--font);
      color: var(--text);
      background:
        radial-gradient(circle at 12% 14%, rgba(232,190,89,.10), transparent 18%),
        radial-gradient(circle at 88% 16%, rgba(232,190,89,.06), transparent 15%),
        linear-gradient(180deg, #ffffff 0%, #fbfaf7 56%, #f7f5ef 100%);
      min-height: 100vh;
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }
    a { text-decoration: none; color: inherit; -webkit-tap-highlight-color: transparent; }
    img { max-width: 100%; }

    ol,ul,dl{margin:0;padding:0;list-style-type:none;}
    a{text-decoration: none!important;}
    a:focus{outline: 0;}
    

    /* ── Layout ── */
    .page { min-height: 100vh; display: flex; flex-direction: column; padding: 0 0 24px; }
    .shell { width: 100%; max-width: 1280px; margin: 0 auto; flex: 1; display: flex; flex-direction: column; padding: 0 24px; }

    /* ── Header ── */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 200;
      margin-bottom: 30px;
      background: rgba(255,255,255,.95);
      border-bottom: 1px solid rgba(0,0,0,.07);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      box-shadow: 0 2px 12px rgba(15,23,42,.06);
    }
    .header-top {
      max-width: 1280px;
      margin: 0 auto;
      padding: 0 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      height: 68px;
      gap: 16px;
    }
    .logo-wrap {
      display: flex; align-items: center; gap: 12px; flex-shrink: 0; text-decoration: none;
      padding-right: 8px;
    }
    .logo-svg { display: none; }
    .logo-mark {
      height: 52px; width: auto; display: block;
      object-fit: contain;
      filter: saturate(1.02);
    }

    /* 로고+메뉴를 왼쪽에 함께 묶는 래퍼 */
    .header-left { display: flex; align-items: center; gap: 4px; flex: 1; min-width: 0; }
    .nav-links { display: flex; align-items: center; gap: 0; margin-left: 12px; }
    .nav-links a {
      padding: 0 16px;
      height: 68px;
      display: flex; align-items: center;
      font-size: 14px; font-weight: 600;
      color: var(--text);
      border-bottom: 3px solid transparent;
      transition: all .2s var(--t-ease);
      white-space: nowrap;
    }
    .nav-links a:hover {
      color: var(--gold-deep);
      border-bottom-color: var(--gold-deep);
    }
    .header-actions {
      display: flex; align-items: center; gap: 10px; flex-shrink: 0;
    }
    .nav-cta, .nav-burger {
      display: inline-flex;
      width: 44px; height: 44px;
      background: rgba(255,255,255,.82);
      border: 1px solid rgba(0,0,0,.08);
      border-radius: 999px;
      cursor: pointer;
      align-items: center; justify-content: center;
      font-size: 16px; color: var(--text) !important;
      flex-shrink: 0;
      box-shadow: 0 6px 18px rgba(15,23,42,.06);
      transition: all .22s var(--t-ease);
      padding: 0;
    }
    .nav-cta span { display: none; }
    .nav-cta:hover, .nav-burger:hover {
      transform: translateY(-1px);
      background: #fff;
      border-color: rgba(199,154,44,.22);
      color: var(--gold-deep) !important;
    }
    .topbar-note-sm { display: none; }

    /* ── Hero ── */
    .hero {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 24px;
    }

    /* Hero Slideshow Panel */
    /* 1. 슬라이드 패널 (모서리 깨짐 방지 추가) */
    .hero-slide-panel {
      width: 100%;
      border-radius: var(--radius-xl);
      overflow: hidden;
      position: relative;
      box-shadow: var(--shadow);
      display: grid;

      /* 📌 추가: 둥근 모서리 바깥으로 삐져나오는 짜글짜글한 픽셀 강제 정리 */
      transform: translateZ(0); 
      backface-visibility: hidden;
    }   

    /* 2. 슬라이드 (안 보이는 건 완전히 숨김 처리) */
    .slide {
      grid-area: 1 / 1;
      opacity: 0; 

      /* 📌 추가: 투명해진 슬라이드는 화면 렌더링에서 완전히 제외 */
      visibility: hidden; 

      /* 📌 수정: opacity와 visibility가 같이 부드럽게 작동하도록 애니메이션 설정 */
      transition: opacity .9s var(--t-ease), visibility .9s var(--t-ease);

      width: 100%;
      height: 100%;
    }   

    /* 3. 활성화된 슬라이드 */
    .slide.active { 
      opacity: 1; 

      /* 📌 추가: 활성화된 슬라이드만 화면에 등장 */
      visibility: visible; 
      z-index: 2; 
    }

    /* 4. 이미지 셋팅 (가장 중요) */
    .slide-img img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover; /* 이미지가 찌그러지지 않고 영역을 가득 채우면서 남는 부분은 잘라냄 */
    }

    /* (반응형 PC/모바일 이미지 숨김 처리는 기존과 동일하게 유지) */
    .m-img { display: none; }
    @media (max-width: 768px) {
      .pc-img { display: none; }
      .m-img { display: block; }
    }
    
    /* 활성화된 슬라이드가 맨 위로 올라오도록 z-index 추가 */
    .slide.active { opacity: 1; z-index: 2; } 
    .slide::after { display: none; }
    
    .slide-content {
      position: absolute; inset: 0; z-index: 3; /* 이미지보다 위에 오도록 3으로 수정 */
      display: flex; flex-direction: column; justify-content: center;
      padding: 52px 64px;
      max-width: 780px;
    }
    .slide-badge {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 7px 14px;
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.22);
      border-radius: 999px;
      color: var(--text); font-size: 12px; font-weight: 700;
      letter-spacing: .8px; text-transform: uppercase;
      backdrop-filter: blur(8px);
      margin-bottom: 18px;
      width: fit-content;
    }
    .slide-badge-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); }
    .slide-title {
      font-size: clamp(28px, 3.6vw, 52px);
      font-weight: 800; letter-spacing: -1.5px;
      color: var(--text); line-height: 1.12;
      margin-bottom: 14px;
    }
    .slide-title em { color: var(--gold); font-style: normal; }
    .slide-desc {
      font-size: clamp(14px, 1.4vw, 17px);
      color: var(--text-sub);
      line-height: 1.7; font-weight: 400;
      max-width: 440px; margin-bottom: 28px;
    }
    .slide-cta {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 13px 26px;
      background: var(--gold-deep); color: #fff;
      border-radius: 999px; font-size: 15px; font-weight: 700;
      box-shadow: 0 4px 16px rgba(199,154,44,.20);
      transition: all .22s var(--t-ease); width: fit-content;
    }
    .slide-cta:hover { background: #b58a24; transform: translateY(-2px); }
    
    .slide-dots {
      position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
      z-index: 4; /* 컨트롤러가 가장 위에 오도록 수정 */
      display: flex; gap: 8px;
    }
    .sdot {
      width: 10px; height: 10px; border-radius: 50%;
      background: rgba(29,29,31,.28);
      border: 1px solid rgba(29,29,31,.16);
      cursor: pointer;
      transition: all .3s var(--t-ease); padding: 0;
      box-shadow: 0 2px 8px rgba(15,23,42,.10);
    }
    .sdot.on {
      background: var(--gold-deep);
      width: 24px; border-radius: 999px;
      border-color: rgba(199,154,44,.34);
    }


    /* -custom slide- */
    .hero-slide-panel .slide:nth-child(1){
      background-color: #fff;
    }
    .hero-slide-panel .slide:nth-child(2){
      background-color: #fff;
    }
    .hero-slide-panel .slide:nth-child(3){
      background-color: #fff;
    }

    /* ── Trust Strip ── */
    .trust-strip {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 14px;
    }
    .trust-item {
      display: flex; align-items: center; gap: 12px;
      padding: 18px 20px;
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-sm);
      backdrop-filter: blur(10px);
      box-shadow: var(--shadow-xs);
      transition: all .28s var(--t-ease);
    }
    .trust-item:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); border-color: rgba(232,190,89,.20); }
    .trust-icon { width: 35px; flex-shrink: 0; display: flex; align-items: center;}
    .trust-text { display: flex; flex-direction: column; gap: 2px; }
    .trust-label { font-size: 13px; font-weight: 700; color: var(--text); }
    .trust-sub { font-size: 11px; color: var(--text-sub); font-weight: 400; }

    /* ── Section Base ── */
    .section { padding: 80px 0; }
    .section-tint { background: rgba(255,255,255,.60); border-radius: var(--radius-xl); padding: 64px 54px; margin-bottom: 24px; border: 1px solid rgba(0,0,0,.04); box-shadow: var(--shadow-xs); }
    .section-eyebrow {
      display: inline-flex; align-items: center; gap: 8px;
      font-size: 12px; font-weight: 800; letter-spacing: 1.4px;
      text-transform: uppercase; color: var(--gold-deep);
      margin-bottom: 14px;
    }
    .section-eyebrow::before {
      content: ''; width: 20px; height: 2px;
      background: var(--gold); border-radius: 2px;
    }
    .section-title {
      font-size: clamp(28px, 3.2vw, 44px);
      font-weight: 800; letter-spacing: -1.2px;
      color: var(--text); line-height: 1.2; margin-bottom: 14px;
    }
    .section-title em { color: var(--gold-deep); font-style: normal; }
    .section-desc { font-size: 16px; color: var(--text-sub); line-height: 1.8;  }
    .center { text-align: center; }
    .center .section-desc { margin: 0 auto; }
    .center .section-eyebrow { margin: 0 auto 14px; }

    /* ── About ── */
    .about-grid {
      display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 44px;
    }
    .about-card {
      padding: 36px 32px;
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-xs);
      transition: all .3s var(--t-ease);
    }
    .about-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-sm); border-color: rgba(232,190,89,.20); }
    .about-card-icon { margin-bottom: 18px; }
    .about-card-icon img{ height: 60px; }
    .about-card h3 { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 10px; letter-spacing: -.4px; }
    .about-card p { font-size: 14px; color: var(--text-sub); line-height: 1.8; }
    .stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 32px; }
    .stat-item {
      text-align: center; padding: 24px 16px;
      background: linear-gradient(135deg, var(--gold-xsoft), #fff);
      border: 1px solid rgba(232,190,89,.18);
      border-radius: var(--radius-sm);
    }
    .stat-num { font-size: 32px; font-weight: 900; color: var(--gold-deep); letter-spacing: -1px; line-height: 1; margin-bottom: 6px; }
    .stat-label { font-size: 12px; color: var(--text-sub); font-weight: 500; }

    /* ── Services ── */
    #services{
      margin: 0 auto;
      max-width: 900px;
    }
    .services-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 44px; }
    .service-card {
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: var(--shadow-xs);
      transition: all .3s var(--t-ease);
    }
    .service-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: rgba(232,190,89,.20); }
    .service-img {
      aspect-ratio: 16/7;
      background-size: cover; background-position: center;
      background-color: #f0ece0;
      position: relative;
    }
    .service-img-icon {
      aspect-ratio: 16/7;
      background: linear-gradient(135deg, var(--gold-xsoft) 0%, #fff7df 100%);
      display: flex; align-items: center; justify-content: center;
    }
    .service-img-icon svg { width: 60%; max-width: 200px; }
    .service-badge {
      position: absolute; top: 16px; left: 16px;
      padding: 5px 12px;
      background: var(--gold-deep); color: #fff;
      font-size: 11px; font-weight: 700; letter-spacing: .4px;
      border-radius: 999px;
    }
    .service-badge.warm { background: var(--gold); color: #1d1d1f; }
    .service-body { padding: 28px 28px 24px; }
    .service-num { font-size: 11px; font-weight: 800; color: var(--gold-deep); letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 8px; }
    .service-title { font-size: 22px; font-weight: 800; color: var(--text); letter-spacing: -.5px; margin-bottom: 6px; }
    .service-sub { font-size: 13px; color: var(--text-sub); line-height: 1.7; margin-bottom: 16px; }
    .service-features { list-style: none; display: flex; flex-direction: column; gap: 6px; }
    .service-features li {
      display: flex; align-items: flex-start; gap: 8px;
      font-size: 13px; color: #3a3a3c;
    }
    .service-features li::before {
      content: '✦'; color: var(--gold-deep); font-size: 10px;
      flex-shrink: 0; margin-top: 3px;
    }

    /* Mini services */
    .mini-services { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
    .mini-chip {
      display: inline-flex; align-items: center; gap: 7px;
      padding: 10px 18px;
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(0,0,0,.07);
      border-radius: 999px;
      font-size: 14px; font-weight: 600; color: var(--text);
      box-shadow: var(--shadow-xs);
      transition: all .22s var(--t-ease);
    }
    .mini-chip:hover { background: var(--gold-soft); border-color: rgba(232,190,89,.25); color: var(--gold-deep); transform: translateY(-2px); }

    .mini-chip-card {
      display: inline-flex; align-items: center; flex-direction: column;
      
      border: 1px solid rgba(0,0,0,.07);
      border-radius: var(--radius-sm);
      font-size: 14px; font-weight: 600; color: var(--text);
      box-shadow: var(--shadow-xs);
      transition: all .22s var(--t-ease);
      overflow: hidden;
    }
    .mini-chip-card > img{
      width: 100px;
    }
    .mini-chip-card > div{
       padding: 10px 18px;
      background: rgba(255,255,255,.92);
    }

    .mini-services-pic {
      display: flex;
      flex-wrap: wrap;
      margin-top: 40px;
    }
    .mini-services-pic li{
      width: 33.333%;
    }
    .mini-services-pic li > div{
      margin: 10px;
    }

    @media(max-width:769px) {
      .mini-services-pic li{
        width: 100%;
      }
    }

    /* ── Why ── */
    .why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 44px; }
    .why-card {
      padding: 32px 26px;
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-xs);
      transition: all .3s var(--t-ease);
    }
    .why-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-sm); border-color: rgba(232,190,89,.20); }
    .why-icon {
      width: 56px; height: 56px;
      padding: 10px;
      border-radius: 16px;
      background: linear-gradient(135deg, var(--gold-xsoft), #fff);
      border: 1px solid rgba(232,190,89,.20);
      display: flex; align-items: center; justify-content: center;
      font-size: 24px; margin-bottom: 20px;
    }
    .why-title { font-size: 17px; font-weight: 800; color: var(--text); margin-bottom: 8px; letter-spacing: -.3px; }
    .why-desc { font-size: 13px; color: var(--text-sub); line-height: 1.8; }

    /* ── Doctors ── */
    .doctors-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 44px; }
    .doctor-card {
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: var(--shadow-xs);
      transition: all .3s var(--t-ease);
    }
    .doctor-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-sm); border-color: rgba(232,190,89,.20); }
    .doctor-photo {
      height: 290px;
      background: linear-gradient(160deg, var(--gold-xsoft) 0%, #f5f0e0 100%);
      display: flex; align-items: center; justify-content: center;
      position: relative; overflow: hidden;
    }
    
    .doctor-photo-badge {
      position: absolute; bottom: 14px; left: 14px;
      padding: 5px 12px;
      background: var(--gold-deep); color: #fff;
      font-size: 11px; font-weight: 700;
      border-radius: 999px;
    }
    .doctor-body { padding: 24px 24px 22px; }
    .doctor-name { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 4px; letter-spacing: -.4px; }
    .doctor-title { font-size: 12px; font-weight: 600; color: var(--gold-deep); margin-bottom: 12px; letter-spacing: .3px; text-transform: uppercase; }
    .doctor-career { list-style: none; display: flex; flex-direction: column; gap: 5px; }
    .doctor-career li { font-size: 12px; color: var(--text-sub); display: flex; gap: 7px; align-items: flex-start; }
    .doctor-career li::before { content: '✦'; color: var(--gold); flex-shrink: 0; }
    .doctor-quote {
      margin-top: 16px;
      padding: 12px 16px;
      background: var(--gold-soft);
      border-left: 3px solid var(--gold-deep);
      border-radius: 0 var(--radius-xs) var(--radius-xs) 0;
      font-size: 13px;
      font-weight: 600;
      color: var(--gold-deep);
      font-style: italic;
      line-height: 1.6;
    }

    /* ── Process ── */
    .process-steps { display: flex; gap: 0; margin-top: 48px; align-items: flex-start; }
    .process-step { flex: 1; display: flex; flex-direction: column; align-items: center; text-align: center; position: relative; }
    .process-step-line {
      position: absolute; top: 32px; left: 50%; width: 100%; height: 2px;
      background: linear-gradient(90deg, var(--gold-deep), rgba(232,190,89,.3));
    }
    .process-step:last-child .process-step-line { display: none; }
    .process-icon {
      width: 64px; height: 64px; border-radius: 50%;
      background: var(--gold-deep); color: #fff;
      display: flex; align-items: center; justify-content: center;
      font-size: 22px; font-weight: 800;
      box-shadow: 0 6px 18px rgba(199,154,44,.28);
      position: relative; z-index: 1;
      transition: all .3s var(--t-ease);
    }
    .process-step:hover .process-icon { transform: scale(1.08); box-shadow: 0 8px 24px rgba(199,154,44,.38); }
    .process-body { padding: 16px 8px 0; }
    .process-num { font-size: 10px; font-weight: 800; color: var(--gold-deep); letter-spacing: 1px; margin-bottom: 4px; }
    .process-step h4 { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
    .process-step p { font-size: 12px; color: var(--text-sub); line-height: 1.6; }

    /* ── ALL DIGITAL ── */
    .Equipment-grid { display: grid; grid-template-columns: repeat(2, 2fr);  gap: 20px; max-width: 800px;  margin: 44px auto 0 auto; }
    .equipment-card {
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: var(--shadow-xs);
      transition: all .3s var(--t-ease);
    }
    .equipment-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: rgba(232,190,89,.20); }
    .equipment-img {
      aspect-ratio: 16/7;
      background-size: cover; background-position: center;
      background-color: #f0ece0;
      position: relative;
    }
    .equipment-img-icon {
      aspect-ratio: 16/7;
      background: #fbfbfb;
      display: flex; align-items: center; justify-content: center;
    }
    .equipment-body { padding: 14px 14px 24px; }
    .equipment-num { font-size: 11px; font-weight: 800; color: var(--gold-deep); letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 8px; }
    .equipment-title { font-size: 22px; font-weight: 800; color: var(--text); letter-spacing: -.5px; margin-bottom: 6px; }
    .equipment-sub { font-size: 13px; color: var(--text-sub); line-height: 1.7; margin-bottom: 16px; }

    

    /* ── FAQ ── */
    .faq-list { display: flex; flex-direction: column; gap: 10px; margin-top: 44px; }
    .faq-item {
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-sm);
      overflow: hidden;
      transition: all .28s var(--t-ease);
    }
    .faq-item.open { border-color: rgba(232,190,89,.22); box-shadow: var(--shadow-xs); }
    .faq-q {
      display: flex; align-items: center; gap: 14px;
      padding: 20px 24px; cursor: pointer;
      font-size: 15px; font-weight: 600; color: var(--text);
      user-select: none;
    }
    .faq-q-icon { color: var(--gold-deep); font-size: 16px; font-weight: 800; flex-shrink: 0; }
    .faq-q-arrow {
      margin-left: auto; flex-shrink: 0;
      font-size: 13px; color: var(--text-sub);
      transition: transform .3s var(--t-ease);
    }
    .faq-item.open .faq-q-arrow { transform: rotate(180deg); }
    .faq-a {
      max-height: 0; overflow: hidden;
      transition: max-height .4s var(--t-ease), padding .3s var(--t-ease);
    }
    .faq-item.open .faq-a { max-height: 400px; }
    .faq-a-inner {
      padding: 0 24px 22px 54px;
      font-size: 14px; color: var(--text-sub); line-height: 1.85;
      border-top: 1px solid rgba(0,0,0,.04);
      padding-top: 16px;
    }

    /* ── CTA Banner ── */
    .cta-banner {
      background: linear-gradient(135deg, #fffdf5 0%, #fff8e8 100%);
      border-radius: var(--radius-xl);
      padding: 64px 54px;
      text-align: center;
      position: relative; overflow: hidden;
      border: 2px solid rgba(232,190,89,.30);
      box-shadow: 0 8px 40px rgba(199,154,44,.10);
    }
    .cta-banner::before {
      content: '';
      position: absolute; top: -80px; right: -80px;
      width: 240px; height: 240px; border-radius: 50%;
      background: radial-gradient(circle, rgba(232,190,89,.20), transparent 70%);
    }
    .cta-banner::after {
      content: '';
      position: absolute; bottom: -60px; left: -60px;
      width: 200px; height: 200px; border-radius: 50%;
      background: radial-gradient(circle, rgba(232,190,89,.15), transparent 72%);
    }
    .cta-banner-inner { position: relative; z-index: 1; }
    .cta-eyebrow { font-size: 12px; font-weight: 800; color: var(--gold-deep); letter-spacing: 1.4px; text-transform: uppercase; margin-bottom: 16px; }
    .cta-title { font-size: clamp(24px, 3vw, 38px); font-weight: 800; color: var(--text); letter-spacing: -1px; line-height: 1.2; margin-bottom: 12px; }
    .cta-title em { color: var(--gold-deep); font-style: normal; }
    .cta-desc { font-size: 15px; color: var(--text-sub); line-height: 1.7; margin-bottom: 32px; }
    .cta-btns { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
    .btn-gold {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 14px 30px;
      background: var(--gold-deep); color: #fff;
      border-radius: 999px; font-size: 15px; font-weight: 700;
      box-shadow: 0 6px 20px rgba(199,154,44,.35);
      transition: all .22s var(--t-ease);
    }
    .btn-gold:hover { background: #b58a24; transform: translateY(-2px); }
    .btn-ghost-light {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 14px 30px;
      background: rgba(255,255,255,.72);
      border: 1.5px solid rgba(199,154,44,.24);
      color: var(--text);
      border-radius: 999px; font-size: 15px; font-weight: 700;
      transition: all .22s var(--t-ease);
      box-shadow: 0 6px 18px rgba(15,23,42,.05);
    }
    .btn-ghost-light:hover {
      background: #fff;
      color: var(--gold-deep);
      transform: translateY(-2px);
    }

    @media(max-width:769px) {
      .cta-eyebrow{
        font-size: 8px;
      }
    }

    /* ── Info Section ── */
    .info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 44px; }
    .info-card {
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(0,0,0,.05);
      border-radius: var(--radius-lg);
      padding: 34px 30px;
      box-shadow: var(--shadow-xs);
    }
    .info-card h3 { font-size: 18px; font-weight: 800; color: var(--text); margin-bottom: 20px; letter-spacing: -.4px; display: flex; align-items: center; gap: 10px; }
    .info-card h3 i { color: var(--gold-deep); }
    .hours-table { width: 100%; border-collapse: collapse; }
    .hours-table b {font-weight: 700; color: var(--gold-deep);}
    .hours-table tr td { padding: 8px 0; font-size: 14px; }
    .hours-table tr td:first-child { color: var(--text-sub); font-weight: 600; width: 150px; }
    .hours-table tr td:last-child { color: var(--text); font-weight: 500; }
    .hours-table tr.night td:last-child { color: var(--gold-deep); font-weight: 700; }
    .hours-table tr + tr td { border-top: 1px solid rgba(0,0,0,.05); }
    .closed-note {
      margin-top: 14px; padding: 10px 14px;
      background: var(--gold-soft); border-radius: var(--radius-xs);
      font-size: 12px; color: var(--gold-deep); font-weight: 600;
    }
    .addr-wrap { display: flex; flex-direction: column; gap: 12px; }
    .addr-row { display: flex; gap: 12px; align-items: flex-start; font-size: 14px; }
    .addr-row i { color: var(--gold-deep); flex-shrink: 0; margin-top: 2px; }
    .addr-row span { color: var(--text); line-height: 1.6; }
    .map-link {
      display: inline-flex; align-items: center; gap: 8px;
      margin-top: 18px; padding: 10px 20px;
      background: var(--gold-soft);
      border: 1px solid rgba(232,190,89,.25);
      border-radius: 999px; font-size: 13px; font-weight: 700;
      color: var(--gold-deep); transition: all .22s var(--t-ease);
    }
    .map-link:hover { background: var(--gold-deep); color: #fff; }

    /* ── Footer ── */
    .site-footer {
      background: #f5f0e8;
      border-radius: var(--radius-xl);
      padding: 54px 54px 40px;
      margin-top: 24px;
      color: var(--text-sub);
      font-size: 13px;
      border: 1px solid rgba(199,154,44,.18);
    }
    .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
    .footer-logo { font-size: 22px; font-weight: 900; color: var(--text); margin-bottom: 10px; letter-spacing: -.5px; }
    .footer-logo span { color: var(--gold-deep); }
    .footer-slogan { font-size: 13px; color: var(--text-sub); line-height: 1.7; margin-bottom: 14px; }
    .footer-addr { font-size: 12px; line-height: 1.8; color: var(--text-sub); }
    .footer-links-title { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 14px; }
    .footer-links-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
    .footer-links-list a { font-size: 13px; color: var(--text-sub); transition: color .2s; }
    .footer-links-list a:hover { color: var(--gold-deep); }
    .footer-bottom {
      padding-top: 24px; border-top: 1px solid rgba(199,154,44,.18);
      display: flex; justify-content: space-between; align-items: center;
      font-size: 12px; color: #aaa; flex-wrap: wrap; gap: 8px;
    }

    /* ── Floating CTA ── */
    .float-cta {
      position: fixed; display: none; bottom: 28px; right: 24px; z-index: 900;
       flex-direction: column; gap: 10px;
      opacity: 0; transform: translateY(20px);
      pointer-events: none; transition: all .4s var(--t-ease);
    }
    .float-cta.show { opacity: 1; transform: translateY(0); pointer-events: auto; }
    .float-btn {
      width: 56px; height: 56px; border-radius: 50%; border: none; cursor: pointer;
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      gap: 3px; font-size: 9px; font-weight: 700; letter-spacing: .04em;
      box-shadow: 0 6px 20px rgba(0,0,0,.18);
      transition: all .22s var(--t-ease);
      text-decoration: none;
    }
    .float-btn:hover { transform: translateY(-3px); }
    .float-btn i { font-size: 18px; }
    .float-call { background: var(--gold-deep); color: #fff; }
    .float-call:hover { background: #b58a24; }
    .float-top {
      background: rgba(255,255,255,.92); color: var(--text);
      border: 1.5px solid rgba(0,0,0,.08);
      backdrop-filter: blur(8px);
    }

    /* ── Mobile Nav ── */
    .mobile-overlay {
      display: none; position: fixed; inset: 0; z-index: 500;
      background: rgba(0,0,0,.5); opacity: 0;
      transition: opacity .3s var(--t-ease);
    }
    .mobile-overlay.open { opacity: 1; }
    .mobile-drawer {
      position: fixed; top: 0; right: 0; bottom: 0;
      width: min(340px, 88vw);
      background: var(--bg);
      display: flex; flex-direction: column;
      padding: 28px 24px; overflow-y: auto;
      transform: translateX(100%); transition: transform .38s var(--t-ease);
      z-index: 501;
    }
    .mobile-overlay.open .mobile-drawer { transform: translateX(0); }
    .mobile-close {
      align-self: flex-end; width: 40px; height: 40px;
      background: rgba(0,0,0,.06); border: none; border-radius: 10px;
      font-size: 16px; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      color: var(--text); margin-bottom: 24px;
    }
    .mobile-logo { margin-bottom: 24px; }
    .mobile-logo-svg { height: 40px; width: auto; display: block; }
    .mobile-nav-list { list-style: none; display: flex; flex-direction: column; gap: 2px; flex: 1; }
    .mobile-nav-list a {
      display: block; padding: 13px 14px;
      font-size: 15px; font-weight: 600; color: var(--text);
      border-radius: var(--radius-xs);
      transition: all .2s var(--t-ease);
    }
    .mobile-nav-list a:hover { background: var(--gold-soft); color: var(--gold-deep); }

    .mobile-nav-group {
      padding: 16px 14px 6px;
      font-size: 12px;
      font-weight: 800;
      letter-spacing: .08em;
      color: var(--gold-deep);
      text-transform: uppercase;
    }

    .mobile-call-btn {
      display: flex; align-items: center; justify-content: center; gap: 10px;
      padding: 15px 20px; margin-top: 20px;
      background: var(--gold-deep); color: #fff;
      border-radius: 999px; font-size: 16px; font-weight: 700;
      box-shadow: 0 4px 14px rgba(199,154,44,.30);
    }

    /* ── Reveal Animation ── */
    .reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--t-ease), transform .7s var(--t-ease); }
    .reveal.visible { opacity: 1; transform: translateY(0); }

    /* ── Responsive ── */
    @media (max-width: 1024px) {
      .header-nav { display: none; }
      .nav-links { display: none; }
      .header-info { display: none; }
      .header-top { gap: 10px; }
      .trust-strip { grid-template-columns: repeat(2, 1fr); }
      .services-grid { grid-template-columns: 1fr; }
      .why-grid { grid-template-columns: repeat(2, 1fr); }
      .Equipment-grid { grid-template-columns: 1fr; }
      .doctors-grid { grid-template-columns: 1fr 1fr; }
      .footer-grid { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 768px) {
      .doctor-photo{
        height: auto;
      }
      .float-cta{
        /* display: flex; */
      }
      .page { padding: 0 0 24px; }
      .header-top { padding: 0px; height: 62px; margin: 0;}
      .logo-mark { height: 40px; max-width: 170px; }
      .header-actions { gap: 8px; }
      .section-tint { padding: 40px 24px; }
      .slide-content { padding: 28px 28px; }
      .trust-strip { grid-template-columns: repeat(2, 1fr); gap: 10px; }
      .about-grid { grid-template-columns: 1fr; }
      .stat-grid { grid-template-columns: repeat(2, 1fr); }
      .process-steps { flex-direction: column; gap: 0; }
      .process-step { flex-direction: row; text-align: left; gap: 16px; }
      .process-step-line { display: none; }
      .process-body { padding: 0 0 20px; }
      .why-grid { grid-template-columns: 1fr; }
      .doctors-grid { grid-template-columns: 1fr; }
      .info-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 44px 28px; }
      .site-footer { padding: 40px 24px 28px; border-radius: var(--radius-lg); }
      .footer-grid { grid-template-columns: 1fr; gap: 28px; }
      .footer-bottom { flex-direction: column; text-align: center; }
      .logo-svg { height: 36px; }
    }
    @media (max-width: 480px) {
      .trust-strip { grid-template-columns: 1fr; }
      .stat-grid { grid-template-columns: repeat(2, 1fr); }
      .slide-title { font-size: 22px; }
      .slide-desc { font-size: 13px; }
    }
  
/* ── Quick Side Menu ── */
.quick-menu {
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 800;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.quick-item {
  width: 80px;
  height: 80px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: #333;
  text-align: center;
  box-shadow: 0 6px 16px rgba(0,0,0,0.08);
  transition: all .2s ease;
}
.quick-item img{
  width: 35px;
}
.quick-item.top-btn{
  background: var(--gold-deep);
  color: #fff;
}
.quick-item:hover {
  background: #fff7df;
  color: #c79a2c;
  transform: translateY(-2px);
}
.quick-item i {
  font-size: 18px;
  margin-bottom: 4px;
}
@media (max-width:768px){
  /* .quick-menu{display:none;} */
  .quick-menu {
      right: 2px;
      top: 70%;
      gap: 0;
  }
  .quick-menu span{
    display: none;
  }
  .quick-item {
    padding: 4px;
      width: 35px;
      height: 35px;
      background: rgba(255, 255, 255, 0.92);
      border: 1px solid rgba(0, 0, 0, 0.08);
      border-radius: 2px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      font-size: 8px;
      color: #333;
      text-align: center;
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
      transition: all .2s ease;
  }
  .quick-item i{
    margin: 0;
    font-size: 10px;
  }
}


.m-img, .m_br{
  display: none !important;
}
@media(max-width:769px){
  .pc-img{
    display: none !important;
  }
  .m-img{
    display: block !important;
  }
  .m_br{
    display: inline !important;
  }
}




/* 팝업레이어 */
#hd_pop {
    z-index: 999999;
    position: relative;
    margin: 0 auto;
    height: 0;
}
#hd_pop h2 {
    position: absolute;
    font-size: 0;
    line-height: 0;
    overflow: hidden;
}
.hd_pops {
    position: absolute;
    border: 1px solid #e9e9e9;
    background: #fff;
    margin: 10px;
}
.hd_pops img {
    width: 100%;
}
.hd_pops_con {
}
.hd_pops_footer {
    padding: 0;
    background: #000;
    color: #fff;
    text-align: left;
    position: relative;
}
.hd_pops_footer:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: '';
}
.hd_pops_footer button {
    padding: 10px;
    border: 0;
    color: #fff;
}
.hd_pops_footer .hd_pops_reject {
    background: #000;
    text-align: left;
}
.hd_pops_footer .hd_pops_close {
    background: #393939;
    position: absolute;
    top: 0;
    right: 0;
}
@media screen and (max-width: 640px) {
    .hd_pops {
        top: 50px !important;
        left: 0 !important;
    }
    .hd_pops_con {
        width: 100% !important;
        height: 100% !important;
        top: 0;
        left: 0;
    }
}