/* ==========================================================================
   IdeaSweetSpot — PAYWALL styles  ·  Apps 4 That Studio
   In-context upsell blocks · the pricing menu overlay · price cards · toast.
   Uses the canonical iss-theme tokens + Sora display face. On-brand, calm,
   no fake scarcity. Loaded after the tool CSS so it can layer cleanly.
   ========================================================================== */

/* ----------------------------------------------------------- upsell block -- */
.iss-upsell {
  margin: 1.1rem 0;
  padding: 1.15rem 1.2rem 1.2rem;
  border: 1px solid var(--iss-accent-line, #D8D0FF);
  border-radius: 16px;
  background:
    linear-gradient(180deg, var(--iss-accent-soft, #ECE9FF) 0%, var(--iss-n-25, #FBFCFE) 100%);
  box-shadow: var(--iss-shadow-sm, 0 1px 2px rgba(15,23,42,.06));
  position: relative;
}
.iss-upsell--compact { padding: .85rem .95rem .95rem; margin: .8rem 0; }

.iss-upsell__badge {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .74rem; font-weight: 700; letter-spacing: .02em;
  color: var(--iss-accent-ink, #5B43E0);
  background: var(--iss-n-0, #fff);
  border: 1px solid var(--iss-accent-line, #D8D0FF);
  padding: .26rem .6rem; border-radius: 999px;
  margin-bottom: .55rem;
}
.iss-upsell__badge svg { color: var(--iss-accent-ink, #5B43E0); }

.iss-upsell__title {
  font-family: var(--iss-font-display, "Sora", sans-serif);
  font-weight: 700; font-size: 1.06rem; line-height: 1.2;
  color: var(--iss-ink, #0F172A); margin: 0 0 .3rem;
}
.iss-upsell__body {
  margin: 0 0 .85rem; color: var(--iss-n-700, #334155);
  font-size: .92rem; line-height: 1.5; max-width: 60ch;
}
.iss-upsell--compact .iss-upsell__title { font-size: .98rem; }
.iss-upsell--compact .iss-upsell__body { font-size: .86rem; margin-bottom: .65rem; }

.iss-upsell__actions { display: flex; flex-wrap: wrap; gap: .55rem; align-items: center; }
.iss-upsell__cta { white-space: nowrap; }

/* a locked stage/section host can dim its content behind the upsell */
.iss-locked-preview { position: relative; }
.iss-locked-preview .iss-locked-veil {
  pointer-events: none;
  -webkit-user-select: none; user-select: none;
  opacity: .45; filter: saturate(.55);
  max-height: 220px; overflow: hidden;
  -webkit-mask-image: linear-gradient(180deg, #000 30%, transparent 100%);
          mask-image: linear-gradient(180deg, #000 30%, transparent 100%);
}

/* --------------------------------------------------------- pricing overlay - */
.iss-menu-overlay {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: flex-start; justify-content: center;
  padding: clamp(1rem, 4vw, 3rem) 1rem;
  background: rgba(15, 23, 42, .55);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  overflow-y: auto;
}
.iss-menu-overlay[hidden] { display: none; }
body.iss-menu-open { overflow: hidden; }

.iss-menu-wrap {
  width: min(960px, 100%);
  background: var(--iss-surface, #fff);
  border: 1px solid var(--iss-n-200, #E2E7F0);
  border-radius: 22px;
  box-shadow: var(--iss-shadow-lg, 0 24px 60px rgba(15,23,42,.22));
  padding: clamp(1.2rem, 3vw, 2rem);
  margin: auto;
}

.iss-menu-bar { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.iss-menu-eyebrow {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .78rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  color: var(--iss-accent-ink, #5B43E0); margin: 0 0 .35rem;
}
#iss-menu-h {
  font-family: var(--iss-font-display, "Sora", sans-serif);
  font-weight: 800; font-size: clamp(1.3rem, 3vw, 1.75rem); line-height: 1.15;
  color: var(--iss-ink, #0F172A); margin: 0;
}
.iss-menu-lede {
  color: var(--iss-n-700, #334155); font-size: .96rem; line-height: 1.55;
  margin: .7rem 0 1.3rem; max-width: 66ch;
}
.iss-close {
  flex: 0 0 auto; appearance: none; border: 1px solid var(--iss-n-200, #E2E7F0);
  background: var(--iss-n-25, #FBFCFE); color: var(--iss-n-700, #334155);
  width: 38px; height: 38px; border-radius: 11px; font-size: 1.5rem; line-height: 1;
  cursor: pointer;
}
.iss-close:hover { background: var(--iss-n-100, #EEF1F7); }
.iss-close:focus-visible { outline: 3px solid var(--iss-accent-ink, #5B43E0); outline-offset: 2px; }

/* ------------------------------------------------------------- price grid -- */
.iss-pricegrid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
}
@media (max-width: 760px) { .iss-pricegrid { grid-template-columns: 1fr; } }

.iss-pricecard {
  display: flex; flex-direction: column;
  border: 1px solid var(--iss-n-200, #E2E7F0); border-radius: 18px;
  background: var(--iss-n-0, #fff); padding: 1.25rem 1.2rem 1.3rem;
  position: relative;
}
.iss-pricecard.is-featured {
  border-color: var(--iss-accent, #7C5CFF);
  box-shadow: 0 0 0 1px var(--iss-accent, #7C5CFF), var(--iss-shadow, 0 8px 24px rgba(15,23,42,.10));
}
.iss-pricecard.is-current { background: var(--iss-accent-soft, #ECE9FF); }
.iss-pricecard__ribbon {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  background: var(--iss-ink, #23262F); color: #fff;
  font-size: .7rem; font-weight: 800; letter-spacing: .03em; text-transform: uppercase;
  padding: .25rem .7rem; border-radius: 999px; white-space: nowrap;
}
.iss-pricecard__head { display: flex; align-items: baseline; justify-content: space-between; gap: .5rem; }
.iss-pricecard__name {
  font-family: var(--iss-font-display, "Sora", sans-serif);
  font-weight: 800; font-size: 1.2rem; margin: 0; color: var(--iss-ink, #0F172A);
}
.iss-pricecard__tag { font-size: .72rem; font-weight: 700; color: var(--iss-n-500, #64748B); }
.iss-pricecard__price { display: flex; align-items: baseline; gap: .4rem; margin: .5rem 0 .15rem; }
.iss-pricecard__price b {
  font-family: var(--iss-font-display, "Sora", sans-serif);
  font-weight: 800; font-size: 2rem; color: var(--iss-ink, #0F172A);
}
.iss-pricecard__price span { font-size: .82rem; color: var(--iss-n-500, #64748B); font-weight: 600; }
.iss-pricecard__sub { font-size: .86rem; color: var(--iss-n-700, #334155); line-height: 1.45; margin: .35rem 0 .9rem; }

.iss-pricecard__list { list-style: none; margin: 0 0 1.1rem; padding: 0; display: grid; gap: .5rem; flex: 1; }
.iss-pricecard__list li { display: flex; align-items: flex-start; gap: .5rem; font-size: .88rem; line-height: 1.4; color: var(--iss-n-700, #334155); }
.iss-pricecard__list svg { flex: 0 0 auto; margin-top: .12rem; color: var(--iss-accent-ink, #4F6B3E); }

.iss-pricecard__own {
  text-align: center; font-size: .85rem; font-weight: 700;
  color: var(--iss-accent-ink, #5B43E0);
  background: var(--iss-accent-soft, #ECE9FF);
  border-radius: 11px; padding: .65rem; margin-top: auto;
}
.btn--block { width: 100%; justify-content: center; }

.iss-menu-fine { font-size: .76rem; color: var(--iss-n-500, #64748B); line-height: 1.5; margin: 1.1rem 0 0; max-width: 80ch; }
.iss-menu-fine--ai { margin-top: .5rem; }

/* ------------------------------------------------------------------ toast -- */
.iss-pay-toast {
  position: fixed; left: 50%; bottom: 24px; transform: translate(-50%, 12px);
  background: var(--iss-ink, #0F172A); color: #fff;
  font-size: .9rem; font-weight: 600;
  padding: .7rem 1.1rem; border-radius: 12px;
  box-shadow: var(--iss-shadow-lg, 0 24px 60px rgba(15,23,42,.22));
  opacity: 0; pointer-events: none; z-index: 1100;
  transition: opacity .2s ease, transform .2s ease;
  max-width: min(90vw, 460px);
}
.iss-pay-toast.is-shown { opacity: 1; transform: translate(-50%, 0); }

/* ------------------------------------------------ "Plans" header entry ----- */
.iss-plans-link {
  display: inline-flex; align-items: center; gap: .35rem;
}

@media (prefers-reduced-motion: reduce) {
  .iss-pay-toast { transition: opacity .2s ease; transform: translate(-50%, 0); }
}

/* ==========================================================================
   LOCKED BRIEF PREVIEW — the free "see your brief" moment.
   Shows the real head + scores + verdict, then the value of the full brief
   behind the upsell. Never a dead end.
   ========================================================================== */
.ss-brief-lock {
  margin-top: 1.2rem;
  padding: 1.2rem 1.2rem 1.3rem;
  border-radius: 18px;
  border: 1px solid var(--iss-n-200, #E7E0D2);
  background:
    linear-gradient(180deg, rgba(255,253,247,.6), rgba(234,243,228,.5)),
    var(--iss-paper, #FFFDF7);
}
.ss-brief-lock__lead {
  margin: 0 0 .8rem;
  font-weight: 700;
  color: var(--iss-ink, #23262F);
}
.ss-brief-lock__list {
  list-style: none; margin: 0 0 1.1rem; padding: 0;
  display: grid; gap: .5rem;
}
.ss-brief-lock__list li {
  display: flex; align-items: flex-start; gap: .5rem;
  font-size: .95rem; line-height: 1.45;
  color: var(--iss-n-700, #3C3A33);
}
.ss-brief-lock__list li svg { flex: 0 0 auto; margin-top: .18rem; color: var(--iss-moss, #6F8F5B); }
