/* ══════════════════════════════════════════════════════
   VISUALAURA — Bespoke Digital Experiences (flagship)
   Layers on website-design.css (sections + motion), inquiry-flow.css,
   branding.css (burgundy theme + FAQ). Adds the floating product hero,
   project grid, case studies, quote card, and the 6-step consultation
   wizard (#bx).
   ══════════════════════════════════════════════════════ */

/* ══ HERO — floating product composition ══ */
.bx-stage {
  position: relative; margin: 70px auto 0; max-width: 1000px;
  display: flex; align-items: center; justify-content: center; gap: clamp(12px, 2.6vw, 30px);
}
.bx-tile {
  flex: 0 0 auto; position: relative; overflow: hidden; background: #fff;
  border: 1px solid var(--border); border-radius: 18px; box-shadow: var(--shadow-lg); opacity: 0;
  animation: brMarkIn 1s var(--ease) forwards;
}
.bx-tile.t1 { animation-delay: .15s, 1.5s; animation-name: brMarkIn, brFloatA; animation-duration: 1s, 7s;   animation-iteration-count: 1, infinite; animation-timing-function: var(--ease), ease-in-out; }
.bx-tile.t2 { animation-delay: .3s, 1.6s;  animation-name: brMarkIn, brFloatB; animation-duration: 1s, 6.2s; animation-iteration-count: 1, infinite; animation-timing-function: var(--ease), ease-in-out; z-index: 2; }
.bx-tile.t3 { animation-delay: .45s, 1.55s;animation-name: brMarkIn, brFloatC; animation-duration: 1s, 6.6s; animation-iteration-count: 1, infinite; animation-timing-function: var(--ease), ease-in-out; }
.bx-tile.t4 { animation-delay: .6s, 1.7s;  animation-name: brMarkIn, brFloatB; animation-duration: 1s, 7.4s; animation-iteration-count: 1, infinite; animation-timing-function: var(--ease), ease-in-out; }

