/* ============================================================
   Component · Plan Card
   Selectors: .plan-card  +  modifiers
   Modifiers: plan-card--free | plan-card--featured
   Sub-elements: __ribbon __head __price __duration __features
                 __feature-item __cta __preview
   ============================================================ */

.plan-card {
  position: relative;
  display: flex;
  flex-direction: column;
  scroll-margin-top: 180px;
  background: var(--gio-color-surface);
  border: 1px solid var(--gio-color-border);
  border-radius: var(--gio-radius-2xl);
  padding: var(--gio-space-7);
  transition:
    border-color var(--gio-dur-med) var(--gio-ease-out),
    box-shadow var(--gio-dur-med) var(--gio-ease-out),
    transform var(--gio-dur-med) var(--gio-ease-out);
}

.plan-card:hover {
  border-color: var(--gio-color-border-strong);
  box-shadow: var(--gio-shadow-md);
}

.plan-card:target {
  border-color: var(--gio-color-action);
  box-shadow: 0 0 0 4px var(--gio-color-action-soft), var(--gio-shadow-lg);
}

.plan-card:target::before {
  content: 'Selected plan';
  position: absolute;
  top: -12px;
  left: var(--gio-space-5);
  z-index: 1;
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 var(--gio-space-3);
  background: var(--gio-color-action);
  color: var(--gio-color-text-on-action);
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  border-radius: var(--gio-radius-pill);
}

/* Featured — amber accent border + ribbon */
.plan-card--featured {
  border: 2px solid var(--gio-color-accent);
  box-shadow: var(--gio-shadow-md);
}
.plan-card--featured:hover {
  box-shadow: var(--gio-shadow-lg);
  transform: translateY(-2px);
}

.plan-card__ribbon {
  position: absolute;
  top: -1px;
  right: 24px;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 var(--gio-space-3);
  background: var(--gio-color-accent);
  color: var(--gio-color-text-on-accent);
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  border-radius: var(--gio-radius-pill);
}

.plan-card__head {
  display: flex;
  flex-direction: column;
  gap: var(--gio-space-2);
  margin-bottom: var(--gio-space-5);
}
.plan-card__type {
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-semibold);
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  color: var(--gio-color-text-muted);
}
.plan-card--featured .plan-card__type { color: var(--gio-color-accent-strong); }
.plan-card__name {
  font-size: var(--gio-text-2xl);
  line-height: var(--gio-text-2xl-lh);
  font-weight: var(--gio-w-bold);
  color: var(--gio-color-text-strong);
  letter-spacing: var(--gio-tracking-tight);
  margin: 0;
}
.plan-card__tagline {
  font-size: var(--gio-text-sm);
  line-height: var(--gio-text-sm-lh);
  color: var(--gio-color-text-muted);
  margin: 0;
}

/* Price block */
.plan-card__price-row {
  display: flex;
  align-items: baseline;
  gap: var(--gio-space-2);
  margin-bottom: var(--gio-space-1);
}
.plan-card__price {
  font-family: var(--gio-font-display);
  font-size: var(--gio-text-4xl);
  line-height: 1;
  font-weight: var(--gio-w-extrabold);
  color: var(--gio-color-text-strong);
  letter-spacing: var(--gio-tracking-tight);
}
.plan-card__price-suffix {
  font-size: var(--gio-text-sm);
  color: var(--gio-color-text-muted);
  font-weight: var(--gio-w-medium);
}
.plan-card__duration {
  font-size: var(--gio-text-sm);
  color: var(--gio-color-text-muted);
  margin-bottom: var(--gio-space-5);
}

/* Subtitle — one-line pitch, slightly muted */
.plan-card__sub {
  font-size: var(--gio-text-sm);
  color: var(--gio-color-text-muted);
  margin-bottom: var(--gio-space-5);
}

/* Adaptive highlight — FLEX flagship, replaces the static counts strip */
.plan-card__adaptive {
  display: flex;
  flex-direction: column;
  gap: var(--gio-space-3);
  padding: var(--gio-space-4);
  border-radius: var(--gio-radius-md);
  border: 1px solid var(--gio-color-accent-soft);
  background:
    radial-gradient(120% 120% at 100% 0%, color-mix(in srgb, var(--gio-color-accent) 12%, transparent), transparent 60%),
    var(--gio-color-bg-subtle);
  background-clip: padding-box;
}
.plan-card__adaptive-tag {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-bold);
  text-transform: uppercase;
  letter-spacing: var(--gio-tracking-wide);
  color: var(--gio-color-accent-strong);
  background: var(--gio-color-surface);
  border: 1px solid var(--gio-color-accent-soft);
  padding: 3px 10px;
  border-radius: var(--gio-radius-pill);
}
.plan-card__adaptive-spark { font-size: 1em; line-height: 1; }
.plan-card__adaptive-lead {
  margin: 0;
  font-size: var(--gio-text-sm);
  line-height: var(--gio-text-sm-lh);
  color: var(--gio-color-text-strong);
  font-weight: var(--gio-w-medium);
}
.plan-card__adaptive-stats {
  display: flex;
  gap: var(--gio-space-5);
}
.plan-card__adaptive-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.plan-card__adaptive-num {
  font-size: var(--gio-text-lg);
  font-weight: var(--gio-w-bold);
  color: var(--gio-color-accent-strong);
  letter-spacing: var(--gio-tracking-tight);
}
.plan-card__adaptive-cap {
  font-size: var(--gio-text-xs);
  color: var(--gio-color-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--gio-tracking-wide);
  font-weight: var(--gio-w-semibold);
}
.plan-card__adaptive-skills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.plan-card__adaptive-skills span {
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-semibold);
  color: var(--gio-color-accent-strong);
  background: var(--gio-color-accent-soft);
  padding: 3px 9px;
  border-radius: var(--gio-radius-pill);
}

