/* ═══════════════════════════════════════
     § 1. 디자인 토큰
  ═══════════════════════════════════════ */
  :root {
    --bg:        #F1F5F9; 
    --white:     #ffffff;
    --bd:        #E2E8F0;
    --bd2:       #CBD5E1;
    --t1:        #0F172A; 
    --t2:        #475569;
    --t3:        #94A3B8;
    --grn:       #2563EB; 
    --grn-dk:    #1D4ED8;
    --grn-lt:    #EFF6FF;
    --grn-rg:    rgba(37, 99, 235, 0.15);
    --cam:       #0F172A;  --cam-lt: #F1F5F9;  --cam-dk: #0F172A; 
    --phn:       #0284C7;  --phn-lt: #E0F2FE;  --phn-dk: #0369A1; 
    --pc:        #7C3AED;  --pc-lt:  #F5F3FF;  --pc-dk:  #5B21B6; 
    --kko:       #FEE500;
    
    --sans:  'Pretendard Variable', Pretendard, 'Plus Jakarta Sans', -apple-system, sans-serif;
    --serif: 'Noto Serif KR', 'Apple Myungjo', Georgia, serif;
    --num:   'Plus Jakarta Sans', 'Pretendard Variable', Pretendard, sans-serif;
    
    --ease:        cubic-bezier(0.25, 1, 0.5, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --sh:    0 8px 24px rgba(15, 23, 42, 0.04);
    --sh-hv: 0 16px 40px rgba(15, 23, 42, 0.08);
    
    /* 앱 가로 폭 480px */
    --app-w: 480px;
  }

  /* ═══════════════════════════════════════
     § 2. 전역 리셋
  ═══════════════════════════════════════ */
  *,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
  html {
    scroll-behavior: smooth;
    /* iOS Safari 텍스트 자동 크기 조정 방지 */
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    background: var(--t1);
  }
  body {
    font-family: var(--sans);
    background: #E2E8F0;
    color: var(--t1);
    line-height: 1.65;
    overflow-x: hidden;
    word-break: keep-all;
    overflow-wrap: break-word;
    /* 폰트 서브픽셀 렌더링 (Webkit/Firefox 공통) */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 15px;
    /* 모바일 더블탭 줌 · 300ms 클릭 딜레이 제거 */
    touch-action: manipulation;
  }
  a { text-decoration:none; color:inherit; }
  img { max-width:100%; display:block; }
  * { -webkit-tap-highlight-color:transparent; }
  button, input, select, textarea { font-family:var(--sans); font-size:inherit; border:none; background:none; outline:none;}
  /* 접근성: 마우스 클릭 시에는 outline 숨기고, 키보드 포커스 시에는 표시 */
  button:focus-visible,
  input:focus-visible,
  select:focus-visible,
  textarea:focus-visible {
    outline: 2px solid var(--grn);
    outline-offset: 2px;
  }
  button { cursor:pointer; }

  /* ═══════════════════════════════════════
     § 3. 키프레임 애니메이션
  ═══════════════════════════════════════ */
  @keyframes fadeUp    { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
  @keyframes fadeIn    { from{opacity:0} to{opacity:1} }
  @keyframes popIn     { 0%{opacity:0;transform:scale(.92) translateY(10px)} 70%{transform:scale(1.02) translateY(-2px)} 100%{opacity:1;transform:scale(1) translateY(0)} }
  @keyframes ripple    { 0%{transform:scale(1);opacity:.42} 75%,100%{transform:scale(2.8);opacity:0} }
  @keyframes float     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
  @keyframes countPop  { 0%{transform:scale(.85);opacity:0} 60%{transform:scale(1.08)} 100%{transform:scale(1);opacity:1} }
  
  /* 모달 애니메이션 */
  @keyframes overlayFadeIn { from { opacity:0; } to { opacity:1; } }
  @keyframes overlayFadeOut { from { opacity:1; } to { opacity:0; } }
  @keyframes cardSlideDown { 0% { opacity:1; transform:translateY(0); } 100% { opacity:0; transform:translateY(48px); } }
  @keyframes cardPopOut { 0% { opacity:1; transform:translateY(0) scale(1); } 100% { opacity:0; transform:translateY(18px) scale(.97); } }
  @keyframes stepPulse { 0% { transform:scale(.85); opacity:.5; } 100% { transform:scale(1.9); opacity:0; } }

  .up { opacity:0; transform:translateY(20px); transition:opacity .6s var(--ease),transform .6s var(--ease); }
  .up.on { opacity:1; transform:none; }
  .d1{transition-delay:.07s} .d2{transition-delay:.14s} .d3{transition-delay:.21s} .d4{transition-delay:.28s}

  /* ═══════════════════════════════════════
     § 4. 페이지 레이아웃 (PC 와이드 480px)
  ═══════════════════════════════════════ */
  .page-shell { display:flex; min-height:100vh; min-height:100svh; justify-content:center; align-items:flex-start; }

  /* PC 사이드 패널 */
  .pc-panel {
    display:none; width:480px; flex-shrink:0;
    position:sticky; top:0; height:100vh; height:100svh;
    flex-direction:column; justify-content:center;
    padding:60px 48px;
    background:var(--t1); /* 다크 네이비 */
    color:var(--white);
    overflow-y:auto;
    box-shadow: 20px 0 40px rgba(0,0,0,0.05);
    z-index:10;
  }
  @media(min-width:860px){ .pc-panel{display:flex} body{background:#E2E8F0} }

  .pc-logo { display:flex; align-items:center; margin-bottom:32px; }
  /* PC 패널 로고: img/main_logo.png 50×50px */
  .pc-logo-img { width:50px; height:50px; border-radius:14px; object-fit:cover; flex-shrink:0; box-shadow:0 8px 24px rgba(0,0,0,0.2); animation:float 3.5s ease-in-out infinite; }

  .pc-ttl { font-family:var(--serif); font-size:clamp(30px, 2.8vw, 36px); font-weight:900; letter-spacing:-1px; line-height:1.35; margin-bottom:14px; color:var(--white); }
  .pc-ttl span { color:var(--grn-lt); }
  .pc-desc { font-size:15px; color:#94A3B8; line-height:1.7; margin-bottom:36px; letter-spacing:-.01em; }
  .pc-desc strong { color:var(--white); font-weight:700; }

  /* PC Stats: 트렌디한 2x2 벤토(Bento) 그리드 */
  .pc-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-bottom: 36px; }
  .pc-stat { display: flex; flex-direction: column; align-items: flex-start; gap: 16px; padding: 20px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.05); border-radius: 20px; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); transition: all .3s var(--ease); }
  .pc-stat-ic { width: 44px; height: 44px; border-radius: 14px; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
  .pc-stat-n  { font-size: 24px; font-weight: 800; letter-spacing: -.04em; line-height: 1; font-family: var(--num); color: var(--white); }
  .pc-stat-n em { color: var(--grn-lt); font-style: normal; }
  .pc-stat-l  { font-size: 12.5px; color: #94A3B8; font-weight: 600; margin-top: 4px; letter-spacing: .01em; }

  .pc-stat-since { background: var(--grn); border-color: var(--grn); }
  .pc-stat-ic-since { background: rgba(255,255,255,.1); box-shadow: none; }
  .pc-stat-n-since { display: flex; align-items: baseline; gap: 4px; }
  .pc-stat-since-pre { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.6); letter-spacing: .06em; padding-bottom: 1px; }
  .pc-stat-n-since em { color: var(--white); }
  .pc-stat-since .pc-stat-l { color: rgba(255,255,255,.8); }

  /* PC 카카오 버튼 */
  .pc-kko { display:flex; align-items:center; justify-content:space-between; height:68px; width:100%; padding:0 24px; background:var(--white); color:var(--t1); border-radius:20px; cursor:pointer; box-shadow:0 8px 30px rgba(0,0,0,.15); margin-bottom:14px; transition:all .2s var(--ease-spring); text-decoration:none; position:relative; overflow:hidden; }
  .pc-kko:active { transform:scale(.97); }
  .pc-kko-left { display:flex; flex-direction:column; align-items:flex-start; gap:2px; position:relative; z-index:1; }
  .pc-kko-main { font-size:16px; font-weight:800; letter-spacing:-.02em; line-height:1; }
  .pc-kko-sub  { font-size:12px; font-weight:600; color:var(--t2); letter-spacing:.02em; }
  .pc-kko-arrow { width:36px; height:36px; border-radius:12px; background:var(--grn-lt); display:flex; align-items:center; justify-content:center; flex-shrink:0; position:relative; z-index:1; transition:all .3s var(--ease); }
  .pc-kko-arrow svg { stroke:var(--grn); transition:stroke .3s; }

  /* PC 운영시간 카드 */
  .pc-hours { margin-top:10px; background:rgba(0,0,0,0.2); border:1px solid rgba(255,255,255,.05); border-radius:20px; padding:20px; transition:border-color .4s; }
  .pc-hours.is-open  { border-color:rgba(37, 99, 235, 0.4); } 
  .pc-hours.is-closed { border-color:rgba(239, 68, 68, 0.2); }
  .pc-hours-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
  .pc-hours-badge { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:700; letter-spacing:-.01em; }
  .is-open   .pc-hours-badge { color:#3B82F6; } 
  .is-closed .pc-hours-badge { color:#EF4444; }
  .pc-hours-sub { font-size:12px; font-weight:600; color:rgba(255,255,255,.6); white-space:nowrap; }
  .pc-hours-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; transition:background .3s; position:relative; }
  .is-open   .pc-hours-dot { background:#3B82F6; }
  .is-open   .pc-hours-dot::before { content:''; position:absolute; inset:-3px; border-radius:50%; background:#3B82F6; opacity:.45; animation:ripple 2s infinite; }
  .is-closed .pc-hours-dot { background:#EF4444; }
  .pc-hours-reason { font-size:12px; font-weight:600; color:rgba(255,255,255,.5); overflow:hidden; max-height:0; opacity:0; transition:max-height .3s var(--ease), opacity .3s; }
  .is-closed .pc-hours-reason:not(:empty) { max-height:28px; opacity:1; margin-bottom:10px; }
  .pc-hours-body { display:flex; flex-direction:column; gap:10px; }
  .pc-hours-row { display:flex; align-items:center; justify-content:space-between; font-size:13px; color:#94A3B8; }
  .pc-hours-label-txt { font-weight:600; }
  .pc-hours-val { font-weight:500; }
  .pc-hours-val.grn { color:var(--white); font-weight:700; }
  .pc-hours-divider-line { height:1px; background:rgba(255,255,255,.05); margin:4px 0; }
  .pc-hours-tel { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:800; color:var(--white); text-decoration:none; padding:6px 12px; background:rgba(255,255,255,.1); border-radius:10px; transition:background .2s; cursor:pointer; pointer-events:auto; -webkit-user-select:none; user-select:none; }


  /* ═══════════════════════════════════════
     § 5. 앱 컨테이너 (App View - 480px)
  ═══════════════════════════════════════ */
  .app { 
    width:100%; max-width:var(--app-w); min-height:100vh; min-height:100svh; 
    background:var(--bg); display:flex; flex-direction:column; position:relative;
  }
  @media(min-width:860px){ .app{ box-shadow:-20px 0 40px rgba(0,0,0,0.05); } }

  .app-scroll {
    flex: 1;
    overflow-y: auto;
    /* 탭 네비 높이(약 100px) + iPhone 홈바 safe-area 여백 */
    padding-bottom: calc(100px + env(safe-area-inset-bottom, 0px));
    /* iOS 모멘텀 스크롤 (구형 iOS 호환) */
    -webkit-overflow-scrolling: touch;
    /* Android Chrome pull-to-refresh 방지 */
    overscroll-behavior-y: contain;
  }
  @media(min-width:860px){ .app-scroll{ padding-bottom:40px; } }

  /* ── 모바일 헤더 (다크 테마 적용) ── */
  .app-hd {
    position:sticky; top:0; z-index:200; height:60px;
    background: rgba(15, 23, 42, 0.98); 
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255,255,255,0.05); 
    display:flex; align-items:center; justify-content:space-between; padding:0 20px; flex-shrink:0;
    animation:fadeIn .4s ease both;
  }
  @media(min-width:860px){ .app-hd{display:none} }

  .app-logo { display:flex; align-items:center; }
  .app-logo-img { width:32px; height:32px; border-radius:8px; object-fit:cover; flex-shrink:0; }

  /* 모바일 헤더 버튼 (흰색 톤) */
  .hd-kko {
    display:flex; align-items:center; gap:6px; height:36px; padding:0 14px;
    background: rgba(255,255,255,0.1); color: var(--white); border-radius:10px;
    font-size:12px; font-weight:700; cursor:pointer; 
    transition:transform .18s var(--ease-spring); text-decoration:none; white-space:nowrap; flex-shrink:0;
  }
  .hd-kko:active { transform:scale(.95); }
  #hdKkoIcon path { fill: var(--white) !important; }

  /* ── 인사 영역 ── 
     모바일: 다크 오버랩 UI / PC: 투명, 오버랩 없음
  */
  .greet { 
    background: var(--t1);
    color: var(--white);
    padding: 24px 20px 72px; 
    border-radius: 0 0 32px 32px; 
    box-shadow: 0 10px 30px rgba(15,23,42,0.1);
  }
  @media (min-width: 860px) {
    .greet {
      background: transparent;
      color: var(--t1);
      padding: 32px 20px 24px;
      border-radius: 0;
      box-shadow: none;
    }
  }

  .live-pill {
    display:inline-flex; align-items:center; gap:8px; padding:6px 14px;
    background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.05); border-radius:20px;
    font-size:12px; font-weight:700; color:var(--white); letter-spacing:.02em; margin-bottom:16px;
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    animation:fadeIn .5s .1s both;
  }
  @media (min-width: 860px) {
    .live-pill {
      background: var(--white);
      border: none;
      color: var(--grn-dk);
      box-shadow: 0 4px 12px rgba(37,99,235,0.08);
      backdrop-filter: none; -webkit-backdrop-filter: none;
    }
  }

  .dot { width:6px; height:6px; border-radius:50%; background:#60A5FA; flex-shrink:0; position:relative; }
  @media (min-width: 860px) { .dot { background: var(--grn); } }
  .dot::before { content:''; position:absolute; inset:-3px; border-radius:50%; background:#60A5FA; opacity:.4; animation:ripple 2s infinite; }
  @media (min-width: 860px) { .dot::before { background: var(--grn); } }

  .greet-h  { font-size:clamp(24px, 6vw, 28px); font-weight:800; letter-spacing:-1px; line-height:1.3; margin-bottom:8px; animation:fadeUp .5s .15s both; color:var(--white);}
  @media (min-width: 860px) { .greet-h { color: var(--t1); font-size: 28px; } }

  .greet-h em { color:#60A5FA; font-style:normal; }
  @media (min-width: 860px) { .greet-h em { color: var(--grn); } }

  .greet-sub { font-family:var(--serif); font-size:15px; font-weight:700; color:#94A3B8; letter-spacing:-.02em; line-height:1.5; animation:fadeUp .5s .22s both; }
  @media (min-width: 860px) { .greet-sub { color: var(--t2); } }

  /* ── 카테고리 카드 (모바일만 Overlap UI) ── */
  .cat-wrap { 
    padding:0 20px 16px; display:flex; flex-direction:column; gap:16px; 
    margin-top: -40px; 
    position: relative; z-index: 10;
  }
  @media (min-width: 860px) {
    .cat-wrap { margin-top: 0; }
  }

  .cat-card {
    display:flex; align-items:center; background:var(--white);
    border: none; border-radius:24px; padding:24px 20px;
    text-decoration:none; color:inherit; position:relative;
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.08); 
    transition:all .3s var(--ease-spring);
    animation:fadeUp .5s both;
  }
  @media (min-width: 860px) {
    .cat-card { border: 1px solid var(--bd); box-shadow: var(--sh); }
  }

  /* ──────────────────────────────────────────────
     hover 효과: 실제 마우스/트랙패드가 있는 기기에만 적용
     (@media hover:hover) — Android/iOS 터치 기기에서
     탭 후 hover 스타일이 잔류하는 현상 방지
  ─────────────────────────────────────────────── */
  @media(hover: hover) and (pointer: fine) {
    .cat-card:hover  { transform:translateY(-4px) scale(1.01); box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12); }
    .cat-card:hover .cat-ic { transform:rotate(-5deg) scale(1.1); }
    .cat-card:hover .cat-arr { background:var(--grn); transform:translateX(3px); }
    .cam:hover .cat-arr svg { stroke:var(--white); }
    .phn:hover .cat-arr svg { stroke:var(--white); }
    .pcc:hover .cat-arr svg { stroke:var(--white); }
    .cam:hover .ctag { background:var(--cam-lt); color:var(--cam-dk); }
    .phn:hover .ctag { background:var(--phn-lt); color:var(--phn-dk); }
    .pcc:hover .ctag { background:var(--pc-lt);  color:var(--pc-dk); }
    .t-chip:hover { transform:translateY(-2px) scale(1.02); }
    .pstep:hover { padding-left:4px; }
    .pstep:hover .ps-ic { transform:scale(1.1); }
    .pc-stat:hover { background: rgba(255,255,255,0.08); transform: translateY(-4px); box-shadow: 0 10px 24px rgba(0,0,0,0.1); }
    .kb-btn.is-open-btn:hover  { transform:scale(1.05); box-shadow:0 4px 16px rgba(254,229,0,.35); }
    .kb-btn.is-closed-btn:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(15,23,42,.2); }
    .q-cat-btn:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(15,23,42,0.08); }
    .q-btn-back:hover { border-color:var(--grn); color:var(--grn-dk); background:var(--grn-lt); }
    .q-btn-next:hover, .q-btn-submit:hover { background:var(--grn-dk); }
    .q-photo-zone:hover { border-color:var(--grn); background:var(--grn-lt); }
    .q-photo-add-btn:hover { border-color:var(--grn); background:var(--grn-lt); color:var(--grn-dk); }
    .q-photo-del:hover { background:rgba(239,68,68,.9); }
    .q-privacy-lbl:hover { border-color:var(--grn); background:var(--grn-lt); }
    .q-done-close:hover { border-color:var(--grn); color:var(--grn-dk); }
    .pc-kko:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(255,255,255,.2); }
    .pc-kko:hover .pc-kko-arrow { background:var(--grn); }
    .pc-kko:hover .pc-kko-arrow svg { stroke:#fff; }
    .pc-hours-tel:hover { background:rgba(255,255,255,.2); }


    /* 문자 견적 버튼 hover — PC(다크 배경) */
    .pc-hours-sms-btn:hover { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.22); }
    .pc-hours-sms-btn:hover .pc-kko-arrow { background:rgba(37,99,235,.5); }
    .pc-hours-sms-btn:hover .pc-kko-arrow svg { stroke:#ffffff; }
    /* 문자 견적 버튼 hover — 모바일(라이트 배경) */
    .mob-hours .pc-hours-sms-btn:hover { background:#E2E8F0; border-color:#CBD5E1; }
    .mob-hours .pc-hours-sms-btn:hover .pc-kko-arrow { background:#2563EB; }
    .mob-hours .pc-hours-sms-btn:hover .pc-kko-arrow svg { stroke:#fff; }
    .biz-links a:hover { color:var(--grn-dk); }
    .soon-close:hover { background:var(--bd2); }
    .quote-x:hover { background:var(--bd); color:var(--t1); }
    .policy-x:hover { background:var(--bd); color:var(--t1); }
    .pc-stat-since:hover { background: var(--grn-dk); }
    @media(min-width:860px) {
      .cat-card:hover { box-shadow: var(--sh-hv); border-color: var(--grn-lt); }
    }
  }
  /* 터치 기기 active 피드백은 유지 */
  .cat-card:active { transform:scale(.98); transition-duration:.1s; }

  /* ── [FIX] 문자 견적 버튼 — 터치/마우스 기기 모두 적용 (hover 미디어쿼리 바깥으로 이동) ── */
  .pc-hours-sms-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    min-height: 52px;
    width: 100%;
    padding: 12px 14px 12px 16px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 14px;
    cursor: pointer;
    margin-top: 10px;
    text-decoration: none;
    transition: background .2s, border-color .2s, transform .15s;
    flex-shrink: 0;
    box-sizing: border-box;
  }
  .pc-hours-sms-btn:active { transform: scale(.98); }
  .pc-hours-sms-btn .pc-kko-left { display:flex; flex-direction:column; align-items:flex-start; gap:2px; flex:1; min-width:0; }
  .pc-hours-sms-btn .pc-kko-main { font-size:13px; font-weight:700; color:#ffffff !important; letter-spacing:-.01em; line-height:1.3; -webkit-text-size-adjust:100%; }
  .pc-hours-sms-btn .pc-kko-sub  { font-size:11px; font-weight:500; color:rgba(255,255,255,.5) !important; letter-spacing:.01em; -webkit-text-size-adjust:100%; }
  .pc-hours-sms-btn .pc-kko-arrow { width:30px; height:30px; border-radius:9px; background:rgba(37,99,235,.25); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; }
  .pc-hours-sms-btn .pc-kko-arrow svg { stroke:#93C5FD; transition:stroke .2s; }
  /* hover 효과는 pointer:fine 기기에서만 */
  /* [통합] pc-hours-sms-btn hover 효과 → 하단 @media(hover:hover) 블록으로 이동 */
  /* 모바일 라이트 패널 override */
  .mob-hours .pc-hours-sms-btn { background:#F1F5F9; border:1px solid #E2E8F0; }
  .mob-hours .pc-hours-sms-btn .pc-kko-left { flex:1; min-width:0; }
  .mob-hours .pc-hours-sms-btn .pc-kko-arrow { background:#EFF6FF; flex-shrink:0; }
  .mob-hours .pc-hours-sms-btn .pc-kko-arrow svg { stroke:#2563EB; }
  .mob-hours .pc-hours-sms-btn .pc-kko-main { color:#0F172A !important; }
  .mob-hours .pc-hours-sms-btn .pc-kko-sub  { color:#64748B !important; }
  .mob-hours .pc-hours-sms-btn:active .pc-kko-arrow { background:#2563EB; }
  .mob-hours .pc-hours-sms-btn:active .pc-kko-arrow svg { stroke:#fff; }
  /* [통합] mob-hours sms-btn hover 효과 → 하단 @media(hover:hover) 블록으로 이동 */

  .cat-ic { width:56px; height:56px; border-radius:18px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-right:16px; transition:transform .3s; }
  .cam .cat-ic{background:var(--cam-lt)} .phn .cat-ic{background:var(--phn-lt)} .pcc .cat-ic{background:var(--pc-lt)}

  .cat-info { flex:1; min-width:0; }
  .cat-kw { font-size:10px; font-weight:800; letter-spacing:1px; margin-bottom:6px; text-transform:uppercase; line-height:1; }
  .cam .cat-kw{color:var(--cam-dk)} .phn .cat-kw{color:var(--phn-dk)} .pcc .cat-kw{color:var(--pc-dk)}
  .cat-nm { font-size:18px; font-weight:800; letter-spacing:-.04em; line-height:1.15; margin-bottom:10px; color:var(--t1); }

  .cat-tags { display:flex; flex-wrap:wrap; gap:6px; }
  .ctag { font-size:11px; font-weight:600; color:var(--t2); background:var(--bg); border-radius:8px; padding:4px 10px; line-height:1.6; transition:background .2s, color .2s; }

  .cat-arr { width:36px; height:36px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-left:10px; background:var(--bg); transition:all .3s var(--ease-spring); }

  /* ── 카카오 배너 (블루 톤) ── */
  .kko-banner { 
    margin:12px 20px 24px; background:var(--grn); color:var(--white);
    border-radius:20px; padding:24px 20px; display:flex; align-items:center; gap:16px; 
    box-shadow:0 12px 24px rgba(37, 99, 235, 0.2); border:none; 
  }
  .kko-banner.is-closed { background:var(--white); color:var(--t1); border:1px solid var(--bd); box-shadow:var(--sh); }
  .kb-txt { flex:1; min-width:0; }
  .kb-ttl { font-size:16px; font-weight:800; margin-bottom:4px; letter-spacing:-.02em; line-height:1.3; }
  .kb-sub { font-size:12px; color:rgba(255,255,255,0.8); letter-spacing:-.01em; line-height:1.4; }
  .is-closed .kb-sub { color:var(--t3); }
  .kb-btn { display:flex; align-items:center; justify-content:center; gap:6px; padding:12px 16px; border-radius:12px; font-size:13px; font-weight:800; cursor:pointer; white-space:nowrap; flex-shrink:0; text-decoration:none; transition:transform .2s var(--ease-spring), box-shadow .2s; }
  .kb-btn.is-open-btn { background:var(--kko); color:#000; }
  .kb-btn.is-closed-btn { background:var(--t1); color:var(--white); }
  .kb-btn:active { transform:scale(.95); }

  /* ── 신뢰 지표 (모바일 전용 - 벤토 그리드 강화) ── */
  .trust-sec { 
    margin:0 20px 24px; padding:24px; background:var(--white); 
    border: none; border-radius:24px; box-shadow:var(--sh); 
  }
  @media(min-width:860px){ .trust-sec{display:none} }
  .sec-label { display:flex; align-items:center; gap:8px; font-size:16px; font-weight:800; color:var(--t1); letter-spacing:-.04em; margin-bottom:20px; }
  .sec-label-ic { width:32px; height:32px; border-radius:10px; background:var(--grn-lt); color:var(--grn-dk); display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
  .trust-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
  .t-chip { display:flex; flex-direction:column; background:var(--bg); border-radius:16px; padding:16px; border:1px solid rgba(0,0,0,0.02); transition:transform .25s var(--ease-spring); }
  .t-chip-ic { width:36px; height:36px; border-radius:10px; background:var(--white); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; margin-bottom:12px; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
  .t-n { font-size:22px; font-weight:800; letter-spacing:-.05em; line-height:1; font-family:var(--num); margin-bottom:4px; }
  .t-n em { color:var(--grn); font-style:normal; }
  .t-l { font-size:11px; font-weight:600; color:var(--t2); letter-spacing:.01em; }
  .t-n.counted { animation:countPop .45s var(--ease-spring) both; }
  
  /* PC버전과 일치하는 다크 카드 */
  .t-chip-since { background:var(--t1); color:var(--white); }
  .t-chip-since .t-chip-ic { background:rgba(255,255,255,0.1); box-shadow:none; }
  .t-n-since { display:flex; align-items:baseline; gap:4px; font-family:var(--num); margin-bottom:4px; }
  .t-n-since span { font-size:10px; font-weight:700; color:rgba(255,255,255,.6); letter-spacing:.05em; line-height:1; }
  .t-n-since em { font-size:24px; font-weight:900; letter-spacing:-.05em; line-height:1; color:#fff; font-style:normal; }
  .t-chip-since .t-l { color:#94A3B8; }

  /* ── 공통 섹션 (테두리 제거, 그림자 활용) ── */
  .section { margin:0 20px 24px; background:var(--white); border-radius:24px; padding:24px; border:none; box-shadow:var(--sh); }
  @media (min-width: 860px) { .section { border: 1px solid var(--bd); } }
  
  .sec-hd { display:flex; align-items:center; gap:8px; margin-bottom:20px; }
  .sec-hd-ic { width:32px; height:32px; border-radius:10px; background:var(--grn-lt); color:var(--grn-dk); display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
  .sec-nm { font-size:16px; font-weight:800; letter-spacing:-.04em; color:var(--t1); }
  .proc-list { display:flex; flex-direction:column; list-style:none; }
  .pstep { display:flex; gap:16px; padding:16px 0; border-bottom:1px solid var(--bd); transition:padding-left .2s; }
  .pstep:last-child { border-bottom:none; padding-bottom:0; }
  .ps-ic { width:36px; height:36px; border-radius:50%; background:var(--bg); color:var(--t2); display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:800; flex-shrink:0; transition:transform .25s var(--ease-spring); }
  .ps-ic.done { background:var(--grn); color:var(--white); border:none; box-shadow:0 4px 12px var(--grn-rg); }
  .ps-ttl  { font-size:15px; font-weight:800; letter-spacing:-.03em; margin-bottom:4px; line-height:1.3; color:var(--t1); }
  .ps-desc { font-size:12px; color:var(--t2); line-height:1.6; letter-spacing:-.01em; }

  /* 모바일 운영시간 위젯 */
  .mob-hours { margin:0 20px 24px; background:var(--white); border:none; border-radius:24px; padding:24px; box-shadow:var(--sh); }
  @media(min-width:860px){ .mob-hours { display:none; } }
  .mob-hours.is-open  { box-shadow: 0 8px 24px rgba(37, 99, 235, 0.08); } 
  .mob-hours .pc-hours-row { color:var(--t2); }
  .mob-hours .pc-hours-val.grn { color:var(--t1); }
  .mob-hours .pc-hours-divider-line { background:var(--bd); }
  .mob-hours .pc-hours-tel { color:var(--t1); background:var(--bg); border:1px solid var(--bd); cursor:pointer; pointer-events:auto; }
  .mob-hours .pc-hours-sub { color:var(--t3); }
  .mob-hours .pc-hours-reason { color:var(--t3); }

  /* 푸터 */
  .biz { margin:0 20px 24px; padding:24px; background:var(--white); border:none; border-radius:24px; box-shadow:var(--sh); font-size:12px; color:var(--t3); line-height:2; letter-spacing:-.01em; }
  @media (min-width: 860px) { .biz { border: 1px solid var(--bd); } }
  
  .biz-links { display:flex; gap:16px; margin-bottom:16px; flex-wrap:wrap; }
  .biz-links a { font-weight:700; color:var(--t2); transition:color .15s; }
  .biz b    { color:var(--t1); font-weight:700; }
  .biz-copy { margin-top:12px; font-size:10px; color:var(--bd2); font-weight:600; letter-spacing:.05em; }

  /* ── 하단 탭 네비 ── */
  .tab-nav {
    position: fixed;
    /* iPhone 홈바 safe-area: 최소 24px, 홈바가 있으면 그 위로 올라감 */
    bottom: max(24px, calc(12px + env(safe-area-inset-bottom, 0px)));
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 40px);
    max-width: calc(var(--app-w) - 40px);
    z-index: 500;
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
    border-radius: 24px;
    box-shadow: 0 12px 40px rgba(15,23,42,0.08);
    border: 1px solid rgba(255,255,255,0.8);
    padding: 8px 12px;
  }
  @media(min-width:860px){ .tab-nav{display:none} }
  @media(max-height:667px){ .tab-nav{ bottom:max(16px, calc(8px + env(safe-area-inset-bottom,0px))); } }
  .tab-inner { display:flex; justify-content:space-between; align-items:center; height:56px; }
  .tab-item { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; text-decoration:none; color:var(--t3); height:100%; border-radius:16px; cursor:pointer; transition:all .3s; user-select:none; }
  .tab-item:active { transform:scale(.92); }
  .tab-ic { width:24px; height:24px; display:flex; align-items:center; justify-content:center; transition:transform .3s var(--ease-spring); }
  .tab-item.active { background:var(--t1); color:var(--white); }
  .tab-item.active .tab-ic { transform:translateY(-2px); }
  .tab-item.active svg { stroke:var(--white); }
  .tab-lbl { display:flex; flex-direction:column; align-items:center; text-align:center; }
  .tab-lbl-main { font-size:11px; font-weight:700; white-space:nowrap; letter-spacing:-.02em; }
  .tab-lbl-sub { display:none; }

  /* 작은 기기 여백 대응 */
  @media(max-width:360px) {
    .greet { padding:24px 16px 64px; }
    .cat-wrap { padding:0 16px 16px; gap:12px; }
    .cat-card { padding:20px 16px; border-radius:20px; }
    .kko-banner, .trust-sec, .section, .biz, .mob-hours { margin:0 16px 20px; padding:20px; }
  }


  /* ═══════════════════════════════════════
     § 6. 모달 공통 (App Bottom Sheet)
  ═══════════════════════════════════════ */
  .soon-overlay, .quote-overlay, .policy-overlay {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    display: flex; opacity: 0; pointer-events: none;
    transition: opacity .25s var(--ease);
    /* iOS 모달 뒷배경 스크롤 방지 */
    overscroll-behavior: contain;
    /* 터치 이벤트를 오버레이 내부로 제한 */
    touch-action: none;
  }
  .soon-overlay.modal-show, .quote-overlay.modal-show, .policy-overlay.show {
    opacity: 1; pointer-events: auto;
  }
  .soon-card, .quote-card, .policy-card {
    background: var(--white);
    width: 100%; max-width: 480px;
    border-radius: 32px 32px 0 0;
    box-shadow: 0 -10px 40px rgba(0,0,0,0.15);
    transform: translateY(48px);
    transition: transform .4s var(--ease-spring);
    /* 카드 내부는 일반 스크롤 허용 */
    touch-action: pan-y;
  }
  
  .soon-overlay { padding:24px; align-items:center; justify-content:center; }
  .policy-overlay { align-items:flex-end; justify-content:center; padding:0; }
  .quote-overlay { align-items:flex-end; justify-content:center; padding:0; }
  .soon-card { max-width:360px; padding:40px 24px 32px; text-align:center; border-radius:32px; transform:translateY(20px) scale(.96); margin:0 auto; }
  
  @media(min-width:500px){
    .soon-card, .quote-card, .policy-card { border-radius:24px; transform:translateY(24px) scale(.96); }
    .policy-overlay, .quote-overlay { align-items:center; padding:24px; }
  }
  .soon-overlay.modal-show .soon-card, .policy-overlay.show .policy-card, .quote-overlay.modal-show .quote-card { transform:none; }

  /* 준비중 모달 */
  .soon-icon { width:80px; height:80px; border-radius:24px; background:var(--grn-lt); display:flex; align-items:center; justify-content:center; font-size:32px; margin:0 auto 20px; }
  .soon-title { font-size:20px; font-weight:800; letter-spacing:-.04em; margin-bottom:12px; color:var(--t1); }
  .soon-title span { color:var(--grn); }
  .soon-desc { font-size:14px; color:var(--t2); line-height:1.6; margin-bottom:24px; letter-spacing:-.01em; }
  .soon-kko { display:flex; align-items:center; justify-content:center; gap:8px; height:52px; width:100%; background:var(--kko); color:#000; border-radius:16px; font-size:14px; font-weight:800; text-decoration:none; margin-bottom:12px; transition:transform .2s; }
  .soon-kko:active { transform:scale(.96); }
  .soon-quote-btn { display:flex; align-items:center; justify-content:center; height:52px; width:100%; background:var(--t1); color:var(--white); border-radius:16px; font-size:14px; font-weight:800; margin-bottom:12px; transition:transform .2s; }
  .soon-quote-btn:active { transform:scale(.96); }
  .soon-close { display:flex; align-items:center; justify-content:center; height:52px; width:100%; background:var(--bd); color:var(--t1); border-radius:16px; font-size:14px; font-weight:700; transition:background .2s, color .2s; }

  /* 견적 신청 모달 카드 */
  .quote-card {
    max-height: 92vh; max-height: 92svh;
    overflow-y: auto; overflow-x: hidden;
    /* iOS 모멘텀 스크롤 (구형 iOS 호환) */
    -webkit-overflow-scrolling: touch;
    /* 카드 내 스크롤이 오버레이로 전파되지 않도록 */
    overscroll-behavior: contain;
    display: flex; flex-direction: column;
    /* iPhone 홈바가 카드 하단 버튼을 가리지 않도록 */
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  .quote-header { padding:24px 24px 16px; border-bottom:1px solid var(--bd); background:var(--white); position:sticky; top:0; z-index:10; flex-shrink:0; border-radius:inherit; }
  .quote-header-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
  .quote-title { font-size:18px; font-weight:800; letter-spacing:-.04em; color:var(--t1); }
  .quote-x { width:36px; height:36px; border-radius:12px; background:var(--bg); color:var(--t3); cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:background .2s, color .2s; }
  .q-steps { display:flex; align-items:center; gap:8px; }
  .q-step { display:flex; align-items:center; gap:6px; font-size:13px; font-weight:600; color:var(--t3); transition:color .3s; white-space:nowrap; }
  .q-step span { width:24px; height:24px; border-radius:50%; background:var(--bd); color:var(--t3); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; transition:all .3s; flex-shrink:0; }
  .q-step.active { color:var(--grn-dk); font-weight:700; }
  .q-step.active span { background:var(--grn); color:var(--white); position:relative; }
  .q-step.active span::before { content:''; position:absolute; inset:-4px; border-radius:50%; background:var(--grn); opacity:0; animation:stepPulse 1.8s infinite; }
  .q-step.done { color:var(--t3); }
  .q-step.done span { background:var(--t1); color:var(--white); }
  .q-step-div { flex:1; height:2px; background:var(--bd); border-radius:1px; min-width:12px; }
  .quote-body { padding:24px; background:var(--white); flex:1; }
  .q-step-title { font-size:18px; font-weight:800; letter-spacing:-.04em; margin-bottom:20px; color:var(--t1); display:flex; align-items:center; gap:8px; line-height:1; }
  #qStep2Title { justify-content:center; }
  .q-cat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
  .q-cat-btn { display:flex; flex-direction:column; align-items:flex-start; padding:20px; background:var(--bg); border:1.5px solid var(--bd); border-radius:16px; cursor:pointer; position:relative; overflow:hidden; transition:all .2s var(--ease-spring); text-align:left; box-shadow:var(--sh); }
  .q-cat-btn::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; border-radius:0; }
  .q-cat-btn[data-cat="camera"]::before { background:var(--cam); } .q-cat-btn[data-cat="phone"]::before  { background:var(--phn); } .q-cat-btn[data-cat="pc"]::before     { background:var(--pc);  } .q-cat-btn[data-cat="other"]::before  { background:var(--t3);  }
  .q-cat-btn.selected { background:var(--grn-lt); border-color:var(--grn); box-shadow:0 4px 16px rgba(37,99,235,.15); }
  .q-cat-btn[data-cat="camera"].selected { border-color:var(--cam); background:var(--cam-lt); }
  .q-cat-btn[data-cat="phone"].selected  { border-color:var(--phn); background:var(--phn-lt); }
  .q-cat-btn[data-cat="pc"].selected     { border-color:var(--pc);  background:var(--pc-lt);  }
  .q-cat-btn[data-cat="other"].selected  { border-color:var(--bd2); background:var(--bg);     }
  .q-cat-btn:active { transform:scale(.97); }
  .q-cat-body { display:flex; flex-direction:column; width:100%; gap:6px; }
  .q-cat-ic-wrap { width:48px; height:48px; border-radius:14px; background:var(--white); display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:4px; }
  .q-cat-btn[data-cat="camera"] .q-cat-ic-wrap { background:var(--cam-lt); } .q-cat-btn[data-cat="phone"]  .q-cat-ic-wrap { background:var(--phn-lt); } .q-cat-btn[data-cat="pc"]     .q-cat-ic-wrap { background:var(--pc-lt);  } .q-cat-btn[data-cat="other"]  .q-cat-ic-wrap { background:var(--white); border:1px solid var(--bd); }
  .q-cat-lbl { font-size:16px; font-weight:800; color:var(--t1); letter-spacing:-.03em; line-height:1; }
  .q-cat-desc { font-size:12px; font-weight:500; color:var(--t3); line-height:1.4; }
  .q-cat-check { position:absolute; top:12px; right:12px; width:20px; height:20px; border-radius:50%; background:var(--grn); display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.5); transition:all .2s var(--ease-spring); pointer-events:none; }
  .q-cat-btn.selected .q-cat-check { opacity:1; transform:scale(1); }

  .q-field { margin-bottom:16px; }
  .q-field-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  @media(max-width:360px){ .q-field-row{ grid-template-columns:1fr; } }
  .q-label { display:block; font-size:14px; font-weight:700; color:var(--t1); margin-bottom:8px; letter-spacing:-.01em; }
  .q-req   { color:var(--grn); }
  .q-input, .q-select, .q-textarea { width:100%; background:var(--bg); border:1.5px solid var(--bd); border-radius:14px; font-family:var(--sans); font-size:15px; color:var(--t1); letter-spacing:-.01em; outline:none; transition:all .2s; }
  .q-input, .q-select { height:56px; padding:0 16px; }
  .q-select-wrap { position:relative; }
  .q-select-wrap::after { content:'▼'; position:absolute; right:16px; top:50%; transform:translateY(-50%); font-size:10px; color:var(--t3); pointer-events:none; }
  .q-select { padding-right:36px; appearance:none; -webkit-appearance:none; cursor:pointer; }
  .q-textarea { min-height:100px; padding:16px; resize:vertical; line-height:1.6; }
  .q-input:focus, .q-select:focus, .q-textarea:focus { border-color:var(--grn); background:var(--white); box-shadow:0 0 0 3px var(--grn-rg); }
  .q-input.err, .q-select.err { border-color:#EF4444; }

  .q-photo-zone { border:2px dashed var(--bd2); border-radius:16px; padding:24px 16px; background:var(--bg); transition:all .2s; cursor:pointer; text-align:center; }
  .q-photo-zone.dragover { border-color:var(--grn); background:var(--grn-lt); }
  .q-photo-zone-icon { font-size:24px; margin-bottom:8px; }
  .q-photo-zone-txt  { font-size:14px; font-weight:700; color:var(--t2); }
  .q-photo-zone-sub  { font-size:11px; color:var(--t3); margin-top:4px; }
  .q-photo-previews  { display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
  .q-photo-thumb { position:relative; width:80px; height:80px; border-radius:12px; overflow:hidden; border:1px solid var(--bd); flex-shrink:0; }
  .q-photo-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
  .q-photo-del { position:absolute; top:4px; right:4px; width:22px; height:22px; border-radius:50%; background:rgba(0,0,0,.6); border:none; cursor:pointer; color:#fff; font-size:14px; display:flex; align-items:center; justify-content:center; padding:0; transition:background .2s; }
  .q-photo-add-btn { width:80px; height:80px; border-radius:12px; border:2px dashed var(--bd2); background:var(--bg); cursor:pointer; font-size:24px; color:var(--t3); display:flex; align-items:center; justify-content:center; transition:all .2s; flex-shrink:0; }
  .q-photo-meta { display:flex; align-items:center; justify-content:space-between; margin-top:8px; }
  .q-photo-err   { font-size:12px; color:#EF4444; font-weight:600; }
  .q-photo-count { font-size:12px; color:var(--t3); }

  .q-privacy { margin:16px 0 12px; }
  .q-privacy-lbl { display:flex; align-items:center; gap:12px; background:var(--bg); border:1.5px solid var(--bd); border-radius:14px; padding:16px; cursor:pointer; user-select:none; transition:all .2s; }
  .q-privacy-lbl input[type=checkbox] { display:none; }
  .q-privacy-box { width:22px; height:22px; border-radius:6px; border:2px solid var(--bd2); background:var(--white); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; }
  .q-privacy-box svg { opacity:0; transition:opacity .15s; stroke-width:2.5; }
  .q-privacy-lbl:has(input:checked) { border-color:var(--grn); background:var(--grn-lt); }
  .q-privacy-lbl:has(input:checked) .q-privacy-box { background:var(--grn); border-color:var(--grn); }
  .q-privacy-lbl:has(input:checked) .q-privacy-box svg { opacity:1; }
  .q-privacy-txt { flex:1; }
  .q-privacy-main { font-size:14px; font-weight:700; color:var(--t1); display:block; letter-spacing:-.02em; }
  .q-privacy-sub  { font-size:11.5px; color:var(--t3); margin-top:2px; display:block; letter-spacing:-.01em; }

  .q-btns { display:flex; gap:10px; margin-top:16px; }
  .q-btn-back { height:56px; flex:0 0 90px; background:var(--bg); color:var(--t2); border:1.5px solid var(--bd); border-radius:16px; font-family:var(--sans); font-size:15px; font-weight:700; cursor:pointer; transition:all .2s; }
  .q-btn-next, .q-btn-submit { flex:1; height:56px; background:var(--grn); color:var(--white); border:none; border-radius:16px; font-family:var(--sans); font-size:16px; font-weight:800; cursor:pointer; transition:all .2s var(--ease-spring); letter-spacing:-.02em; }
  .q-btn-submit:active { transform:scale(.97); }
  .q-btn-submit:disabled { background:var(--bd2); cursor:not-allowed; }

  .q-done-wrap { text-align:center; padding:16px 0; }
  .q-done-icon { width:80px; height:80px; border-radius:50%; background:var(--grn-lt); display:flex; align-items:center; justify-content:center; font-size:36px; margin:0 auto 20px; animation:popIn .5s var(--ease-spring) both; }
  .q-done-title { font-size:20px; font-weight:800; letter-spacing:-.04em; color:var(--t1); margin-bottom:12px; }
  .q-done-status { display:inline-flex; align-items:center; gap:8px; background:var(--grn-lt); border-radius:20px; padding:6px 16px; font-size:13px; font-weight:700; color:var(--grn-dk); margin-bottom:20px; }
  .q-done-dot { width:8px; height:8px; border-radius:50%; background:var(--grn); flex-shrink:0; animation:ripple 2s infinite; }
  .q-done-desc { font-size:14px; color:var(--t2); line-height:1.8; margin-bottom:0; }
  .q-done-divider { height:1px; background:var(--bd); margin:24px 0; }
  .q-done-kko { display:flex; align-items:center; justify-content:center; gap:8px; height:52px; width:100%; background:var(--kko); color:#000; border-radius:16px; font-family:var(--sans); font-size:14px; font-weight:800; text-decoration:none; border:none; cursor:pointer; margin-bottom:10px; transition:transform .2s; }
  .q-done-kko:active { transform:scale(.96); }
  .q-done-close { display:flex; align-items:center; justify-content:center; height:52px; width:100%; background:var(--bg); color:var(--t2); border-radius:16px; border:1.5px solid var(--bd); cursor:pointer; font-family:var(--sans); font-size:14px; font-weight:700; transition:all .2s; }
  .q-err { margin-top:12px; padding:12px 16px; background:#FEF2F2; color:#EF4444; border-radius:12px; font-size:13px; font-weight:600; display:none; }

  /* 정책 모달 */
  .policy-card {
    display: flex; flex-direction: column;
    max-height: 88vh; max-height: 88svh;
    background: var(--white);
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  .policy-hd { padding:24px 24px 16px; border-bottom:1px solid var(--bd); display:flex; justify-content:space-between; align-items:center; position:sticky; top:0; z-index:1; background:var(--white); border-radius:inherit;}
  .policy-hd-left { display:flex; flex-direction:column; gap:4px; }
  .policy-hd-badge { display:inline-flex; align-items:center; gap:5px; font-size:10px; font-weight:800; letter-spacing:1px; color:var(--grn-dk); background:var(--grn-lt); border-radius:8px; padding:4px 10px; width:fit-content; margin-bottom:4px; }
  .policy-hd h2 { font-size:18px; font-weight:800; color:var(--t1); letter-spacing:-.03em; }
  .policy-hd-date { font-size:12px; color:var(--t3); }
  .policy-x { width:36px; height:36px; border-radius:12px; background:var(--bg); color:var(--t3); cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:background .2s, color .2s; flex-shrink:0; }
  .policy-body {
    padding: 24px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    flex: 1;
  }
  .policy-body h3 { font-size:15px; font-weight:800; color:var(--t1); letter-spacing:-.03em; margin:24px 0 12px; padding-bottom:8px; border-bottom:1px solid var(--bd); }
  .policy-body h3:first-child { margin-top:0; }
  .policy-body p, .policy-body li { font-size:14px; color:var(--t2); line-height:1.8; margin-bottom:6px; letter-spacing:-.01em; }
  .policy-body ol, .policy-body ul { padding-left:20px; margin:8px 0; }
  .policy-body strong { color:var(--t1); font-weight:700; }
  .policy-table { width:100%; border-collapse:collapse; margin:16px 0; font-size:13px; }
  .policy-table th { background:var(--bg); color:var(--t1); font-weight:700; padding:10px 12px; text-align:left; border:1px solid var(--bd); }
  .policy-table td { padding:10px 12px; border:1px solid var(--bd); color:var(--t2); vertical-align:top; line-height:1.6; }
  .policy-highlight { background:var(--grn-lt); border:1px solid var(--grn-rg); border-radius:16px; padding:16px; margin:16px 0; font-size:13px; color:var(--grn-dk); font-weight:600; line-height:1.7; }
  body.modal-open { overflow:hidden; }

  /* ──────────────────────────────────────────────
     모바일 폰트 최적화
     · iOS Safari: font-size < 16px 입력 필드 → 자동 줌 발생
       → 모든 input / select / textarea를 최소 16px로 강제
     · Android Chrome: 동일 규칙 적용
  ─────────────────────────────────────────────── */
  @media(max-width:767px) {
    /* 모든 폼 요소 iOS 자동 줌 방지 (16px 미만 시 줌 트리거) */
    input, select, textarea,
    .q-input, .q-select, .q-textarea {
      font-size: 16px !important;
    }
    /* 버튼·레이블은 폰트 크기 유지 (줌 트리거 없음) */
  }

  /* ──────────────────────────────────────────────
     추가 모바일 최적화
     · 탭 버튼 최소 터치 영역 44×44px (Apple HIG / WCAG 2.5.5)
     · 버튼 텍스트 줄바꿈 방지
     · 모달 내부 텍스트 선택 방지 (UX)
  ─────────────────────────────────────────────── */
  @media(max-width:859px) {
    /* 탭 네비 터치 타겟 최소 44px 확보 */
    .tab-item { min-height: 44px; min-width: 44px; }

    /* 하단 버튼 영역: 손가락으로 정확히 탭 가능하도록 높이 보장 */
    .q-btn-next, .q-btn-submit, .q-btn-back,
    .soon-kko, .soon-quote-btn, .soon-close,
    .q-done-kko, .q-done-close { min-height: 48px; }

    /* 카드 내 버튼 텍스트 줄바꿈 방지 */
    .kb-btn, .hd-kko { white-space: nowrap; }

    /* iPhone SE (1세대) / 작은 안드로이드 대응: 폰트 계층 최소화 */
    .cat-nm    { font-size: 17px; }
    .greet-h   { font-size: clamp(22px, 5.5vw, 28px); }
    .ps-ttl    { font-size: 14px; }

    /* 모달 헤더 스텝 텍스트가 좁은 화면에서 겹치지 않도록 */
    .q-step { font-size: 12px; }
    .q-step span { width: 22px; height: 22px; font-size: 11px; }
  }

  /* ──────────────────────────────────────────────
     iPhone SE 2세대·초소형 기기 (320px 이하) 대응
  ─────────────────────────────────────────────── */
  @media(max-width:320px) {
    .q-steps { gap: 4px; }
    .q-step-div { min-width: 6px; }
    .q-step { font-size: 11px; }
    .cat-card { padding: 16px 12px; }
    .cat-ic { width: 48px; height: 48px; margin-right: 12px; }
  }
