/* ============================================================
   trade-pages.css — shared styles for AI visual quote landing pages
   under /trades/. Scoped under .trade-page so nothing leaks into
   the rest of the site. Designed to feel native to the existing
   D2 theme (Inter font, #0071e3 accent, 20px card radius, light
   #f5f5f7 background).
   ============================================================ */

.trade-page {
  --tp-bg: #f5f5f7;
  --tp-white: #fff;
  --tp-dark: #0a0a0c;
  --tp-text: #1d1d1f;
  --tp-text2: #515154;
  --tp-text3: #86868b;
  --tp-accent: #0071e3;
  --tp-accent-soft: rgba(0,113,227,.08);
  --tp-accent-dark: #0058b0;
  --tp-border: rgba(0,0,0,.08);
  --tp-border2: rgba(0,0,0,.05);
  --tp-radius: 20px;
  --tp-radius-sm: 12px;
  --tp-shadow-1: 0 1px 2px rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.04);
  --tp-shadow-2: 0 4px 24px rgba(0,0,0,.08);
  --tp-shadow-cta: 0 8px 32px rgba(0,113,227,.35);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--tp-text);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

.trade-page * { box-sizing: border-box; }

/* ----- Section wrapper ----- */
.trade-section {
  max-width: 1100px;
  margin: 0 auto;
  padding: 64px 32px;
}
.trade-section--narrow { max-width: 880px; }
.trade-section--tight { padding-top: 32px; padding-bottom: 32px; }

.trade-eyebrow {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--tp-accent);
  background: var(--tp-accent-soft);
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 20px;
}

.trade-page h1 {
  font-size: clamp(34px, 5.6vw, 56px);
  font-weight: 800;
  letter-spacing: -.035em;
  line-height: 1.05;
  margin: 0 0 20px;
  color: var(--tp-text);
}
.trade-page h2 {
  font-size: clamp(26px, 3.4vw, 36px);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.15;
  margin: 0 0 16px;
}
.trade-page h3 {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -.01em;
  margin: 0 0 8px;
}
.trade-page p {
  font-size: 17px;
  color: var(--tp-text2);
  margin: 0 0 14px;
}
.trade-page p.lead {
  font-size: 19px;
  line-height: 1.55;
  color: var(--tp-text2);
}

/* ----- Buttons ----- */
.trade-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 26px;
  border-radius: 999px;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -.01em;
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  cursor: pointer;
  border: 0;
  white-space: nowrap;
}
.trade-btn--primary {
  background: var(--tp-accent);
  color: #fff;
  box-shadow: var(--tp-shadow-cta);
}
.trade-btn--primary:hover {
  background: var(--tp-accent-dark);
  transform: translateY(-1px);
  text-decoration: none;
}
.trade-btn--secondary {
  background: #fff;
  color: var(--tp-text);
  border: 1px solid var(--tp-border);
}
.trade-btn--secondary:hover {
  border-color: rgba(0,0,0,.18);
  text-decoration: none;
}
.trade-btn--ghost-light {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,.32);
}
.trade-btn--ghost-light:hover {
  background: rgba(255,255,255,.08);
  text-decoration: none;
}

/* ----- Hero ----- */
.trade-hero {
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(0,113,227,.08), transparent 60%),
    radial-gradient(1000px 500px at 110% 0%, rgba(0,113,227,.05), transparent 55%),
    linear-gradient(180deg, #fafafc 0%, #f5f5f7 100%);
  border-bottom: 1px solid var(--tp-border);
  padding-top: 96px; /* clear fixed nav */
}
.trade-hero__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 48px 32px 72px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.trade-hero__content { min-width: 0; }
.trade-hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}
.trade-hero__visual {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius);
  padding: 14px;
  box-shadow: var(--tp-shadow-2);
}

/* ----- Feature strip (under hero) ----- */
.trade-feature-strip {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 32px 56px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.trade-feature-strip__item {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius-sm);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: var(--tp-shadow-1);
}
.trade-feature-strip__icon {
  width: 36px; height: 36px;
  background: var(--tp-accent-soft);
  color: var(--tp-accent);
  border-radius: 10px;
  display: grid; place-items: center;
  flex-shrink: 0;
  font-size: 18px;
}
.trade-feature-strip__label {
  font-size: 14.5px;
  font-weight: 600;
  color: var(--tp-text);
  line-height: 1.3;
}

