/* TSQ Thank You Page v1.9.0 — leader lines + roadmap */
:root {
  --tsq-primary: #0ea5e9;
  --tsq-secondary: #22c55e;
  --tsq-accent: #f59e0b;
  --tsq-button: #65C2FF;
  --tsq-bg: #f8fafc;
  --tsq-card: rgba(255,255,255,0.97);
  --tsq-border: rgba(0,0,0,0.08);
  --tsq-text: #0b1220;
  --tsq-muted: #334155;
  --tsq-road: #d8dee9;
  --shadow-xl: 0 24px 50px rgba(12, 18, 32, 0.16);
}

.tsq-thankyou-wrap.tsq-full-bleed { width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.tsq-thankyou-wrap { position: relative; min-height: 80vh; padding: clamp(24px, 4vw, 64px); color: var(--tsq-text);
  background: radial-gradient(1000px 500px at 10% 10%, color-mix(in oklab, var(--tsq-primary) 18%, transparent), transparent 70%),
              radial-gradient(800px 400px at 90% 20%, color-mix(in oklab, var(--tsq-secondary) 16%, transparent), transparent 60%),
              radial-gradient(1000px 500px at 50% 100%, color-mix(in oklab, var(--tsq-accent) 14%, transparent), transparent 60%), var(--tsq-bg);
  overflow: hidden; font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
}
.tsq-thankyou-card { position:relative; margin:0 auto; max-width:1200px; background: linear-gradient(180deg, color-mix(in oklab, #fff 90%, transparent), color-mix(in oklab, #fff 60%, transparent)); backdrop-filter: blur(16px);
  border:1px solid var(--tsq-border); border-radius:22px; box-shadow: var(--shadow-xl); overflow:hidden; }

.tsq-thankyou-hero { padding: clamp(24px, 3vw, 40px) clamp(24px, 4vw, 48px); border-bottom: 1px solid var(--tsq-border); }
.tsq-hero-layout { display:grid; grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr); gap: 24px; align-items: stretch; }
.tsq-hero-primary { padding: 28px; border-radius: 24px; background: linear-gradient(140deg, rgba(101,194,255,0.12), rgba(14,165,233,0.08)); border:1px solid color-mix(in oklab, var(--tsq-button) 25%, #ffffff); box-shadow: 0 22px 50px rgba(12, 18, 32, 0.12); }
.tsq-hero-badge { display:inline-flex; align-items:center; justify-content:center; padding:6px 12px; border-radius:999px; font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; background:#fff; color: var(--tsq-button); border:1px solid color-mix(in oklab, var(--tsq-button) 40%, #ffffff); }
.tsq-hero-subtitle { margin: 6px 0 16px 0; color: var(--tsq-muted); font-size:15px; }
.tsq-hero-brokerage { margin-top: 14px; padding:16px; border-radius:18px; background:#fff; border:1px solid var(--tsq-border); display:flex; gap:14px; align-items:flex-start; }
.tsq-hero-brokerage-logo { width:78px; height:78px; border-radius:16px; background:#fff; border:1px solid var(--tsq-border); box-shadow: 0 10px 24px rgba(0,0,0,0.12); display:flex; align-items:center; justify-content:center; overflow:hidden; color: var(--tsq-button); font-weight:800; }
.tsq-hero-brokerage-logo img { width:100%; height:100%; object-fit:contain; padding:8px; background:#fff; }
.tsq-hero-brokerage-label { font-size:12px; text-transform:uppercase; letter-spacing:.08em; color: var(--tsq-muted); font-weight:700; }
.tsq-hero-brokerage-name { font-size:18px; font-weight:800; margin-top:2px; }
.tsq-hero-brokerage-pill { display:inline-flex; padding:4px 10px; border-radius:999px; background: color-mix(in oklab, var(--tsq-primary) 14%, #ffffff); color:#1f2937; font-size:12px; font-weight:700; margin-top:6px; }
.tsq-hero-brokerage-copy { margin:10px 0 0 0; color: var(--tsq-muted); font-size:14px; line-height:1.5; }
.tsq-hero-actions-panel { padding: 22px; border-radius: 22px; background:#fff; border:1px solid var(--tsq-border); box-shadow: 0 20px 44px rgba(12, 18, 32, 0.1); display:flex; flex-direction:column; gap:12px; }
.tsq-hero-actions-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.tsq-hero-actions-title { font-size:12px; text-transform:uppercase; letter-spacing:.12em; color: var(--tsq-muted); font-weight:700; }
.tsq-hero-actions-header p { margin:6px 0 0 0; color: var(--tsq-muted); font-size:14px; }
.tsq-hero-actions-badge { background: color-mix(in oklab, var(--tsq-secondary) 18%, #ffffff); color:#0f172a; border:1px solid color-mix(in oklab, var(--tsq-secondary) 35%, #ffffff); padding:4px 10px; border-radius:999px; font-size:12px; font-weight:700; white-space:nowrap; }
.tsq-hero-steps-grid { display:grid; gap:10px; margin-top:4px; }
.tsq-hero-step { display:grid; grid-template-columns: 28px 1fr; gap:10px; align-items:start; padding:12px; border-radius:14px; background: color-mix(in oklab, var(--tsq-bg) 92%, transparent); border:1px solid var(--tsq-border); }
.tsq-step-dot { width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; background: var(--tsq-button); color:#fff; font-weight:700; font-size:12px; }
.tsq-hero-step strong { display:block; font-size:14px; }
.tsq-hero-step p { margin:4px 0 0 0; color: var(--tsq-muted); font-size:13px; line-height:1.45; }
.tsq-hero-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }
.tsq-hero-actions-note { font-size:13px; color: var(--tsq-muted); padding:10px 12px; border-radius:12px; background: color-mix(in oklab, var(--tsq-bg) 92%, transparent); border:1px solid var(--tsq-border); }
.tsq-thankyou-title { font-size: clamp(28px, 4vw, 46px); line-height: 1.15; margin: 0 0 12px 0; font-weight: 800; letter-spacing: -0.02em; color: var(--tsq-text); }
.tsq-thankyou-subtitle { color: var(--tsq-muted); font-size: clamp(14px, 1.6vw, 18px); margin: 0 0 10px 0; display:flex; gap:8px; flex-wrap:wrap; align-items:center; line-height: 1.5; }
.tsq-thankyou-subtitle .dev-badge { display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:999px; font-weight:600; font-size:12px; background: color-mix(in oklab, var(--tsq-button) 18%, #ffffff); color:#1f2937; border:1px solid color-mix(in oklab, var(--tsq-button) 36%, #ffffff); }
.tsq-thankyou-subtitle .dev-badge svg { width: 14px; height: 14px; }
.tsq-thankyou-hero-more { display: block; width: 100%; margin-top: 4px; font-style: italic; }
.tsq-assigned-logo { width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; background: #fff; border:1px solid var(--tsq-border); box-shadow: 0 6px 18px rgba(0,0,0,0.08); overflow:hidden; color: var(--tsq-button); font-weight:800; font-size:16px; }
.tsq-assigned-logo img { width:100%; height:100%; object-fit:contain; padding:6px; }
.tsq-assigned-title { font-size:12px; text-transform:uppercase; letter-spacing:.08em; color: var(--tsq-muted); font-weight:700; }
.tsq-assigned-name { font-size:16px; font-weight:800; margin-top:2px; color: var(--tsq-text); }
.tsq-assigned-copy { margin:4px 0 0 0; color: var(--tsq-muted); font-size:14px; line-height:1.45; }
.tsq-thankyou-ref { margin: 10px 0 0 0; padding: 8px 12px; background: color-mix(in oklab, var(--tsq-bg) 92%, transparent); border-radius: 8px; font-size: 14px; color: var(--tsq-muted); border: 1px solid var(--tsq-border); }
.tsq-thankyou-ref { display: inline-flex; align-items: center; gap: 8px; }
.tsq-thankyou-ref svg { flex-shrink: 0; color: var(--tsq-button); }
.tsq-thankyou-cta { margin-top:20px; display:flex; gap:10px; flex-wrap:wrap; }
.tsq-btn { appearance:none; border:1px solid var(--tsq-border); background: rgba(127,127,127,0.07); color: var(--tsq-text); padding:10px 14px; border-radius:12px; font-weight:600; text-decoration:none; cursor:pointer; transition: transform .12s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease; box-shadow:0 6px 18px rgba(0,0,0,0.08); }
.tsq-btn-primary { display:inline-flex; align-items:center; gap:6px; background: linear-gradient(90deg, var(--tsq-button), var(--tsq-button)); border-color: transparent; color:#fff; box-shadow: 0 10px 24px rgba(101,194,255,0.35); }
.tsq-btn-primary:hover { background: linear-gradient(90deg, #4BA8E6, #4BA8E6); color:#fff; transform:translateY(-1px); }

.tsq-thankyou-summary, .tsq-thankyou-roadmap, .tsq-thankyou-faq { padding: clamp(22px, 3vw, 38px) clamp(24px, 4vw, 48px); border-bottom:1px solid var(--tsq-border); }
.tsq-recap-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; }
.tsq-recap-head p { margin:0; color: var(--tsq-muted); }
.tsq-recap-compact { display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.tsq-recap-pill { display:inline-flex; gap:6px; align-items:center; padding:8px 12px; border-radius:999px; background:#fff; border:1px solid var(--tsq-border); box-shadow: 0 10px 20px rgba(12, 18, 32, 0.08); font-size:13px; }
.tsq-recap-pill strong { text-transform:uppercase; letter-spacing:.08em; font-size:11px; color: var(--tsq-muted); }
.tsq-thankyou-details { margin-top:14px; }
.tsq-thankyou-details summary { cursor:pointer; font-weight:700; color: var(--tsq-button); list-style:none; }
.tsq-thankyou-details summary::-webkit-details-marker { display:none; }
.tsq-thankyou-details[open] summary { margin-bottom: 10px; }
.tsq-thankyou-kv { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px 18px; padding:0; margin:10px 0 0 0; list-style:none; }
.tsq-thankyou-kv li { display:flex; justify-content:space-between; align-items:center; padding:12px 14px; border:1px solid var(--tsq-border); border-radius:12px; background: color-mix(in oklab, var(--tsq-bg) 92%, transparent); }
.tsq-thankyou-kv li span:first-child { color: var(--tsq-muted); }

/* Anchored roadmap */
.tsq-thankyou-roadmap h2 { margin: 0 0 4px 0; }
.tsq-thankyou-path.with-cards { position: relative; margin-top: 32px; padding-top: 180px; padding-bottom: 260px; }
.tsq-road-svg { width:100%; display:block; overflow:visible; z-index: 1; position: relative; }
.tsq-road-svg .road { fill:none; stroke: var(--tsq-road); stroke-width: 10; stroke-linecap: round; stroke-dasharray: 14 18; }
.tsq-road-svg .pin { fill: url(#tsq-road-grad); stroke: rgba(255,255,255,0.95); stroke-width: 2; filter: drop-shadow(0 6px 12px rgba(0,0,0,0.15)); }
.tsq-road-svg .pin-label { pointer-events: none; }

@media (prefers-reduced-motion: no-preference) {
  .tsq-road-svg .road { animation: roadFlow 9s linear infinite; }
  @keyframes roadFlow { to { stroke-dashoffset: -220; } }
}

/* Leader lines layer (behind cards, above road) */
.tsq-leaders-svg { position:absolute; inset:0; z-index: 2; pointer-events:none; overflow:visible; }
.tsq-leader { fill:none; stroke: color-mix(in oklab, var(--tsq-button) 60%, #ffffff); stroke-opacity: .55; stroke-width: 2; stroke-linecap: round; stroke-dasharray: 6 8; }
@media (prefers-reduced-motion: no-preference) {
  .tsq-leader { animation: dash 7s linear infinite; }
  @keyframes dash { to { stroke-dashoffset: -160; } }
}

.road-cards { position:absolute; inset:0; pointer-events:none; z-index: 3; }
.road-card { position:absolute; width: min(260px, 24vw); background: var(--tsq-card); border-radius:16px; padding:14px 16px; pointer-events:auto; box-shadow: var(--shadow-xl); border: 1px solid color-mix(in oklab, var(--tsq-button) 32%, #ffffff); transform-origin: 50% calc(100% + 10px); opacity:0; transform: translate(-50%, -12px) scale(.96); will-change: transform, opacity; transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease; }
.road-card h3 { margin:0 0 6px 0; font-size:14.5px; font-weight:700; display:flex; align-items:center; }
.road-card h3 .tsq-card-num { display:inline-flex; align-items:center; justify-content:center; width:20px; height:20px; border-radius:50%; background: var(--tsq-button); color:#fff; font-size:11px; font-weight:700; margin-right:6px; flex-shrink:0; }
.road-card h3 .tsq-card-title { color: var(--tsq-button); }
.road-card p { margin:0; font-size:13px; color: var(--tsq-muted); }
.road-card.above { --yshift: -48px; } .road-card.below { --yshift: 48px; transform-origin: 50% -10px; }
.road-card::after { display: none !important; content: ""; }
.road-card.reveal { opacity:1; transform: translate(-50%, var(--yshift, -12px)) scale(1); transition: opacity .5s ease, transform .6s cubic-bezier(.2,.8,.2,1); }
.road-card:hover { transform: translate(-50%, var(--yshift, -12px)) scale(1.03) rotateZ(-.3deg); box-shadow: 0 28px 56px rgba(12, 18, 32, 0.2); }

/* Timeframe badge */
.tsq-step-timeframe { display:inline-block; padding:2px 8px; border-radius:999px; font-size:11px; font-weight:600; letter-spacing:.02em; background:color-mix(in oklab, var(--tsq-accent) 18%, #ffffff); color:#92400e; border:1px solid color-mix(in oklab, var(--tsq-accent) 35%, #ffffff); }
.road-card .tsq-step-timeframe { display:block; width:fit-content; margin:2px 0 4px 0; }
.vertical-steps .tsq-step-timeframe { display:inline-block; margin-bottom:4px; font-size:12px; }

/* Total timeline subtitle */
.tsq-roadmap-total-timeline { display:inline-flex; align-items:center; gap:6px; margin:4px 0 0 0; padding:5px 14px; border-radius:999px; font-size:13px; font-weight:600; background:color-mix(in oklab, var(--tsq-accent) 12%, #ffffff); color:#92400e; border:1px solid color-mix(in oklab, var(--tsq-accent) 25%, #ffffff); position:relative; z-index:4; }
.tsq-roadmap-total-timeline svg { flex-shrink:0; }

/* Mobile vertical roadmap */
.tsq-vertical-roadmap { display:none; margin-top: 0; padding-top: 8px; }
.vertical-steps { position:relative; list-style:none; margin:0; padding:0; }
.vertical-steps li { display:grid; grid-template-columns: 26px 1fr; column-gap: 12px; align-items:start; margin: 18px 0; }
.vertical-steps li:first-child { margin-top: 0; }
.vertical-steps .dot { width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:#fff; background: var(--tsq-button); box-shadow: 0 2px 8px rgba(0,0,0,.15); position:relative; z-index:1; }
.vertical-steps h4 { margin:0 0 4px 0; font-size:16px; }
.vertical-steps p { margin:0; font-size:14px; color: var(--tsq-muted); grid-column: 2; }
.vertical-steps li.current h4 { color: var(--tsq-button); }
.vertical-steps::before { content:""; position:absolute; left:12px; top:0; bottom:0; width:2px; background: var(--tsq-road); }

/* Approval notice */
.tsq-approval-notice { 
  display: flex; 
  align-items: flex-start; 
  gap: 12px; 
  margin-top: 24px; 
  padding: 16px 18px; 
  background: linear-gradient(135deg, rgba(101, 194, 255, 0.08) 0%, rgba(14, 165, 233, 0.08) 100%);
  border-left: 3px solid var(--tsq-button);
  border-radius: 8px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--tsq-text);
}
.tsq-approval-notice svg { 
  flex-shrink: 0; 
  margin-top: 2px; 
  color: var(--tsq-button); 
}
.tsq-approval-notice strong { 
  color: var(--tsq-button); 
  font-weight: 700; 
}

/* FAQ + sticky + footer */
.tsq-thankyou-faq { border-bottom: none; }
.tsq-thankyou-faq details { border:1px solid var(--tsq-border); border-radius:12px; padding:12px 14px; background: color-mix(in oklab, var(--tsq-bg) 92%, transparent); margin:8px 0; }
.tsq-thankyou-footer { padding: clamp(18px, 3vw, 28px) clamp(24px, 4vw, 48px); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; background: color-mix(in oklab, var(--tsq-bg) 92%, transparent); border-top: 1px solid var(--tsq-border); font-size: 14px; }
.tsq-thankyou-footer .left { color: var(--tsq-muted); }
.tsq-thankyou-footer .right a { color: var(--tsq-button); text-decoration: none; font-weight: 600; }
.tsq-thankyou-ref { margin: 8px 0 0 0; font-size: 14px; color: var(--tsq-muted); }
.tsq-thankyou-hero-more { font-style: italic; }
.tsq-thankyou-emoji { font-size: 1.2em; margin-right: 0.2em; }
.tsq-thankyou-disclaimer { margin-top: 16px; font-size: 13px; color: var(--tsq-muted); font-style: italic; }
.tsq-ft-brand { color: #65C2FF; font-weight: 700; }

.tsq-sticky-actions { position: sticky; bottom: 0; display: none; gap: 10px; padding: 10px; background: linear-gradient(180deg, transparent, color-mix(in oklab, var(--tsq-bg) 70%, transparent)); border-top: 1px solid var(--tsq-border); }
.tsq-sticky-btn { flex:1; display:inline-block; text-align:center; padding:12px 14px; border-radius:12px; font-weight:700; text-decoration:none; }
.tsq-sticky-btn.call { background: var(--tsq-button); color:#fff; }
.tsq-sticky-btn.call:hover { background: #4BA8E6; color:#fff; }
.tsq-sticky-btn.schedule { background: color-mix(in oklab, var(--tsq-primary) 18%, #fff); color:#111827; }

/* Confetti */
.tsq-confetti { position:fixed; inset:0; pointer-events:none; overflow:hidden; z-index: 2147483647; }
.tsq-confetti i { position:absolute; width:8px; height:14px; opacity:0.9; top:-20px; background:var(--tsq-primary); transform: translateY(-100px) rotate(0deg); animation: fall linear forwards; }
@keyframes fall { to { transform: translateY(calc(100vh + 40px)) rotate(720deg); opacity:1; } }

/* Responsive */
@media (max-width: 1150px) {
  .tsq-thankyou-path.with-cards { display:none; }
  .tsq-vertical-roadmap { display:block; } 
  .tsq-thankyou-hero { padding: 20px 24px; }
  .tsq-thankyou-title { font-size: clamp(24px, 5vw, 32px); margin-bottom: 10px; }
  .tsq-thankyou-subtitle { flex-direction: column; align-items: flex-start; gap: 6px; }
  .tsq-thankyou-hero-more { margin-top: 2px; }
  .tsq-hero-layout { grid-template-columns: 1fr; }
  .tsq-hero-primary { padding:20px; }
}
@media (max-width: 680px) { 
  .tsq-thankyou-kv { grid-template-columns: 1fr; } 
  .tsq-sticky-actions { display:flex; } 
  .tsq-thankyou-footer { flex-direction: column; text-align: center; } 
  .tsq-thankyou-cta { gap: 8px; }
  .tsq-btn { font-size: 14px; padding: 10px 12px; }
  .tsq-hero-brokerage-logo { width:70px; height:70px; }
}

