/* Pricing page — extends landing.css tokens */

/* ─── HERO ─── */
.pr-hero {
  padding: 100px 40px 60px;
  text-align: center;
  background:
    radial-gradient(700px 400px at 50% 20%, rgba(0,231,255,.10), transparent 70%),
    var(--bg);
  border-bottom: 1px solid var(--line);
}
.pr-hero-inner { max-width: 800px; margin: 0 auto; }
.pr-hero h1 {
  font-size: 76px;
  font-weight: 900;
  letter-spacing: -.04em;
  line-height: 1.05;
  margin: 16px 0 24px;
}
.pr-hero p {
  font-size: 18px;
  color: var(--ink-2);
  line-height: 1.6;
  margin: 0 0 40px;
}

.pr-toggle {
  display: inline-flex;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 999px;
  padding: 4px;
  gap: 4px;
}
.pr-toggle button {
  background: transparent;
  border: 0;
  color: var(--ink-2);
  padding: 10px 22px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -.01em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.pr-toggle button.active {
  background: var(--accent);
  color: #001318;
}
.pr-toggle button small {
  font-size: 11px;
  font-weight: 800;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(0, 231, 255, .2);
  color: var(--accent);
  letter-spacing: .04em;
}
.pr-toggle button.active small {
  background: rgba(0, 0, 0, .2);
  color: #001318;
}

/* ─── 4 TIER CARDS ─── */
.pr-tiers {
  background: var(--bg-light);
  color: var(--ink-light);
  border-radius: 60px 60px 0 0;
  margin-top: -40px;
  position: relative;
  z-index: 1;
  padding-top: 80px;
}
.pr-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.tier {
  background: #fff;
  border-radius: 22px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  border: 1px solid rgba(0,0,0,.06);
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease;
}
.tier:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 40px rgba(0,0,0,.08);
}
.tier-feat {
  background: #0d0d10;
  color: var(--ink);
  border-color: var(--accent);
  box-shadow: 0 16px 40px rgba(0, 231, 255, .15);
}
.tier-feat:hover { box-shadow: 0 28px 56px rgba(0, 231, 255, .25); }
.tier.tier-feat h3, .tier.tier-feat .tier-price .amt, .tier.tier-feat .tier-list .head { color: var(--ink); }
.tier.tier-feat .tier-price .amt small { color: var(--ink-2); }
.tier.tier-feat .tier-h p, .tier.tier-feat .cycle, .tier.tier-feat .tier-tag { color: var(--ink-2); }
.tier-feat .tier-list li { color: var(--ink-2); border-color: var(--line); }
.tier-feat .tier-list li b { color: var(--accent); }
.tier-feat .tier-list li.off { color: var(--ink-4); }

.tier-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent);
  color: #001318;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .15em;
  padding: 6px 16px;
  border-radius: 999px;
  text-transform: uppercase;
  white-space: nowrap;
  z-index: 2;
}