/* dashboard tile */
.bx-dash { width: clamp(220px, 30vw, 340px); height: clamp(170px, 22vw, 240px); display: flex; }
.bx-dash .side { width: 24%; background: #1d1416; padding: 12px 8px; display: flex; flex-direction: column; gap: 7px; }
.bx-dash .side .lg { height: 8px; width: 70%; border-radius: 3px; background: linear-gradient(90deg, var(--accent), var(--primary-l)); margin-bottom: 6px; }
.bx-dash .side i { height: 7px; border-radius: 3px; background: rgba(255,255,255,.12); }
.bx-dash .side i.on { background: rgba(201,169,110,.5); }
.bx-dash .main { flex: 1; padding: 12px; display: flex; flex-direction: column; gap: 9px; }
.bx-dash .row { display: grid; grid-template-columns: repeat(3,1fr); gap: 7px; }
.bx-dash .row div { height: 32px; border-radius: 7px; background: rgba(110,20,35,.06); border: 1px solid rgba(110,20,35,.08); }
.bx-dash .chart { flex: 1; border-radius: 8px; background: rgba(110,20,35,.04); display: flex; align-items: flex-end; gap: 6px; padding: 10px; }
.bx-dash .chart span { flex: 1; border-radius: 4px 4px 0 0; background: linear-gradient(180deg, var(--accent), rgba(110,20,35,.35)); }
.bx-dash .chart span:nth-child(even) { background: linear-gradient(180deg, var(--primary), rgba(201,169,110,.35)); }

/* phone app tile */
.bx-app { width: clamp(96px, 13vw, 140px); aspect-ratio: 9/19; border: 6px solid #221d18; background: #221d18; border-radius: 24px; }
.bx-app .scr { background: #fff; border-radius: 16px; overflow: hidden; height: 100%; display: flex; flex-direction: column; }
.bx-app .hd { background: linear-gradient(150deg, var(--primary), #2b1116); padding: 14px 10px 12px; }
.bx-app .hd .h { height: 9px; width: 70%; border-radius: 3px; background: rgba(255,255,255,.85); margin-bottom: 5px; }
.bx-app .hd .s { height: 6px; width: 45%; border-radius: 3px; background: rgba(255,255,255,.4); }
.bx-app .bd { padding: 9px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.bx-app .bd div { height: 28px; border-radius: 7px; background: rgba(110,20,35,.07); }
.bx-app .bd div.g { background: linear-gradient(135deg, var(--accent), #e0c898); }

/* AI tile */
.bx-ai { width: clamp(150px, 19vw, 220px); aspect-ratio: 4/3.4; background: linear-gradient(160deg, #2b1116, #6E1423); padding: 18px; display: flex; flex-direction: column; gap: 10px; }
.bx-ai .badge { align-self: flex-start; font-family: var(--font-body); font-size: .5rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: #2b1116; background: var(--accent); padding: 4px 10px; border-radius: 30px; }
.bx-ai .ln { height: 8px; border-radius: 3px; background: rgba(255,255,255,.22); }
.bx-ai .ln.s { width: 70%; }
.bx-ai .orb { margin-top: auto; align-self: flex-end; width: 44px; height: 44px; border-radius: 50%; background: radial-gradient(circle at 35% 30%, #fff, var(--accent) 45%, var(--primary) 100%); box-shadow: 0 8px 24px rgba(201,169,110,.4); }

@media (max-width: 760px) { .bx-stage { flex-wrap: wrap; gap: 14px; } .bx-app { display: none; } }

/* ══ Project type numbers (reuse .wd-types-grid / .wd-type) ══ */
.wd-type .bx-num { display: block; font-family: var(--font-head); font-size: 1.05rem; font-weight: 500; color: var(--accent); letter-spacing: .08em; margin-bottom: 14px; }

/* ══ Showcase mockups (inside .wd-hpanel) ══ */
.bx-mock { border-radius: 14px; overflow: hidden; height: clamp(240px, 32vw, 300px); border: 1px solid var(--border); box-shadow: var(--shadow-md); display: flex; }
.bx-mock-dash { background: #fff; }
.bx-mock-dash .side { width: 22%; background: #1d1416; }
.bx-mock-dash .main { flex: 1; padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.bx-mock-dash .row { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; }
.bx-mock-dash .row div { height: 40px; border-radius: 9px; background: rgba(110,20,35,.07); }
.bx-mock-dash .chart { flex: 1; border-radius: 10px; background: rgba(110,20,35,.05); display: flex; align-items: flex-end; gap: 9px; padding: 16px; }
.bx-mock-dash .chart span { flex: 1; border-radius: 5px 5px 0 0; background: linear-gradient(180deg, var(--accent), rgba(110,20,35,.4)); }
.bx-mock-app { background: linear-gradient(160deg, #2b1116, #6E1423); align-items: center; justify-content: center; padding: 26px; }
.bx-mock-app .scr { width: 44%; height: 88%; background: #fff; border-radius: 20px; padding: 14px; display: flex; flex-direction: column; gap: 8px; box-shadow: 0 24px 60px rgba(0,0,0,.32); }
.bx-mock-app .scr .b { height: 34px; border-radius: 9px; background: linear-gradient(135deg, var(--primary), #2b1116); }
.bx-mock-app .scr i { height: 9px; border-radius: 3px; background: rgba(110,20,35,.12); }
.bx-mock-market { background: linear-gradient(160deg, #FBF6EF, #efe3d2); padding: 22px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.bx-mock-market div { border-radius: 10px; background: #fff; border: 1px solid rgba(110,20,35,.08); }
.bx-mock-market div:nth-child(odd) { background: linear-gradient(135deg, var(--primary), #2b1116); }
.bx-mock-ai { background: linear-gradient(160deg, #2b1116, #6E1423); flex-direction: column; justify-content: center; gap: 14px; padding: 30px; }
.bx-mock-ai .badge { align-self: flex-start; font-family: var(--font-body); font-size: .54rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: #2b1116; background: var(--accent); padding: 5px 12px; border-radius: 30px; }
.bx-mock-ai .ln { height: 11px; border-radius: 4px; background: rgba(255,255,255,.22); }
.bx-mock-ai .ln.s { width: 66%; }
.bx-mock-ai .orb { align-self: flex-end; width: 70px; height: 70px; border-radius: 50%; background: radial-gradient(circle at 35% 30%, #fff, var(--accent) 45%, var(--primary) 100%); box-shadow: 0 14px 38px rgba(201,169,110,.4); }

/* ══ Case studies grid ══ */
.bx-cases { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }
.bx-case {
  background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg);
  padding: 34px 32px; transition: transform .45s var(--ease), box-shadow .45s var(--ease);
}
.bx-case.visible { transition-delay: var(--delay, 0s); }
.bx-case:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.bx-case-cat { font-family: var(--font-body); font-size: .64rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.bx-case h3 { font-family: var(--font-head); font-size: 1.6rem; font-weight: 500; color: var(--text); letter-spacing: -.01em; margin-bottom: 18px; }
.bx-case-psr { display: flex; flex-direction: column; gap: 10px; margin-bottom: 22px; }
.bx-case-psr div { display: flex; gap: 12px; font-family: var(--font-body); font-size: .88rem; line-height: 1.6; color: var(--text-m); font-weight: 300; }
.bx-case-psr b { font-family: var(--font-body); font-size: .58rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--primary); flex-shrink: 0; width: 70px; padding-top: 3px; }
.bx-case-link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-size: .72rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--primary); cursor: pointer; border-bottom: 1px solid transparent; transition: gap .3s, border-color .3s; }
.bx-case-link svg { width: 14px; height: 14px; }
.bx-case:hover .bx-case-link { gap: 12px; border-color: rgba(110,20,35,.4); }
@media (max-width: 760px) { .bx-cases { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; } }

/* ══ Quote card (no fixed pricing) ══ */
.bx-quote-sec { background: var(--white); }
.bx-quote {
  max-width: 720px; margin: 0 auto; text-align: center; position: relative; overflow: hidden;
  background: radial-gradient(120% 120% at 50% 0%, #2c161b 0%, #1d1012 70%);
  border: 1px solid rgba(201,169,110,.25); border-radius: var(--radius-xl);
  padding: 64px 48px; box-shadow: var(--shadow-lg);
}
.bx-quote::before { content: ''; position: absolute; inset: 0; pointer-events: none; background-image: linear-gradient(rgba(201,169,110,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(201,169,110,.05) 1px, transparent 1px); background-size: 44px 44px; -webkit-mask-image: radial-gradient(circle at 50% 0%, #000, transparent 75%); mask-image: radial-gradient(circle at 50% 0%, #000, transparent 75%); }
.bx-quote-eyebrow { position: relative; font-family: var(--font-body); font-size: .62rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--accent-l); margin-bottom: 18px; }
.bx-quote h2 { position: relative; font-family: var(--font-head); font-size: clamp(2.2rem, 5vw, 3.4rem); font-weight: 400; line-height: 1.1; letter-spacing: -.02em; color: #f8f2ea; margin-bottom: 18px; }
.bx-quote h2 em { font-style: italic; color: var(--accent-l); }
.bx-quote p { position: relative; font-family: var(--font-body); font-size: 1rem; font-weight: 300; line-height: 1.85; color: rgba(246,239,230,.7); max-width: 480px; margin: 0 auto 32px; }
.bx-quote .btn-primary { position: relative; background: linear-gradient(135deg, var(--accent), #b8945a); color: #2b1116; box-shadow: 0 12px 32px rgba(201,169,110,.3); }
.bx-quote .btn-primary:hover { box-shadow: 0 18px 44px rgba(201,169,110,.45); }

/* ══════════════════════════════════════════════════════
   6-STEP CONSULTATION WIZARD (#bx)
   ══════════════════════════════════════════════════════ */
.bx { position: fixed; inset: 0; z-index: 3200; display: flex; flex-direction: column; overflow: hidden;
  background: radial-gradient(120% 80% at 50% 0%, #FCF8F1 0%, var(--beige) 52%, #EFE5D6 100%);
  opacity: 0; visibility: hidden; transform: scale(1.02);
  transition: opacity .55s var(--ease), transform .65s var(--ease), visibility .55s; }
.bx.open { opacity: 1; visibility: visible; transform: scale(1); }
.bx-grid-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; background-image: linear-gradient(rgba(110,20,35,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(110,20,35,.035) 1px, transparent 1px); background-size: 64px 64px; -webkit-mask-image: radial-gradient(circle at 50% 28%, #000, transparent 78%); mask-image: radial-gradient(circle at 50% 28%, #000, transparent 78%); }
.bx-confetti { position: absolute; inset: 0; pointer-events: none; z-index: 5; overflow: hidden; }
.bx-particle { position: absolute; top: -24px; opacity: 0; animation: wqFall linear forwards; }

.bx-top { flex-shrink: 0; position: relative; z-index: 6; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 30px; }
.bx-brand { font-family: var(--font-head); font-size: 1.1rem; font-weight: 600; color: var(--text); display: inline-flex; align-items: center; gap: 9px; }
.bx-brand span { color: var(--accent); font-size: .8rem; }
.bx-close { font-family: var(--font-body); font-size: .72rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--text-m); background: none; border: none; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: color .3s var(--ease); }
.bx-close:hover { color: var(--primary); }
.bx-close svg { width: 13px; height: 13px; }

.bx-progress { flex-shrink: 0; position: relative; z-index: 6; display: flex; max-width: 760px; width: 100%; margin: 4px auto 6px; padding: 0 30px; }
.bx-pstep { flex: 1; position: relative; display: flex; flex-direction: column; align-items: center; gap: 9px; }
.bx-pstep::before { content: ''; position: absolute; top: 16px; right: 50%; width: 100%; height: 2px; background: rgba(201,169,110,.28); z-index: 0; }
.bx-pstep:first-child::before { display: none; }
.bx-pstep.done::before, .bx-pstep.active::before { background: linear-gradient(90deg, var(--accent), var(--primary)); }
.bx-pdot { position: relative; z-index: 1; width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-head); font-size: .9rem; font-weight: 500; background: var(--beige); border: 1.5px solid rgba(201,169,110,.45); color: var(--text-l); transition: all .45s var(--ease); }
.bx-pstep.active .bx-pdot { background: linear-gradient(135deg, var(--primary), var(--primary-d)); border-color: transparent; color: #fff; transform: scale(1.08); box-shadow: 0 10px 24px rgba(110,20,35,.28); }
.bx-pstep.done .bx-pdot { background: rgba(110,20,35,.1); border-color: var(--primary); color: var(--primary); }
.bx-plabel { font-family: var(--font-body); font-size: .56rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--text-l); transition: color .4s var(--ease); }
.bx-pstep.active .bx-plabel { color: var(--primary); }

.bx-body { flex: 1; overflow-y: auto; position: relative; z-index: 4; padding: 26px 30px 36px; }
.bx-screen { max-width: 860px; margin: 0 auto; animation: pjScreenIn .55s var(--ease); }
.bx-screen[hidden] { display: none; }
@keyframes pjScreenIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
.bx-eyebrow { text-align: center; font-family: var(--font-body); font-size: .6rem; font-weight: 600; letter-spacing: .26em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; }
.bx-h { text-align: center; font-family: var(--font-head); font-size: clamp(2rem, 5vw, 3.1rem); font-weight: 400; line-height: 1.12; letter-spacing: -.02em; color: var(--text); margin: 0 auto 10px; max-width: 18ch; }
.bx-h em { font-style: italic; color: var(--primary); }
.bx-sub { text-align: center; font-family: var(--font-body); font-size: .95rem; font-weight: 300; line-height: 1.8; color: var(--text-m); max-width: 520px; margin: 0 auto 36px; }

.bx-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.bx-cards.two { grid-template-columns: repeat(2, 1fr); max-width: 640px; margin: 0 auto; }
.bx-card { position: relative; text-align: left; cursor: pointer; background: var(--white); border: 1.5px solid rgba(201,169,110,.22); border-radius: 18px; padding: 22px 20px; box-shadow: 0 8px 26px rgba(110,20,35,.05); transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease); }
.bx-card:hover { transform: translateY(-5px); box-shadow: 0 18px 44px rgba(110,20,35,.13); }
.bx-card.selected { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent), 0 20px 48px rgba(201,169,110,.26); transform: translateY(-5px); }
.bx-card-ic { width: 44px; height: 44px; border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 14px; color: var(--primary); background: linear-gradient(135deg, rgba(110,20,35,.1), rgba(201,169,110,.16)); border: 1px solid rgba(110,20,35,.12); transition: all .4s var(--ease); }
.bx-card-ic svg { width: 23px; height: 23px; }
.bx-card.selected .bx-card-ic { background: linear-gradient(135deg, var(--primary), var(--primary-d)); color: #fff; border-color: transparent; }
.bx-card-name { display: block; font-family: var(--font-head); font-size: 1.18rem; font-weight: 500; color: var(--text); letter-spacing: -.01em; }
.bx-card-desc { display: block; font-family: var(--font-body); font-size: .8rem; font-weight: 300; line-height: 1.55; color: var(--text-m); margin-top: 6px; }
.bx-check { position: absolute; top: 14px; right: 14px; width: 24px; height: 24px; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: .72rem; opacity: 0; transform: scale(.4); transition: opacity .3s var(--ease), transform .35s var(--ease); }
.bx-card.selected .bx-check { opacity: 1; transform: scale(1); }

.bx-feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.bx-feat { position: relative; display: flex; align-items: center; gap: 13px; cursor: pointer; background: var(--white); border: 1.5px solid rgba(201,169,110,.22); border-radius: 16px; padding: 17px 18px; transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease); }
.bx-feat:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(110,20,35,.1); }
.bx-feat.selected { border-color: var(--primary); background: rgba(110,20,35,.04); box-shadow: 0 0 0 1.5px var(--primary); }
.bx-feat-ic { width: 38px; height: 38px; border-radius: 11px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--primary); background: rgba(201,169,110,.13); border: 1px solid rgba(201,169,110,.28); }
.bx-feat-ic svg { width: 20px; height: 20px; }
.bx-feat-name { font-family: var(--font-body); font-size: .9rem; font-weight: 400; color: var(--text); }
.bx-feat-tick { margin-left: auto; width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid rgba(201,169,110,.4); display: flex; align-items: center; justify-content: center; color: #fff; font-size: .66rem; flex-shrink: 0; transition: all .3s var(--ease); }
.bx-feat.selected .bx-feat-tick { background: var(--primary); border-color: var(--primary); }

.bx-textarea { display: block; width: 100%; max-width: 680px; margin: 0 auto; box-sizing: border-box; font-family: var(--font-body); font-size: 1rem; line-height: 1.75; color: var(--text); background: var(--white); border: 1.5px solid rgba(201,169,110,.3); border-radius: 20px; padding: 22px 24px; resize: vertical; min-height: 200px; transition: border-color .3s var(--ease), box-shadow .3s var(--ease); }
.bx-textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(110,20,35,.08); }
.bx-textarea::placeholder { color: var(--text-l); }

.bx-fields { max-width: 540px; margin: 0 auto; display: flex; flex-direction: column; gap: 24px; }
.bx-field { display: flex; flex-direction: column; gap: 9px; }
.bx-field label { font-family: var(--font-body); font-size: .64rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--text-m); }
.bx-field input { font-family: var(--font-head); font-size: 1.3rem; font-weight: 400; color: var(--text); background: transparent; border: none; border-bottom: 1.5px solid rgba(201,169,110,.4); padding: 10px 2px; width: 100%; box-sizing: border-box; transition: border-color .3s var(--ease); }
.bx-field input::placeholder { color: var(--text-l); font-family: var(--font-head); font-style: italic; }
.bx-field input:focus { outline: none; border-bottom-color: var(--primary); }
.bx-field.error input { border-bottom-color: #c2573f; }

.bx-foot { flex-shrink: 0; position: relative; z-index: 6; padding: 18px 30px 26px; border-top: 1px solid rgba(201,169,110,.22); background: rgba(252,248,241,.84); -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px); }
.bx-actions { display: flex; align-items: center; justify-content: space-between; gap: 16px; max-width: 860px; margin: 0 auto; }
.bx-back { font-family: var(--font-body); font-size: .74rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--text-m); background: none; border: none; cursor: pointer; transition: color .3s var(--ease); }
.bx-back:hover { color: var(--primary); }
.bx-next { font-family: var(--font-body); font-size: .76rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; padding: 16px 44px; border-radius: 50px; border: none; cursor: pointer; color: #fff; background: linear-gradient(135deg, #8a2433, #6E1423 55%, #54101b); box-shadow: 0 12px 32px rgba(110,20,35,.3); display: inline-flex; align-items: center; gap: 10px; opacity: .45; pointer-events: none; transition: all .4s var(--ease); }
.bx-next.ready { opacity: 1; pointer-events: auto; }
.bx-next.ready:hover { transform: translateY(-2px); box-shadow: 0 18px 46px rgba(110,20,35,.42); }

/* Final */
.bx-final { max-width: 720px; margin: 0 auto; text-align: center; animation: pjScreenIn .6s var(--ease); }
.bx-final[hidden] { display: none; }
.bx-final-ring { width: 84px; height: 84px; margin: 0 auto 8px; }
.bx-final-ring svg { width: 100%; height: 100%; fill: none; }
.bx-fr-circle { stroke: rgba(201,169,110,.55); stroke-width: 2; stroke-dasharray: 151; stroke-dashoffset: 151; animation: wqCircle 1s var(--ease) .2s forwards; }
.bx-fr-check { stroke: var(--primary); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 42; stroke-dashoffset: 42; animation: wqCheck .55s var(--ease) .95s forwards; }
.bx-final h2 { font-family: var(--font-head); font-size: clamp(2rem, 5vw, 3rem); font-weight: 400; line-height: 1.12; letter-spacing: -.02em; color: var(--text); margin: 18px 0 12px; }
.bx-final h2 em { font-style: italic; color: var(--primary); }
.bx-final-lead { font-family: var(--font-body); font-size: .96rem; font-weight: 300; line-height: 1.85; color: var(--text-m); max-width: 480px; margin: 0 auto 30px; }
.bx-summary { text-align: left; background: var(--white); border: 1.5px solid rgba(201,169,110,.28); border-radius: 22px; overflow: hidden; box-shadow: 0 16px 44px rgba(110,20,35,.1); margin: 0 auto 30px; max-width: 600px; }
.bx-summary-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 20px 26px; background: linear-gradient(135deg, #FBF4EA, #F6E9DA); border-bottom: 1px solid rgba(201,169,110,.25); }
.bx-summary-head b { font-family: var(--font-head); font-size: 1.2rem; font-weight: 500; color: var(--text); }
.bx-summary-head span { font-family: var(--font-body); font-size: .58rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--primary); background: rgba(110,20,35,.08); border: 1px solid rgba(110,20,35,.2); padding: 5px 12px; border-radius: 30px; }
.bx-srow { display: flex; gap: 18px; padding: 15px 26px; border-bottom: 1px solid rgba(110,20,35,.08); }
.bx-srow:last-child { border-bottom: none; }
.bx-sk { font-family: var(--font-body); font-size: .6rem; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; color: var(--text-l); width: 104px; flex-shrink: 0; padding-top: 3px; }
.bx-sv { font-family: var(--font-body); font-size: .92rem; font-weight: 300; color: var(--text); line-height: 1.6; }
.bx-sv em { font-family: var(--font-head); font-style: italic; color: var(--primary); font-size: 1rem; }
.bx-final-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.bx-fbtn { font-family: var(--font-body); font-size: .74rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; padding: 16px 34px; border-radius: 50px; cursor: pointer; border: none; transition: transform .4s var(--ease), box-shadow .4s var(--ease), background .4s var(--ease); }
.bx-fbtn.primary { color: #fff; background: linear-gradient(135deg, #8a2433, #6E1423 55%, #54101b); box-shadow: 0 14px 34px rgba(110,20,35,.32); }
.bx-fbtn.primary:hover { transform: translateY(-2px); box-shadow: 0 20px 48px rgba(110,20,35,.44); }
.bx-fbtn.ghost { color: var(--primary); background: transparent; border: 1.5px solid rgba(110,20,35,.4); }
.bx-fbtn.ghost:hover { background: rgba(110,20,35,.06); border-color: var(--primary); }
.bx-spark { position: absolute; color: var(--accent); opacity: 0; animation-name: wqSpark; animation-iteration-count: infinite; animation-timing-function: ease-in-out; z-index: 5; }

@media (max-width: 760px) {
  .bx-cards { grid-template-columns: repeat(2, 1fr); }
  .bx-feats { grid-template-columns: repeat(2, 1fr); }
  .bx-plabel { display: none; }
  .bx-top { padding: 16px 18px; } .bx-progress { padding: 0 18px; } .bx-body { padding: 22px 18px 30px; }
}
@media (max-width: 520px) {
  .bx-cards, .bx-cards.two { grid-template-columns: 1fr; }
  .bx-feats { grid-template-columns: 1fr; }
  .bx-next { padding: 15px 30px; font-size: .7rem; }
  .bx-final-actions { flex-direction: column; width: 100%; max-width: 320px; margin: 0 auto; }
  .bx-fbtn { width: 100%; box-sizing: border-box; text-align: center; }
  .bx-srow { flex-direction: column; gap: 4px; } .bx-sk { width: auto; }
}
