/* ═══════════════════════════════════════
     § 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:'\25BC'; 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; }
  }

/* ── 예상 매입가 프리뷰 ─────────────────────────── */
.q-price-preview{
  background:linear-gradient(135deg,#f0fdf4,#dcfce7);
  border:1.5px solid #86efac;border-radius:12px;
  padding:12px 14px;margin-bottom:14px;
}
.q-price-preview-hd{
  display:flex;align-items:center;gap:6px;margin-bottom:10px;
}
.q-price-preview-icon{font-size:14px;}
.q-price-preview-title{
  font-size:12px;font-weight:700;color:#166534;flex:1;letter-spacing:-.01em;
}
.q-price-preview-model{
  font-size:11px;color:#16a34a;font-weight:700;
  background:#bbf7d0;padding:2px 8px;border-radius:20px;
}
.q-price-preview-grades{
  display:flex;gap:6px;flex-wrap:wrap;
}
.q-price-grade-item{
  flex:1;min-width:0;
  background:#fff;border:1px solid #bbf7d0;border-radius:8px;
  padding:8px 10px;transition:all .15s;
}
.q-price-grade-item.active{
  border-color:#16a34a;background:#f0fdf4;
  box-shadow:0 0 0 2px rgba(22,163,74,.15);
}
.q-pg-badge{
  display:block;font-size:10px;font-weight:800;
  margin-bottom:3px;letter-spacing:.2px;
}
.q-pg-badge.s{color:#92400e;}
.q-pg-badge.a{color:#1e40af;}
.q-pg-badge.b{color:#374151;}
.q-pg-range{
  display:block;font-size:11px;font-weight:700;
  color:#166534;line-height:1.4;
}

/* ── Step 2.5 추가 품목 ─────────────────────────── */
.q-addon-main-card{
  display:flex;align-items:center;gap:10px;
  background:#f8fafc;border:1.5px solid #e2e8f0;
  border-radius:10px;padding:12px 14px;margin-bottom:12px;
}
.q-addon-main-icon{font-size:22px;}
.q-addon-main-name{
  font-size:13px;font-weight:700;color:var(--t1);letter-spacing:-.02em;
}
.q-addon-main-price{
  font-size:12px;color:var(--grn-dk);font-weight:700;margin-top:2px;
}

.q-addon-item-card{
  display:flex;align-items:center;gap:10px;
  background:#fff;border:1.5px solid #e2e8f0;
  border-radius:10px;padding:10px 12px;margin-bottom:8px;
  animation:slideIn .2s ease;
}
@keyframes slideIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.q-addon-item-icon{font-size:18px;flex-shrink:0;}
.q-addon-item-info{flex:1;}
.q-addon-item-name{font-size:12px;font-weight:700;color:var(--t1);}
.q-addon-item-price{font-size:11px;color:var(--grn-dk);font-weight:700;margin-top:2px;}
.q-addon-item-del{
  width:22px;height:22px;border-radius:50%;
  background:#fee2e2;border:none;cursor:pointer;
  font-size:12px;color:#dc2626;display:flex;
  align-items:center;justify-content:center;flex-shrink:0;
}

.q-addon-total{
  display:flex;justify-content:space-between;align-items:center;
  background:#f0fdf4;border:1.5px solid #86efac;
  border-radius:10px;padding:12px 14px;margin-bottom:14px;
}
.q-addon-total-label{font-size:12px;font-weight:700;color:#166534;}
.q-addon-total-amt{font-size:16px;font-weight:800;color:#16a34a;}

.q-addon-cta{
  background:linear-gradient(135deg,#eff6ff,#dbeafe);
  border:1.5px dashed #93c5fd;border-radius:12px;
  padding:14px;margin-bottom:14px;
}
.q-addon-cta-txt{
  font-size:12px;color:#1e40af;margin-bottom:10px;line-height:1.6;
}
.q-addon-cta-txt strong{font-size:13px;}
.q-addon-cta-btns{display:flex;gap:8px;}
.q-addon-btn{
  flex:1;padding:10px;
  background:#2563eb;border:none;border-radius:8px;
  font-size:12px;font-weight:700;color:#fff;
  cursor:pointer;font-family:inherit;transition:opacity .15s;
}
.q-addon-btn:hover{opacity:.88;}
.q-addon-btn-etc{background:#0369a1;}

.q-addon-form{
  background:#f8fafc;border:1.5px solid #e2e8f0;
  border-radius:12px;padding:14px;margin-bottom:12px;
  animation:slideIn .2s ease;
}
.q-addon-form-title{
  font-size:13px;font-weight:700;color:var(--t1);
  margin-bottom:12px;letter-spacing:-.02em;
}
.q-addon-form-btns{display:flex;gap:8px;margin-top:12px;}
.q-addon-price-hint{
  font-size:12px;color:var(--grn-dk);font-weight:700;
  background:#f0fdf4;border:1px solid #bbf7d0;
  border-radius:6px;padding:6px 10px;
}

/* Step 인디케이터 추가품목 스텝 */
.q-step-addon{font-size:11px;}
.q-step-addon span{width:18px;height:18px;font-size:10px;}

/* ── 카메라 아이템 섹션 (바디/렌즈) ─────────────── */
.q-item-section{
  border:1.5px solid var(--bd);border-radius:14px;
  overflow:hidden;margin-bottom:12px;
  background:var(--white);
}
.q-item-section-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 14px;background:var(--bg);
  border-bottom:1px solid var(--bd);
}
.q-item-section-left{
  display:flex;align-items:center;gap:8px;
}
.q-item-section-icon{font-size:16px;}
.q-item-section-label{
  font-size:14px;font-weight:800;color:var(--t1);letter-spacing:-.02em;
}
.q-item-add-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 14px;border-radius:20px;
  background:var(--grn);border:none;
  font-size:12px;font-weight:700;color:#fff;
  cursor:pointer;font-family:inherit;
  transition:opacity .15s;
}
.q-item-add-btn:hover{opacity:.85;}
.q-item-add-btn--lens{background:#2563eb;}

/* ── 개별 아이템 카드 ───────────────────────────── */
.q-item-card{
  padding:14px;border-bottom:1px solid var(--bd);
  animation:slideDown .2s ease;
  position:relative;
}
.q-item-card:last-child{border-bottom:none;}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

.q-item-card-hd{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.q-item-card-title{
  font-size:12px;font-weight:700;color:var(--t2);
}
.q-item-card-del{
  width:22px;height:22px;border-radius:50%;
  background:#fee2e2;border:none;cursor:pointer;
  font-size:13px;color:#dc2626;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-family:inherit;
}

/* 가격 프리뷰 인라인 */
.q-item-price-hint{
  font-size:11px;color:var(--grn-dk);font-weight:700;
  background:#f0fdf4;border:1px solid #bbf7d0;
  border-radius:6px;padding:5px 10px;
  margin-top:8px;display:none;
}

/* ── 등급 선택 버튼 ─────────────────────────────── */
.q-grade-btns{display:flex;gap:6px;}
.q-grade-btn{
  flex:1;padding:8px 4px;
  background:var(--white);border:1.5px solid var(--bd);
  border-radius:8px;font-size:12px;font-weight:700;
  color:var(--t2);cursor:pointer;text-align:center;
  transition:all .15s;font-family:inherit;
}
.q-grade-btn.s.active{border-color:#92400e;background:#fef3c7;color:#92400e;}
.q-grade-btn.a.active{border-color:#1e40af;background:#dbeafe;color:#1e40af;}
.q-grade-btn.b.active{border-color:#374151;background:#f3f4f6;color:#374151;}
.q-grade-btn:hover:not(.active){border-color:var(--grn);background:#f0fdf4;}

/* 합산 예상가 */
.q-camera-total{
  display:flex;justify-content:space-between;align-items:center;
  background:#f0fdf4;border:1.5px solid #86efac;
  border-radius:10px;padding:11px 14px;
  margin-bottom:12px;
}
.q-camera-total-label{font-size:12px;font-weight:700;color:#166534;}
.q-camera-total-amt{font-size:15px;font-weight:800;color:var(--grn-dk);}


/* =========================================
   커스텀 오버라이드
   ========================================= */
.quote-card {
  background: #FFFFFF !important;
}
.quote-header {
  background: rgba(255, 255, 255, 0.8) !important;
  backdrop-filter: blur(20px) !important;
  border-bottom: 0.5px solid #E5E7EB !important;
}
.q-item-section {
  background: #FFFFFF !important;
  border: 0.5px solid #E5E7EB !important;
  border-radius: 16px !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.02) !important;
}
.q-item-section-hd {
  background: #FAFAFA !important;
  border-bottom: 0.5px solid #E5E7EB !important;
}
.q-item-section-label {
  color: #000000 !important;
  font-weight: 700 !important;
}
.q-input, .q-select, .q-textarea {
  background: #FFFFFF !important;
  border: 0.5px solid #D1D5DB !important;
  border-radius: 10px !important;
}
.q-input:focus, .q-select:focus, .q-textarea:focus {
  border-color: #000000 !important;
}
.q-grade-btns {
  background: #F3F4F6 !important;
  padding: 4px !important;
  border-radius: 10px !important;
  gap: 0 !important;
}
.q-grade-btn {
  background: transparent !important;
  border: none !important;
  border-radius: 8px !important;
  color: #4B5563 !important;
  box-shadow: none !important;
  transform: none !important;
}
.q-grade-btn.s.active,
.q-grade-btn.a.active,
.q-grade-btn.b.active {
  background: #FFFFFF !important;
  color: #000000 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
  border: none !important;
  transform: none !important;
}
.q-btn-next {
  background: #000000 !important;
  border-radius: 14px !important;
}
.q-btn-next:hover {
  background: #1a1a1a !important;
  transform: none !important;
}
.q-item-price-hint {
  background: #F9FAFB !important;
  border: 0.5px solid #E5E7EB !important;
  color: #111827 !important;
}
.q-item-price-hint::before {
  color: #6B7280 !important;
}

/* =====================================================
   2026 리뉴얼 오버라이드
   ===================================================== */

/* Pretendard 폰트 명시 */
.quote-card, .quote-card * {
  font-family: 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, sans-serif !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

/* ── 팝업 전체 배경 ── */
.quote-card {
  background: #FFFFFF !important;
  border-radius: 24px !important;
}

/* ── 헤더 ── */
.quote-header {
  background: rgba(255,255,255,0.92) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-bottom: 0.5px solid #E5E7EB !important;
  padding: 20px 22px 14px !important;
  border-radius: 24px 24px 0 0 !important;
}
.quote-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #0A0A0A !important;
  letter-spacing: -0.5px !important;
}

/* ── X 닫기 버튼 ── */
.quote-x {
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  background: #F3F4F6 !important;
  color: #6B7280 !important;
  font-size: 13px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.15s, color 0.15s !important;
  border: none !important;
  cursor: pointer !important;
}
.quote-x:hover {
  background: #FEE2E2 !important;
  color: #DC2626 !important;
}

/* ── 스텝 인디케이터 ── */
.q-step {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #9CA3AF !important;
  letter-spacing: -0.1px !important;
}
.q-step span {
  width: 22px !important;
  height: 22px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  background: #E5E7EB !important;
  color: #9CA3AF !important;
}
.q-step.active {
  color: #111827 !important;
  font-weight: 700 !important;
}
.q-step.active span {
  background: #111827 !important;
  color: #FFFFFF !important;
}
.q-step.active span::before { display: none !important; }
.q-step-div {
  background: #E5E7EB !important;
  height: 1px !important;
}

/* ── 폼 바디 ── */
.quote-body {
  padding: 18px 20px 24px !important;
  gap: 12px !important;
}
.q-step-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #0A0A0A !important;
  letter-spacing: -0.4px !important;
  margin-bottom: 16px !important;
}

/* ── 섹션 (바디 / 렌즈) ── */
.q-item-section {
  background: #FFFFFF !important;
  border: 0.5px solid #E5E7EB !important;
  border-radius: 16px !important;
  margin-bottom: 10px !important;
  overflow: hidden !important;
}
.q-item-section-hd {
  background: #FAFAFA !important;
  border-bottom: 0.5px solid #F0F0F0 !important;
  padding: 13px 16px !important;
}
.q-item-section-label {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #0A0A0A !important;
  letter-spacing: -0.3px !important;
}
.q-item-add-btn {
  font-size: 12px !important;
  font-weight: 700 !important;
  padding: 6px 14px !important;
  border-radius: 20px !important;
  background: #111827 !important;
  color: #FFFFFF !important;
  border: none !important;
  letter-spacing: -0.1px !important;
  transition: opacity 0.15s !important;
}
.q-item-add-btn:hover { opacity: 0.82 !important; }
.q-item-add-btn--lens { background: #111827 !important; }

/* ── 아이템 카드 ── */
.q-item-card {
  padding: 14px 16px !important;
  border-bottom: 0.5px solid #F5F5F5 !important;
  background: #FFFFFF !important;
}
.q-item-card:last-child { border-bottom: none !important; }
.q-item-card-hd { margin-bottom: 10px !important; }
.q-item-card-title {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #9CA3AF !important;
  letter-spacing: 0.2px !important;
  text-transform: uppercase !important;
}
.q-item-card-del {
  width: 20px !important;
  height: 20px !important;
  border-radius: 50% !important;
  background: #FEE2E2 !important;
  color: #EF4444 !important;
  font-size: 12px !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.15s !important;
}
.q-item-card-del:hover {
  background: #FCA5A5 !important;
  color: #B91C1C !important;
}

/* ── 라벨 ── */
.q-label {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #6B7280 !important;
  margin-bottom: 6px !important;
  letter-spacing: -0.1px !important;
}

/* ── 입력창 & 드롭다운 ── */
.q-input, .q-select, .q-textarea {
  background: #F9FAFB !important;
  border: 0.5px solid #E5E7EB !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #111827 !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
  letter-spacing: -0.2px !important;
}
.q-input, .q-select { height: 46px !important; padding: 0 14px !important; }
.q-input:focus, .q-select:focus, .q-textarea:focus {
  background: #FFFFFF !important;
  border-color: #111827 !important;
  box-shadow: 0 0 0 3px rgba(17,24,39,0.07) !important;
  outline: none !important;
}
.q-input::placeholder { color: #C4C9D4 !important; font-weight: 400 !important; }
.q-select-wrap::after {
  font-size: 9px !important;
  color: #9CA3AF !important;
  right: 13px !important;
}

/* ── 외관상태 + 구성품 동일 높이 정렬 ── */
.q-field-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  align-items: end !important;
}

/* 등급 버튼과 드롭다운 높이 통일 */
.q-grade-btns {
  display: flex !important;
  gap: 0 !important;
  background: #F3F4F6 !important;
  border-radius: 10px !important;
  padding: 3px !important;
  height: 46px !important;
  align-items: center !important;
}
.q-grade-btn {
  flex: 1 !important;
  height: 40px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 7px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #6B7280 !important;
  cursor: pointer !important;
  transition: all 0.18s !important;
  transform: none !important;
  box-shadow: none !important;
  letter-spacing: -0.2px !important;
}
.q-grade-btn:hover:not(.active) {
  background: rgba(255,255,255,0.6) !important;
  color: #374151 !important;
}
.q-grade-btn.s.active,
.q-grade-btn.a.active,
.q-grade-btn.b.active {
  background: #FFFFFF !important;
  color: #0A0A0A !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.10), 0 0 0 0.5px rgba(0,0,0,0.05) !important;
  border: none !important;
  transform: none !important;
}

/* ── 예상 매입가 ── */
.q-item-price-hint {
  background: #F9FAFB !important;
  border: 0.5px solid #E5E7EB !important;
  border-radius: 10px !important;
  padding: 10px 13px !important;
  margin-top: 8px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  display: block !important;
  letter-spacing: -0.2px !important;
}
.q-item-price-hint::before {
  content: '예상 매입가' !important;
  display: inline !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #9CA3AF !important;
  margin-right: 8px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

/* ── 사진 업로드 ── */
.q-photo-zone {
  background: #F9FAFB !important;
  border: 1.5px dashed #E5E7EB !important;
  border-radius: 14px !important;
}

/* ── 개인정보 동의 ── */
.q-privacy-lbl {
  border-radius: 12px !important;
  border: 0.5px solid #E5E7EB !important;
  background: #FAFAFA !important;
  padding: 14px 16px !important;
}
.q-privacy-main {
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: -0.2px !important;
}
.q-privacy-sub {
  font-size: 11px !important;
  color: #9CA3AF !important;
}

/* ── 하단 버튼 ── */
.q-btns { gap: 8px !important; margin-top: 14px !important; }
.q-btn-back {
  height: 52px !important;
  flex: 0 0 80px !important;
  background: #F3F4F6 !important;
  border: none !important;
  border-radius: 14px !important;
  color: #374151 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: -0.2px !important;
}
.q-btn-back:hover {
  background: #E5E7EB !important;
  border-color: transparent !important;
  color: #111827 !important;
}
.q-btn-next, .q-btn-submit {
  height: 52px !important;
  background: #111827 !important;
  border-radius: 14px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -0.3px !important;
  border: none !important;
}
.q-btn-next:hover, .q-btn-submit:hover {
  background: #1F2937 !important;
  transform: none !important;
}
.q-btn-submit:active { transform: scale(0.98) !important; }

/* ── 완료 화면 ── */
.q-done-wrap { padding: 32px 20px !important; }
.q-done-title {
  font-size: 20px !important;
  font-weight: 800 !important;
  letter-spacing: -0.5px !important;
}
.q-done-close {
  background: #111827 !important;
  border-radius: 14px !important;
  color: #FFFFFF !important;
  font-weight: 700 !important;
  letter-spacing: -0.2px !important;
}

/* ── SMS 동의 점선 스타일 ── */
.q-privacy-lbl--sms {
  border-style: dashed !important;
  background: #FDFDFD !important;
}

/* 예상 매입가 - 외관상태/구성품 아래 배치 */
.q-item-price-hint:empty {
  display: none !important;
}
.q-item-price-hint {
  display: none;
  margin-top: 10px !important;
  margin-bottom: 0 !important;
  background: #F9FAFB !important;
  border: 0.5px solid #E5E7EB !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  letter-spacing: -0.2px !important;
  animation: fadeInHint .2s ease;
}
@keyframes fadeInHint {
  from { opacity:0; transform:translateY(-4px); }
  to   { opacity:1; transform:translateY(0); }
}
.q-item-price-hint::before {
  content: '' !important;
  display: none !important;
}

/* ── 자동완성 드롭다운 ── */
.q-autocomplete {
  font-family: 'Pretendard Variable', Pretendard, -apple-system, sans-serif;
}
.q-autocomplete-item:last-child {
  border-bottom: none !important;
}
.q-autocomplete-item:hover {
  background: #F9FAFB !important;
}
