/* page-specific */
.hero { padding: clamp(3.5rem, 9vh, 7rem) 0 clamp(3rem, 7vh, 5.5rem); }
.hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(2.5rem, 5vw, 6rem); align-items: center; }
.kicker { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--jbmono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--blue); background: var(--blue-tint); padding: .4rem .8rem; border-radius: 99px; margin-bottom: 1.4rem; }
.kicker .dot { width: .5rem; height: .5rem; border-radius: 50%; background: var(--green); animation: pulse 2.4s infinite; }
@keyframes pulse { 50% { opacity: .3; } }
.hero h1 { font-size: clamp(2.6rem, 5.2vw, 4.4rem); font-weight: 700; }
.hero h1 em { font-style: normal; color: var(--blue); }
.hero .lede { font-size: clamp(1.1rem, 1.5vw, 1.3rem); color: var(--ink-60); margin-top: 1.3rem; max-width: 36rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2.1rem; }
.hero-note { font-size: .85rem; color: var(--ink-40); margin-top: 1rem; }

/* ── hero demo: question → bot → answers → business card + count ── */
.hero-demo { position: relative; min-height: 560px; }
.hd-scene { position: absolute; inset: 0; opacity: 0; transition: opacity .45s ease; pointer-events: none; display: flex; flex-direction: column; gap: .9rem; }
.hd-scene.on { opacity: 1; pointer-events: auto; }
.hd-msg { max-width: 88%; border-radius: var(--radius); padding: 1rem 1.2rem; font-size: .95rem; line-height: 1.5; opacity: 0; transform: translateY(10px); transition: opacity .4s, transform .4s; }
.hd-msg.show { opacity: 1; transform: none; }
.hd-user { align-self: flex-end; background: var(--blue); color: #fff; border-bottom-right-radius: 4px; box-shadow: var(--shadow); }
.hd-user .hd-user-label { display: flex; align-items: center; gap: .45rem; font-family: var(--jbmono); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.75); margin-bottom: .5rem; }
.hd-user .hd-user-label::before { content: "?"; display: grid; place-items: center; width: 1.25rem; height: 1.25rem; border-radius: 4px; background: rgba(255,255,255,.18); color: #fff; font-size: .7rem; font-weight: 600; }
.hd-bot { align-self: flex-start; background: #fff; border: 1px solid var(--line); border-bottom-left-radius: 4px; box-shadow: var(--shadow); color: var(--ink-60); }
.hd-bot b { color: var(--ink); }
.hd-bot .hd-bot-label { display: flex; align-items: center; gap: .45rem; font-family: var(--jbmono); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--blue); margin-bottom: .5rem; }
.hd-bot .hd-bot-label::before { content: "DD"; display: grid; place-items: center; width: 1.25rem; height: 1.25rem; border-radius: 4px; background: var(--blue); color: #fff; font-size: .55rem; }
.hd-bot ol { list-style: none; counter-reset: q; margin-top: .6rem; }
.hd-bot ol li { counter-increment: q; padding: .3rem 0; opacity: 0; transform: translateY(6px); transition: opacity .35s, transform .35s; }
.hd-bot ol li::before { content: counter(q); font-family: var(--jbmono); font-size: .66rem; color: var(--blue-deep); background: var(--blue-tint); border-radius: 99px; padding: .12rem .5rem; margin-right: .55rem; }
.hd-bot ol li.show { opacity: 1; transform: none; }
.hd-answers { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: flex-end; }
.hd-chip { font-size: .85rem; font-weight: 500; color: var(--blue-deep); background: var(--blue-tint); border: 1px solid rgba(21,101,232,.25); border-radius: 99px; padding: .45rem .95rem; opacity: 0; transform: translateY(8px) scale(.95); transition: opacity .35s, transform .35s; }
.hd-chip.show { opacity: 1; transform: none; }
.hd-summary { font-family: var(--jbmono); font-size: .7rem; letter-spacing: .04em; color: var(--ink-60); background: var(--bg-soft); border: 1px solid var(--line); border-radius: 99px; padding: .5rem 1rem; align-self: center; }
.hd-summary i { font-style: normal; color: var(--green); }
.record-id { display: flex; align-items: center; gap: .75rem; }
.record-favicon { width: 2.1rem; height: 2.1rem; border-radius: 6px; border: 1px solid var(--line); background: #fff; box-shadow: 0 1px 2px rgba(19,35,58,.08); }
.hd-result .record { opacity: 0; transform: translateY(22px) scale(.96); transition: opacity .6s cubic-bezier(.2,.6,.2,1), transform .6s cubic-bezier(.2,.6,.2,1); }
.hd-result.on .record { opacity: 1; transform: none; }
.hd-count { display: flex; align-items: baseline; justify-content: center; gap: .55rem; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: .9rem 1.2rem; opacity: 0; transform: translateY(10px); transition: opacity .45s .25s, transform .45s .25s; }
.hd-result.on .hd-count { opacity: 1; transform: none; }
.hd-count b { font-family: var(--jbmono); font-size: 1.45rem; font-weight: 400; color: var(--blue-deep); }
.hd-count span { font-size: .85rem; color: var(--ink-60); }
@media (max-width: 1080px) { .hero-demo { min-height: 600px; } }
@media (prefers-reduced-motion: reduce) {
  .hd-scene, .hd-msg, .hd-bot ol li, .hd-chip, .hd-result .record, .hd-count { transition: none; }
}

.stats { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg-soft); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 1.7rem 1rem; text-align: center; }
.stat + .stat { border-left: 1px solid var(--line); }
.stat b { display: block; font-family: var(--jbmono); font-size: clamp(1.35rem, 2.4vw, 2rem); font-weight: 400; }
.stat span { font-size: .84rem; color: var(--ink-60); }

.cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.9rem 1.7rem; box-shadow: var(--shadow); transition: transform .2s, box-shadow .2s; }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.card-icon { margin-bottom: 1.1rem; }
.card h3 { font-size: 1.18rem; margin-bottom: .5rem; }
.card p { font-size: .94rem; color: var(--ink-60); }

.teaser { background: var(--bg-soft); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.teaser-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2.5rem, 5vw, 6rem); align-items: center; }
.query-mock { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-lg); overflow: hidden; }
.query-bar { display: flex; gap: .8rem; align-items: center; padding: 1rem 1.3rem; border-bottom: 1px solid var(--line); }
.query-bar .q-icon { color: var(--blue); font-family: var(--jbmono); }
.query-bar p { font-size: .95rem; font-weight: 500; }
.query-bar .caret { display: inline-block; width: 2px; height: 1.1em; background: var(--blue); vertical-align: text-bottom; animation: blink 1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
.query-resp { padding: 1.1rem 1.3rem; font-size: .9rem; color: var(--ink-60); border-bottom: 1px solid var(--line); }
.query-resp b { color: var(--ink); }
.query-result { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.3rem; background: var(--blue-tint); }
.query-result b { font-family: var(--jbmono); font-size: 1.3rem; font-weight: 400; color: var(--blue-deep); }
.query-result span { font-size: .85rem; color: var(--ink-60); }

.sets { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.set { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; transition: transform .2s, box-shadow .2s; }
.set:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.set-head { padding: 1.4rem 1.5rem .6rem; }
.set-head .mono-tag { font-family: var(--jbmono); font-size: .66rem; text-transform: uppercase; letter-spacing: .08em; color: var(--blue); }
.set h3 { font-size: 1.22rem; margin-top: .4rem; }
.set-body { padding: 0 1.5rem 1.2rem; flex: 1; }
.set-body p { font-size: .9rem; color: var(--ink-60); }
.set-count { font-family: var(--jbmono); font-size: .78rem; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 8px; padding: .55rem .8rem; margin-top: 1rem; display: flex; justify-content: space-between; }
.set-count i { font-style: normal; color: var(--green); }
.set-foot { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.5rem; border-top: 1px solid var(--line); background: var(--bg-soft); }
.set-price { font-weight: 600; }
.set-price small { display: block; font-weight: 400; font-size: .72rem; color: var(--ink-40); }

.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; counter-reset: step; }
.step { padding: 1.5rem 1.4rem; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; }
.step::before { counter-increment: step; content: counter(step); width: 1.9rem; height: 2.1rem; display: grid; place-items: center; background: var(--blue); color: #fff; font-family: var(--jbmono); font-size: .75rem; clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.step h3 { font-size: 1.08rem; margin: .5rem 0 .4rem; }
.step p { font-size: .88rem; color: var(--ink-60); }
.step .meta { display: block; font-family: var(--jbmono); font-size: .65rem; color: var(--ink-40); margin-top: .8rem; padding-top: .7rem; border-top: 1px dashed var(--line); }

.insight-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2.5rem, 5vw, 6rem); align-items: center; }
.insight-grid .chart-block { margin: 0; }

