
  /* ===== 컨테이너 ===== */
  .contact-inner{width:min(980px,92%);margin:0 auto;padding:64px 0 96px;box-sizing:border-box;text-align:center}
  .inquiry-title{
    margin:0 0 8px;
    font-size:var(--fs-sec-title);
    line-height:var(--lh-sec-title);
    color: var(--brand);font-weight:800;letter-spacing:.01em
  }
  .inquiry-desc{
    margin:0 0 32px;
    font-size:var(--fs-sec-desc);
    line-height:var(--lh-sec-desc);
    color:#6b7280
  }

  /* ===== 카드 ===== */
  .form-box{display:flex;justify-content:center}
  .form-con{width:100%;max-width:860px;padding:0}

  /* ===== 필드 공통 ===== */
  .fld{display:flex;flex-direction:column;gap:10px;text-align:left}
  .fld-label{
    font-size:var(--fs-head);
    line-height:var(--lh-head);
    font-weight:600;color:#374151
  }
  .req{color:#f43f5e;margin-left:4px}

  /* ===== 2열 그리드 ===== */
  .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px;margin-bottom:18px}
  .fld-textarea{margin-top:4px;margin-bottom: 18px;}

  /* ===== 입력요소 ===== */
  .form-box input,.form-box select,.form-box textarea{
    width:100%;box-sizing:border-box;border:1px solid #cdd1d5;border-radius:10px;
    padding:12px 14px;
    font-size:var(--fs-body);
    line-height:var(--lh-body);
    background:#fff;color:#111
  }
  /* 실제 input 숨김 */
  #pp-check{
    position:absolute;
    opacity:0;
    width:0;
    height:0;
  }

  /* 커스텀 라디오 외형 */
  #pp-check + span::before{
    content:"";
    display:inline-block;
    width:18px;
    height:18px;
    border:2px solid #cdd1d5;
    margin-right: 8px;
    border-radius:50%;
    background:#fff;
    box-sizing:border-box;
    transition:border-color .2s, background .2s;
  }

  /* 활성 상태 */
  #pp-check:checked + span::before{
    border-color:var(--brand);
    background:
      radial-gradient(var(--brand) 45%, transparent 46%);
  }

  /* 포커스(키보드 접근 시) */
  #pp-check:focus-visible + span::before{
    outline:2px solid var(--brand);
    outline-offset:2px;
  }
  .form-box input:focus,.form-box select:focus,.form-box textarea:focus{outline:2px solid #a7b3ff;border-color: var(--brand)}
  .form-box textarea{min-height:220px;resize:vertical}

  /* ===== 전화번호 묶음 ===== */
  .tel-box{display:grid;grid-template-columns:140px 1fr 1fr;gap:10px}
  .tel-sel{appearance:auto}

  /* ===== 약관 ===== */
  .provision{display:flex;justify-content:flex-start;align-items:center;gap:12px;margin:24px 0 36px;flex-wrap:wrap}
  /* 라디오형 디자인 체크박스 */
  .pp-label{
    position:relative;
    display:flex;
    align-items:center;
    gap:10px;
    cursor:pointer;
    font-size:var(--fs-body);
    line-height:var(--lh-body);
    color:#374151;
  }
  .pp-label span {font-size:var(--fs-body);line-height:var(--lh-body);display: flex;align-items: center;}
  .pp-open{padding:8px 12px;font-size:var(--fs-body);background:#9aa0b4;color:#fff;border-radius:6px;border:none}

  /* ===== 전송 버튼 ===== */
  /* 기존 .btn-send 주석 유지 시 def_btn 사용 */
  .def_btn{
    --stroke: var(--white);
    --fg: var(--white);
    --bg: transparent;
    display:inline-flex;align-items:center;justify-content:center;
    padding:14px 28px;border-radius:12px;border:2px solid var(--stroke);
    background:var(--bg);color:var(--fg);
    font-weight:700;
    font-size:var(--fs-head);
    line-height:1.2;
    text-decoration:none;transition:background .2s,color .2s,border-color .2s,box-shadow .2s;
    box-shadow:0 0 0 0 rgba(0,0,0,0)
  }
  .def_btn.b_b{--stroke:#31376a;--fg:#31376a}
  .def_btn.b_b:hover{background:#31376a;color:#fff;border-color:#31376a}

  /* ===== 개인정보처리방침 모달(단일) ===== */
  :root{ --pp-bg:#fff; --pp-ink:#111; --pp-line:#e6e7ea; --pp-shadow:0 16px 40px rgba(0,0,0,.18),0 2px 10px rgba(0,0,0,.08) }
  .pp-wrap{position:fixed;inset:0;z-index:100000000}
  .pp-wrap[hidden]{display:none} /* 최초 숨김 전용 */
  #ppDim{position:absolute;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .2s ease}
  .pp-panel{
    position:absolute;inset:6% max(12px, env(safe-area-inset-right)) auto max(12px, env(safe-area-inset-left));
    margin:auto;max-width:min(900px,92vw);max-height:min(84vh,900px);
    background:var(--pp-bg);color:var(--pp-ink);border:1px solid var(--pp-line);
    border-radius:14px;box-shadow:var(--pp-shadow);overflow:auto;
    opacity:0;transform:translateY(8px) scale(.98);transition:opacity .2s ease,transform .2s ease
  }
  .pp-head{
    position:sticky;top:0;background:var(--pp-bg);
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:14px 16px;border-bottom:1px solid var(--pp-line);z-index:1
  }
  .pp-head h2{
    margin:0;
    font-size:var(--fs-head);
    line-height:var(--lh-head);
    font-weight:700
  }
  .pp-close{border:0;background:transparent;cursor:pointer;padding:6px;border-radius:8px}
  .pp-body{
    padding:16px 18px 22px;
    font-size:var(--fs-body);
    line-height:var(--lh-body)
  }

  .pp-wrap.is-open #ppDim{opacity:1;pointer-events:auto}
  .pp-wrap.is-open .pp-panel{opacity:1;transform:translateY(0) scale(1)}

  /* ===== 반응형 ===== */
  @media (max-width:768px){
    .contact-inner{padding:44px 0 72px}
    .grid-2{grid-template-columns:1fr;gap:14px}
    .tel-box{grid-template-columns:120px 1fr 1fr}
    .pp-panel{inset:auto 0 0 0;max-width:none;max-height:min(90svh,760px);border-radius:16px 16px 0 0;border-left:none;border-right:none}
  }
  @media (max-width:480px){
    /* iOS 확대 방지 */
    .form-box input,.form-box select,.form-box textarea{font-size:16px}
    .tel-box{grid-template-columns:110px 1fr 1fr}
  }
  @media (prefers-color-scheme: dark){
    :root{ --pp-bg:#111316; --pp-ink:#e7e9ef; --pp-line:#2a2e36 }
  }
  @media (prefers-reduced-motion: reduce){
    #ppDim,.pp-panel{transition:none !important}
  }