/* ==========================================================================
   Flow screens: check / payment / report
   ========================================================================== */
.flow { display: grid; gap: 16px; }

.flow__bar { display: flex; align-items: center; gap: 14px 18px; padding: 12px 14px 12px 18px; flex-wrap: wrap; }
.flow__back { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 13px; color: var(--ink-soft); white-space: nowrap; }
.flow__back:hover { color: var(--brand-ink); }
.flow__query { display: inline-flex; align-items: center; gap: 11px; padding: 7px 8px 7px 16px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--line); }
.flow__query-label { font-size: 10px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); }
.flow__query-val { font-family: var(--font-display); font-weight: 800; font-size: 1.04rem; letter-spacing: 0.04em; color: var(--ink); }
.flow__query-type { font-size: 10px; font-weight: 800; letter-spacing: 0.06em; color: var(--on-brand); background: var(--grad); padding: 5px 11px; border-radius: 999px; }
.flow__search { display: flex; gap: 9px; flex: 1; min-width: 260px; max-width: 460px; margin-left: auto; }
.flow__search .input { flex: 1; }
.flow__search .btn { white-space: nowrap; }
@media (max-width: 720px) { .flow__search { max-width: none; flex-basis: 100%; } }

.flow__grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 16px; align-items: start; }
@media (max-width: 960px) { .flow__grid { grid-template-columns: 1fr; } }

.preview__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.preview__body { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 22px; align-items: start; }
@media (max-width: 560px) { .preview__body { grid-template-columns: 1fr; } }

.purchase { display: grid; gap: 18px; align-content: start; }
.purchase__price { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.purchase__price strong { font-family: var(--font-display); font-size: 3rem; line-height: 0.9; letter-spacing: -0.02em; color: var(--ink); white-space: nowrap; }
.decide { display: grid; gap: 10px; }
.decide__row { display: flex; gap: 12px; align-items: flex-start; padding: 14px 15px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--surface-2); }
.decide__row .led { margin-top: 6px; }
.decide__row strong { display: block; font-size: 0.9rem; font-weight: 800; }
.decide__row .micro { display: block; }
.purchase__actions { display: grid; gap: 10px; }

/* payment */
.pay { display: grid; gap: 22px; }
.pay__hero { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.pay__badges { display: grid; gap: 8px; justify-items: end; }
.pay__grid { display: grid; grid-template-columns: 1fr 0.92fr; gap: 16px; align-items: start; }
@media (max-width: 960px) { .pay__grid { grid-template-columns: 1fr; } }

.order { display: grid; gap: 16px; align-content: start; }
.order__top { display: grid; grid-template-columns: 130px 1fr; gap: 14px; align-items: center; }
.order__top h3 { margin-bottom: 8px; }

.checkout { display: grid; gap: 16px; align-content: start; }
.checkout__amount { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 18px; border: 1px solid var(--line-strong); border-radius: var(--r-sm); background: var(--bg-deep); }
.checkout__amount strong { font-family: var(--font-display); font-size: 2rem; color: var(--brand-ink); white-space: nowrap; }
.checkout__qr { position: relative; justify-self: center; padding: 16px; border-radius: var(--r-md); background: #fff; box-shadow: var(--shadow); overflow: hidden; }
.qr { display: block; }
.checkout__qr.is-paid .qr { opacity: .25; }
.checkout__scanline { position: absolute; left: 16px; right: 16px; top: 16px; height: 3px; border-radius: 2px; background: linear-gradient(90deg, transparent, var(--brand), transparent); box-shadow: 0 0 12px 2px var(--brand); animation: qrscan 2.1s var(--ease) infinite; }
@keyframes qrscan { 0%,100% { transform: translateY(0); } 50% { transform: translateY(156px); } }
.checkout__ok { position: absolute; inset: 16px; display: flex; align-items: center; justify-content: center; gap: 9px; font-weight: 800; color: var(--ok); background: rgba(255,255,255,0.7); border-radius: var(--r-sm); }
.checkout__foot { display: flex; gap: 11px; align-items: flex-start; padding: 14px 15px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--surface); }
.checkout__foot .led { margin-top: 5px; }
.checkout__foot strong { display: block; font-size: 0.88rem; font-weight: 800; }
.checkout__foot .micro { display: block; }

/* offer / policy page */
.offer-defs { display: grid; gap: 6px; }
.offer-defs strong { color: var(--ink); }
.offer-defs--sm { font-size: 0.9rem; }
.offer-toc { margin-top: 12px; }
.offer-toc a { cursor: pointer; }

/* report */
.report { display: grid; gap: 24px; }
.report__grid { display: grid; grid-template-columns: 1.25fr 0.75fr; gap: 20px; align-items: start; }
@media (max-width: 960px) { .report__grid { grid-template-columns: 1fr; } }
.report__badges { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 20px; }
.report__actions { display: flex; gap: 11px; flex-wrap: wrap; margin-top: 24px; }
.report__side { display: grid; gap: 12px; align-content: start; }
.report__side .h3 { margin-top: 2px; }

.report__inside { padding-top: 24px; border-top: 1px solid var(--line); }
.report__inside-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 11px; margin-top: 18px; }
@media (max-width: 960px) { .report__inside-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px) { .report__inside-grid { grid-template-columns: 1fr; } }
.ichip { display: flex; gap: 12px; align-items: flex-start; padding: 14px 15px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--surface); animation: ichip-in .5s var(--ease) backwards; animation-delay: calc(var(--i) * .09s); }
@keyframes ichip-in { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.ichip .led { margin-top: 5px; }
.ichip strong { display: block; font-size: 0.88rem; font-weight: 800; }
.ichip .micro { display: block; }