.tier-h {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 130px;
  justify-content: flex-start;
}
.tier-tag {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .2em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.tier h3 {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -.02em;
  margin: 0;
  color: #0d0d10;
  line-height: 1.25;
}
.tier-h p {
  margin: 2px 0 0;
  font-size: 13px;
  color: #4a4d54;
  letter-spacing: -.01em;
  line-height: 1.4;
}

.tier-price {
  padding: 16px 0;
  border-top: 1px dashed rgba(0,0,0,.1);
  border-bottom: 1px dashed rgba(0,0,0,.1);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-height: 104px;
  justify-content: center;
}
.tier-cta { min-height: 46px; }
.tier-feat .tier-price { border-color: var(--line-2); }
.tier-price .amt {
  font-size: 36px;
  font-weight: 900;
  letter-spacing: -.03em;
  line-height: 1;
  color: #0d0d10;
}
.tier-price .amt small {
  font-size: 16px;
  font-weight: 700;
  color: #4a4d54;
  margin-left: 4px;
  letter-spacing: -.01em;
}
.tier-price .cycle {
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 600;
  letter-spacing: -.01em;
}

.tier-cta {
  display: block;
  text-align: center;
  padding: 13px;
  border-radius: 12px;
  background: #f3f5f7;
  color: #0d0d10;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -.01em;
  transition: background .15s ease;
}
.tier-cta:hover { background: #e7ebef; }
.tier-cta.primary {
  background: var(--accent);
  color: #001318;
  font-size: 15px;
  padding: 16px;
  font-weight: 800;
  min-height: 52px;
  box-shadow: 0 8px 24px rgba(0, 231, 255, .35);
}
.tier-cta.primary:hover { filter: brightness(1.08); box-shadow: 0 12px 32px rgba(0, 231, 255, .45); }
.tier-feat .tier-cta { background: rgba(255,255,255,.08); color: var(--ink); }
.tier-feat .tier-cta:hover { background: rgba(255,255,255,.12); }
.tier-feat .tier-cta.primary { background: var(--accent); color: #001318; }

/* ─── STARTER tier accent ─── */
.tier-starter {
  background: linear-gradient(180deg, #c7eff5 0%, #e6f9fc 60%, #ffffff 100%);
  border-color: var(--accent);
  box-shadow: 0 12px 32px rgba(0, 231, 255, .18);
}
.tier-starter:hover { box-shadow: 0 24px 48px rgba(0, 231, 255, .28); }
.tier-starter .tier-tag { color: #006975; }
.tier-starter .tier-price { border-color: rgba(0, 231, 255, .35); }
.tier-badge-starter {
  background: linear-gradient(135deg, #ff7ab6 0%, #e54a8e 100%) !important;
  color: #fff !important;
}
.tier-badge-deep {
  background: linear-gradient(135deg, #4a5cbe 0%, #2b3a8f 100%) !important;
  color: #fff !important;
}

/* ─── ELITE BLACK tier variant ─── */
.tier-elite {
  background: linear-gradient(180deg, #15171c 0%, #0a0b0e 100%);
  color: var(--ink);
  border-color: #2d2a22;
  position: relative;
}
.tier-elite::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(400px 200px at 80% -10%, rgba(212,165,72,.15), transparent 60%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.015) 0 1px, transparent 1px 14px);
  pointer-events: none;
}
.tier-elite > *:not(.tier-badge) { position: relative; z-index: 1; }
.tier.tier-elite h3, .tier.tier-elite .amt { color: #fff; }
.tier.tier-elite .tier-h p, .tier.tier-elite .cycle, .tier.tier-elite .tier-tag { color: var(--ink-2); }.tier-elite .tier-price { border-color: rgba(212,165,72,.18); }
.tier-elite .tier-price .amt small { color: var(--ink-2); }
.tier-elite .tier-list li { color: var(--ink-2); }
.tier-elite .tier-list li b { color: #d4a548; }
.tier-elite .tier-list li.off { color: #555548; }
.tier-elite .tier-list li.head { color: #d4a548; }

.tier-cta-gold {
  background: linear-gradient(135deg, #e6b656 0%, #b87f1c 100%) !important;
  color: #1a1206 !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  padding: 16px !important;
  min-height: 52px !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 24px rgba(212, 165, 72, .35) !important;
}
.tier-cta-gold:hover { filter: brightness(1.08); box-shadow: 0 12px 32px rgba(212, 165, 72, .45) !important; }

.tier-badge-gold {
  background: linear-gradient(135deg, #d4a548 0%, #b07f1f 100%) !important;
  color: #1a1206 !important;
}

/* ─── Recommended targets (이런 사장님께 추천) ─── */
.tier-for {
  margin-top: auto;
  padding: 16px;
  background: #f3f5f7;
  border-radius: 12px;
}
.tier-feat .tier-for {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.06);
}
.tier-elite .tier-for {
  background: rgba(212,165,72,.06);
  border: 1px solid rgba(212,165,72,.15);
}
.tier-for-h {
  font-size: 11px;
  font-weight: 800;
  color: var(--ink-3);
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.tier-feat .tier-for-h { color: var(--accent); }
.tier-elite .tier-for-h { color: #d4a548; }
.tier-for ul {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.tier-for li {
  position: relative;
  padding-left: 16px;
  font-size: 12.5px;
  line-height: 1.55;
  color: #4a4d54;
  letter-spacing: -.005em;
}
.tier-for li::before {
  content: '"';
  position: absolute;
  left: 0; top: -2px;
  font-size: 18px;
  font-weight: 900;
  color: var(--accent);
  line-height: 1;
}
.tier-for li b { color: #0d0d10; font-weight: 800; }
.tier-feat .tier-for li { color: var(--ink-2); }
.tier-feat .tier-for li b { color: var(--ink); }
.tier-elite .tier-for li { color: var(--ink-2); }
.tier-elite .tier-for li b { color: #fff; }
.tier-elite .tier-for li::before { color: #d4a548; }

/* ─── Compare table — gold column for Elite ─── */
.compare-tbl thead th.gold {
  background: linear-gradient(180deg, #1a1612, #0d0a08);
  color: #d4a548;
}
.compare-tbl thead th.gold::after {
  content: '풀패키지';
  display: block;
  margin-top: 4px;
  font-size: 10px;
  letter-spacing: .2em;
  color: #d4a548;
}
.compare-tbl thead th.gold small { color: var(--ink-3); }
.compare-tbl tbody td.gold {
  background: rgba(212,165,72,.06);
  color: #0d0d10;
  font-weight: 700;
}
.compare-tbl tbody td.gold b { color: #b07f1f; }

.compare-note {
  margin-top: 18px;
  font-size: 12.5px;
  color: var(--ink-3);
  letter-spacing: -.005em;
  text-align: center;
}

.tier-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.tier-list li {
  position: relative;
  padding-left: 22px;
  font-size: 13px;
  line-height: 1.5;
  color: #4a4d54;
}
.tier-list li.head {
  padding-left: 0;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.tier-list li.head:first-child { margin-top: 0; }
.tier-list li:not(.head)::before {
  content: '';
  position: absolute;
  left: 0; top: 5px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: rgba(0, 231, 255, .12);
  border: 1.5px solid var(--accent);
}
.tier-list li:not(.head)::after {
  content: '✓';
  position: absolute;
  left: 3px; top: 2px;
  font-size: 9px;
  color: var(--accent);
  font-weight: 900;
}
.tier-list li.off { color: #b5b8bf; }
.tier-list li.off::before { background: transparent; border-color: #d0d3d8; }
.tier-list li.off::after { content: '×'; color: #b5b8bf; font-size: 13px; top: 0; left: 2.5px; }
.tier-list li b { color: #0d0d10; font-weight: 800; }

/* ─── COMPARE TABLE ─── */
.pr-compare {
  background: var(--bg-light);
  color: var(--ink-light);
}
.pr-compare .display { color: #0d0d10; }
.compare-wrap { margin-top: 40px; overflow-x: auto; }
.compare-tbl {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.06);
  font-size: 13.5px;
}
.compare-tbl thead th {
  padding: 22px 20px;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -.01em;
  text-align: center;
  color: #0d0d10;
  background: #f3f5f7;
  border-bottom: 2px solid rgba(0,0,0,.06);
}
.compare-tbl thead th.feat { text-align: left; background: #fff; width: 28%; }
.compare-tbl thead th.hi {
  background: #0d0d10;
  color: var(--accent);
  position: relative;
}
.compare-tbl thead th.hi::after {
  content: '인기';
  display: block;
  margin-top: 4px;
  font-size: 10px;
  letter-spacing: .2em;
  color: var(--accent);
}
.compare-tbl thead th small {
  display: block;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink-3);
  margin-top: 4px;
  letter-spacing: -.01em;
}
.compare-tbl thead th.hi small { color: var(--ink-3); }
.compare-tbl tbody td {
  padding: 14px 20px;
  border-bottom: 1px solid rgba(0,0,0,.05);
  text-align: center;
  color: #4a4d54;
}
.compare-tbl tbody td:first-child { text-align: left; font-weight: 600; color: #0d0d10; }
.compare-tbl tbody td.hi { background: rgba(0,231,255,.05); color: #0d0d10; font-weight: 700; }
.compare-tbl tbody td.hi b { color: var(--accent); }
.compare-tbl tbody tr:last-child td { border-bottom: 0; }
.compare-tbl tr td.grp {
  background: #0d0d10;
  color: var(--accent);
  text-align: left;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: 10px 20px;
}

/* ─── FAQ ─── */
.pr-faq {
  background: var(--bg);
  border-radius: 60px 60px 0 0;
  margin-top: -40px;
  position: relative;
  padding-top: 100px;
}
.faq-list { margin-top: 40px; display: flex; flex-direction: column; gap: 10px; max-width: 920px; }
.faq {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 24px;
  transition: border-color .15s ease;
}
.faq[open] { border-color: var(--accent); }
.faq summary {
  cursor: pointer;
  list-style: none;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -.015em;
  color: var(--ink);
  position: relative;
  padding-right: 28px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: '＋';
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  color: var(--accent);
  font-size: 22px;
  font-weight: 400;
  transition: transform .2s ease;
}
.faq[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq p {
  margin: 14px 0 0;
  color: var(--ink-2);
  font-size: 14px;
  line-height: 1.65;
  letter-spacing: -.005em;
}
