.loc-wrap { max-width:920px; margin:0 auto; padding:0 20px; }

/* Hero — 메인 index.astro 히어로 CTA와 동일 톤·여백 */
.loc-hero { padding:50px 0 60px; text-align:center; }
.loc-badge { display:inline-flex; align-items:center; gap:7px; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:999px; padding:6px 16px; font-size:12px; font-weight:700; color:#16a34a; }
.loc-hero > h1 { margin-top:22px; }
.loc-hero h1 { font-size:clamp(28px,5vw,52px); font-weight:900; letter-spacing:-1.5px; line-height:1.1; color:#0f172a; margin-bottom:16px; }
.loc-hero h1 em { font-style:normal; color:#6366f1; }
.loc-hero-desc { font-size:16px; color:#64748b; line-height:1.75; margin-bottom:38px; max-width:520px; margin-left:auto; margin-right:auto; }
.loc-hero-image { margin:30px auto 48px; max-width:800px; border-radius:20px; overflow:hidden; box-shadow:0 20px 50px rgba(0,0,0,0.15); }
.loc-section-image-wrap { margin:0 auto 30px; max-width:800px; border-radius:20px; overflow:hidden; box-shadow:0 10px 30px rgba(0,0,0,0.1); }
.loc-section-img { width:100%; height:auto; display:block; aspect-ratio:16/9; object-fit:cover; }
.loc-section-img--spa2 { object-position:center 30%; }
.loc-section-img--spa3 { object-position:center 20%; }
.loc-hero-image img {
  width:100%;
  height:auto;
  display:block;
  aspect-ratio:1/1;
  object-fit:cover;
  object-position:top center;
}
@media(min-width:768px) {
  .loc-hero-image img { height:500px; aspect-ratio:auto; }
}
.cta-group { display:flex; flex-direction:column; align-items:center; gap:12px; }
.loc-hero .cta-main { display:inline-flex; align-items:center; gap:10px; padding:18px 40px; background:linear-gradient(135deg,#6366f1,#8b5cf6); color:#fff; font-size:17px; font-weight:800; text-decoration:none; border-radius:14px; box-shadow:0 8px 30px rgba(99,102,241,.42); transition:all .2s; }
.loc-hero .cta-main:hover { transform:translateY(-2px); box-shadow:0 16px 40px rgba(99,102,241,.52); }
.cta-sub { font-size:13px; color:#94a3b8; }
.loc-hero .sns-row { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:14px; }
.sns-link { display:inline-flex; align-items:center; justify-content:center; padding:10px 16px; font-size:13.5px; font-weight:700; color:#475569; background:#fff; border:1px solid #e2e8f0; border-radius:12px; text-decoration:none; transition:all .15s; }
.sns-link:hover { border-color:#c7d2fe; color:#6366f1; background:#f8fafc; }
.sns-text { display:inline-flex; align-items:center; justify-content:center; padding:10px 16px; font-size:13.5px; font-weight:700; color:#475569; background:#fff; border:1px solid #e2e8f0; border-radius:12px; cursor:default; }
.loc-cta .sns-row { max-width:100%; margin-top:20px; }
.loc-cta .sns-link { border-color:rgba(255,255,255,.35); color:#fff; background:rgba(255,255,255,.12); }
.loc-cta .sns-link:hover { background:rgba(255,255,255,.22); border-color:rgba(255,255,255,.55); }
.loc-cta .sns-text { border-color:rgba(255,255,255,.35); color:#fff; background:rgba(255,255,255,.12); }

/* Trust row */
.trust-row { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; padding:0 0 52px; }
@media(max-width:640px) { .trust-row { grid-template-columns:repeat(2,1fr); } }
.trust-pill { background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding:22px 14px; text-align:center; }
.trust-pill-icon { font-size:28px; margin-bottom:10px; }
.trust-pill-title { font-size:14px; font-weight:800; color:#0f172a; margin-bottom:5px; }
.trust-pill-sub { font-size:12.5px; color:#64748b; line-height:1.5; }

/* Section */
.divider { height:1px; background:#e5e7eb; margin-bottom:52px; }
.sec { padding-bottom:52px; }
.sec-eyebrow { font-size:11.5px; font-weight:700; color:#6366f1; text-transform:uppercase; letter-spacing:.10em; margin-bottom:9px; }
.sec-title { font-size:clamp(20px,3vw,30px); font-weight:900; letter-spacing:-0.7px; color:#0f172a; margin-bottom:14px; }
.sec-lead { font-size:14.5px; color:#64748b; line-height:1.75; margin-bottom:28px; }
.sec > .sec-eyebrow,
.sec > .sec-title { text-align:center; }
.sec > p.sec-lead {
  text-align:center;
  max-width:640px;
  margin-left:auto;
  margin-right:auto;
}

/* Services — 카드 내부 전체 중앙 정렬 */
.srv-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:540px) { .srv-grid { grid-template-columns:1fr; } }
.srv-card { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:20px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px; transition:all .2s; }
.srv-card:hover { border-color:#c7d2fe; box-shadow:0 6px 20px rgba(0,0,0,.06); }
.srv-icon { font-size:26px; flex-shrink:0; }
.srv-name { font-size:14px; font-weight:800; color:#0f172a; margin-bottom:5px; }
.srv-time { font-size:11.5px; font-weight:700; color:#6366f1; background:rgba(99,102,241,.08); border-radius:999px; padding:2px 9px; display:inline-block; margin-bottom:6px; }
.srv-desc { font-size:13px; color:#64748b; line-height:1.6; margin:0; }

/* Steps — 제목 아래 여백 넉넉히(레퍼런스 레이아웃) */
.sec-steps > .sec-title,
.sec-reasons > .sec-title { margin-bottom:36px; }

/* Steps — 메인 steps-grid / step 과 동일하게 카드 내부 전부 중앙 */
.steps-row { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media(max-width:700px) { .steps-row { grid-template-columns:repeat(2,1fr); } }
.step-card { background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding:24px 18px; text-align:center; position:relative; }
.step-num { width:36px; height:36px; background:linear-gradient(135deg,#6366f1,#8b5cf6); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:900; color:#fff; margin:0 auto 14px; box-shadow:0 4px 12px rgba(99,102,241,.4); }
.step-label { font-size:14px; font-weight:800; color:#0f172a; margin-bottom:7px; text-align:center; }
.step-desc { font-size:12.5px; color:#64748b; line-height:1.55; text-align:center; margin:0; }

/* Reasons — 메인 reasons-grid / reason-item 과 동일(아이콘 좌·텍스트 좌, 2열 그리드) */
.reasons-list { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:640px) { .reasons-list { grid-template-columns:1fr; } }
.reason { background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding:22px 20px; display:flex; flex-direction:row; align-items:flex-start; gap:14px; text-align:left; transition:all .2s; }
.reason:hover { border-color:#c7d2fe; box-shadow:0 6px 20px rgba(0,0,0,.06); }
.reason-badge { width:26px; height:26px; background:linear-gradient(135deg,#6366f1,#8b5cf6); border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px; box-shadow:0 3px 10px rgba(99,102,241,.35); }
.reason-badge svg { width:14px; height:14px; color:#fff; }
.reason-title { font-size:14px; font-weight:800; color:#0f172a; margin-bottom:5px; }
.reason-desc { font-size:13px; color:#64748b; line-height:1.6; }

/* FAQ */
.faq-list { display:flex; flex-direction:column; gap:8px; }
.faq-item { background:#fff; border:1px solid #e5e7eb; border-radius:12px; overflow:hidden; }
.faq-q {
  position:relative;
  padding:16px 44px 16px 18px;
  font-size:14px;
  font-weight:700;
  color:#0f172a;
  cursor:pointer;
  text-align:center;
}
.sec-faq > .sec-eyebrow,
.sec-faq > .sec-title { text-align:left; }
.sec-faq .faq-q { text-align:left; }
.sec-faq .faq-a { text-align:left; }
.faq-q::after {
  content:'＋';
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  font-size:18px;
  font-weight:400;
  color:#6366f1;
}
.faq-item.open .faq-q::after { content:'－'; }
.faq-a { display:none; padding:0 18px 18px; font-size:13.5px; color:#64748b; line-height:1.7; text-align:center; }
.faq-item.open .faq-a { display:block; }

/* Nearby */
.nearby-chips { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.nearby-chip { padding:7px 14px; background:#fff; border:1px solid #e5e7eb; border-radius:999px; font-size:13px; font-weight:600; color:#475569; text-decoration:none; transition:all .15s; }
.nearby-chip:hover { color:#6366f1; border-color:#c7d2fe; background:rgba(99,102,241,.05); }

/* Bottom CTA */
.loc-cta { background:linear-gradient(135deg,#6366f1,#8b5cf6); border-radius:20px; padding:40px 28px; text-align:center; margin-bottom:60px; }
.loc-cta h2 { font-size:clamp(20px,3vw,30px); font-weight:900; letter-spacing:-0.7px; color:#fff; margin-bottom:12px; }
.loc-cta p { font-size:15px; color:rgba(255,255,255,.75); margin-bottom:28px; line-height:1.6; }
.loc-cta .cta-white {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:18px 44px;
  background:#fff;
  color:#6366f1;
  font-size:17px;
  font-weight:800;
  text-decoration:none;
  border-radius:14px;
  box-shadow:0 8px 30px rgba(0,0,0,.2);
  transition:all .2s;
  white-space:nowrap;
  flex-wrap:nowrap;
  max-width:100%;
  box-sizing:border-box;
}
@media(max-width:420px) {
  .loc-cta .cta-white { font-size:15px; padding:16px 22px; gap:8px; }
}
.loc-cta .cta-white:hover { transform:translateY(-2px); box-shadow:0 16px 40px rgba(0,0,0,.3); }
.loc-cta .cta-notice { font-size:13px; color:rgba(255,255,255,.55); margin-top:14px; margin-bottom:0; }
