  :root {
    --navy-900: #0a1f44;
    --navy-800: #0f2a5c;
    --navy-700: #17387a;
    --blue-600: #1e56c8;
    --blue-500: #2e6fe0;
    --blue-400: #4a8cf0;
    --sky-100:  #e8f1ff;
    --sky-50:   #f3f7fe;
    --cream:    #fff8ea;
    --tan:      #e8c989;
    --tan-dark: #8a5a2a;
    --wood:     #6b4423;
    --ink:      #0b1320;
    --ink-70:   #384256;
    --ink-50:   #6b7486;
    --line:     #dbe3f1;
    --white:    #ffffff;
    --danger:   #e94040;
    --yellow:   #ffd233;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html, body { scroll-behavior: smooth; }
  body {
    font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--ink);
    background: var(--white);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
  }
  .display { font-family: 'Paperlogy', 'Pretendard', sans-serif; letter-spacing: -0.02em; }
  .accent-font { font-family: 'Gowun Dodum', 'Pretendard', sans-serif; }

  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  button { font-family: inherit; cursor: pointer; border: none; background: none; }

  .wrap { max-width: 1240px; margin: 0 auto; padding: 0 24px; }

  /* ---------- TOP BAR ---------- */
  .topbar {
    background: var(--navy-900);
    color: #cfd8ec;
    font-size: 13px;
    padding: 8px 0;
  }
  .topbar .wrap { display: flex; justify-content: space-between; align-items: center; }
  .topbar .chips { display: flex; gap: 18px; }
  .topbar .chips span { display: inline-flex; align-items: center; gap: 6px; }
  .topbar .dot { width: 6px; height: 6px; border-radius: 50%; background: #5ae39a; box-shadow: 0 0 8px #5ae39a;}

  /* ---------- HEADER ---------- */
  header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--line);
  }
  .nav { display: flex; align-items: center; justify-content: space-between; height: 76px; }
  .logo { display: flex; align-items: center; gap: 12px; }
  .logo-mark {
    width: 48px; height: 48px; border-radius: 14px;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-500));
    display: grid; place-items: center;
    box-shadow: 0 6px 18px rgba(30,86,200,0.28);
    overflow: hidden;
    position: relative;
  }
  /* 새 비버 마스코트 이미지를 로고 마크로 사용 — 로드 성공 시 .is-loaded로 전환 */
  .logo-mark .logo-mark-img {
    display: cover;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 30%; /* 얼굴 중심이 보이도록 약간 위 정렬 */
  }
  .logo-mark.is-loaded {
    background: linear-gradient(135deg, #fff8ea, #e8f1ff);
    box-shadow: 0 6px 18px rgba(10,31,68,0.18);
  }
  .logo-mark.is-loaded .logo-mark-img { display: block; }
  .logo-mark.is-loaded > svg { display: none; }
  .logo-text { line-height: 1.1; }
  .logo-text .brand { font-weight: 800; font-size: 19px; color: var(--navy-900); letter-spacing: -0.02em;}
  .logo-text .sub { font-size: 11px; color: var(--ink-50); letter-spacing: 0.08em; font-weight: 500; }
  .logo-contact {
    margin-top: 0;
    margin-left: 6px;
    display: inline-flex; align-items: center; gap: 8px;
    background: linear-gradient(135deg, var(--navy-900), var(--blue-600));
    color: white;
    padding: 4px 10px 4px 4px;
    border-radius: 999px;
    box-shadow: 0 4px 12px -4px rgba(30,86,200,0.45);
    white-space: nowrap;
    transform: scale(0.75);
    transform-origin: left center;
  }
  .logo-contact__label {
    background: var(--yellow);
    color: var(--navy-900);
    font-family: 'Paperlogy', sans-serif;
    font-weight: 900;
    font-size: 13px; letter-spacing: 0.06em;
    padding: 4px 12px;
    border-radius: 999px;
  }
  .logo-contact__nums {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: 'Paperlogy', sans-serif;
    font-weight: 800; font-size: 16px;
    letter-spacing: 0.02em;
  }
  .logo-contact__num {
    color: white;
    transition: color .15s;
  }
  .logo-contact__num:hover { color: var(--yellow); }
  .logo-contact__sep { color: rgba(255,255,255,0.4); font-weight: 400;}
  @media (max-width: 600px) {
    .logo-contact { padding: 3px 8px 3px 3px; gap: 6px;}
    .logo-contact__label { font-size: 12px; padding: 3px 9px;}
    .logo-contact__nums { font-size: 14px; gap: 4px;}
  }

  .nav ul { display: flex; gap: 32px; list-style: none; }
  .nav ul a { font-weight: 600; font-size: 15px; color: var(--ink-70); transition: color .2s; }
  .nav ul a:hover { color: var(--blue-600); }

  /* ---------- 메인 메뉴 pill 버튼 ---------- */
  .main-menu { gap: 8px !important; }
  .main-menu li { list-style: none;}
  .nav-pill {
    position: relative;
    display: inline-flex; align-items: center; gap: 7px;
    padding: 9px 16px 9px 11px !important;
    border-radius: 999px;
    background: white;
    border: 1.5px solid var(--line);
    color: var(--navy-800) !important;
    font-family: 'Paperlogy', 'Pretendard', sans-serif;
    font-weight: 800 !important;
    font-size: 14px !important;
    letter-spacing: -0.01em;
    transition: color .18s, background .18s, border-color .18s, transform .18s, box-shadow .18s;
    white-space: nowrap;
  }
  .nav-pill:hover {
    color: white !important;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-600));
    border-color: transparent;
    transform: translateY(-2px);
    box-shadow: 0 10px 22px -8px rgba(30,86,200,0.45);
  }
  .nav-pill:hover .nav-pill__ic {
    background: rgba(255,255,255,0.22);
    color: var(--yellow);
  }
  .nav-pill__ic {
    width: 24px; height: 24px; border-radius: 50%;
    background: var(--sky-100);
    color: var(--blue-600);
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .18s, color .18s;
  }
  .nav-pill__label { line-height: 1;}
  /* 활성 섹션 표시 (선택) — URL hash가 맞을 때 노란 악센트 점 */
  .nav-pill:active { transform: translateY(0); }
  @media (max-width: 1080px) {
    .main-menu { gap: 4px !important;}
    .nav-pill { padding: 8px 12px 8px 9px !important; font-size: 13px !important;}
    .nav-pill__ic { width: 20px; height: 20px;}
    .nav-pill__ic svg { width: 13px; height: 13px;}
  }
  .nav-cta {
    background: var(--blue-600); color: white; padding: 11px 22px;
    border-radius: 999px; font-weight: 700; font-size: 14px;
    box-shadow: 0 6px 16px rgba(30,86,200,0.32);
    transition: transform .15s;
  }
  .nav-cta:hover { transform: translateY(-1px); }

  /* ---------- HERO ---------- */
  .hero {
    position: relative;
    background-color: #e8f1ff;
    padding: 72px 0 100px;
    overflow: hidden;
    min-height: 640px;
  }
  /* 좌측 텍스트 가독성 확보용 그라데이션 — 왼쪽만 어둡게, 오른쪽(비버 일러스트)는 선명하게 */
  .hero::before {
    content: ""; position: absolute; inset: 0;
    background:
      linear-gradient(100deg,
        rgba(255,255,255,0.96) 0%,
        rgba(255,255,255,0.88) 28%,
        rgba(255,255,255,0.40) 52%,
        rgba(255,255,255,0.00) 70%);
    pointer-events: none;
    z-index: 1;
  }
  /* 하단 페이드 — 섹션 전환 자연스럽게 */
  .hero::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 120px;
    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, #ffffff 100%);
    pointer-events: none;
    z-index: 1;
  }
  .hero-grid {
    display: block; position: relative; z-index: 2;
    min-height: 520px;
  }

  /* 헤드라인과 비버팀 이미지를 나란히 배치 (비버는 우측 absolute 오버레이) */
  .headline-row {
    position: relative;
    margin-bottom: 0;
  }
  .headline-row h1 {
    margin-bottom: 0 !important;
    /* h1이 비버 이미지 영역을 침범하지 않도록 오른쪽 여백 확보
       (비버가 왼쪽 컬럼 끝에서 20px 이격된 지점(390px)부터 우측 끝까지
        차지하므로 h1 본문은 왼쪽 390px 영역 안에서만 렌더) */
    width: 390px;
    max-width: 390px;
    padding-right: 0;
  }
  .headline-beaver {
    position: absolute;
    /* 비버 위치/크기 규칙:
       - 왼쪽 edge: "비버가 뚫어드립니다" 텍스트(하이라이트)의
                    오른쪽 끝(약 370px, CTA/lede 폭과 동일)
       - 오른쪽 edge: 상단 헤더 ".nav-cta" (💬 상담 문의) 버튼의
                       오른쪽 끝과 정렬 → .wrap 오른쪽 끝(right: 0)
       - width:       auto (두 edge 사이를 꽉 채움, 약 430–870px) */
    top: -40px;
    left: 370px;
    right: 0;
    width: auto;
  }
  .headline-beaver .beaver-team-img {
    width: 96%;
    max-width: 96%;
    height: auto;
    display: block;
    margin-left: auto;
    margin-right: 0;
    filter: drop-shadow(0 14px 28px rgba(10,31,68,0.18));
    animation: bob-soft 5s ease-in-out infinite;
  }
  .headline-beaver .beaver-placeholder {
    width: 100%;
    aspect-ratio: 1024 / 882;
    background: linear-gradient(135deg, #eaf2ff 0%, #f7f2e4 100%);
    border: 2px dashed #b9c8e4;
    border-radius: 20px;
    display: flex; align-items: center; justify-content: center;
    position: relative;
  }
  .headline-beaver .beaver-placeholder .ph-inner {
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    color: #6b7a95; text-align: center;
  }
  .headline-beaver .beaver-placeholder .ph-img {
    width: min(78%, 420px);
    height: auto;
    border-radius: 14px;
    object-fit: contain;
    box-shadow: 0 8px 22px rgba(10,31,68,0.16);
  }
  .headline-beaver .beaver-placeholder .ph-sub {
    font-size: 11px; color: var(--ink-50);
    font-family: ui-monospace, 'SF Mono', monospace;
    background: rgba(255,255,255,0.7); padding: 3px 8px; border-radius: 6px;
  }

  /* 비버는 넓은 뷰포트에서 텍스트 오른쪽에 absolute로 배치됨.
     폰이나 아주 좋은 뷰포트(≤640px)에서만 아래로 였개짐. */
  @media (min-width: 641px) and (max-width: 960px) {
    .hero h1 { font-size: 52px; }
  }
  @media (max-width: 640px) {
    .headline-row h1 {
      width: 100%;
      max-width: 100%;
      padding-right: 0;
      font-size: 42px;
    }
    .headline-beaver {
      position: static;
      left: auto;
      right: auto;
      top: auto;
      width: 240px;
      margin: 20px 0 0;
    }
  }
  .badge-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
  .badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 14px; border-radius: 999px;
    background: white; border: 1px solid var(--line);
    font-size: 13px; font-weight: 600; color: var(--navy-800);
  }
  .badge.red { background: #ffecec; border-color: #ffc8c8; color: var(--danger); }
  .badge .pulse {
    width: 7px; height: 7px; border-radius: 50%; background: var(--danger);
    animation: pulse 1.4s ease-in-out infinite;
  }
  @keyframes pulse {
    0%,100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.8); opacity: 0.4; }
  }

  .hero h1 {
    /* 폰트 크기 고정 — 어떤 뷰포트에서도 줄바꿈 위치 동일 유지 */
    font-size: 56px;
    font-weight: 900;
    font-family: 'Paperlogy', sans-serif;
    line-height: 1.08;
    color: var(--navy-900);
    letter-spacing: -0.03em;
    /* lede 텍스트를 "비버가 뚫어드립니다." 바로 아래 한 줄 간격으로 붙이기 위해 margin 제거 */
    margin-bottom: 0;
  }
  .hero h1 .hl {
    position: relative; display: inline-block; color: var(--blue-600);
  }
  .hero h1 .hl::after {
    content: ""; position: absolute; left: -4px; right: -4px; bottom: 4px; height: 14px;
    background: var(--yellow); z-index: -1; border-radius: 4px; opacity: 0.65;
  }
  .hero p.lede {
    font-size: 19px; color: var(--ink-70); line-height: 1.65;
    /* "비버가 뚫어드립니다." 바로 하부 한 줄 간격만 유지 */
    margin-top: 12px;
    margin-bottom: 28px;
    /* h1 "비버가 뚫어드립니다." 줄의 렌더 너비(약 370px)에 맞춰 동일 폭으로 설정 */
    max-width: 370px !important;
    width: 370px !important;
    box-sizing: border-box;
  }

  .cta-row {
    display: flex; gap: 12px; flex-wrap: nowrap; margin-bottom: 44px;
    /* 상단 "비버가 뚫어드립니다." 텍스트 폭(370px)에 맞춤 */
    width: 370px; max-width: 370px;
  }
  .cta-primary {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-600));
    color: white; padding: 14px 16px; border-radius: 14px;
    font-weight: 800; font-size: 16px;
    box-shadow: 0 12px 30px rgba(30,86,200,0.35);
    transition: transform .15s;
    flex: 1 1 0; min-width: 0;
  }
  .cta-primary:hover { transform: translateY(-2px); }
  .cta-primary .tel-icon {
    width: 28px; height: 28px; border-radius: 50%;
    background: rgba(255,255,255,0.22); display: grid; place-items: center;
    flex-shrink: 0;
  }
  .cta-primary .num-box { display: flex; flex-direction: column; line-height: 1.1; min-width: 0;}
  .cta-primary .num-box small { font-size: 10px; opacity: 0.8; font-weight: 500; letter-spacing: 0.08em; white-space: nowrap;}
  .cta-primary .num-box b { font-size: 15px; letter-spacing: 0.01em; font-family: 'Paperlogy', sans-serif; white-space: nowrap;}

  .cta-secondary {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    background: white; color: var(--navy-900);
    padding: 14px 16px; border-radius: 14px;
    font-weight: 700; font-size: 15px;
    border: 2px solid var(--navy-900);
    transition: all .15s;
    flex: 1 1 0; min-width: 0; white-space: nowrap;
  }
  .cta-secondary:hover { background: var(--navy-900); color: white; }

  .trust {
    display: flex; gap: 28px; padding-top: 28px;
    border-top: 1px dashed #c9d4e8;
  }
  .trust-item { display: flex; flex-direction: column; gap: 2px;}
  .trust-item .num { font-size: 28px; font-weight: 900; color: var(--navy-900); font-family: 'Paperlogy', sans-serif;}
  .trust-item .num .plus { color: var(--blue-600);}
  .trust-item .lbl { font-size: 13px; color: var(--ink-50); font-weight: 500;}

  .float-chip {
    position: absolute; background: white;
    padding: 12px 16px; border-radius: 14px;
    box-shadow: 0 10px 24px rgba(10,31,68,0.14);
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; font-weight: 600;
    animation: bob 4s ease-in-out infinite;
  }
  .float-chip small { display: block; font-size: 10px; color: var(--ink-50); font-weight: 500;}
  .float-chip b { color: var(--navy-900); font-size: 14px;}
  .float-chip .ic {
    width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center;
  }
  @keyframes bob { 0%,100% { transform: translateY(0);} 50% { transform: translateY(-8px);} }

  .fc-1 { top: 8%; left: -20px; }
  .fc-1 .ic { background: #e8f1ff; color: var(--blue-600);}
  .fc-2 { bottom: 14%; right: -12px; animation-delay: .8s;}
  .fc-2 .ic { background: #fff4d6; color: #b5820a;}
  .fc-3 { top: 48%; right: -26px; animation-delay: 1.6s;}
  .fc-3 .ic { background: #dbf7e5; color: #1a8a4a;}

  /* 비버 기사팀 일러스트 (기본 스타일 - 헤드라인 영역에서 .headline-beaver로 오버라이드됨) */
  .beaver-team-img {
    position: relative;
    z-index: 3;
    height: auto;
    display: block;
    animation: bob-soft 5s ease-in-out infinite;
  }
  @keyframes bob-soft {
    0%,100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
  }

  /* 이미지 업로드 전 플레이스홀더 */
  .beaver-placeholder {
    position: relative; z-index: 3;
    width: 100%; max-width: 560px; aspect-ratio: 1 / 0.88;
    margin: 0 auto;
    background: linear-gradient(135deg, #eaf2ff 0%, #f7f2e4 100%);
    border: 2px dashed #b9c8e4;
    border-radius: 28px;
    display: flex; align-items: center; justify-content: center;
  }
  .beaver-placeholder .ph-inner {
    display: flex; flex-direction: column; align-items: center; gap: 10px;
    color: #6b7a95; text-align: center;
  }
  .beaver-placeholder .ph-title {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 18px; color: var(--navy-900); margin-top: 6px;
  }
  .beaver-placeholder .ph-sub {
    font-size: 12px; color: var(--ink-50); font-family: ui-monospace, 'SF Mono', monospace;
    background: rgba(255,255,255,0.7); padding: 4px 10px; border-radius: 8px;
  }

  /* ---------- STRIP ---------- */
  .strip {
    background: var(--navy-900); color: white;
    padding: 28px 0; overflow: hidden;
  }
  .strip-track {
    display: flex; gap: 56px; white-space: nowrap;
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 22px; letter-spacing: 0.01em;
    animation: scroll 30s linear infinite;
  }
  .strip-track span { display: inline-flex; align-items: center; gap: 56px; color: #cdd8f0;}
  .strip-track .dot { width: 8px; height: 8px; background: var(--yellow); border-radius: 50%; display: inline-block;}
  @keyframes scroll { to { transform: translateX(-50%);} }

  /* ---------- SECTION BASE ---------- */
  section { padding: 100px 0; }
  .sec-head { text-align: center; margin-bottom: 56px;}
  .sec-label {
    display: inline-block; color: var(--blue-600); font-weight: 700;
    font-size: 14px; letter-spacing: 0.12em; text-transform: uppercase;
    margin-bottom: 12px;
  }
  .sec-label::before, .sec-label::after {
    content: ""; display: inline-block; width: 22px; height: 2px;
    background: var(--blue-500); vertical-align: middle; margin: 0 10px;
  }
  .sec-title {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: clamp(30px, 3.4vw, 44px); color: var(--navy-900);
    letter-spacing: -0.02em; line-height: 1.2;
  }
  .sec-desc { color: var(--ink-70); font-size: 17px; margin-top: 14px; max-width: 640px; margin-left: auto; margin-right: auto;}

  /* ---------- SERVICES ---------- */
  .services { background: var(--sky-50); }
  .svc-grid {
    display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px;
  }
  .svc-card {
    background: white; border-radius: 22px; padding: 36px 28px;
    border: 1px solid var(--line);
    position: relative; overflow: hidden;
    transition: all .25s cubic-bezier(.2,.8,.2,1);
  }
  .svc-card:hover {
    transform: translateY(-6px);
    border-color: var(--blue-400);
    box-shadow: 0 24px 48px -16px rgba(30,86,200,0.25);
  }
  .svc-card .num {
    position: absolute; top: 24px; right: 28px;
    font-family: 'Paperlogy', sans-serif; font-weight: 900;
    font-size: 64px; color: var(--sky-100); line-height: 1;
    transition: color .2s;
  }
  .svc-card:hover .num { color: #cfe0fc; }
  .svc-ic {
    width: 64px; height: 64px; border-radius: 18px;
    background: linear-gradient(135deg, var(--sky-100), white);
    display: grid; place-items: center; margin-bottom: 24px;
    color: var(--blue-600);
    border: 1px solid var(--line);
  }
  .svc-card h3 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 22px; color: var(--navy-900); margin-bottom: 10px;
  }
  .svc-card p { color: var(--ink-70); font-size: 15px; line-height: 1.65;}
  .svc-card ul {
    list-style: none; margin-top: 18px; padding-top: 18px;
    border-top: 1px dashed var(--line);
  }
  .svc-card ul li {
    font-size: 13px; color: var(--ink-50); padding: 3px 0;
    display: flex; align-items: center; gap: 6px;
  }
  .svc-card ul li::before { content: "✓"; color: var(--blue-500); font-weight: 900;}

  /* ---------- PROCESS ---------- */
  .process { background: white; }
  .proc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; position: relative; }
  .proc-grid::before {
    content: ""; position: absolute; top: 42px; left: 10%; right: 10%; height: 2px;
    background: repeating-linear-gradient(90deg, var(--blue-400) 0 6px, transparent 6px 14px);
    z-index: 0;
  }
  .proc-step { text-align: center; position: relative; z-index: 1; }
  .proc-circle {
    width: 84px; height: 84px; border-radius: 50%; margin: 0 auto 20px;
    background: white; border: 3px solid var(--blue-600);
    display: grid; place-items: center;
    color: var(--blue-600); font-family: 'Paperlogy', sans-serif;
    font-size: 30px; font-weight: 900;
    box-shadow: 0 8px 20px rgba(30,86,200,0.2);
  }
  .proc-step h4 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 18px; color: var(--navy-900); margin-bottom: 6px;
  }
  .proc-step p { font-size: 14px; color: var(--ink-50);}

  /* Service Area 섹션 중앙정렬 (area-left 내부 전체) */
  .area-left--center {
    text-align: center;
  }
  .area-left--center .sec-label {
    text-align: center !important;
  }
  .area-left--center .area-chips {
    justify-content: center;
  }

  /* 진행과정 하단 연락처 박스 */
  .proc-contact {
    margin-top: 60px;
    background: linear-gradient(135deg, var(--navy-900) 0%, var(--blue-600) 100%);
    color: white;
    border-radius: 20px;
    padding: 28px 40px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 32px;
    box-shadow: 0 20px 40px -16px rgba(30,86,200,0.35);
    position: relative; overflow: hidden;
  }
  .proc-contact::before {
    content: ""; position: absolute; inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,0.06) 1px, transparent 1.5px);
    background-size: 22px 22px;
    pointer-events: none;
  }
  .proc-contact__left {
    display: flex; flex-direction: column; gap: 6px;
    position: relative; z-index: 1;
  }
  .proc-contact__label {
    display: inline-block;
    background: var(--yellow);
    color: var(--navy-900);
    font-family: 'Paperlogy', sans-serif;
    font-weight: 900;
    font-size: 12px; letter-spacing: 0.08em;
    padding: 4px 11px;
    border-radius: 999px;
    align-self: flex-start;
  }
  .proc-contact__msg {
    font-family: 'Paperlogy', sans-serif;
    font-weight: 800; font-size: 22px;
    letter-spacing: -0.01em;
  }
  .proc-contact__nums {
    display: flex; align-items: center; gap: 14px;
    flex-wrap: wrap;
    position: relative; z-index: 1;
  }
  .proc-contact__num {
    display: inline-flex; align-items: center; gap: 8px;
    background: white;
    color: var(--navy-900);
    font-family: 'Paperlogy', sans-serif;
    font-weight: 800; font-size: 22px;
    padding: 14px 22px;
    border-radius: 14px;
    box-shadow: 0 6px 16px -4px rgba(0,0,0,0.25);
    transition: transform .15s, box-shadow .15s, color .15s;
  }
  .proc-contact__num:hover {
    transform: translateY(-2px);
    color: var(--blue-600);
    box-shadow: 0 10px 22px -6px rgba(0,0,0,0.3);
  }
  .proc-contact__num svg { flex-shrink: 0; color: var(--blue-600);}
  @media (max-width: 820px) {
    .proc-contact {
      flex-direction: column; align-items: flex-start;
      padding: 26px;
      gap: 18px;
    }
    .proc-contact__msg { font-size: 18px;}
    .proc-contact__num { font-size: 18px; padding: 12px 18px;}
    .proc-contact__nums { width: 100%;}
  }
  @media (max-width: 520px) {
    .proc-contact__nums { flex-direction: column; align-items: stretch;}
    .proc-contact__num { justify-content: center;}
  }

  /* ---------- GALLERY (before/after) ---------- */
  .gallery { background: var(--sky-50); }
  .gal-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  }
  .gal-item {
    background: white; border-radius: 20px; overflow: hidden;
    border: 1px solid var(--line);
    transition: transform .25s;
  }
  .gal-item:hover { transform: translateY(-4px);}
  .ba-wrap {
    display: grid; grid-template-columns: 1fr 1fr; gap: 2px;
    background: var(--navy-800); position: relative;
  }
  .ba-img {
    aspect-ratio: 1/1; position: relative;
    display: grid; place-items: center; overflow: hidden;
  }
  .ba-img.before {
    background:
      radial-gradient(circle at 30% 40%, #5a3a1f 0%, #3d2410 60%),
      #2a1a08;
  }
  .ba-img.after {
    background:
      radial-gradient(circle at 50% 50%, #c9d9f0 0%, #8fb0e0 100%);
  }
  .ba-img .tag {
    position: absolute; top: 10px; left: 10px;
    background: rgba(10,31,68,0.85); color: white;
    padding: 4px 10px; border-radius: 6px;
    font-size: 11px; font-weight: 800; letter-spacing: 0.1em;
  }
  .ba-img.after .tag { background: var(--blue-600);}
  .ba-icon-before, .ba-icon-after { opacity: 0.5; }
  .ba-divider {
    position: absolute; top: 0; bottom: 0; left: 50%; transform: translateX(-50%);
    width: 40px; display: grid; place-items: center; z-index: 2;
    pointer-events: none;
  }
  .ba-divider div {
    width: 40px; height: 40px; border-radius: 50%;
    background: white; box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    display: grid; place-items: center; color: var(--navy-800);
  }
  .gal-body { padding: 20px 22px; }
  .gal-body .cat {
    display: inline-block; color: var(--blue-600);
    font-size: 12px; font-weight: 700; letter-spacing: 0.08em;
    margin-bottom: 6px;
  }
  .gal-body h4 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 18px; color: var(--navy-900); margin-bottom: 4px;
  }
  .gal-body .meta { font-size: 13px; color: var(--ink-50);}

  /* ---------- PRICING ---------- */
  .pricing { background: var(--navy-900); color: white; }
  .pricing .sec-label { color: var(--blue-400);}
  .pricing .sec-label::before, .pricing .sec-label::after { background: var(--blue-400);}
  .pricing .sec-title { color: white;}
  .pricing .sec-desc { color: #9fb2d4;}
  .price-table {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 24px; overflow: hidden;
  }
  .price-row {
    display: grid; grid-template-columns: 2fr 3fr 1.2fr 1.5fr;
    gap: 16px; padding: 24px 32px;
    align-items: center;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }
  .price-row:last-child { border-bottom: none; }
  .price-row.head {
    background: rgba(255,255,255,0.06);
    font-size: 33px; color: #9fb2d4;
    font-weight: 700; letter-spacing: 0.08em;
    align-items: end;
  }
  .price-row.head > div {
    line-height: 1.2;
    margin: 0;
    padding: 0;
  }
  .price-row.head > div:last-child { align-self: center; }
  .price-row .name {
    font-family: 'Paperlogy', sans-serif; font-weight: 800; font-size: 19px;
  }
  .price-row .desc { color: #b8c3d8; font-size: 14px; line-height: 1.5;}
  .price-row .time { color: #cbd3e3; font-size: 14px;}
  .price-row .price {
    font-family: 'Paperlogy', sans-serif; font-size: 22px; font-weight: 800;
    color: var(--yellow); text-align: right;
  }
  .price-row .price small { display: block; font-size: 11px; color: #9fb2d4; font-weight: 500; letter-spacing: 0;}
  .price-note {
    margin-top: 18px; font-size: 20px; color: #9fb2d4; text-align: center;
  }
  .price-note b { color: var(--yellow);}

  /* ---------- REVIEWS ---------- */
  .reviews { background: var(--sky-50); }
  .reviews-head {
    position: relative;
    text-align: center;
  }
  .reviews-head .reviews-head-left { text-align: center; }
  .reviews-head .sec-desc { margin-top: 10px; }
  .reviews-head .review-write-btn {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .reviews-head .review-write-btn:hover {
    transform: translateY(calc(-50% - 2px));
  }
  .review-write-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--blue-600); color: white;
    padding: 14px 22px; border-radius: 12px;
    font-weight: 700; font-size: 15px;
    box-shadow: 0 8px 20px -6px rgba(30,86,200,0.45);
    transition: transform .15s, background .15s;
    white-space: nowrap;
    flex-shrink: 0;
  }
  .review-write-btn:hover {
    background: var(--blue-500); transform: translateY(-2px);
  }
  @media (max-width: 720px) {
    .reviews-head .review-write-btn {
      position: static;
      transform: none;
      display: inline-flex;
      margin-top: 18px;
    }
    .reviews-head .review-write-btn:hover { transform: translateY(-2px); }
  }

  /* ---------- 후기 작성 모달 ---------- */
  .review-modal {
    position: fixed; inset: 0; z-index: 1000;
    display: none;
    align-items: center; justify-content: center;
    padding: 20px;
  }
  .review-modal.is-open { display: flex; }
  .review-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,31,68,0.55);
    backdrop-filter: blur(6px);
    animation: modalFade .22s ease-out;
  }
  .review-modal__panel {
    position: relative;
    width: 100%; max-width: 560px;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    background: white;
    border-radius: 22px;
    padding: 34px 36px 30px;
    box-shadow: 0 30px 60px -20px rgba(10,31,68,0.4);
    animation: modalPop .25s cubic-bezier(.2,.9,.3,1.2);
  }
  @keyframes modalFade { from { opacity: 0;} to { opacity: 1;} }
  @keyframes modalPop {
    from { opacity: 0; transform: translateY(16px) scale(.96);}
    to   { opacity: 1; transform: translateY(0) scale(1);}
  }
  .review-modal__close {
    position: absolute; top: 14px; right: 16px;
    width: 36px; height: 36px; border-radius: 10px;
    font-size: 26px; line-height: 1; color: var(--ink-50);
    background: var(--sky-50); border: 1px solid var(--line);
    transition: background .15s, color .15s;
  }
  .review-modal__close:hover { background: var(--sky-100); color: var(--navy-900);}
  .review-modal__head { margin-bottom: 22px; }
  .review-modal__head h3 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 26px; color: var(--navy-900); letter-spacing: -0.02em;
    margin-top: 4px;
  }
  .review-modal__head .sec-label::before,
  .review-modal__head .sec-label::after { display: none;}
  .review-modal__sub {
    color: var(--ink-50); font-size: 14px; margin-top: 8px;
  }

  .review-form .rf-field { margin-bottom: 16px; display: block;}
  .review-form label {
    display: block; font-weight: 700; font-size: 13px;
    color: var(--navy-800); margin-bottom: 6px;
  }
  .rf-req { color: var(--danger);}
  .review-form input[type="text"],
  .review-form select,
  .review-form textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: white;
    font-family: inherit; font-size: 14px; color: var(--ink);
    transition: border-color .15s, box-shadow .15s;
  }
  .review-form textarea { resize: vertical; min-height: 110px; line-height: 1.6;}
  .review-form input[type="text"]:focus,
  .review-form select:focus,
  .review-form textarea:focus {
    outline: none; border-color: var(--blue-500);
    box-shadow: 0 0 0 3px rgba(46,111,224,0.15);
  }
  .rf-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  }
  .rf-count {
    display: block; text-align: right; font-size: 12px;
    color: var(--ink-50); margin-top: 4px;
  }
  .rf-stars { display: flex; gap: 4px; }
  .rf-star {
    font-size: 28px; line-height: 1;
    color: #e0e6f2; background: none; border: none;
    padding: 2px; transition: color .12s, transform .12s;
  }
  .rf-star:hover { transform: scale(1.15);}
  .rf-star.is-active { color: var(--yellow);}
  .rf-actions {
    display: flex; gap: 10px; margin-top: 22px;
  }
  .rf-btn {
    flex: 1; padding: 14px;
    border-radius: 12px; font-weight: 800; font-size: 15px;
    transition: transform .15s, background .15s;
    font-family: inherit;
  }
  .rf-btn--ghost {
    background: var(--sky-50); color: var(--ink-70);
    border: 1px solid var(--line);
  }
  .rf-btn--ghost:hover { background: var(--sky-100);}
  .rf-btn--primary {
    background: var(--blue-600); color: white;
    box-shadow: 0 8px 20px -6px rgba(30,86,200,0.45);
  }
  .rf-btn--primary:hover { background: var(--blue-500); transform: translateY(-1px);}

  .review-modal__success {
    display: none; text-align: center; padding: 20px 0 8px;
  }
  .review-modal__success-ic {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--blue-600); color: white;
    display: grid; place-items: center;
    font-size: 34px; font-weight: 900;
    margin: 0 auto 14px;
    animation: popIn .35s cubic-bezier(.2,.9,.3,1.3);
  }
  @keyframes popIn {
    from { opacity: 0; transform: scale(.5);}
    to { opacity: 1; transform: scale(1);}
  }
  .review-modal__success h4 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 20px; color: var(--navy-900); margin-bottom: 6px;
  }
  .review-modal__success p { color: var(--ink-50); font-size: 14px;}

  /* 새로 추가된 후기 카드 하이라이트 */
  .rev-card--new {
    animation: cardIn .45s cubic-bezier(.2,.9,.3,1.1);
    box-shadow: 0 0 0 2px var(--blue-500), 0 8px 24px -8px rgba(30,86,200,0.25);
  }
  @keyframes cardIn {
    from { opacity: 0; transform: translateY(-10px) scale(.98);}
    to   { opacity: 1; transform: translateY(0) scale(1);}
  }

  @media (max-width: 520px) {
    .review-modal__panel { padding: 28px 22px 24px;}
    .rf-grid { grid-template-columns: 1fr;}
  }

  /* ---------- ADMIN LOGIN 버튼 (topbar) ---------- */
  .admin-login-btn {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,0.08);
    color: #e3ebff;
    border: 1px solid rgba(255,255,255,0.18);
    padding: 5px 11px; border-radius: 999px;
    font-family: 'Paperlogy', 'Pretendard', sans-serif;
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    transition: background .15s, color .15s, border-color .15s, transform .15s;
    cursor: pointer;
  }
  .admin-login-btn:hover {
    background: var(--yellow);
    color: var(--navy-900);
    border-color: var(--yellow);
    transform: translateY(-1px);
  }
  .admin-login-btn svg { flex-shrink: 0; }

  /* ---------- ADMIN 모달 ---------- */
  .admin-modal {
    position: fixed; inset: 0; z-index: 1100;
    display: none; align-items: center; justify-content: center;
    padding: 20px;
  }
  .admin-modal.is-open { display: flex; }
  .admin-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,31,68,0.65);
    backdrop-filter: blur(6px);
    animation: modalFade .2s ease-out;
  }
  .admin-modal__panel {
    position: relative;
    width: 100%; max-width: 420px;
    background: white;
    border-radius: 22px;
    padding: 34px 36px 28px;
    box-shadow: 0 30px 60px -20px rgba(10,31,68,0.45);
    animation: modalPop .24s cubic-bezier(.2,.9,.3,1.2);
  }
  .admin-modal__close {
    position: absolute; top: 14px; right: 16px;
    width: 34px; height: 34px; border-radius: 10px;
    font-size: 24px; line-height: 1; color: var(--ink-50);
    background: var(--sky-50); border: 1px solid var(--line);
    transition: background .15s, color .15s;
  }
  .admin-modal__close:hover { background: var(--sky-100); color: var(--navy-900);}
  .admin-modal__head { text-align: center; margin-bottom: 22px;}
  .admin-modal__ic {
    width: 60px; height: 60px; border-radius: 16px;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-600));
    color: white; display: grid; place-items: center;
    margin: 0 auto 14px;
    box-shadow: 0 10px 22px -6px rgba(30,86,200,0.5);
  }
  .admin-modal__head h3 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 22px; color: var(--navy-900); margin-bottom: 6px;
  }
  .admin-modal__head p { color: var(--ink-50); font-size: 13px; line-height: 1.55;}
  .admin-form .rf-field { margin-bottom: 14px;}
  .admin-form input[type="text"],
  .admin-form input[type="password"] {
    width: 100%;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: white;
    font-family: inherit; font-size: 14px; color: var(--ink);
    transition: border-color .15s, box-shadow .15s;
  }
  .admin-form input:focus {
    outline: none; border-color: var(--blue-500);
    box-shadow: 0 0 0 3px rgba(46,111,224,0.15);
  }
  .admin-form__err {
    background: #fff1f1; color: var(--danger);
    font-size: 13px; font-weight: 600;
    padding: 10px 12px; border-radius: 8px;
    margin: 4px 0 12px;
    border: 1px solid #ffd4d4;
  }
  .admin-form__hint {
    margin-top: 14px; text-align: center;
    font-size: 11px; color: var(--ink-50);
    padding: 10px; background: var(--sky-50); border-radius: 8px;
  }
  .admin-form__hint b { color: var(--navy-800); font-weight: 700;}

  /* ---------- ADMIN 편집 툴바 ---------- */
  body.admin-mode { padding-top: 52px; }
  .admin-toolbar {
    position: fixed; top: 0; left: 0; right: 0;
    z-index: 1200;
    background: linear-gradient(135deg, var(--navy-900), var(--blue-600));
    color: white;
    box-shadow: 0 4px 20px rgba(10,31,68,0.3);
    animation: slideDown .3s cubic-bezier(.2,.9,.3,1.2);
  }
  @keyframes slideDown { from { transform: translateY(-100%);} to { transform: translateY(0);} }
  .admin-toolbar__inner {
    max-width: 1240px; margin: 0 auto;
    padding: 10px 24px;
    display: flex; align-items: center; gap: 14px;
    flex-wrap: wrap;
  }
  .admin-toolbar__badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--yellow); color: var(--navy-900);
    padding: 5px 11px; border-radius: 999px;
    font-family: 'Paperlogy', sans-serif; font-weight: 900;
    font-size: 11px; letter-spacing: 0.08em;
  }
  .admin-toolbar__dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--danger);
    box-shadow: 0 0 0 3px rgba(233,64,64,0.35);
    animation: pulse 1.8s ease-in-out infinite;
  }
  .admin-toolbar__msg {
    flex: 1;
    font-size: 13px; color: #cdd8f0;
    min-width: 200px;
  }
  .admin-toolbar__actions { display: flex; gap: 8px;}
  .admin-toolbar__btn {
    padding: 7px 14px; border-radius: 8px;
    font-family: inherit; font-weight: 700; font-size: 12px;
    letter-spacing: 0.04em;
    transition: background .15s, transform .15s;
    cursor: pointer;
  }
  .admin-toolbar__btn--save {
    background: var(--yellow); color: var(--navy-900);
  }
  .admin-toolbar__btn--save:hover { background: #ffe066; transform: translateY(-1px);}
  .admin-toolbar__btn--reset {
    background: rgba(255,255,255,0.12); color: white;
    border: 1px solid rgba(255,255,255,0.2);
  }
  .admin-toolbar__btn--reset:hover { background: rgba(255,255,255,0.2);}
  .admin-toolbar__btn--logout {
    background: rgba(255,255,255,0.06); color: #cdd8f0;
    border: 1px solid rgba(255,255,255,0.15);
  }
  .admin-toolbar__btn--logout:hover { background: rgba(233,64,64,0.25); color: white; border-color: rgba(233,64,64,0.5);}

  /* 편집 가능한 요소 표시 */
  body.admin-mode [data-editable] {
    cursor: text;
    outline: 1px dashed rgba(30,86,200,0.35);
    outline-offset: 3px;
    transition: outline-color .15s, background .15s;
    border-radius: 4px;
  }
  body.admin-mode [data-editable]:hover {
    outline-color: var(--blue-500);
    background: rgba(30,86,200,0.06);
  }
  body.admin-mode [data-editable]:focus {
    outline: 2px solid var(--blue-500);
    background: rgba(255, 236, 140, 0.3);
  }

  /* 저장 토스트 */
  .admin-toast {
    position: fixed; bottom: 30px; left: 50%;
    transform: translateX(-50%) translateY(40px);
    background: var(--navy-900); color: white;
    padding: 14px 24px; border-radius: 12px;
    font-weight: 700; font-size: 14px;
    box-shadow: 0 12px 28px -8px rgba(10,31,68,0.5);
    opacity: 0; z-index: 1300;
    transition: opacity .25s, transform .25s;
    display: inline-flex; align-items: center; gap: 8px;
  }
  .admin-toast.is-show {
    opacity: 1; transform: translateX(-50%) translateY(0);
  }
  .admin-toast__ic {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--yellow); color: var(--navy-900);
    display: grid; place-items: center;
    font-size: 13px; font-weight: 900;
  }

  /* ---------- 헤더 우측 그룹 (상담 문의 + 회원 로그인) ---------- */
  .nav-right { display: flex; align-items: center; gap: 10px; }
  .member-btn {
    display: inline-flex; align-items: center; gap: 6px;
    background: white;
    color: var(--navy-800);
    border: 1.5px solid var(--line);
    padding: 10px 16px; border-radius: 10px;
    font-family: inherit; font-weight: 700; font-size: 14px;
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s, transform .15s;
    white-space: nowrap;
  }
  .member-btn:hover {
    border-color: var(--blue-500);
    color: var(--blue-600);
    background: var(--sky-50);
    transform: translateY(-1px);
  }
  .member-btn.is-logged-in {
    background: var(--sky-50);
    border-color: var(--blue-400);
    color: var(--navy-900);
  }
  .member-btn.is-logged-in:hover {
    background: var(--sky-100);
  }
  .member-btn__avatar {
    width: 22px; height: 22px; border-radius: 50%;
    background: linear-gradient(135deg, var(--blue-500), var(--navy-700));
    color: white; display: grid; place-items: center;
    font-size: 11px; font-weight: 800;
    font-family: 'Paperlogy', sans-serif;
  }
  /* 아이콘 + LOGIN 태그 묶음 */
  .member-btn__ic {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 8px 3px 5px;
    background: var(--navy-900);
    color: white;
    border-radius: 999px;
    transition: background .15s;
  }
  .member-btn:hover .member-btn__ic {
    background: var(--blue-600);
  }
  .member-btn__ic-tag {
    font-family: 'Paperlogy', sans-serif;
    font-weight: 900;
    font-size: 11px;
    letter-spacing: 0.08em;
    line-height: 1;
    color: var(--yellow);
  }
  @media (max-width: 960px) {
    .nav-right { gap: 8px; }
    .member-btn { padding: 8px 12px; font-size: 13px;}
    .member-btn__label { display: none; }
    .member-btn.is-logged-in .member-btn__label { display: inline;}
    .member-btn.is-logged-in .member-btn__ic { display: none;}
  }

  /* ---------- 회원 모달 ---------- */
  .member-modal {
    position: fixed; inset: 0; z-index: 1100;
    display: none; align-items: center; justify-content: center;
    padding: 20px;
  }
  .member-modal.is-open { display: flex; }
  .member-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,31,68,0.6);
    backdrop-filter: blur(6px);
    animation: modalFade .2s ease-out;
  }
  .member-modal__panel {
    position: relative;
    width: 100%; max-width: 460px;
    max-height: calc(100vh - 40px); overflow-y: auto;
    background: white;
    border-radius: 22px;
    padding: 28px 32px 26px;
    box-shadow: 0 30px 60px -20px rgba(10,31,68,0.45);
    animation: modalPop .25s cubic-bezier(.2,.9,.3,1.2);
  }
  .member-modal__close {
    position: absolute; top: 14px; right: 16px;
    width: 34px; height: 34px; border-radius: 10px;
    font-size: 24px; line-height: 1; color: var(--ink-50);
    background: var(--sky-50); border: 1px solid var(--line);
    transition: background .15s, color .15s;
  }
  .member-modal__close:hover { background: var(--sky-100); color: var(--navy-900);}
  .member-modal__head { text-align: center; margin-bottom: 20px;}
  .member-modal__ic {
    width: 58px; height: 58px; border-radius: 16px;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-600));
    color: white; display: grid; place-items: center;
    margin: 0 auto 16px;
    box-shadow: 0 10px 22px -6px rgba(30,86,200,0.5);
  }
  .member-tabs {
    display: inline-flex;
    background: var(--sky-50);
    border-radius: 12px;
    padding: 4px;
    gap: 2px;
  }
  .member-tab {
    padding: 8px 20px;
    border-radius: 9px;
    font-family: inherit; font-weight: 700; font-size: 14px;
    color: var(--ink-50);
    background: transparent;
    cursor: pointer;
    transition: background .18s, color .18s;
  }
  .member-tab:hover { color: var(--navy-800);}
  .member-tab.is-active {
    background: white;
    color: var(--navy-900);
    box-shadow: 0 2px 8px -2px rgba(10,31,68,0.15);
  }
  .member-form .rf-field { margin-bottom: 12px;}
  .member-form input[type="text"],
  .member-form input[type="email"],
  .member-form input[type="password"] {
    width: 100%;
    padding: 11px 14px;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: white;
    font-family: inherit; font-size: 14px; color: var(--ink);
    transition: border-color .15s, box-shadow .15s;
  }
  .member-form input:focus {
    outline: none; border-color: var(--blue-500);
    box-shadow: 0 0 0 3px rgba(46,111,224,0.15);
  }
  .member-form__err {
    background: #fff1f1; color: var(--danger);
    font-size: 13px; font-weight: 600;
    padding: 10px 12px; border-radius: 8px;
    margin: 4px 0 12px;
    border: 1px solid #ffd4d4;
  }
  .member-form__submit {
    width: 100%; margin-top: 4px;
    padding: 14px;
  }
  .member-form__agree {
    display: flex; align-items: flex-start; gap: 8px;
    margin: 4px 0 14px;
    font-size: 13px; color: var(--ink-70);
    cursor: pointer;
  }
  .member-form__agree input { margin-top: 3px; flex-shrink: 0;}
  .member-form__switch {
    margin-top: 16px; text-align: center;
    font-size: 13px; color: var(--ink-50);
  }
  .member-form__link {
    background: none; border: none; padding: 0;
    color: var(--blue-600); font-weight: 700; cursor: pointer;
    font-family: inherit; font-size: inherit;
    text-decoration: underline;
    margin-left: 4px;
  }
  .member-form__link:hover { color: var(--blue-500);}

  /* ---------- 카카오톡 상담 헬퍼 ---------- */
  .kakao-helper {
    position: fixed; inset: 0; z-index: 1200;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    animation: modalFade .2s ease-out;
  }
  .kakao-helper__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,31,68,0.6);
    backdrop-filter: blur(6px);
  }
  .kakao-helper__panel {
    position: relative;
    width: 100%; max-width: 440px;
    background: white;
    border-radius: 22px;
    padding: 34px 32px 28px;
    text-align: center;
    box-shadow: 0 30px 60px -20px rgba(10,31,68,0.45);
    animation: modalPop .25s cubic-bezier(.2,.9,.3,1.2);
  }
  .kakao-helper__close {
    position: absolute; top: 14px; right: 16px;
    width: 34px; height: 34px; border-radius: 10px;
    font-size: 24px; line-height: 1; color: var(--ink-50);
    background: var(--sky-50); border: 1px solid var(--line);
    cursor: pointer;
  }
  .kakao-helper__close:hover { background: var(--sky-100); color: var(--navy-900);}
  .kakao-helper__ic {
    width: 64px; height: 64px; border-radius: 50%;
    background: #fee500;
    display: grid; place-items: center;
    font-size: 32px;
    margin: 0 auto 14px;
    box-shadow: 0 10px 22px -6px rgba(254,229,0,0.55);
  }
  .kakao-helper__panel h3 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 22px; color: var(--navy-900); margin-bottom: 8px;
  }
  .kakao-helper__panel > p {
    color: var(--ink-70); font-size: 14px; line-height: 1.6; margin-bottom: 18px;
  }
  .kakao-helper__panel > p b { color: var(--navy-900);}
  .kakao-helper__idbox {
    display: flex; align-items: stretch; gap: 0;
    background: var(--sky-50);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 4px;
    margin-bottom: 18px;
    overflow: hidden;
  }
  .kakao-helper__idlabel {
    display: inline-flex; align-items: center;
    background: var(--navy-900); color: white;
    font-family: 'Paperlogy', sans-serif;
    font-weight: 800; font-size: 11px; letter-spacing: 0.08em;
    padding: 0 12px; border-radius: 8px;
    flex-shrink: 0;
  }
  .kakao-helper__id {
    flex: 1;
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    font-size: 15px; font-weight: 700; color: var(--navy-900);
    padding: 10px 12px;
    background: none;
    text-align: left;
    user-select: all;
    overflow: hidden; text-overflow: ellipsis;
  }
  .kakao-helper__copy {
    background: var(--blue-600); color: white;
    font-family: inherit; font-weight: 700; font-size: 13px;
    padding: 0 16px; border-radius: 8px; border: none;
    cursor: pointer;
    transition: background .15s;
    flex-shrink: 0;
  }
  .kakao-helper__copy:hover { background: var(--blue-500);}
  .kakao-helper__copy.is-done { background: #1a8a4a;}
  .kakao-helper__actions {
    display: flex; gap: 8px; margin-bottom: 14px;
  }
  .kakao-helper__btn {
    flex: 1; padding: 13px;
    border-radius: 11px; font-weight: 800; font-size: 14px;
    font-family: inherit; text-align: center;
    cursor: pointer; border: none;
    transition: transform .15s, background .15s;
  }
  .kakao-helper__btn--yellow {
    background: #fee500; color: #3c1e1e;
    text-decoration: none;
  }
  .kakao-helper__btn--yellow:hover {
    background: #ffdf00; transform: translateY(-1px);
  }
  .kakao-helper__btn--ghost {
    background: var(--sky-50); color: var(--ink-70);
    border: 1px solid var(--line);
  }
  .kakao-helper__btn--ghost:hover { background: var(--sky-100);}
  .kakao-helper__note {
    font-size: 11px; color: var(--ink-50); line-height: 1.6;
    padding-top: 14px; border-top: 1px dashed var(--line);
  }

  /* ---------- 견적 신청 모달 ---------- */
  .quote-modal {
    position: fixed; inset: 0; z-index: 1100;
    display: none; align-items: center; justify-content: center;
    padding: 20px;
  }
  .quote-modal.is-open { display: flex; }
  .quote-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,31,68,0.55);
    backdrop-filter: blur(6px);
    animation: modalFade .2s ease-out;
  }
  .quote-modal__panel {
    position: relative;
    width: 100%; max-width: 620px;
    max-height: calc(100vh - 40px); overflow-y: auto;
    background: white;
    border-radius: 22px;
    padding: 34px 36px 30px;
    box-shadow: 0 30px 60px -20px rgba(10,31,68,0.45);
    animation: modalPop .25s cubic-bezier(.2,.9,.3,1.2);
  }
  .quote-modal__close {
    position: absolute; top: 14px; right: 16px;
    width: 34px; height: 34px; border-radius: 10px;
    font-size: 24px; line-height: 1; color: var(--ink-50);
    background: var(--sky-50); border: 1px solid var(--line);
    transition: background .15s, color .15s;
  }
  .quote-modal__close:hover { background: var(--sky-100); color: var(--navy-900);}
  .quote-modal__head { text-align: center; margin-bottom: 22px;}
  .quote-modal__ic {
    width: 62px; height: 62px; border-radius: 16px;
    background: linear-gradient(135deg, #fff4d6, var(--yellow));
    display: grid; place-items: center;
    font-size: 32px; margin: 0 auto 14px;
    box-shadow: 0 10px 22px -6px rgba(255,210,51,0.5);
  }
  .quote-modal__head h3 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 24px; color: var(--navy-900); margin-bottom: 6px;
  }
  .quote-modal__sub { color: var(--ink-50); font-size: 14px;}
  .quote-form .rf-field { margin-bottom: 14px;}
  .quote-form label {
    display: block; font-weight: 700; font-size: 13px;
    color: var(--navy-800); margin-bottom: 6px;
  }
  .quote-form input,
  .quote-form select,
  .quote-form textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: white;
    font-family: inherit; font-size: 14px; color: var(--ink);
    transition: border-color .15s, box-shadow .15s;
  }
  .quote-form textarea { resize: vertical; min-height: 100px; line-height: 1.6;}
  .quote-form input:focus,
  .quote-form select:focus,
  .quote-form textarea:focus {
    outline: none; border-color: var(--blue-500);
    box-shadow: 0 0 0 3px rgba(46,111,224,0.15);
  }
  .quote-modal__success {
    text-align: center; padding: 30px 10px 10px;
  }
  .quote-modal__success-ic {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--blue-600); color: white;
    display: grid; place-items: center;
    font-size: 34px; font-weight: 900;
    margin: 0 auto 14px;
    animation: popIn .35s cubic-bezier(.2,.9,.3,1.3);
  }
  .quote-modal__success h4 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 20px; color: var(--navy-900); margin-bottom: 8px;
  }
  .quote-modal__success p { color: var(--ink-70); font-size: 14px; line-height: 1.6;}
  .quote-modal__success b { color: var(--blue-600);}

  /* ---------- 견적 신청 리스트 섹션 ---------- */
  .quotes-list { background: white; }
  .quotes-head {
    position: relative; text-align: center;
  }
  .quotes-head__left { text-align: center;}
  .quote-new-btn {
    position: absolute; right: 0; top: 50%;
    transform: translateY(-50%);
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--yellow); color: var(--navy-900);
    padding: 14px 22px; border-radius: 12px;
    font-weight: 800; font-size: 15px;
    font-family: inherit;
    box-shadow: 0 8px 20px -6px rgba(255,210,51,0.55);
    border: none; cursor: pointer;
    transition: transform .15s, background .15s;
    white-space: nowrap;
  }
  .quote-new-btn:hover {
    background: #ffe066;
    transform: translateY(calc(-50% - 2px));
  }
  @media (max-width: 720px) {
    .quote-new-btn {
      position: static; transform: none; display: inline-flex;
      margin-top: 18px;
    }
    .quote-new-btn:hover { transform: translateY(-2px);}
  }
  .quotes-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px;
  }
  @media (max-width: 680px) {
    .quotes-grid { grid-template-columns: 1fr;}
  }
  .quote-card {
    background: white;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 22px 24px;
    position: relative;
    transition: transform .2s, box-shadow .2s, border-color .2s;
  }
  .quote-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 32px -12px rgba(10,31,68,0.18);
    border-color: var(--blue-400);
  }
  .quote-card__top {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 12px; margin-bottom: 12px;
  }
  .quote-card__service {
    font-family: 'Paperlogy', sans-serif;
    font-weight: 800; font-size: 16px;
    color: var(--navy-900);
  }
  .quote-card__status {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 800; letter-spacing: 0.05em;
    white-space: nowrap;
  }
  .quote-card__status.is-pending {
    background: #fff4d6; color: #b5820a;
  }
  .quote-card__status.is-contacted {
    background: #dbf7e5; color: #1a8a4a;
  }
  .quote-card__status .dot {
    width: 5px; height: 5px; border-radius: 50%;
    background: currentColor;
  }
  .quote-card__meta {
    display: flex; flex-wrap: wrap; gap: 10px 16px;
    font-size: 13px; color: var(--ink-50);
    padding-top: 12px; border-top: 1px dashed var(--line);
    margin-top: 12px;
  }
  .quote-card__meta span b {
    color: var(--navy-800); font-weight: 700;
  }
  .quote-card__detail {
    font-size: 13px; color: var(--ink-70); line-height: 1.6;
    margin-top: 10px; padding: 10px 12px;
    background: var(--sky-50); border-radius: 8px;
    border-left: 3px solid var(--blue-400);
  }
  .quote-card__time {
    position: absolute; top: 22px; right: 24px;
    font-size: 11px; color: var(--ink-50); font-weight: 600;
  }

  .quotes-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 20px;
    background: var(--sky-50);
    border: 1px dashed var(--line);
    border-radius: 20px;
  }
  .quotes-empty__ic {
    font-size: 54px; margin-bottom: 14px;
    opacity: 0.7;
  }
  .quotes-empty h4 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: 19px; color: var(--navy-900); margin-bottom: 8px;
  }
  .quotes-empty p {
    color: var(--ink-50); font-size: 14px; line-height: 1.65;
  }
  .quotes-empty b { color: var(--navy-800);}

  /* 새로 추가된 신청 카드 하이라이트 */
  .quote-card--new {
    animation: cardIn .45s cubic-bezier(.2,.9,.3,1.1);
    box-shadow: 0 0 0 2px var(--yellow), 0 12px 28px -10px rgba(10,31,68,0.25);
    border-color: var(--yellow);
  }

  /* 로그인 필요 오버레이 (후기 작성 시) */
  .member-required {
    text-align: center;
    padding: 14px 16px;
    background: var(--sky-50);
    border: 1px dashed var(--blue-400);
    border-radius: 10px;
    margin-bottom: 16px;
    font-size: 13px; color: var(--navy-800);
  }
  .member-required b { color: var(--blue-600);}
  .rev-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px;
  }
  .rev-card {
    background: white; border-radius: 20px; padding: 28px;
    border: 1px solid var(--line);
    display: flex; flex-direction: column;
    position: relative;
  }
  .rev-quote {
    position: absolute; top: 18px; right: 22px;
    font-family: 'Paperlogy', sans-serif; font-size: 60px;
    color: var(--sky-100); line-height: 1; font-weight: 900;
  }
  .rev-stars { color: var(--yellow); font-size: 16px; letter-spacing: 2px; margin-bottom: 14px; }
  .rev-card p {
    color: var(--ink); font-size: 15px; line-height: 1.7; margin-bottom: 24px;
    flex: 1;
  }
  .rev-person { display: flex; align-items: center; gap: 12px; padding-top: 18px; border-top: 1px dashed var(--line);}
  .rev-avatar {
    width: 44px; height: 44px; border-radius: 50%;
    background: linear-gradient(135deg, var(--blue-500), var(--navy-700));
    display: grid; place-items: center; color: white;
    font-weight: 800; font-size: 16px;
    font-family: 'Paperlogy', sans-serif;
  }
  .rev-person .info { font-size: 13px;}
  .rev-person .info b { display: block; color: var(--navy-900); font-size: 14px;}
  .rev-person .info span { color: var(--ink-50);}

  /* ---------- AREA ---------- */
  .area { background: white; }
  .area-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 48px; align-items: center; }
  .area-left h3 {
    font-family: 'Paperlogy', sans-serif; font-weight: 800;
    font-size: clamp(28px, 3vw, 38px); color: var(--navy-900);
    margin-bottom: 16px; letter-spacing: -0.02em; line-height: 1.2;
  }
  .area-left p { color: var(--ink-70); font-size: 16px; line-height: 1.7; margin-bottom: 24px;}
  .area-chips { display: flex; gap: 8px; flex-wrap: wrap;}
  .area-chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 16px; background: var(--sky-50);
    border: 1px solid var(--line); border-radius: 10px;
    font-size: 14px; font-weight: 600; color: var(--navy-800);
  }
  .area-chip .bullet { width: 6px; height: 6px; border-radius: 50%; background: var(--blue-500);}

  .map-box {
    position: relative; aspect-ratio: 4/3;
    background: var(--sky-100); border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--line);
  }
  .map-bg {
    position: absolute; inset: 0;
    background:
      radial-gradient(circle at 30% 40%, rgba(30,86,200,0.15) 0%, transparent 40%),
      radial-gradient(circle at 70% 60%, rgba(30,86,200,0.1) 0%, transparent 40%);
  }
  .map-bg::before {
    content: ""; position: absolute; inset: 0;
    background-image:
      linear-gradient(rgba(30,86,200,0.1) 1px, transparent 1px),
      linear-gradient(90deg, rgba(30,86,200,0.1) 1px, transparent 1px);
    background-size: 40px 40px;
  }
  .pin {
    position: absolute; transform: translate(-50%, -100%);
    display: flex; flex-direction: column; align-items: center;
  }
  .pin-dot {
    width: 14px; height: 14px; border-radius: 50%;
    background: var(--blue-600); border: 3px solid white;
    box-shadow: 0 2px 8px rgba(30,86,200,0.5);
  }
  .pin-dot.main {
    width: 20px; height: 20px; background: var(--danger);
  }
  .pin-label {
    background: white; padding: 4px 10px; border-radius: 6px;
    font-size: 12px; font-weight: 700; color: var(--navy-900);
    margin-bottom: 6px; white-space: nowrap;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  }
  .pin .ring {
    position: absolute; top: -2px; left: 50%; transform: translateX(-50%);
    width: 40px; height: 40px; border: 2px solid var(--blue-400);
    border-radius: 50%; opacity: 0.6;
    animation: ring 2s ease-out infinite;
  }
  .pin.main .ring { border-color: var(--danger); width: 60px; height: 60px; top: -6px;}
  @keyframes ring {
    0% { transform: translateX(-50%) scale(0.4); opacity: 0.8;}
    100% { transform: translateX(-50%) scale(2.4); opacity: 0;}
  }

  /* ---------- FINAL CTA ---------- */
  .final-cta {
    background:
      linear-gradient(135deg, var(--navy-900) 0%, var(--blue-600) 100%);
    color: white; position: relative; overflow: hidden;
  }
  .final-cta::before {
    content: ""; position: absolute; inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,0.08) 1.2px, transparent 1.5px);
    background-size: 26px 26px;
  }
  .fc-grid {
    display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px;
    align-items: center; position: relative; z-index: 2;
  }
  .fc-grid h2 {
    font-family: 'Paperlogy', sans-serif; font-weight: 900;
    font-size: clamp(34px, 4.2vw, 54px);
    letter-spacing: -0.02em; line-height: 1.15;
  }
  .fc-grid h2 span { color: var(--yellow);}
  .fc-grid p { font-size: 17px; color: #cdd8f0; margin-top: 16px; line-height: 1.7;}
  .fc-box {
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 24px; padding: 36px;
  }
  .fc-box .tel-big {
    font-family: 'Paperlogy', sans-serif;
    font-size: 44px; font-weight: 900;
    color: white; letter-spacing: 0.02em;
    margin: 8px 0 6px;
  }
  .fc-box .tel-lbl { color: var(--yellow); font-weight: 700; font-size: 14px; letter-spacing: 0.1em;}
  .fc-box .tel-sub { color: #cdd8f0; font-size: 14px; margin-bottom: 24px;}
  .fc-box .fc-cta {
    display: block; background: var(--yellow); color: var(--navy-900);
    text-align: center; padding: 16px; border-radius: 12px;
    font-weight: 800; font-size: 17px;
    transition: transform .15s;
  }
  .fc-box .fc-cta:hover { transform: translateY(-2px);}
  .fc-perks { display: flex; gap: 16px; margin-top: 20px;}
  .fc-perks .perk {
    flex: 1; text-align: center;
    background: rgba(255,255,255,0.08); padding: 12px; border-radius: 10px;
    font-size: 12px; color: #cdd8f0;
  }
  .fc-perks .perk b { display: block; color: var(--yellow); font-size: 18px; font-family: 'Paperlogy', sans-serif;}

  /* ---------- EQUIPMENT (장비현황) ---------- */
  .equipment { background: var(--white); }
  .eq-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
    margin-top: 32px;
  }
  .eq-card {
    background: linear-gradient(180deg, #fff, var(--sky-50));
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px 24px;
    position: relative;
    overflow: hidden;
    transition: transform .18s, box-shadow .18s;
  }
  .eq-card:hover { transform: translateY(-4px); box-shadow: 0 20px 40px -16px rgba(10,31,68,0.18); }
  .eq-card .eq-ic {
    width: 54px; height: 54px; border-radius: 14px;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-600));
    color: white; display: grid; place-items: center;
    margin-bottom: 16px; box-shadow: 0 8px 18px -6px rgba(30,86,200,0.5);
  }
  .eq-card h4 {
    font-family: 'Paperlogy', sans-serif; font-size: 19px; font-weight: 800;
    color: var(--navy-900); margin-bottom: 8px; letter-spacing: -0.02em;
  }
  .eq-card p { font-size: 14px; color: var(--ink-70); line-height: 1.65; margin-bottom: 14px;}
  .eq-card .eq-spec {
    display: flex; flex-wrap: wrap; gap: 6px;
  }
  .eq-card .eq-spec span {
    font-size: 12px; padding: 4px 10px; border-radius: 999px;
    background: var(--sky-100); color: var(--navy-800); font-weight: 600;
  }
  .eq-card .eq-badge {
    position: absolute; top: 20px; right: 20px;
    font-size: 11px; font-weight: 800; letter-spacing: 0.12em;
    color: var(--blue-600);
    background: rgba(30,86,200,0.08);
    padding: 4px 10px; border-radius: 999px;
  }

  /* ---------- TEAM (기술진현황) ---------- */
  .team { background: var(--sky-50); }
  .team-stats {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
    margin-bottom: 40px; margin-top: 32px;
  }
  .team-stats .stat {
    background: white; border: 1px solid var(--line);
    border-radius: 16px; padding: 24px 20px; text-align: center;
  }
  .team-stats .stat .big {
    font-family: 'Paperlogy', sans-serif; font-size: 38px; font-weight: 900;
    color: var(--navy-900); line-height: 1;
  }
  .team-stats .stat .big .unit { color: var(--blue-600); font-size: 24px; margin-left: 2px;}
  .team-stats .stat .label { font-size: 13px; color: var(--ink-50); margin-top: 8px; font-weight: 600;}

  .team-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  }
  .tm-card {
    background: white; border-radius: 20px; padding: 28px 24px;
    border: 1px solid var(--line);
    transition: all .18s;
  }
  .tm-card:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -20px rgba(10,31,68,0.22); }
  .tm-avatar {
    width: 72px; height: 72px; border-radius: 50%;
    background: linear-gradient(135deg, #ffc421, #e89005);
    display: grid; place-items: center;
    margin-bottom: 18px; box-shadow: 0 10px 20px -8px rgba(232,144,5,0.5);
    position: relative;
  }
  .tm-avatar::after {
    content: ""; position: absolute; inset: -6px;
    border-radius: 50%; border: 2px dashed var(--blue-400);
    opacity: 0.4;
  }
  .tm-card .tm-role {
    display: inline-block; font-size: 11px; font-weight: 800;
    letter-spacing: 0.12em; color: var(--blue-600);
    background: rgba(30,86,200,0.08); padding: 4px 10px;
    border-radius: 999px; margin-bottom: 10px;
  }
  .tm-card h4 {
    font-family: 'Paperlogy', sans-serif; font-size: 20px; font-weight: 800;
    color: var(--navy-900); margin-bottom: 6px;
  }
  .tm-card .tm-career { font-size: 13px; color: var(--ink-50); margin-bottom: 14px; }
  .tm-card .tm-skills {
    padding-top: 14px; border-top: 1px dashed var(--line);
    display: flex; flex-direction: column; gap: 6px;
  }
  .tm-card .tm-skills li {
    list-style: none; font-size: 13px; color: var(--ink-70);
    padding-left: 18px; position: relative;
  }
  .tm-card .tm-skills li::before {
    content: "✓"; position: absolute; left: 0; top: 0;
    color: var(--blue-600); font-weight: 900;
  }

  /* ---------- FAQ (질의응답) ---------- */
  .faq { background: var(--white); }
  .faq-list {
    max-width: 880px; margin: 32px auto 0;
    display: flex; flex-direction: column; gap: 12px;
  }
  .faq-item {
    background: var(--sky-50); border: 1px solid var(--line);
    border-radius: 14px; overflow: hidden;
    transition: border-color .2s;
  }
  .faq-item[open] { border-color: var(--blue-500); background: white; box-shadow: 0 12px 28px -14px rgba(30,86,200,0.24); }
  .faq-item summary {
    list-style: none; cursor: pointer;
    padding: 20px 24px; display: flex; align-items: center; gap: 14px;
    font-family: 'Paperlogy', sans-serif; font-size: 17px; font-weight: 700;
    color: var(--navy-900); letter-spacing: -0.01em;
  }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item .q-mark {
    flex-shrink: 0; width: 30px; height: 30px; border-radius: 8px;
    background: linear-gradient(135deg, var(--navy-800), var(--blue-600));
    color: white; display: grid; place-items: center;
    font-weight: 900; font-size: 15px;
  }
  .faq-item summary .arrow {
    margin-left: auto; transition: transform .2s;
    color: var(--ink-50);
  }
  .faq-item[open] summary .arrow { transform: rotate(180deg); color: var(--blue-600); }
  .faq-item .answer {
    padding: 0 24px 22px 68px;
    color: var(--ink-70); font-size: 14.5px; line-height: 1.75;
  }
  .faq-item .answer b { color: var(--navy-800); }

  /* ---------- FOOTER ---------- */
  footer {
    background: #05142f; color: #8a99b8;
    padding: 56px 0 32px;
  }
  .foot-grid { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px;}
  .foot-col h5 {
    color: white; font-weight: 800; font-size: 15px; margin-bottom: 16px;
    font-family: 'Paperlogy', sans-serif;
  }
  .foot-col ul { list-style: none;}
  .foot-col ul li { font-size: 13px; padding: 4px 0; color: #a0aecb;}
  .foot-brand { display: flex; gap: 12px; margin-bottom: 14px; align-items: center;}
  .foot-brand .logo-mark { box-shadow: none;}
  .foot-brand b { color: white; font-size: 18px; font-family: 'Paperlogy', sans-serif;}
  .foot-col p { font-size: 13px; line-height: 1.7; color: #8a99b8;}
  .foot-col p b { color: #cdd8f0;}
  .foot-bottom {
    padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.08);
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px;
  }
  .foot-bottom .cert { display: flex; gap: 12px;}
  .foot-bottom .cert span {
    padding: 4px 10px; background: rgba(255,255,255,0.04);
    border-radius: 6px; border: 1px solid rgba(255,255,255,0.08);
  }

  /* ---------- RESPONSIVE ---------- */
  @media (max-width: 1200px) {
    .svc-grid { grid-template-columns: repeat(3, 1fr); }
  }
  @media (max-width: 960px) {
    .hero-grid { grid-template-columns: 1fr; }
    .svc-grid, .proc-grid, .gal-grid, .rev-grid,
    .eq-grid, .team-grid { grid-template-columns: repeat(2, 1fr);}
    .team-stats { grid-template-columns: repeat(2, 1fr);}
    .price-row { grid-template-columns: 1.5fr 1fr; gap: 8px;}
    .price-row .desc, .price-row .time { display: none;}
    .area-grid, .fc-grid { grid-template-columns: 1fr;}
    .foot-grid { grid-template-columns: 1fr 1fr;}
    .nav ul { display: none;}
    .faq-item summary { font-size: 15px; padding: 16px 18px;}
    .faq-item .answer { padding: 0 18px 18px 58px; }
  }
  @media (max-width: 960px) {
    .hero { min-height: 0; }
    .hero-grid { min-height: 0; }
  }
  @media (max-width: 600px) {
    .svc-grid, .proc-grid, .gal-grid, .rev-grid,
    .eq-grid, .team-grid { grid-template-columns: 1fr;}
    .team-stats { grid-template-columns: repeat(2, 1fr);}
    .trust { flex-wrap: wrap; gap: 16px;}
    section { padding: 64px 0;}
    .topbar .chips span:last-child { display: none;}
    .admin-login-btn { font-size: 10px !important; padding: 4px 8px !important;}
  }

  .work-videos {
    padding: 70px 0 60px;
    background: linear-gradient(180deg, #ffffff 0%, #f5f9ff 100%);
  }
  .work-videos .sec-head {
    text-align: center;
    margin-bottom: 28px;
  }

  /* 섹션 헤더에 위치하는 동영상 추가 버튼 — 항상 표시
     단, 실제 동작은 JS에서 관리자 권한을 검증해 차단 */
  .wv-sec-head {
    position: relative;
  }
  .wv-add-btn--header {
    display: inline-flex;
    margin: 16px auto 0;
  }
  /* 관리자 모드일 때 펄스 애니메이션으로 활성 상태 강조 */
  body.admin-mode .wv-add-btn--header {
    animation: wvBtnPulse 2.2s ease-in-out infinite;
  }
  /* 비관리자 상태 — 버튼은 보이지만 시각적으로 잠긴 느낌 */
  body:not(.admin-mode) .wv-add-btn--header {
    background: #6b7790;
    cursor: not-allowed;
    box-shadow: 0 4px 10px -4px rgba(10, 31, 68, 0.25);
  }
  body:not(.admin-mode) .wv-add-btn--header:hover {
    background: #56627a;
    transform: none;
  }
  body:not(.admin-mode) .wv-add-btn--header svg {
    stroke: #c8d0dd;
  }
  body:not(.admin-mode) .wv-add-btn--header::after {
    content: " 🔒";
    margin-left: 2px;
    font-size: 13px;
  }

  /* 삭제 버튼: 관리자만 보임 (목록을 어지럽히지 않기 위해 유지) */
  .wv-del-btn { pointer-events: none; }
  body.admin-mode .wv-del-btn { pointer-events: auto; }
  @keyframes wvBtnPulse {
    0%, 100% { box-shadow: 0 6px 14px -4px rgba(10, 31, 68, 0.4), 0 0 0 0 rgba(232, 166, 0, 0.55); }
    50%      { box-shadow: 0 6px 14px -4px rgba(10, 31, 68, 0.4), 0 0 0 10px rgba(232, 166, 0, 0); }
  }

  .wv-add-btn {
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    background: var(--navy-900, #0a1f44);
    color: #fff;
    border: 0;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: transform .2s, background .2s;
    box-shadow: 0 6px 14px -4px rgba(10, 31, 68, 0.4);
  }
  .wv-add-btn:hover {
    background: #1748a6;
    transform: translateY(-2px);
  }
  .wv-add-btn svg { stroke: #ffd54a; }

  /* 관리자 안내 배지 (관리자 모드에서만 표시) */
  .wv-admin-bar {
    display: none;
    align-items: center;
    gap: 14px;
    margin: 18px 0 22px;
    padding: 14px 18px;
    background: linear-gradient(135deg, #fff8e1, #ffefb4);
    border: 1.5px dashed #e8a600;
    border-radius: 12px;
  }
  body.admin-mode .wv-admin-bar { display: flex; }
  .wv-admin-bar__ic {
    flex: 0 0 auto;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(232, 166, 0, 0.18);
    color: #b07a00;
    display: grid;
    place-items: center;
  }
  .wv-admin-bar__msg {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 13px;
    color: #6b5410;
    line-height: 1.45;
  }
  .wv-admin-bar__msg b {
    font-size: 14px;
    color: #8a6700;
    font-weight: 800;
  }
  .wv-admin-bar__msg em {
    font-style: normal;
    font-weight: 700;
    color: #0a1f44;
    background: rgba(255,255,255,0.7);
    padding: 1px 6px;
    border-radius: 5px;
  }

  /* 동영상 리스트 — 가로 4개 그리드 */
  .wv-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
  }
  @media (max-width: 1100px) {
    .wv-list { grid-template-columns: repeat(3, 1fr); }
  }
  @media (max-width: 800px) {
    .wv-list { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  }
  @media (max-width: 480px) {
    .wv-list { grid-template-columns: 1fr; }
  }

  .wv-item {
    position: relative;
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 14px -6px rgba(10, 31, 68, 0.18);
    border: 1px solid #e7eef9;
    transition: transform .25s, box-shadow .25s;
    cursor: pointer;
  }
  .wv-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px -8px rgba(10, 31, 68, 0.28);
  }
  .wv-thumb {
    position: relative;
    aspect-ratio: 16 / 9;
    background: #0a1f44 center/cover no-repeat;
    overflow: hidden;
  }
  .wv-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .wv-thumb__play {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    background: rgba(10, 31, 68, 0.18);
    transition: background .25s;
  }
  .wv-item:hover .wv-thumb__play {
    background: rgba(10, 31, 68, 0.36);
  }
  .wv-thumb__play-ic {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.95);
    display: grid;
    place-items: center;
    box-shadow: 0 8px 20px -4px rgba(0,0,0,0.4);
    transition: transform .25s;
  }
  .wv-item:hover .wv-thumb__play-ic {
    transform: scale(1.12);
  }
  .wv-thumb__play-ic svg {
    color: #cc0000;
    margin-left: 4px;
  }
  .wv-thumb__cat {
    position: absolute;
    top: 10px;
    left: 10px;
    background: rgba(10, 31, 68, 0.88);
    color: #fff;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: -0.2px;
  }
  .wv-meta {
    padding: 12px 14px 14px;
  }
  .wv-meta__title {
    font-size: 14px;
    font-weight: 700;
    color: #0a1f44;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0 0 6px;
    min-height: 38px;
  }
  .wv-meta__date {
    font-size: 12px;
    color: #7d8aa3;
    font-weight: 500;
  }

  /* 관리자 모드 전용 — 삭제 버튼 */
  .wv-del-btn {
    display: none;
    position: absolute;
    top: 8px;
    right: 8px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: rgba(220, 53, 53, 0.95);
    color: #fff;
    border: 0;
    cursor: pointer;
    z-index: 4;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px -2px rgba(0,0,0,0.4);
    transition: transform .2s, background .2s;
  }
  body.admin-mode .wv-del-btn {
    display: flex;
  }
  .wv-del-btn:hover {
    background: #b02828;
    transform: scale(1.1);
  }

  /* 빈 상태 */
  .wv-empty {
    text-align: center;
    padding: 40px 20px;
    color: #7d8aa3;
  }
  .wv-empty svg { color: #c7d3e6; margin-bottom: 10px; }
  .wv-empty p { font-size: 15px; font-weight: 500; margin: 0; }

  /* 동영상 추가 모달 (회원 모달과 동일 톤) */
  .wv-modal {
    position: fixed;
    inset: 0;
    z-index: 9000;
    display: none;
  }
  .wv-modal[aria-hidden="false"] { display: block; }
  .wv-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 31, 68, 0.5);
    backdrop-filter: blur(4px);
  }
  .wv-modal__panel {
    position: relative;
    max-width: 480px;
    width: 92%;
    margin: 70px auto;
    background: #fff;
    border-radius: 16px;
    padding: 28px 26px 22px;
    box-shadow: 0 24px 60px -12px rgba(10, 31, 68, 0.45);
    max-height: calc(100vh - 100px);
    overflow-y: auto;
  }
  .wv-modal__close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 0;
    background: transparent;
    font-size: 24px;
    color: #6b7790;
    cursor: pointer;
    line-height: 1;
  }
  .wv-modal__close:hover { background: #e7eef9; color: #0a1f44; }
  .wv-modal__head { text-align: center; margin-bottom: 20px; }
  .wv-modal__ic { font-size: 32px; margin-bottom: 6px; }
  .wv-modal__head h3 { margin: 0 0 4px; font-size: 20px; color: #0a1f44; }
  .wv-modal__sub { font-size: 13px; color: #6b7790; margin: 0; }

  .wv-form .rf-field { margin-bottom: 14px; }
  .wv-form .rf-field label {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: #0a1f44;
    margin-bottom: 6px;
  }
  .wv-form .rf-field input,
  .wv-form .rf-field select {
    width: 100%;
    padding: 10px 12px;
    border: 1.5px solid #d9e1ee;
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    background: #fff;
    color: #0a1f44;
    transition: border-color .2s;
  }
  .wv-form .rf-field input:focus,
  .wv-form .rf-field select:focus {
    outline: none;
    border-color: #1e56c8;
  }
  .wv-form .rf-req { color: #dc3535; }
  .wv-hint {
    display: block;
    font-size: 11px;
    color: #7d8aa3;
    margin-top: 4px;
  }
  .wv-form__err {
    background: #fdecec;
    color: #b02828;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 12px;
  }

  /* 동영상 재생 모달 */
  .wv-player {
    position: fixed;
    inset: 0;
    z-index: 9100;
    display: none;
  }
  .wv-player[aria-hidden="false"] { display: block; }
  .wv-player__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(6px);
  }
  .wv-player__panel {
    position: relative;
    max-width: 960px;
    width: 92%;
    margin: 5vh auto;
    background: #000;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 30px 80px -10px rgba(0,0,0,0.7);
  }
  .wv-player__close {
    position: absolute;
    top: -42px;
    right: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    color: #fff;
    border: 0;
    font-size: 22px;
    cursor: pointer;
    z-index: 10;
    line-height: 1;
  }
  .wv-player__close:hover { background: rgba(255,255,255,0.3); }
  .wv-player__frame {
    position: relative;
    aspect-ratio: 16 / 9;
    background: #000;
  }
  .wv-player__frame iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
  }
  .wv-player__title {
    color: #fff;
    padding: 14px 18px;
    font-size: 15px;
    font-weight: 600;
    background: #0a1320;
  }

  .float-chip .fc-note {
    display: block;
    margin-top: 2px;
    font-size: 11px;
    font-style: normal;
    font-weight: 600;
    color: #c25a1a;          /* 살짝 경고톤 오렌지 (눈에 띄지만 과하지 않게) */
    letter-spacing: -0.2px;
    line-height: 1.2;
  }
  .float-chip .fc-note::before {
    content: "※ ";
    opacity: 0.85;
  }

  .sec-title--with-mascots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 32px;
    flex-wrap: nowrap;
  }
  .sec-title--with-mascots .sec-title__txt {
    display: inline-block;
    line-height: 1.25;
    text-align: center;
    flex: 0 1 auto;
  }

  /* 비디오 마스코트 공통 (1.5배 확대) */
  .sec-mascot {
    width: 300px;
    height: 300px;
    object-fit: contain;
    flex: 0 0 auto;
    filter: drop-shadow(0 12px 26px rgba(10, 31, 68, 0.24));
    background: transparent;
    border: 0;
    outline: 0;
    pointer-events: none; /* 영상 컨트롤 클릭 차단 — 자동 재생만 */
  }
  /* 왼쪽 비버는 좌우 반전 — 두 비버가 텍스트 쪽을 향함 */
  .sec-mascot--left {
    transform: scaleX(-1);
  }

  /* 태블릿 */
  @media (max-width: 900px) {
    .sec-title--with-mascots { gap: 18px; }
    .sec-mascot { width: 195px; height: 195px; }
  }
  /* 모바일 */
  @media (max-width: 560px) {
    .sec-title--with-mascots { gap: 10px; }
    .sec-mascot { width: 126px; height: 126px; }
  }

  /* 서비스 카드 01~05 번호
     기본:  #e8f1ff (L≈96%) → -20% → L≈76%  →  #b3cdf2
     호버:  #cfe0fc (L≈90%) → -30% → L≈60%  →  #7099d9 */
  .svc-card .num {
    color: #b3cdf2 !important;
  }
  .svc-card:hover .num {
    color: #7099d9 !important;
  }
  /* 프로세스 01~04 동그라미 숫자
     기본: #1e56c8 (L≈45%) → -20% → L≈25%  →  #103272 */
  .proc-step .proc-circle {
    color: #103272 !important;
  }