/* ----- Before / After gallery ----- */
.before-after-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
}
.before-after-card {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius);
  padding: 24px;
  box-shadow: var(--tp-shadow-1);
}
.before-after-card__title {
  font-size: 16px;
  font-weight: 600;
  color: var(--tp-text);
  margin: 0 0 14px;
  letter-spacing: -.01em;
}
.before-after-image-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.before-after-image-group figure {
  margin: 0;
  display: flex;
  flex-direction: column;
}
.before-after-image-group img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--tp-radius-sm);
  border: 1px solid var(--tp-border2);
  background: #f0f0f3;
}
.before-after-card__caption {
  font-size: 14.5px;
  color: var(--tp-text2);
  margin-top: 14px;
  line-height: 1.55;
}

/* Image debug label — visible review pill, removable. */
.image-debug-label {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff;
  background: #0a0a0c;
  padding: 5px 10px;
  border-radius: 999px;
  margin-bottom: 8px;
  align-self: flex-start;
}
.image-debug-label--after { background: var(--tp-accent); }

/* Hero before/after block (used inside .trade-hero__visual) */
.trade-hero__visual .before-after-image-group { gap: 12px; }
.trade-hero__visual .before-after-image-group img { aspect-ratio: 4 / 3; }
.trade-hero__visual .image-debug-label {
  font-size: 10px;
  padding: 4px 9px;
}

/* ----- Customer hesitation / problem / why-visual sections ----- */
.trade-customer-hesitation,
.trade-problem,
.trade-why-visual {
  max-width: 880px;
  margin: 0 auto;
  padding: 56px 32px;
}
.trade-customer-hesitation { background: var(--tp-bg); }
.trade-customer-hesitation .trade-callout {
  background: var(--tp-white);
  border-left: 4px solid var(--tp-accent);
  border-radius: var(--tp-radius-sm);
  padding: 24px 28px;
  margin-top: 20px;
  box-shadow: var(--tp-shadow-1);
  font-size: 17px;
  line-height: 1.6;
  color: var(--tp-text);
}

/* ----- Steps ----- */
.trade-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  counter-reset: step;
}
.trade-steps__item {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius);
  padding: 28px 22px;
  position: relative;
  box-shadow: var(--tp-shadow-1);
}
.trade-steps__item::before {
  counter-increment: step;
  content: counter(step);
  position: absolute;
  top: -14px; left: 22px;
  width: 32px; height: 32px;
  background: var(--tp-accent);
  color: #fff;
  border-radius: 999px;
  display: grid; place-items: center;
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(0,113,227,.35);
}
.trade-steps__title {
  font-size: 16px;
  font-weight: 700;
  margin: 8px 0 6px;
}
.trade-steps__copy {
  font-size: 14.5px;
  color: var(--tp-text2);
  line-height: 1.55;
}

/* ----- E-signature section ----- */
.trade-esignature {
  background: linear-gradient(180deg, #fafafc 0%, #f5f5f7 100%);
  border-top: 1px solid var(--tp-border);
  border-bottom: 1px solid var(--tp-border);
}
.trade-esignature__inner {
  max-width: 980px;
  margin: 0 auto;
  padding: 64px 32px;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  align-items: center;
}
.trade-esignature__flow {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius);
  padding: 28px;
  box-shadow: var(--tp-shadow-2);
}
.trade-esignature__step {
  display: flex;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--tp-border2);
  align-items: flex-start;
}
.trade-esignature__step:last-child { border-bottom: 0; }
.trade-esignature__num {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 999px;
  background: var(--tp-accent-soft);
  color: var(--tp-accent);
  display: grid; place-items: center;
  font-weight: 700;
  font-size: 13px;
}
.trade-esignature__step h4 {
  font-size: 15px;
  font-weight: 700;
  margin: 0 0 2px;
  color: var(--tp-text);
}
.trade-esignature__step p {
  font-size: 14px;
  color: var(--tp-text2);
  margin: 0;
}

/* ----- Feature card grid ----- */
.trade-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 28px;
}
.trade-feature-card {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius);
  padding: 26px 24px;
  box-shadow: var(--tp-shadow-1);
  transition: box-shadow .2s, transform .2s;
}
.trade-feature-card:hover {
  box-shadow: var(--tp-shadow-2);
  transform: translateY(-2px);
}
.trade-feature-card__icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--tp-accent-soft);
  color: var(--tp-accent);
  display: grid; place-items: center;
  font-size: 20px;
  margin-bottom: 14px;
}
.trade-feature-card h3 {
  font-size: 16px;
  margin-bottom: 6px;
}
.trade-feature-card p {
  font-size: 14.5px;
  margin: 0;
  color: var(--tp-text2);
  line-height: 1.55;
}

/* ----- ROI block ----- */
.trade-roi {
  background: var(--tp-bg);
}
.trade-roi__inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 56px 32px;
}
.trade-roi__box {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius);
  padding: 32px 36px;
  box-shadow: var(--tp-shadow-1);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.trade-roi__box p {
  font-size: 17.5px;
  color: var(--tp-text);
  line-height: 1.55;
  margin: 0;
}
.trade-roi__box .price-line {
  font-size: 14px;
  color: var(--tp-text3);
}

