/* Harga (Pricing) page — ported from design/harga.html <style> (final-cta in common.css). */

.price-intro { padding-top: clamp(40px, 5vw, 72px); padding-bottom: 24px; }
.price-intro-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: end; }
@media (max-width: 820px) { .price-intro-grid { grid-template-columns: 1fr; } }

.currency-toggle {
  display: inline-flex; gap: 4px; padding: 4px;
  border: 1px solid var(--line); background: var(--paper);
  border-radius: var(--r-full); margin-top: 24px;
}
.currency-btn {
  padding: 8px 16px; border-radius: var(--r-full); background: transparent; border: none; cursor: pointer;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-soft);
  transition: background 0.15s, color 0.15s;
}
.currency-btn.is-active { background: var(--ink); color: var(--paper); }

.price-cards-section { padding-top: 24px; }
.price-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: stretch; }
.price-card {
  display: flex; flex-direction: column; gap: 24px; padding: 32px;
  background: var(--paper); border: 1px solid var(--line-soft); border-radius: var(--r-lg);
}
.price-card-feature { background: var(--ink); color: var(--paper); border-color: var(--ink); transform: translateY(-8px); }
.price-card-feature h2, .price-card-feature .price { color: var(--paper); }
.price-card-feature .price-unit, .price-card-feature .price-desc, .price-card-feature .price-list { color: color-mix(in oklab, var(--paper) 76%, transparent); }
.price-card-feature .feature-kbd { color: var(--accent-soft); }
.price-card-feature .price-list li::before { color: var(--accent-soft); }
.price-tag h2 { font-size: 1.5rem; margin: 8px 0 16px; }
.price-line { display: flex; align-items: baseline; gap: 8px; margin-bottom: 12px; }
.price { font-family: var(--serif); font-size: 2.6rem; letter-spacing: -0.02em; color: var(--ink); }
.price-unit { font-family: var(--mono); font-size: 11.5px; color: var(--ink-mute); letter-spacing: 0.04em; }
.price-desc { color: var(--ink-soft); font-size: 14.5px; }
.price-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; flex: 1; color: var(--ink-soft); font-size: 14.5px; }
.price-list li { padding-left: 22px; position: relative; }
.price-list li::before { content: "—"; position: absolute; left: 0; color: var(--accent); }
@media (max-width: 900px) {
  .price-cards { grid-template-columns: 1fr; }
  .price-card-feature { transform: none; }
}

.group-section { background: var(--paper); border-block: 1px solid var(--line-soft); }
.group-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(32px, 5vw, 64px); align-items: center; }
.group-card { background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 32px; }
.group-row { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.group-row .kbd { margin-right: auto; color: var(--accent); }
.group-price { font-family: var(--serif); font-size: 2.8rem; letter-spacing: -0.02em; }
.group-unit { color: var(--ink-mute); font-family: var(--mono); font-size: 11.5px; }
.group-features { list-style: none; padding: 16px 0 24px; margin: 0; display: flex; flex-direction: column; gap: 8px; color: var(--ink-soft); font-size: 14.5px; }
.group-features li { padding-left: 22px; position: relative; }
.group-features li::before { content: "—"; position: absolute; left: 0; color: var(--accent); }
@media (max-width: 820px) { .group-grid { grid-template-columns: 1fr; } }

.includes-grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.includes-grid li {
  display: grid; grid-template-columns: 32px 1fr; gap: 14px; align-items: start; padding: 20px;
  border: 1px solid var(--line-soft); border-radius: var(--r-md); background: var(--paper);
}
.inc-mark { width: 28px; height: 28px; border-radius: 50%; background: var(--moss); color: var(--paper); display: grid; place-items: center; font-size: 14px; }
.includes-grid strong { display: block; font-weight: 500; }
.includes-grid p { font-size: 13.5px; color: var(--ink-soft); margin-top: 2px; }
@media (max-width: 820px) { .includes-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .includes-grid { grid-template-columns: 1fr; } }

.future-card {
  display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(32px, 5vw, 64px); align-items: center;
  padding: 48px; background: var(--paper-2); border: 1px dashed var(--line); border-radius: var(--r-xl);
}
.future-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px; }
.future-right svg { width: 100%; height: auto; max-width: 320px; }
@media (max-width: 820px) { .future-card { grid-template-columns: 1fr; padding: 32px 24px; } }
