/* XERO1 가격 및 결제 정책 */
:root {
      --bg: #eef4ff;
      --card: #ffffff;
      --text: #141824;
      --muted: #6b7280;
      --line: #e5e7eb;
      --primary: #1d4ed8;
      --primary-soft: #eff6ff;
      --accent: #0f766e;
      --accent-soft: #ecfdf5;
    }

    * {
      box-sizing: border-box;
    }

    .pricing-policy-page {
      flex: 1;
      width: 100%;
      font-family: inherit;
      color: var(--text);
    }

    .pricing-policy-inner {
      width: 100%;
      margin: 0 auto;
      background: transparent;
      border: none;
      border-radius: 0;
      padding: 0;
      box-shadow: none;
    }

    .policy-intro {
      margin-bottom: 24px;
    }

    .policy-brief {
      margin: 10px 0 0;
      padding: 10px 12px;
      border: 1px solid #e2e8f0;
      border-radius: 10px;
      background: #f8fafc;
      color: #334155;
      font-size: 12px;
      line-height: 1.5;
    }

    .policy-brief strong {
      color: #0f172a;
      font-weight: 800;
    }

    .brand {
      margin: 0 0 6px;
      font-size: 13px;
      color: #1d4ed8;
      font-weight: 800;
      letter-spacing: 0.08em;
    }

    .heading {
      margin: 0 0 8px;
      font-size: 30px;
      font-weight: 900;
    }

    .subheading {
      margin: 0;
      color: var(--muted);
      font-size: 14px;
    }

    .pricing {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
    }

    .card {
      background: var(--card);
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 24px;
      box-shadow: 0 8px 24px rgba(20, 24, 36, 0.07);
    }

    .badge {
      display: inline-block;
      padding: 6px 10px;
      border-radius: 999px;
      font-weight: 700;
      font-size: 13px;
      letter-spacing: 0.02em;
      margin-bottom: 14px;
    }

    .badge--one {
      color: var(--primary);
      background: var(--primary-soft);
    }

    .badge--split {
      color: var(--accent);
      background: var(--accent-soft);
    }

    .badge--install {
      color: #92400e;
      background: #fef3c7;
    }

    .card--install .price {
      color: #0f172a;
    }

    .card-note {
      margin: 14px 0 0;
      padding-top: 12px;
      border-top: 1px dashed var(--line);
      font-size: 12px;
      line-height: 1.5;
      color: #64748b;
    }

    .title {
      margin: 0 0 6px 0;
      font-size: 26px;
      font-weight: 800;
      line-height: 1.2;
    }

    .desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-size: 14px;
    }

    .price-block {
      border-top: 1px solid var(--line);
      padding-top: 18px;
    }

    .label {
      margin: 0 0 8px 0;
      color: var(--muted);
      font-size: 13px;
      font-weight: 600;
    }

    .price {
      margin: 0;
      font-size: 19px;
      font-weight: 800;
      line-height: 1.3;
    }

    .price-original {
      margin: 0 0 6px;
      font-size: 13px;
      color: #94a3b8;
      text-decoration: line-through;
      font-weight: 700;
    }

    .row .price-original {
      margin: 0;
    }

    .unit {
      font-size: 19px;
      font-weight: 800;
      margin-left: 1px;
    }

    .meta {
      margin-top: 12px;
      padding-top: 12px;
      border-top: 1px dashed var(--line);
      display: grid;
      gap: 8px;
    }

    .benefit {
      margin-top: 14px;
      padding: 10px 12px;
      border-radius: 10px;
      font-size: 13px;
      font-weight: 700;
      line-height: 1.45;
      background: #f8fafc;
      border: 1px solid #e2e8f0;
      color: #0f172a;
    }

    .row {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      gap: 12px;
    }

    .row .name {
      color: var(--muted);
      font-size: 14px;
      font-weight: 600;
    }

    .row .value {
      font-size: 19px;
      font-weight: 800;
    }

    .price-before {
      color: #94a3b8;
      text-decoration: line-through;
      font-size: 13px;
      font-weight: 700;
      margin-right: 6px;
    }

    .price-arrow {
      color: #64748b;
      font-size: 13px;
      font-weight: 700;
      margin-right: 6px;
    }

    .footnote {
      margin-top: 18px;
      padding-top: 12px;
      border-top: 1px dashed var(--line);
      color: #6b7280;
      font-size: 12px;
      line-height: 1.5;
    }

    .consulting-sheet {
      margin-top: 18px;
      padding: 16px;
      border: 1px solid #dbe4f0;
      border-radius: 12px;
      background: #fcfdff;
    }

    .consulting-sheet-title {
      margin: 0 0 10px;
      font-size: 14px;
      font-weight: 800;
      color: #0f172a;
      letter-spacing: 0.01em;
    }

    .terms-sheet {
      margin-top: 14px;
      padding: 14px 16px;
      border: 1px solid #e2e8f0;
      border-radius: 12px;
      background: #ffffff;
    }

    .terms-title {
      margin: 0 0 8px;
      font-size: 13px;
      font-weight: 800;
      color: #1f2937;
    }

    .terms-list {
      margin: 0;
      padding-left: 18px;
      color: #475569;
      font-size: 12px;
      line-height: 1.6;
    }

    .terms-list a {
      color: #1d4ed8;
      font-weight: 600;
      text-decoration: none;
    }

    .terms-list a:hover {
      text-decoration: underline;
    }

    .model-section {
      margin-top: 28px;
      padding-top: 8px;
    }

    .model-heading {
      margin: 0 0 16px;
      font-size: 22px;
      font-weight: 800;
      color: #0f172a;
    }

    .refund-table {
      width: 100%;
      border-collapse: collapse;
      margin: 12px 0 0;
      font-size: 12px;
    }

    .refund-table th,
    .refund-table td {
      padding: 8px 10px;
      border: 1px solid #e2e8f0;
      text-align: left;
    }

    .refund-table th {
      background: #f8fafc;
      font-weight: 700;
      color: #475569;
    }

    .refund-table td:last-child {
      font-weight: 700;
      color: #1d4ed8;
      text-align: right;
      white-space: nowrap;
    }

    .refund-summary {
      margin: 0 0 12px;
      font-size: 13px;
      line-height: 1.6;
      color: #334155;
    }

    .refund-summary strong {
      color: #1d4ed8;
    }

    .refund-table-lead {
      margin: 14px 0 8px;
      font-size: 13px;
      font-weight: 700;
      color: #0f172a;
    }

    .refund-th-sub {
      display: block;
      margin-top: 2px;
      font-size: 11px;
      font-weight: 600;
      color: #64748b;
    }

    .refund-table th {
      vertical-align: bottom;
      line-height: 1.35;
    }

    .refund-full {
      font-size: 11px;
      font-weight: 700;
      color: #16a34a;
    }

    .refund-notes {
      margin: 12px 0 0;
      padding: 0 0 0 1.1em;
      font-size: 12px;
      line-height: 1.55;
      color: #64748b;
    }

    .refund-notes li + li {
      margin-top: 6px;
    }

    .refund-notes strong {
      color: #334155;
    }

    .pricing--pass {
      grid-template-columns: 1fr;
      max-width: 720px;
    }

    .pricing--pass .card--pass-monthly {
      grid-column: 1;
    }

    .card--pass-monthly .pass-pricing-plans-intro,
    .card--pass-monthly .pass-pricing-plan-legend,
    .card--pass-monthly .pass-pricing-plan-cards,
    .card--pass-monthly .pass-pricing-vat-note {
      margin-left: 0;
      margin-right: 0;
    }

    .card--pass-monthly .desc {
      margin-bottom: 12px;
    }

    .consulting-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px 16px;
    }

    .field {
      display: flex;
      align-items: center;
      gap: 10px;
      min-height: 28px;
    }

    .field-label {
      min-width: 66px;
      color: #64748b;
      font-size: 12px;
      font-weight: 700;
    }

    .field-value {
      flex: 1;
      padding-bottom: 2px;
      border-bottom: 1px solid #cbd5e1;
      color: #111827;
      font-size: 13px;
      font-weight: 600;
      min-height: 20px;
    }

    .field-value--signature {
      min-height: 28px;
    }

    @media screen and (max-width: 1024px) {
      .pricing {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media screen and (max-width: 760px) {
      .pricing-policy-inner {
        padding: 22px;
        border-radius: 16px;
      }

      .heading {
        font-size: 24px;
      }

      .pricing {
        grid-template-columns: 1fr;
      }

      .consulting-grid {
        grid-template-columns: 1fr;
      }

      .card {
        padding: 20px;
      }

      .price {
        font-size: 19px;
      }
    }

    @media print {
      @page {
        size: A4;
        margin: 10mm;
      }

      .pricing-policy-page {
        background: #fff;
        padding: 0;
        font-size: 11px;
      }

      .pricing-policy-inner {
        width: 100%;
        border: 1px solid #e5e7eb;
        border-radius: 0;
        box-shadow: none;
        padding: 14px;
      }

      .policy-intro {
        margin-bottom: 10px;
      }

      .brand {
        margin: 0 0 3px;
        font-size: 10px;
      }

      .heading {
        margin: 0;
        font-size: 20px;
      }

      .policy-brief {
        margin-top: 6px;
        padding: 7px 8px;
        font-size: 10px;
      }

      .pricing {
        gap: 10px;
      }

      .pricing {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .card {
        box-shadow: none;
        break-inside: avoid;
        padding: 12px;
        border-radius: 10px;
      }

      .badge {
        margin-bottom: 6px;
        padding: 3px 7px;
        font-size: 10px;
      }

      .title {
        font-size: 17px;
        margin: 0 0 4px;
      }

      .desc {
        margin: 0 0 8px;
        font-size: 11px;
      }

      .price-block {
        padding-top: 8px;
      }

      .label {
        margin: 0 0 4px;
        font-size: 10px;
      }

      .price,
      .unit,
      .row .value {
        font-size: 15px;
      }

      .price-original {
        font-size: 10px;
        margin: 0 0 4px;
      }

      .meta {
        margin-top: 8px;
        padding-top: 8px;
        gap: 5px;
      }

      .row .name {
        font-size: 11px;
      }

      .price-before,
      .price-arrow {
        font-size: 10px;
      }

      .benefit {
        margin-top: 8px;
        padding: 7px 8px;
        font-size: 10px;
        border-radius: 8px;
      }

      .footnote {
        margin-top: 8px;
        padding-top: 8px;
        font-size: 10px;
        line-height: 1.4;
      }

      .consulting-sheet {
        break-inside: avoid;
        margin-top: 8px;
        padding: 10px;
        border-radius: 8px;
      }

      .consulting-sheet-title {
        margin: 0 0 6px;
        font-size: 11px;
      }

      .consulting-grid {
        gap: 6px 10px;
      }

      .field {
        min-height: 20px;
      }

      .field-label {
        min-width: 48px;
        font-size: 10px;
      }

      .field-value {
        min-height: 16px;
        font-size: 11px;
      }

      .field-value--signature {
        min-height: 20px;
      }

      .terms-sheet {
        margin-top: 8px;
        padding: 10px;
        border-radius: 8px;
      }

      .terms-title {
        margin: 0 0 5px;
        font-size: 11px;
      }

      .terms-list {
        font-size: 10px;
        line-height: 1.4;
      }

    }

@media screen and (max-width: 760px) {
  .pricing-policy-page {
    padding-left: 12px;
    padding-right: 12px;
  }
}