/* ----- Common exclusions ----- */
.trade-exclusions {
  max-width: 980px;
  margin: 0 auto;
  padding: 56px 32px;
}
.trade-exclusions__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 28px;
  margin-top: 20px;
  padding: 0;
  list-style: none;
}
.trade-exclusions__list li {
  font-size: 15px;
  color: var(--tp-text2);
  padding-left: 22px;
  position: relative;
  line-height: 1.55;
}
.trade-exclusions__list li::before {
  content: "";
  position: absolute;
  left: 0; top: 9px;
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--tp-accent);
}
.trade-exclusions__note {
  font-size: 14px;
  color: var(--tp-text3);
  margin-top: 18px;
  font-style: italic;
}

/* ----- FAQ (uses native <details>) ----- */
.trade-faq {
  max-width: 880px;
  margin: 0 auto;
  padding: 56px 32px;
}
.trade-faq__item {
  background: var(--tp-white);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius-sm);
  margin-bottom: 12px;
  overflow: hidden;
  box-shadow: var(--tp-shadow-1);
}
.trade-faq__item summary {
  cursor: pointer;
  list-style: none;
  padding: 18px 22px;
  font-size: 16px;
  font-weight: 600;
  color: var(--tp-text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.trade-faq__item summary::-webkit-details-marker { display: none; }
.trade-faq__item summary::after {
  content: "+";
  font-weight: 400;
  font-size: 22px;
  color: var(--tp-accent);
  transition: transform .2s;
  flex-shrink: 0;
}
.trade-faq__item[open] summary::after { content: "−"; }
.trade-faq__item-body {
  padding: 0 22px 20px;
  font-size: 15.5px;
  color: var(--tp-text2);
  line-height: 1.6;
}

/* AI illustrative caveat block */
.trade-ai-caveat {
  background: #fff8e6;
  border: 1px solid #ffe7a8;
  border-left: 4px solid #d99a00;
  border-radius: var(--tp-radius-sm);
  padding: 16px 20px;
  margin: 20px 0;
  font-size: 14.5px;
  line-height: 1.6;
  color: #6b4500;
}
.trade-ai-caveat strong { color: #4d3200; }

/* ----- Try-the-demo push (between gallery and why-visual) ----- */
.trade-demo-push {
  background:
    radial-gradient(800px 400px at 90% 110%, rgba(0,113,227,.10), transparent 60%),
    radial-gradient(600px 300px at 5% -10%, rgba(0,113,227,.06), transparent 55%),
    linear-gradient(180deg, #f7f9fd 0%, #eef3fb 100%);
  border-top: 1px solid var(--tp-border);
  border-bottom: 1px solid var(--tp-border);
}
.trade-demo-push__inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 64px 32px;
  text-align: center;
}
.trade-demo-push__pill {
  display: inline-block;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--tp-accent);
  background: rgba(0,113,227,.10);
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 18px;
}
.trade-demo-push h2 {
  margin-bottom: 14px;
}
.trade-demo-push p {
  font-size: 17px;
  color: var(--tp-text2);
  max-width: 620px;
  margin: 0 auto 22px;
  line-height: 1.6;
}
.trade-demo-push .trade-btn {
  font-size: 17px;
  padding: 16px 32px;
}
.trade-demo-push__note {
  font-size: 13.5px;
  color: var(--tp-text3);
  margin: 16px auto 0 !important;
}
.trade-demo-push__learn {
  display: block;
  font-size: 14px;
  color: var(--tp-accent);
  text-decoration: none;
  margin-top: 8px;
  font-weight: 500;
}
.trade-demo-push__learn:hover { text-decoration: underline; }

@media (max-width: 720px) {
  .trade-demo-push__inner { padding: 48px 20px; }
  .trade-demo-push .trade-btn { width: 100%; }
}

/* ----- Final CTA ----- */
.trade-cta {
  background: var(--tp-dark);
  color: #fff;
  padding: 72px 32px;
  text-align: center;
}
.trade-cta__inner { max-width: 720px; margin: 0 auto; }
.trade-cta h2 {
  color: #fff;
  font-size: clamp(28px, 4vw, 38px);
  margin-bottom: 14px;
}
.trade-cta p {
  color: rgba(255,255,255,.72);
  font-size: 17px;
  margin-bottom: 28px;
}
.trade-cta__row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}
.trade-cta__small {
  font-size: 13px;
  color: rgba(255,255,255,.5);
  margin-top: 18px;
}

/* ----- Last reviewed stamp ----- */
.trade-last-reviewed {
  text-align: center;
  font-size: 13px;
  color: var(--tp-text3);
  padding: 32px 24px;
}

/* ----- Cross-link "see also" block ----- */
.trade-seealso {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 32px 56px;
}
.trade-seealso__box {
  background: #f0f4fa;
  border: 1px solid rgba(0,113,227,.18);
  border-radius: var(--tp-radius-sm);
  padding: 18px 22px;
  font-size: 14.5px;
  color: var(--tp-text2);
  line-height: 1.55;
}
.trade-seealso__box a {
  color: var(--tp-accent);
  font-weight: 600;
  text-decoration: none;
}
.trade-seealso__box a:hover { text-decoration: underline; }

/* ============================================================
   Demo modal — iframe popup of /10/index12.html
   Loads when [data-demo-modal] link is clicked. Falls back to
   plain navigation if JS fails. Attached by /trade-demo-modal.js.
   ============================================================ */
.tq-demo-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  background: rgba(10,10,12,.78);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: tq-demo-fadein .18s ease-out;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
.tq-demo-modal.is-open { display: flex; }
.tq-demo-modal__panel {
  background: #fff;
  border-radius: 20px;
  width: min(1100px, 100%);
  height: min(840px, 100%);
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.tq-demo-modal__bar {
  height: 52px;
  background: #fafafc;
  border-bottom: 1px solid rgba(0,0,0,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 14px 0 20px;
  flex-shrink: 0;
}
.tq-demo-modal__title {
  font-size: 14.5px;
  font-weight: 600;
  color: #1d1d1f;
  letter-spacing: -.005em;
}
.tq-demo-modal__title span {
  font-weight: 400;
  color: #6e6e73;
  font-size: 13px;
  margin-left: 8px;
}
.tq-demo-modal__close {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: transparent;
  border: 0;
  font-size: 22px;
  font-weight: 400;
  color: #1d1d1f;
  cursor: pointer;
  display: grid;
  place-items: center;
  line-height: 1;
  transition: background .15s;
}
.tq-demo-modal__close:hover { background: rgba(0,0,0,.06); }
.tq-demo-modal__iframe {
  flex: 1;
  width: 100%;
  border: 0;
  display: block;
  background: #f5f5f7;
}
@keyframes tq-demo-fadein {
  from { opacity: 0; }
  to { opacity: 1; }
}
@media (max-width: 720px) {
  .tq-demo-modal { padding: 0; }
  .tq-demo-modal__panel { width: 100%; height: 100%; border-radius: 0; }
}

/* ============================================================
   Responsive — tablet
   ============================================================ */
@media (max-width: 1024px) {
  .trade-hero__inner { grid-template-columns: 1fr; gap: 36px; }
  .trade-hero__visual { max-width: 640px; margin: 0 auto; }
  .trade-feature-strip { grid-template-columns: repeat(3, 1fr); }
  .trade-steps { grid-template-columns: repeat(2, 1fr); }
  .trade-feature-grid { grid-template-columns: repeat(2, 1fr); }
  .trade-esignature__inner { grid-template-columns: 1fr; }
}

/* ============================================================
   Responsive — mobile
   ============================================================ */
@media (max-width: 720px) {
  .trade-section,
  .trade-customer-hesitation,
  .trade-problem,
  .trade-why-visual,
  .trade-exclusions,
  .trade-faq { padding: 44px 20px; }
  .trade-hero { padding-top: 80px; }
  .trade-hero__inner { padding: 32px 20px 56px; }
  .trade-feature-strip { padding: 0 20px 40px; grid-template-columns: 1fr; gap: 10px; }
  .trade-roi__inner { padding: 44px 20px; }
  .trade-roi__box { padding: 24px 22px; }
  .trade-cta { padding: 56px 22px; }
  .before-after-image-group { grid-template-columns: 1fr; gap: 14px; }
  .before-after-image-group img { aspect-ratio: 4 / 3; }
  .trade-steps { grid-template-columns: 1fr; gap: 16px; }
  .trade-feature-grid { grid-template-columns: 1fr; }
  .trade-exclusions__list { grid-template-columns: 1fr; }
  .trade-hero__cta-row .trade-btn,
  .trade-cta__row .trade-btn { flex: 1 1 auto; min-width: 0; }
  .trade-seealso { padding: 0 20px 44px; }
}

/* ============================================================
   Print styles — clean PDF print of any page
   ============================================================ */
@media print {
  .trade-hero { padding-top: 24px; background: none; }
  .trade-hero__cta-row,
  .trade-cta,
  .trade-seealso { display: none; }
  .before-after-image-group { grid-template-columns: 1fr 1fr; }
  .trade-page { font-size: 12pt; }
}
