/* ===========================================================
   Aifit — refined card UI (loaded last; enriches base cards)
   =========================================================== */

/* ---------- Reasons cards ---------- */
.rcard {
  overflow: hidden;
  background: linear-gradient(180deg, #fff 0%, var(--lav) 140%);
  border: 1px solid var(--line-soft);
  border-top: 3px solid var(--purple);
  border-radius: 18px;
  padding: clamp(1.5rem, 2.2vw, 2rem) clamp(1.4rem, 2vw, 1.8rem) clamp(1.6rem, 2.2vw, 2rem);
}
.rcard-watermark {
  position: absolute; top: -0.18em; right: 0.12em; z-index: 0;
  font-family: var(--mincho); font-weight: 700; font-size: 6rem; line-height: 1;
  color: var(--lav-2); letter-spacing: -0.02em; pointer-events: none;
  transition: color .35s;
}
.rcard-ic {
  position: relative; z-index: 1;
  width: 3.1rem; height: 3.1rem; border-radius: 15px;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(140deg, var(--lav-2), #fff);
  color: var(--purple);
  box-shadow: 0 10px 22px -12px rgba(124,107,166,.5), inset 0 0 0 1px rgba(124,107,166,.12);
  margin-bottom: 1rem;
  transition: background .35s, color .35s, transform .35s;
}
.rcard-ic .ic { width: 1.6rem; height: 1.6rem; }
.rcard-kicker {
  position: relative; z-index: 1; display: block;
  font-size: 0.64rem; font-weight: 700; letter-spacing: .2em; color: var(--gold-deep);
  margin-bottom: 0.45rem;
}
.rcard-title { position: relative; z-index: 1; }
.rcard-desc { position: relative; z-index: 1; }
.rcard:hover { transform: translateY(-6px); box-shadow: 0 30px 56px -28px rgba(124,107,166,.55); border-color: var(--purple); }
.rcard:hover .rcard-watermark { color: color-mix(in srgb, var(--purple) 16%, var(--lav-2)); }
.rcard:hover .rcard-ic { background: linear-gradient(140deg, var(--purple), var(--purple-deep)); color: #fff; transform: translateY(-2px); }

/* ---------- Plans cards ---------- */
.pcard {
  position: relative; overflow: visible;
  background: linear-gradient(180deg, #fff, var(--lav) 160%);
  border: 1px solid var(--line);
  border-radius: 18px;
}
.pcard-top { display: flex; flex-direction: column; }
.pcard-people {
  align-self: flex-start;
  background: linear-gradient(135deg, var(--lav-2), #fff);
  box-shadow: inset 0 0 0 1px rgba(124,107,166,.14);
  color: var(--purple-deep);
}
.pcard-name { letter-spacing: .01em; }
.pcard-note { color: var(--text); }
.pcard-price {
  margin-top: 0.4rem;
  background: linear-gradient(135deg, var(--lav), #fff);
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  padding: 0.9rem 1rem;
}
.pcard-member { display: inline-flex; align-items: center; gap: 0.35em; }
.pcard-member .ic { width: 0.9em; height: 0.9em; color: var(--purple); }
.pcard-num { display: flex; align-items: baseline; }
.pcard-cta { background: #fff; }
.pcard:hover { transform: translateY(-6px); box-shadow: 0 30px 56px -28px rgba(124,107,166,.55); border-color: var(--purple); }

/* featured plan */
.pcard--featured {
  border: 1.6px solid var(--purple);
  box-shadow: 0 26px 54px -26px rgba(124,107,166,.6);
}
.pcard--featured .pcard-price { background: linear-gradient(135deg, var(--lav-3), var(--lav)); border-color: color-mix(in srgb, var(--purple) 30%, transparent); }
.pcard--featured .pcard-num { color: var(--purple-deep); }
.pcard-flag {
  position: absolute; top: -0.85rem; left: 50%; transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: 0.35em; white-space: nowrap;
  font-size: 0.72rem; font-weight: 700; color: var(--purple-ink);
  background: linear-gradient(135deg, #EFE2BC, var(--gold) 55%, var(--gold-deep));
  padding: 0.45em 1.05em; border-radius: 999px;
  box-shadow: 0 10px 22px -8px rgba(159,130,56,.6), inset 0 1px 0 rgba(255,255,255,.5);
}
.pcard-flag .ic { width: 0.95em; height: 0.95em; color: #fff; }

/* plan card photo header */
.pcard { padding: 0; overflow: hidden; position: relative; }
.pcard-media { position: relative; aspect-ratio: 16/9.5; overflow: hidden; background: var(--lav-2); }
.pcard-media image-slot { display: block; width: 100%; height: 100%; transition: transform .55s ease; }
.pcard:hover .pcard-media image-slot { transform: scale(1.05); }
.pcard-media image-slot::part(empty) { background: linear-gradient(140deg, var(--lav-2), var(--lav-3)); color: var(--purple); }
.pcard-media-scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(to top, rgba(47,41,66,.34), transparent 52%); }
.pcard-media .pcard-people { position: absolute; left: 0.85rem; bottom: 0.75rem; z-index: 2; box-shadow: 0 8px 18px -8px rgba(0,0,0,.55); }
.pcard-body { display: flex; flex-direction: column; flex: 1; padding: 1.05rem clamp(1.2rem, 1.8vw, 1.5rem) clamp(1.2rem, 1.8vw, 1.5rem); }
.pcard-flag { z-index: 3; top: 0.8rem; left: auto; right: 0.8rem; transform: none; }
.pcard--featured .pcard-media-scrim { background: linear-gradient(to top, rgba(47,41,66,.34), transparent 52%), linear-gradient(to bottom, rgba(47,41,66,.18), transparent 36%); }

/* ---------- Journey cards ---------- */
.jcard { border-radius: 18px; }
.jcard-media { position: relative; overflow: hidden; }
.jcard-media-scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(to top, rgba(47,41,66,.55) 0%, rgba(47,41,66,.05) 50%, transparent 100%);
}
.jcard-tag {
  position: absolute; left: 0.9rem; bottom: 0.85rem; z-index: 2;
  display: inline-flex; align-items: center;
  font-size: 0.72rem; font-weight: 700; color: #fff; letter-spacing: .02em;
  background: var(--node, var(--purple)); padding: 0.4em 0.95em; border-radius: 999px;
  box-shadow: 0 8px 18px -8px color-mix(in srgb, var(--node) 70%, transparent);
}
.jcard-index {
  position: absolute; top: 0.5rem; right: 0.95rem; z-index: 2;
  font-family: var(--mincho); font-weight: 700; font-size: 1.5rem; color: rgba(255,255,255,.92);
  text-shadow: 0 2px 12px rgba(47,41,66,.5);
}
.jcard-body { gap: 0; }
.jcard-title { margin-top: 0.1rem; }
.jcard-more {
  position: static; width: auto; height: auto; border-radius: 0; background: none;
  display: inline-flex; align-items: center; gap: 0.55em; margin-top: 1rem;
  font-weight: 700; font-size: 0.86rem; color: var(--node, var(--purple-deep));
}
.jcard-more-arr {
  width: 1.9rem; height: 1.9rem; border-radius: 50%;
  background: var(--lav-2); color: var(--node, var(--purple));
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .3s, color .3s, transform .3s;
}
.jcard-more-arr .ic { width: 0.95em; height: 0.95em; }
.jcard:hover .jcard-more-arr { background: var(--node, var(--purple)); color: #fff; transform: translateX(3px); }

/* ---------- Support cards (dark band) ---------- */
.scard {
  background: linear-gradient(180deg, #fff, var(--lav) 170%);
  border: 1px solid rgba(255,255,255,.06);
}
.scard-ic {
  background: linear-gradient(140deg, var(--lav-2), var(--lav-3));
  box-shadow: inset 0 0 0 1px rgba(124,107,166,.14);
  transition: background .3s, color .3s, transform .3s;
}
.scard:hover .scard-ic { background: linear-gradient(140deg, var(--purple), var(--purple-deep)); color: #fff; transform: translateY(-2px); }
.scard-arr { transition: background .3s, color .3s; }
.scard:hover .scard-arr { background: var(--purple); color: #fff; }

/* ---------- Worry cards ---------- */
.worry {
  background: linear-gradient(180deg, #fff, var(--lav) 170%);
  border: 1px solid var(--line-soft);
  position: relative; overflow: hidden;
}
.worry::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(var(--purple), var(--purple-deep)); opacity: .5;
}
.worry-ic {
  background: linear-gradient(140deg, var(--lav-2), #fff);
  box-shadow: inset 0 0 0 1px rgba(124,107,166,.12);
}

/* ---------- Notes cards ---------- */
.ncard { background: linear-gradient(180deg, #fff, var(--lav) 170%); }
.ncard-badge {
  background: linear-gradient(135deg, var(--lav-2), var(--lav-3));
  color: var(--purple-deep);
}
.ncard::before {
  content: ""; display: block; width: 2.2rem; height: 2.2rem; margin-bottom: 0.9rem;
  border-radius: 12px; background: linear-gradient(140deg, var(--lav-2), #fff);
  box-shadow: inset 0 0 0 1px rgba(124,107,166,.12);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 3.5h7l3.5 3.5V20.5H7Z'/%3E%3Cpath d='M14 3.5V7h3.5M9.5 12h5M9.5 15.5h5'/%3E%3C/svg%3E") center / 1.3rem no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 3.5h7l3.5 3.5V20.5H7Z'/%3E%3Cpath d='M14 3.5V7h3.5M9.5 12h5M9.5 15.5h5'/%3E%3C/svg%3E") center / 1.3rem no-repeat;
  display: none;
}

/* ---------- Chat mode cards ---------- */
.cmode { background: linear-gradient(180deg, #fff, color-mix(in srgb, var(--node) 6%, #fff) 180%); }
.cmode-ic { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--node) 22%, transparent); }

/* ---------- Voice cards ---------- */
.vcard {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, #fff, var(--lav) 160%);
  border: 1px solid var(--line-soft);
  padding-top: 2.2rem;
}
.vcard::before {
  content: "\201C"; position: absolute; top: 0.1rem; left: 1.1rem;
  font-family: var(--mincho); font-size: 3.4rem; line-height: 1; color: var(--lav-3);
  pointer-events: none;
}
.vcard--real { background: linear-gradient(180deg, #fff, var(--gold-tint) 200%); }
.vcard--real::before { color: color-mix(in srgb, var(--gold) 45%, var(--lav-3)); }