/* Counts strip — small breakdown of included content */
.plan-card__counts {
  display: flex;
  gap: var(--gio-space-4);
  padding: var(--gio-space-4);
  background: var(--gio-color-bg-subtle);
  border-radius: var(--gio-radius-md);
  margin-bottom: var(--gio-space-5);
}
.plan-card__count {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}
.plan-card__count-value {
  font-size: var(--gio-text-lg);
  font-weight: var(--gio-w-bold);
  color: var(--gio-color-text-strong);
  letter-spacing: var(--gio-tracking-default);
}
.plan-card__count-label {
  font-size: var(--gio-text-xs);
  color: var(--gio-color-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--gio-tracking-wide);
  font-weight: var(--gio-w-semibold);
}

/* Feature list */
.plan-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--gio-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--gio-space-2);
}
.plan-card__feature-item {
  display: flex;
  align-items: flex-start;
  gap: var(--gio-space-3);
  font-size: var(--gio-text-sm);
  line-height: var(--gio-text-sm-lh);
  color: var(--gio-color-text);
}
.plan-card__feature-icon {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  margin-top: 2px;
  border-radius: 50%;
  background: var(--gio-color-action-soft);
  color: var(--gio-color-action);
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: var(--gio-w-bold);
}
.plan-card--featured .plan-card__feature-icon {
  background: var(--gio-color-accent-soft);
  color: var(--gio-color-accent-strong);
}

.plan-card__cta { margin-top: auto; }

/* Inline contents preview (hover/expand) — store·main·dashboard 공통 */
.plan-contents {
  margin-top: 0;
  border-top: 1px solid var(--gio-color-divider);
}
.plan-contents__preview {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--gio-space-3);
  background: transparent;
}
.plan-contents__preview-item {
  display: flex;
  align-items: center;
  gap: var(--gio-space-2);
  min-width: 0;
  font-size: var(--gio-text-xs);
  color: var(--gio-color-text);
}
.plan-contents__preview-item > span:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.plan-contents__toggle {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px var(--gio-space-3);
  background: transparent;
  border: 0;
  border-top: 1px dashed var(--gio-color-divider);
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-semibold);
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  color: var(--gio-color-text-muted);
  cursor: pointer;
}
.plan-contents__toggle::after {
  content: '+';
  font-size: 14px;
  color: var(--gio-color-action);
}
.plan-contents__list {
  list-style: none;
  padding: var(--gio-space-3);
  margin: 0;
  display: none;
  flex-direction: column;
  gap: 6px;
}
.plan-contents__list li {
  display: flex;
  align-items: center;
  gap: var(--gio-space-2);
  font-size: var(--gio-text-xs);
  color: var(--gio-color-text);
}
.plan-contents.is-open .plan-contents__list { display: flex; }
.plan-contents.is-open .plan-contents__preview { display: none; }
.plan-contents.is-open .plan-contents__toggle::after { content: '−'; }
.plan-contents__type {
  flex: 0 0 auto;
  font-size: 10px;
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  font-weight: var(--gio-w-bold);
  padding: 2px 6px;
  border-radius: var(--gio-radius-xs);
  background: var(--gio-color-bg-subtle);
  color: var(--gio-color-text-muted);
}

/* Inventory panel + features separator — store·main·dashboard 공통 */
.plan-card__inventory {
  overflow: hidden;
  background: var(--gio-color-bg-subtle);
  border: 1px solid var(--gio-color-divider);
  border-radius: var(--gio-radius-md);
}
.plan-card__inventory .plan-card__counts {
  background: transparent;
  border-radius: 0;
  margin-bottom: 0;
}
.plan-card--compact .plan-card__features {
  border-top: 1px solid var(--gio-color-divider);
  padding-top: var(--gio-space-4);
  margin-top: var(--gio-space-4);
}
