@charset "utf-8";

.procedure-page { background: var(--bg); }
.procedure-hero { padding: 38px 0 28px; background: radial-gradient(circle at 15% 20%, rgba(187,156,241,.18), transparent 45%), linear-gradient(180deg, #fff 0%, var(--bg-soft) 100%); }
.procedure-hero__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 20px; align-items: stretch; }
.procedure-hero__content { display: flex; flex-direction: column; gap: 14px; }
.procedure-hero__badge { align-self: flex-start; font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 900; color: #7b65d1; }
.procedure-hero__title { margin: 0; font-size: 34px; letter-spacing: -.02em; font-weight: 900; color: #111827; }
.procedure-hero__lead { margin: 0; font-size: 15px; color: #4b5563; }
.procedure-hero__summary { margin: 0; padding: 16px 18px; border-radius: 16px; background: rgba(187,156,241,.12); border: 1px solid rgba(187,156,241,.24); color: #1f2937; line-height: 1.7; }
.procedure-hero__card { height: 100%; }
.procedure-meta { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.procedure-meta__item { padding: 12px 14px; border-radius: 14px; background: var(--bg-soft); border: 1px solid var(--border); display: flex; flex-direction: column; gap: 4px; }
.procedure-meta__item strong { font-size: 14px; color: #111827; }
.procedure-meta__item span { font-size: 13px; color: var(--muted); }

.procedure-nav { border-bottom: 1px solid var(--border); background: #fff; position: sticky; top: var(--header-h); z-index: 20; }
.procedure-nav__list { margin: 0; padding: 10px 0; list-style: none; display: flex; gap: 10px; flex-wrap: wrap; }
.procedure-nav__link { display: inline-flex; align-items: center; height: 34px; padding: 0 14px; border-radius: 999px; border: 1px solid var(--border); background: #fff; font-weight: 700; font-size: 13px; color: #374151; }
.procedure-nav__link:hover { background: var(--bg-soft); }

.procedure-section .card { height: 100%; }
.procedure-body { margin: 0; color: #374151; line-height: 1.75; }
.procedure-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.procedure-list li { position: relative; padding-left: 18px; line-height: 1.7; color: #1f2937; }
.procedure-list li::before { content: "•"; position: absolute; left: 0; top: 0; color: var(--primary); font-weight: 900; }

.procedure-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.procedure-step { border: 1px solid var(--border); border-radius: 16px; background: #fff; padding: 16px; box-shadow: 0 10px 24px rgba(15, 23, 42, .06); }
.procedure-step__num { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 999px; background: var(--primary-weak); color: #4b2ca3; font-weight: 900; font-size: 12px; }
.procedure-step__title { margin: 10px 0 6px; font-size: 15px; font-weight: 900; color: #111827; }
.procedure-step__desc { margin: 0; font-size: 13px; color: #4b5563; line-height: 1.6; }

.procedure-faq { display: grid; gap: 10px; }
.procedure-faq__item { border: 1px solid var(--border); border-radius: 14px; background: #fff; padding: 14px 16px; }
.procedure-faq__q { margin: 0 0 6px; font-size: 14px; font-weight: 900; color: #111827; }
.procedure-faq__a { margin: 0; font-size: 13px; color: #4b5563; line-height: 1.7; }

.procedure-cta { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; margin-top: 16px; }
.procedure-cta .btn { height: 44px; padding: 0 18px; font-size: 14px; }

.procedure-related { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.procedure-related a { display: flex; flex-direction: column; gap: 8px; padding: 16px; border-radius: 16px; border: 1px solid var(--border); background: #fff; box-shadow: 0 8px 20px rgba(15, 23, 42, .06); font-weight: 800; color: #111827; }
.procedure-related span { font-size: 13px; color: #6b7280; font-weight: 600; }

.procedure-note { margin: 0; font-size: 12px; color: var(--muted); line-height: 1.6; }

@media (max-width: 960px) {
  .procedure-hero__grid { grid-template-columns: 1fr; }
  .procedure-hero__title { font-size: 28px; }
  .procedure-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .procedure-related { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px) {
  .procedure-hero { padding: 32px 0 22px; }
  .procedure-nav__list { padding: 8px 0; gap: 8px; }
  .procedure-nav__link { height: 32px; padding: 0 12px; font-size: 12px; }
  .procedure-steps { grid-template-columns: 1fr; }
  .procedure-related { grid-template-columns: 1fr; }
  .procedure-cta { justify-content: stretch; }
  .procedure-cta .btn { width: 100%; }
}