.price-band { text-align: center; }
.price-line { display: flex; justify-content: center; align-items: baseline; gap: 1.2rem; flex-wrap: wrap; margin: 1.8rem 0 .8rem; }
.price-big { font-size: clamp(2rem, 4.5vw, 3.4rem); font-weight: 700; }
.price-big small { font-size: 45%; font-weight: 500; color: var(--ink-60); }
.price-plus { font-size: 1.6rem; color: var(--ink-40); }
.price-sub { color: var(--ink-60); max-width: 38rem; margin: 0 auto; }

.cta { background: var(--blue); color: #fff; border-radius: var(--radius); padding: clamp(2.5rem, 6vw, 4.5rem); display: grid; grid-template-columns: 1.4fr 1fr; gap: 2rem; align-items: center; box-shadow: var(--shadow-lg); }
.cta h2 { font-size: clamp(1.8rem, 3.2vw, 2.6rem); }
.cta p { margin-top: .7rem; color: rgba(255,255,255,.85); }
.cta-actions { display: flex; flex-direction: column; gap: .8rem; }
.btn-white { background: #fff; color: var(--blue-deep); }
.btn-white:hover { background: var(--blue-tint); }
.btn-outline-white { border-color: rgba(255,255,255,.6); color: #fff; }
.btn-outline-white:hover { background: rgba(255,255,255,.12); }

@media (max-width: 1080px) {
  .hero-grid, .teaser-grid, .insight-grid, .cta { grid-template-columns: 1fr; }
  .cards-3, .steps, .sets { grid-template-columns: 1fr 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stat:nth-child(3) { border-left: 0; }
}
@media (max-width: 640px) { .cards-3, .steps, .sets { grid-template-columns: 1fr; } }
