
:root {

  --wine: #B43852;
  --wine-light: #E7665F;
  --wine-deep: #8E2A40;
  --salmon: #FFB7A7;
  --gold: #E0B873;

  --success: #11935F;
  --success-light: #26B978;
  --teal: #176C72;
  --teal-soft: #D8F2ED;

  --card: #FFF8F5;
  --card-2: #F6ECE6;
  --ink: #20171A;
  --ink-soft: #6E6064;
  --line: rgba(32,23,26,.13);

  --on-dark: #FFFFFF;
  --on-dark-soft: rgba(255,255,255,.84);
  --on-dark-faint: rgba(255,255,255,.22);
  --glass-bg: rgba(255,255,255,.12);
  --glass-bd: rgba(255,255,255,.26);

  --radius: 16px;
  --radius-sm: 11px;
  --radius-btn: 13px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.18);
  --shadow: 0 24px 70px -22px rgba(0,0,0,.6), 0 6px 18px rgba(0,0,0,.18);
  --shadow-glow: 0 18px 50px -18px rgba(180,56,82,.55);

  --container: 1120px;
  --narrow: 600px;
  --font-head: 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--on-dark);
  line-height: 1.6;
  min-height: 100dvh;
  overflow-x: hidden;

  background:
    radial-gradient(760px 560px at 2% 14%, rgba(180,56,82,.20), transparent 56%),
    linear-gradient(168deg, rgba(20,9,12,.72) 0%, rgba(20,9,12,.50) 48%, rgba(20,9,12,.80) 100%),
    url('/assets/hero.jpg') 50% 16% / cover no-repeat,
    linear-gradient(158deg, #2C1418, #160A0D);
  background-attachment: scroll, fixed, fixed, fixed;
}
body::after {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0; opacity: .05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main, .topbar, footer { position: relative; z-index: 1; }

h1, h2, h3 { font-family: var(--font-head); line-height: 1.04; margin: 0 0 .4em; letter-spacing: -.015em; }
h1 { font-size: clamp(2.1rem, 6.4vw, 4.5rem); font-weight: 800; overflow-wrap: break-word; }
h2 { font-size: clamp(1.5rem, 4.5vw, 2.1rem); font-weight: 700; }
.card h2 { font-family: var(--font-body); font-weight: 800; letter-spacing: -.01em; }
p { margin: 0 0 1rem; }
a { color: var(--salmon); }
img { max-width: 100%; display: block; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 20px; }
.narrow { max-width: var(--narrow); margin: 0 auto; }
.muted { color: var(--ink-soft); }
.center { text-align: center; }
.small { font-size: .86rem; }
.hidden { display: none !important; }

.topbar { position: sticky; top: 0; z-index: 40; backdrop-filter: blur(8px);
  background: linear-gradient(180deg, rgba(22,10,13,.62), rgba(22,10,13,0)); transition: background .25s; }
.topbar .container { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--font-head); font-weight: 800;
  font-size: 1.2rem; color: var(--on-dark); text-decoration: none; flex: none; white-space: nowrap; }
.brand > span:last-child { white-space: nowrap; }
.brand-mark { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; color: #fff;
  flex: none; background: linear-gradient(135deg, var(--wine), var(--wine-light)); box-shadow: var(--shadow-glow); }
.nav-right { display: flex; align-items: center; gap: 12px; flex-wrap: nowrap; }
.topbar a.link { color: var(--on-dark-soft); text-decoration: none; font-size: .92rem; font-weight: 600; }
.topbar a.link:hover { color: var(--on-dark); }
.price-pill { display: inline-flex; align-items: center; gap: 8px; border: 1px solid var(--on-dark-faint);
  border-radius: 999px; padding: 7px 14px; font-size: .82rem; color: var(--on-dark-soft); }
.price-pill b { color: var(--on-dark); }
.pill-anchor { opacity: .55; text-decoration: line-through; font-weight: 600; }
.total-anchor { opacity: .5; text-decoration: line-through; font-weight: 600; font-size: .85em; margin-right: 6px; color: var(--ink-soft); }
.trust-pay { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 7px; margin: 14px 0 10px; font-size: .78rem; color: var(--ink-soft); text-align: center; line-height: 1.4; }
.trust-pay .ic { width: 13px; height: 13px; vertical-align: -2px; color: #1c854a; }
.trust-pay b { color: var(--ink); font-weight: 700; }
.trust-pay .dot { opacity: .4; }
.guarantees { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 16px 0 4px; }
.g-card { background: rgba(255,255,255,.6); border: 1px solid rgba(142,42,64,.12); border-radius: 12px; padding: 11px 8px; text-align: center; }
.g-ic { font-size: 18px; display: block; margin-bottom: 5px; }
.g-card b { display: block; font-size: .78rem; color: var(--ink); margin-bottom: 3px; line-height: 1.2; }
.g-card > span:last-child { display: block; font-size: .68rem; color: var(--ink-soft); line-height: 1.32; }
.gen-reassure { margin: 16px auto 0; max-width: 420px; background: var(--cream, #fff6f3); border: 1px solid rgba(142,42,64,.1); border-radius: 12px; padding: 12px 14px; font-size: .82rem; color: var(--ink-soft); line-height: 1.5; text-align: center; }
.gen-reassure b { color: var(--wine, #8e2a40); }
.order-summary { background: linear-gradient(180deg, rgba(227,178,97,.07), rgba(142,42,64,.04)); border: 1px solid rgba(142,42,64,.12); border-radius: 16px; padding: 16px; margin: 0 0 16px; }
.order-summary .os-title { text-align: center; font-size: .8rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--wine, #8e2a40); margin-bottom: 12px; }
.os-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.os-cell { background: rgba(255,255,255,.62); border: 1px solid rgba(142,42,64,.08); border-radius: 10px; padding: 9px 11px; }
.os-cell.wide { grid-column: 1 / -1; }
.os-k { font-size: .6rem; text-transform: uppercase; letter-spacing: .07em; color: var(--ink-soft); margin-bottom: 2px; }
.os-v { font-size: .92rem; font-weight: 700; color: var(--ink); line-height: 1.2; word-break: break-word; }
.os-s { font-size: .7rem; color: var(--ink-soft); margin-top: 1px; }
@media (min-width: 560px) { .os-grid { grid-template-columns: repeat(3, 1fr); } }
.trust-strip .trust-line { flex-basis: 100%; justify-content: center; text-align: center; }
.price-pill .free { color: var(--gold); font-weight: 700; }

.hero { text-align: center; padding: 48px 0 16px; }
.hero h1 { color: var(--on-dark); }
.hero .sub, .hero p.sub { color: var(--on-dark-soft); max-width: 34em; margin: 0 auto; }
.hero .eyebrow { display: inline-block; color: var(--salmon); font-size: .8rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 14px; }

.hero-split { display: grid; grid-template-columns: 1fr; gap: 30px; align-items: center; padding: 30px 0 24px; }
.hero-split > * { min-width: 0; }
.hero-left .eyebrow { display: inline-block; color: var(--salmon); font-size: .8rem; font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase; margin-bottom: 18px; }
.hero-left h1 { font-size: clamp(1.7rem, 3.2vw, 2.7rem); color: var(--on-dark); line-height: 1.08; text-shadow: 0 2px 22px rgba(0,0,0,.65), 0 1px 3px rgba(0,0,0,.4); }
.hero-left .accent { font-style: italic; color: var(--gold); }
.hero-left p.sub { font-size: 1.1rem; color: var(--on-dark-soft); max-width: 31em; }

.hero-pills { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 22px; }
.glass-pill { display: inline-flex; align-items: center; gap: 6px; padding: 8px 13px; border-radius: 999px;
  background: var(--glass-bg); border: 1px solid var(--glass-bd); color: var(--on-dark); font-size: .82rem; font-weight: 600; white-space: nowrap; }
.glass-pill .ic { width: 14px; height: 14px; color: var(--salmon); flex: none; }

.card { background: var(--card); color: var(--ink); border: 1px solid rgba(255,255,255,.6);
  border-radius: var(--radius); box-shadow: var(--shadow); padding: 26px; }
.card.lg { padding: 28px; }
.panel { margin: 8px 0 0; }
.card-eyebrow { color: var(--wine); font-size: .74rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; margin-bottom: 6px; }
.card h2, .card h3 { color: var(--ink); }
.card .muted { color: var(--ink-soft); }

.steps { display: flex; gap: 7px; margin: 4px 0 18px; }
.steps .dot { width: 8px; height: 8px; border-radius: 999px; background: var(--line); transition: all .25s ease; }
.steps .dot.active { background: var(--wine); width: 24px; }

.wiz-steps { display: flex; align-items: center; gap: 6px; margin: 14px 0 20px; }
.wiz-step { display: flex; align-items: center; gap: 8px; font-size: .82rem; font-weight: 700; color: var(--ink-soft); white-space: nowrap; }
.wiz-step .num { width: 28px; height: 28px; flex: none; border-radius: 50%; display: grid; place-items: center;
  background: #fff; border: 1.5px solid var(--line); color: var(--ink-soft); font-size: .85rem; font-weight: 800; transition: all .2s; }
.wiz-step.active { color: var(--ink); }
.wiz-step.active .num { background: linear-gradient(135deg, var(--wine), var(--wine-light)); color: #fff; border-color: transparent; box-shadow: var(--shadow-glow); }
.wiz-step.done .num { background: var(--success); color: #fff; border-color: transparent; }
.wiz-line { flex: 1; height: 2px; background: var(--line); border-radius: 2px; }
.wiz-title { font-family: var(--font-body); font-weight: 800; font-size: 1.18rem; letter-spacing: -.01em; margin-bottom: 16px; color: var(--ink); }
.wiz-nav { display: flex; gap: 10px; margin-top: 6px; }
.wiz-panel { animation: wizIn .28s ease; }
@keyframes wizIn { from { opacity: 0; transform: translateX(8px); } to { opacity: 1; transform: none; } }

.field { margin-bottom: 18px; }
.field > label { display: block; font-weight: 700; font-size: .92rem; margin-bottom: 8px; color: var(--ink); }
.field > label .opt { font-weight: 400; color: var(--ink-soft); }
.field .help { font-size: .82rem; color: var(--ink-soft); margin-top: 7px; }
.err { font-size: .82rem; color: var(--wine); margin-top: 6px; min-height: 1em; font-weight: 600; }
#briefForm { scroll-margin-top: 88px; }
.field.has-error .choice-grid { outline: 2px solid var(--wine); outline-offset: 5px; border-radius: 14px; }
.field.has-error input, .field.has-error textarea, .field.has-error select { border-color: var(--wine); }
input, select, textarea {
  width: 100%; min-width: 0; max-width: 100%; font: inherit; color: var(--ink); background: #fff;
  border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  padding: 13px 15px; min-height: 50px; transition: border-color .15s, box-shadow .15s;
}
textarea { min-height: 128px; resize: vertical; line-height: 1.55; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--wine); box-shadow: 0 0 0 4px rgba(180,56,82,.14); }
input::placeholder, textarea::placeholder { color: #B9A39C; }

.choice-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.choice {
  position: relative; display: flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; text-align: center;
  border: 1.5px solid var(--line); border-radius: var(--radius-sm); padding: 13px 12px; background: #fff;
  font-weight: 600; color: var(--ink); transition: all .15s; min-height: 50px;
}
.choice:hover { border-color: #E6C3BA; background: #FFFDFC; }

.choice input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; margin: 0; padding: 0; border: 0; clip-path: inset(50%); }
.choice .ic { display: none; }
.choice.selected { border-color: transparent; color: #fff; box-shadow: var(--shadow-glow);
  background: linear-gradient(135deg, var(--wine), var(--wine-light)); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; font: inherit;
  font-weight: 800; cursor: pointer; border: none; border-radius: var(--radius-btn); padding: 15px 22px; min-height: 54px;
  width: 100%; transition: transform .12s ease, box-shadow .2s, filter .2s; text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn-primary { color: #fff; background: linear-gradient(135deg, var(--wine), var(--wine-light)); box-shadow: var(--shadow-glow); }
.btn-primary:hover { filter: brightness(1.05); transform: translateY(-1px); }
.btn-primary:disabled { filter: grayscale(.4) opacity(.7); cursor: not-allowed; box-shadow: none; transform: none; }
.btn-success { color: #fff; background: linear-gradient(135deg, var(--success), var(--success-light)); box-shadow: 0 18px 50px -18px rgba(17,147,95,.5); }
.btn-success:hover { filter: brightness(1.05); transform: translateY(-1px); }
.btn-success:disabled { filter: grayscale(.4) opacity(.7); cursor: not-allowed; box-shadow: none; transform: none; }
.btn-ghost { background: #fff; color: var(--ink); border: 1.5px solid var(--line); }
.btn-ghost:hover { border-color: #E6C3BA; }
.btn-teal { background: var(--teal-soft); color: var(--teal); }
.btn-sm { min-height: 46px; padding: 11px 18px; font-size: .92rem; width: auto; }
.btn .ic { width: 20px; height: 20px; }
.btn-note { text-align: center; font-size: .82rem; color: var(--ink-soft); margin-top: 10px; }
.btn-note b { color: var(--ink); }

.trust { display: flex; flex-wrap: wrap; gap: 12px 18px; justify-content: center; margin-top: 16px; }
.trust span { display: inline-flex; align-items: center; gap: 7px; font-size: .82rem; color: var(--ink-soft); font-weight: 600; }
.trust .ic { width: 16px; height: 16px; color: var(--success); }

.gen { text-align: center; padding: 14px 0; }
.gen .ring { position: relative; width: 96px; height: 96px; margin: 8px auto 18px; border-radius: 50%;
  background: conic-gradient(var(--wine) var(--p, 12%), var(--line) 0); display: grid; place-items: center; transition: background .4s; }
.gen .ring::after { content: ''; width: 74px; height: 74px; border-radius: 50%; background: var(--card); display: block; }
.gen .ring .pct { position: absolute; font-weight: 800; color: var(--wine-deep); font-variant-numeric: tabular-nums; }

#delRing { position: relative; width: 112px; height: 112px; margin: 20px auto; border-radius: 50%;
  background: conic-gradient(var(--wine) var(--p, 0%), var(--line) 0); display: grid; place-items: center; transition: background .6s linear; }
#delRing::after { content: ''; width: 88px; height: 88px; border-radius: 50%; background: var(--card); display: block; }
#delRing .pct { position: absolute; font-weight: 800; font-size: 1.55rem; color: var(--wine-deep); font-variant-numeric: tabular-nums; }
.gen-steps { list-style: none; padding: 0; margin: 18px auto 0; max-width: 300px; text-align: left; }
.gen-steps li { display: flex; align-items: center; gap: 11px; padding: 8px 0; color: var(--ink-soft); font-weight: 600; }
.gen-steps li.done { color: var(--ink); }
.gen-steps li .ic { width: 21px; height: 21px; flex: none; color: var(--line); }
.gen-steps li.done .ic { color: var(--success); }
.gen-steps li.active .ic { color: var(--wine); }

.player { display: flex; align-items: center; gap: 14px; background: var(--card-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 15px 17px; }
.player .play { width: 56px; height: 56px; flex: none; border-radius: 50%; border: none; cursor: pointer; color: #fff;
  background: linear-gradient(135deg, var(--wine), var(--wine-light)); display: grid; place-items: center; box-shadow: var(--shadow-glow); }
.player .play .ic { width: 24px; height: 24px; }
.player .play:disabled { filter: grayscale(.6) opacity(.55); cursor: not-allowed; box-shadow: none; }
.player .meta { flex: 1; min-width: 0; }
.player .meta strong { color: var(--ink); }
.player .bar { height: 6px; background: var(--line); border-radius: 999px; overflow: hidden; margin-top: 8px; }
.player .bar > span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--wine), var(--wine-light)); }
.player .time { font-size: .78rem; color: var(--ink-soft); font-variant-numeric: tabular-nums; margin-top: 5px; }
.preview-tag { display: inline-block; background: #FBE6DF; color: #9A3A2E; font-size: .72rem; font-weight: 800;
  padding: 3px 10px; border-radius: 999px; margin-left: 8px; vertical-align: middle; }

.prev-badge { display: inline-block; background: var(--wine); color: #fff; font-size: .66rem; font-weight: 800;
  letter-spacing: .04em; text-transform: uppercase; padding: 2px 7px; border-radius: 999px; margin-right: 6px; vertical-align: middle; }
.play-info { font-size: .8rem; color: var(--ink-soft); margin: 10px 2px 0; display: flex; align-items: center; gap: 6px; }
.play-info.warn { color: var(--wine); font-weight: 600; }

.variant-picker { margin: 12px 2px 0; }
.link-other { background: none; border: none; color: var(--wine); font-weight: 700; font-size: .84rem;
  cursor: pointer; text-decoration: underline; text-underline-offset: 2px; padding: 4px 0; }
.link-other:hover { color: var(--wine-deep); }
.variant-tabs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.variant-tabs .vt-label { font-size: .82rem; color: var(--ink-soft); }
.vt { border: 1px solid var(--line); background: #fff; color: var(--ink); border-radius: 999px;
  padding: 6px 15px; font-weight: 700; font-size: .84rem; cursor: pointer; transition: all .15s ease; }
.vt:hover { border-color: var(--wine); }
.vt.is-active { background: var(--wine); color: #fff; border-color: var(--wine); box-shadow: 0 4px 12px -4px rgba(180,56,82,.5); }

.lyrics-wrap { margin-top: 18px; }
.lyrics-head { display: flex; align-items: center; gap: 7px; font-weight: 700; font-size: .92rem; color: var(--ink); margin-bottom: 8px; }
.lyrics-head .ic { color: var(--wine); }
.lyrics { white-space: pre-wrap; background: #fff; border: 1px dashed var(--line); border-radius: var(--radius-sm);
  padding: 16px; font-size: .94rem; color: #4A3C3E; max-height: 260px; overflow: auto; line-height: 1.7; }

.offer { border: 2px solid var(--wine); border-radius: var(--radius); padding: 18px; background: #fff; }
.price-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px dashed var(--line); color: var(--ink); }
.price-row:last-child { border-bottom: none; }
.price-row .v { font-weight: 700; font-variant-numeric: tabular-nums; }
.price-total { display: flex; align-items: center; justify-content: space-between; margin-top: 8px; padding-top: 12px; border-top: 2px solid var(--line); color: var(--ink); }
.price-total .v { font-size: 1.6rem; font-weight: 800; color: var(--wine-deep); font-family: var(--font-head); }
.bump { display: flex; gap: 12px; align-items: flex-start; border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  padding: 15px; margin: 14px 0; cursor: pointer; transition: all .15s; background: #fff; }
.bump.selected { border-color: var(--gold); background: #FFFBF3; }

.bump input { -webkit-appearance: none; appearance: none; width: 22px; height: 22px; min-height: 0; padding: 0;
  flex: none; margin: 1px 0 0; border: 2px solid #D9C4BD; border-radius: 6px; background: #fff; cursor: pointer;
  position: relative; transition: all .15s; }
.bump input:hover { border-color: var(--success); }
.bump input:checked { background: linear-gradient(135deg, var(--success), var(--success-light)); border-color: transparent;
  box-shadow: 0 3px 10px -2px rgba(17,147,95,.45); }
.bump input:checked::after { content: ''; position: absolute; left: 7.5px; top: 3px; width: 4.5px; height: 9px;
  border: solid #fff; border-width: 0 2.2px 2.2px 0; transform: rotate(45deg); }
.bump input:focus-visible { outline: none; box-shadow: 0 0 0 4px rgba(17,147,95,.2); }
.bump .t { font-weight: 800; color: var(--ink); }
.bump .badge { display: inline-block; background: #FBE6DF; color: #9A3A2E; font-size: .72rem; font-weight: 800; padding: 2px 9px; border-radius: 999px; margin-left: 6px; }

.pix { text-align: center; }
.pix img { width: 220px; height: 220px; margin: 8px auto; border: 1px solid var(--line); border-radius: var(--radius-sm); background: #fff; }
.pix .copy { display: flex; gap: 8px; }
.pix .copy input { font-family: ui-monospace, monospace; font-size: .8rem; }
.status-line { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: var(--ink); }
.status-line .pulse { width: 10px; height: 10px; border-radius: 50%; background: var(--gold); animation: pulse 1.4s infinite; }
.status-line.ok .pulse { background: var(--success); animation: none; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }

.alert { border-radius: var(--radius-sm); padding: 12px 14px; font-size: .9rem; margin: 12px 0; }
.alert-err { background: #FCEDEC; color: #8E2A20; border: 1px solid #F3C9C4; }
.alert-ok { background: #EAF7F0; color: #1E6B49; border: 1px solid #BFE6D2; }

footer { margin: 48px 0 30px; text-align: center; color: var(--on-dark-soft); font-size: .82rem; }
footer a { color: var(--on-dark-soft); margin: 0 8px; }

.sp-toast {

  position: fixed; left: 14px; bottom: calc(116px + env(safe-area-inset-bottom, 0px)); z-index: 60;
  width: min(290px, calc(100vw - 28px));
  display: flex; align-items: center; gap: 11px;
  background: #fff; color: var(--ink); border: 1px solid var(--line);
  border-radius: 14px; padding: 10px 11px; box-shadow: 0 16px 44px -14px rgba(0,0,0,.45);
  transform: translateY(24px) scale(.98); opacity: 0; pointer-events: none;
  transition: transform .38s cubic-bezier(.2,.85,.25,1), opacity .38s;
}

.sp-toast.show { transform: translateY(0) scale(1); opacity: 1; pointer-events: none; }
.sp-ava { width: 38px; height: 38px; flex: none; border-radius: 50%; display: grid; place-items: center;
  color: #fff; font-weight: 800; font-size: .95rem; background: linear-gradient(135deg, var(--wine), var(--wine-light)); }
.sp-body { flex: 1; min-width: 0; }
.sp-msg { font-size: .82rem; font-weight: 600; line-height: 1.3; color: var(--ink); }
.sp-msg b { font-weight: 800; }
.sp-time { font-size: .69rem; color: var(--ink-soft); margin-top: 2px; display: flex; align-items: center; gap: 5px; }
.sp-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--success); display: inline-block; animation: spPulse 1.6s infinite; }
@keyframes spPulse { 0%{box-shadow:0 0 0 0 rgba(38,185,120,.5)} 70%{box-shadow:0 0 0 6px rgba(38,185,120,0)} 100%{box-shadow:0 0 0 0 rgba(38,185,120,0)} }
.sp-close { flex: none; background: none; border: none; color: #B9A8A2; cursor: pointer; font-size: 1.2rem; line-height: 1; padding: 0 2px; pointer-events: auto; }
.sp-close:hover { color: var(--ink); }
@media (prefers-reduced-motion: reduce) { .sp-toast { transition: opacity .3s; transform: none; } .sp-toast.show { transform: none; } }

@media (max-width: 768px) {
  .sp-toast {
    top: calc(env(safe-area-inset-top, 0px) + 58px); bottom: auto; left: 8px;
    width: min(184px, calc(100vw - 16px));
    padding: 6px 8px; gap: 7px; border-radius: 10px;
    box-shadow: 0 6px 18px -9px rgba(0,0,0,.4);
    transform: translateY(-12px) scale(.98);
    pointer-events: none !important;
  }
  .sp-toast.show { transform: translateY(0) scale(1); }
  .sp-close { pointer-events: auto; font-size: .9rem; padding: 0; }
  .sp-ava { width: 24px; height: 24px; font-size: .68rem; }
  .sp-msg { font-size: .69rem; line-height: 1.18; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
  .sp-time { font-size: .58rem; margin-top: 1px; }
}

.spinner { width: 18px; height: 18px; border: 2.5px solid rgba(255,255,255,.5); border-top-color: #fff; border-radius: 50%; animation: spin .7s linear infinite; }
.btn-ghost .spinner { border-color: rgba(0,0,0,.2); border-top-color: var(--ink); }
@keyframes spin { to { transform: rotate(360deg); } }

@media (min-width: 880px) {
  .hero-split { grid-template-columns: 1.05fr .95fr; gap: 48px; padding: 56px 0 36px; align-items: start; }
  .choice-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }

  .hero-h1-mob, .hero-by, .hero-video { display: none !important; }
  .hero-h1-desk { display: block; font-size: clamp(2.8rem, 4.6vw, 4.2rem); line-height: 1.04; margin: 4px 0 10px; }
  .hero-left .auth-line { justify-content: flex-start; }

  .hero-cta, .hero-risk { display: none; }
}
@media (max-width: 879px) {
  .hero-left { text-align: center; }
  .hero-left p.sub { margin-left: auto; margin-right: auto; }
  .hero-pills { justify-content: center; }
  .hero-h1-desk { display: none; }
  .hero-h1-mob { font-size: clamp(1.8rem, 6.8vw, 2.4rem); }
  .hero-left .auth-line { justify-content: center; }

  .price-pill, .nav-cta { display: none; }
}
@media (max-width: 520px) {
  h1 { font-size: 1.8rem; line-height: 1.06; overflow-wrap: anywhere; }
  .hero-left h1 { line-height: 1.06; }
  .topbar .container { height: 62px; }
  .brand { font-size: 1.05rem; }
  .card, .card.lg { padding: 20px; }
  .hero-split { padding: 22px 0 18px; }
  .wiz-step .lbl { display: none; }
  .hero-pills { gap: 6px; }
  .glass-pill { font-size: .72rem; padding: 7px 10px; gap: 5px; }
  .glass-pill .ic { width: 13px; height: 13px; }
}
@media (prefers-reduced-motion: reduce) { *, body::after { animation: none !important; transition: none !important; } }

.lang-switch { display: inline-flex; align-items: center; }
.lang-select {
  appearance: none; -webkit-appearance: none;
  background: var(--glass-bg); color: var(--on-dark);
  border: 1px solid var(--glass-bd); border-radius: 999px;
  padding: 6px 28px 6px 12px; font: inherit; font-size: .82rem; font-weight: 600;
  cursor: pointer; line-height: 1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center;
}
.lang-select option { color: #20171A; }

.intl-checkout {
  margin-top: 18px; padding: 18px; border-radius: var(--radius);
  border: 1px dashed var(--line); background: var(--card-2);
  color: var(--ink); text-align: left;
}
.intl-checkout h3 { margin: 0 0 6px; font-family: var(--font-head); font-size: 1.15rem; }
.intl-checkout .copy { margin-top: 12px; }
.intl-checkout #intlEmail {
  flex: 1; min-width: 0; padding: 11px 12px; border: 1px solid var(--line);
  border-radius: var(--radius-sm); font: inherit;
}
.intl-checkout #intlDone { margin-top: 10px; }

@media (max-width: 520px) {
  .lang-select { padding: 5px 24px 5px 10px; font-size: .78rem; }
}

.lp { padding: 40px 0; }
.lp + .lp { border-top: 1px solid var(--on-dark-faint); }
.lp .lp-eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  color: var(--gold); font-size: .76rem; font-weight: 800;
  letter-spacing: .12em; text-transform: uppercase; margin-bottom: 12px;
}
.lp .lp-eyebrow .ic { width: 15px; height: 15px; color: var(--gold); }
.lp h2 { color: var(--on-dark); text-shadow: 0 2px 18px rgba(0,0,0,.55); }
.lp .lp-sub {
  color: var(--on-dark-soft); font-size: 1.04rem; max-width: 42ch;
  margin: 0 auto 22px;
}
.lp .lp-cta { display: flex; width: fit-content; max-width: 100%; margin: 22px auto 0; padding-left: 30px; padding-right: 30px; }

.lp-ex-grid {
  display: grid; grid-template-columns: 1fr; gap: 16px;
  margin: 26px auto 4px; max-width: 760px;
}
.lp-ex-card {
  margin: 0; text-align: left;
  background: var(--card); color: var(--ink);
  border: 1px solid rgba(255,255,255,.6); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 22px;
}
.lp-ex-tag {
  display: inline-block; background: #FBE6DF; color: #9A3A2E;
  font-size: .72rem; font-weight: 800; letter-spacing: .02em;
  padding: 4px 11px; border-radius: 999px; margin-bottom: 10px;
}
.lp-ex-title {
  font-family: var(--font-body); font-weight: 800; font-size: 1.12rem;
  color: var(--ink); margin: 0 0 4px;
}
.lp-ex-story { color: var(--ink-soft); font-size: .92rem; margin: 0 0 14px; }

.lp-ex-audio.is-enhanced { display: none; }
.lp-ex-audio { width: 100%; height: 46px; border-radius: 999px; background: var(--card-2); border: 1px solid var(--line); }
.lp-ex-player {
  display: flex; align-items: center; gap: 13px;
  padding: 9px 14px 9px 9px; border-radius: 999px;
  background: linear-gradient(180deg, #FFF6F0, #FCEDE6);
  border: 1px solid rgba(154,58,46,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}
.lp-ex-play {
  flex: none; width: 46px; height: 46px; border: 0; cursor: pointer;
  border-radius: 50%; display: grid; place-items: center; color: #fff;
  background: linear-gradient(135deg, var(--wine), var(--wine-light));
  box-shadow: var(--shadow-glow); transition: transform .15s ease;
}
.lp-ex-play:hover { transform: scale(1.06); }
.lp-ex-play:active { transform: scale(.95); }
.lp-ex-play svg { margin-left: 1px; }
.lp-ex-player.playing .lp-ex-play svg { margin-left: 0; }
.lp-ex-bar {
  flex: 1; height: 7px; border-radius: 999px; cursor: pointer; position: relative;
  background: rgba(142,42,64,.15); overflow: hidden;
}
.lp-ex-fill { position: absolute; inset: 0 auto 0 0; width: 0; background: linear-gradient(90deg, var(--wine), var(--gold)); border-radius: 999px; }
.lp-ex-time {
  flex: none; min-width: 36px; text-align: right;
  font-variant-numeric: tabular-nums; font-weight: 800; font-size: .8rem; color: var(--wine);
}

.lp-how, .lp-proof {
  background: linear-gradient(180deg, rgba(18,9,12,0) 0%, rgba(18,9,12,.5) 18%, rgba(18,9,12,.5) 82%, rgba(18,9,12,0) 100%);
}
.lp-how .lp-eyebrow { margin-bottom: 12px; }
.lp-steps {
  list-style: none; margin: 36px auto 8px; padding: 0; max-width: 920px;
  display: grid; grid-template-columns: 1fr; gap: 30px; position: relative;
}
.lp-step { background: none; border: 0; box-shadow: none; padding: 0; text-align: center; position: relative; }
.lp-step-num {
  display: grid; place-items: center; width: 66px; height: 66px; margin: 0 auto 14px;
  position: relative; z-index: 1; border-radius: 50%;
  font-family: var(--font-head); font-weight: 700; font-size: 1.9rem; color: var(--gold);
  background: rgba(26,14,18,.82); border: 1.5px solid rgba(227,178,97,.42);
  box-shadow: 0 10px 26px rgba(0,0,0,.4), inset 0 0 0 5px rgba(255,255,255,.025);
  -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px);
}
.lp-step h3 { color: var(--on-dark); font-family: var(--font-body); font-weight: 800; font-size: 1.12rem; margin: 0 0 6px; text-shadow: 0 2px 14px rgba(0,0,0,.7); }
.lp-step p { color: var(--on-dark-soft); margin: 0 auto; font-size: .96rem; max-width: 24ch; text-shadow: 0 1px 10px rgba(0,0,0,.6); }

.lp-chips { display: flex; flex-wrap: wrap; gap: 11px; justify-content: center; margin-top: 26px; }
.chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 11px 18px; border-radius: 999px;
  background: rgba(255,250,244,.12);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.30);
  color: #fff; font-size: .92rem; font-weight: 600; white-space: nowrap;
  box-shadow: 0 4px 14px rgba(0,0,0,.22);
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
}
.chip .ic { width: 13px; height: 13px; color: var(--gold); flex: none; }
.chip:hover { transform: translateY(-2px); background: rgba(255,250,244,.20); border-color: var(--gold); }

.lp-compare .cmp-grid { display: grid; grid-template-columns: 1fr; gap: 14px; max-width: 760px; margin: 26px auto 6px; text-align: left; }
.cmp-col { border-radius: var(--radius); padding: 20px 20px 10px; }
.cmp-win { background: var(--card); color: var(--ink); border: 1px solid var(--gold); box-shadow: var(--shadow); }
.cmp-lose { background: rgba(20,12,14,.5); color: var(--on-dark-soft); border: 1px solid rgba(255,255,255,.12); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.cmp-head { font-family: var(--font-head); font-weight: 700; font-size: 1.15rem; margin-bottom: 10px; }
.cmp-win .cmp-head { color: var(--wine); }
.cmp-col ul { list-style: none; margin: 0; padding: 0; }
.cmp-col li { display: flex; align-items: flex-start; gap: 9px; padding: 9px 0; font-size: .95rem; line-height: 1.35; border-top: 1px solid rgba(0,0,0,.06); }
.cmp-lose li { border-top-color: rgba(255,255,255,.08); }
.cmp-col li:first-child { border-top: 0; }
.cmp-win li::before { content: '✓'; color: #1f9d5b; font-weight: 800; flex: none; }
.cmp-lose li::before { content: '✕'; color: #cf7d73; font-weight: 800; flex: none; }
@media (min-width: 760px) { .lp-compare .cmp-grid { grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; } }

.preview-bridge { margin-top: 16px; padding: 14px 16px; border-radius: var(--radius-sm); background: rgba(180,56,82,.08); border: 1px solid rgba(180,56,82,.22); text-align: center; }
.preview-bridge p { margin: 0; color: var(--ink); font-weight: 700; font-size: .98rem; line-height: 1.45; }
.btn.pulse { animation: ctaPulse 1.5s ease-in-out infinite; }
@keyframes ctaPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(45,160,90,0); } 50% { box-shadow: 0 0 0 7px rgba(45,160,90,.20); } }
.pl-modal { position: fixed; inset: 0; z-index: 60; display: grid; place-items: center; padding: 20px; background: rgba(20,12,14,.62); -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); }
.pl-modal.hidden { display: none; }
.pl-modal-card { background: var(--card); color: var(--ink); border-radius: var(--radius); border: 2px solid var(--gold); box-shadow: var(--shadow); padding: 30px 26px; max-width: 380px; width: 100%; text-align: center; }
.pl-modal-emoji { font-size: 2rem; line-height: 1; }
.pl-modal-card h3 { margin: 10px 0 6px; font-size: 1.35rem; color: var(--ink); }
.pl-modal-card p { margin: 0 0 18px; color: var(--ink-soft); line-height: 1.5; font-size: .96rem; }
.pl-modal-card .btn-success { width: 100%; }
.pl-modal-close { display: block; margin: 12px auto 0; background: none; border: none; color: var(--ink-soft); font-size: .9rem; cursor: pointer; text-decoration: underline; }

.cover-preview { text-align: center; margin: 4px 0 20px; }
.cover-art { width: 196px; height: 196px; margin: 0 auto; border-radius: 16px; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.16); background: linear-gradient(150deg, var(--wine), var(--wine-deep)); color: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 14px; }
.cover-emblem .ic { width: 30px; height: 30px; color: var(--gold); margin-bottom: 6px; }
.cover-para { font-size: .68rem; letter-spacing: .3em; opacity: .82; }
.cover-name { font-family: var(--font-head); font-size: 1.85rem; line-height: 1.08; color: var(--gold); padding: 2px 8px; word-break: break-word; }
.cover-brand { font-size: .62rem; letter-spacing: .26em; opacity: .85; margin-top: 6px; }
.cover-caption { margin: 12px 0 0; font-size: .82rem; color: var(--ink-soft); }

.quiz-progress { height: 6px; border-radius: 999px; background: rgba(0,0,0,.08); overflow: hidden; margin: 2px 0 22px; }
.quiz-progress span { display: block; height: 100%; width: 25%; background: linear-gradient(90deg, var(--wine), var(--gold)); border-radius: 999px; transition: width .35s ease; }

.gen-proof { margin-top: 22px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,.08); }
.gen-proof-title { font-weight: 700; color: var(--ink); margin: 0 0 12px; font-size: .98rem; line-height: 1.4; }
.gen-proof-video { width: 100%; max-width: 280px; aspect-ratio: 9 / 16; border-radius: 14px; box-shadow: var(--shadow); background: #000; display: block; margin: 0 auto; }
.gen-proof-cap { margin: 10px 0 0; font-size: .8rem; color: var(--ink-soft); }

.sticky-cta { position: fixed; left: 50%; bottom: 16px; transform: translate(-50%, 170%); z-index: 80; width: calc(100% - 26px); max-width: 460px; display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 13px 22px; border-radius: 16px; text-decoration: none; color: #fff; background: linear-gradient(135deg, #2fa463, #1c854a); box-shadow: 0 12px 34px rgba(0,0,0,.42); transition: transform .45s cubic-bezier(.2,.9,.25,1); }
.sticky-cta.show { transform: translate(-50%, 0); animation: stickyPulse 2.2s ease-in-out infinite; }
.sticky-cta-main { font-weight: 800; font-size: 1.06rem; letter-spacing: -.01em; }
.sticky-cta-sub { font-size: .76rem; opacity: .92; }
@keyframes stickyPulse { 0%,100% { box-shadow: 0 12px 34px rgba(0,0,0,.42), 0 0 0 0 rgba(47,164,99,.5); } 55% { box-shadow: 0 12px 34px rgba(0,0,0,.42), 0 0 0 13px rgba(47,164,99,0); } }
@media (min-width: 760px) { .sticky-cta { bottom: 22px; } }

#briefForm { text-align: center; }
#briefForm .wiz-title, #briefForm label, #briefForm .help, #briefForm .card-eyebrow { text-align: center; }
#briefForm input { text-align: center; }
#briefForm textarea { text-align: left; }
.offer-pricerow { justify-content: center; }
.offer-badges { justify-content: center; }

.offer-line { display: flex; flex-direction: column; align-items: center; gap: 10px; margin: 10px 0 16px; }
.offer-badges { display: flex; flex-wrap: wrap; align-items: center; gap: 7px; }
.offer-copa { display: inline-flex; align-items: center; gap: 5px; background: linear-gradient(90deg, rgba(142,42,64,.12), rgba(227,178,97,.18)); color: var(--wine); border: 1px solid rgba(227,178,97,.5); font-weight: 800; font-size: .72rem; letter-spacing: .02em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; white-space: nowrap; }
.offer-free { display: inline-flex; align-items: center; gap: 5px; background: rgba(31,157,91,.12); color: #1c854a; border: 1px solid rgba(31,157,91,.28); font-weight: 800; font-size: .72rem; letter-spacing: .01em; padding: 4px 10px; border-radius: 999px; white-space: nowrap; }
.offer-free .ic { width: 13px; height: 13px; }
.offer-free .ic { width: 14px; height: 14px; }
.offer-pricerow { display: flex; align-items: baseline; gap: 9px; flex-wrap: wrap; }
.offer-lbl { color: var(--ink-soft); font-size: .95rem; }
.offer-anchor { color: var(--ink-soft); opacity: .6; text-decoration: line-through; font-weight: 600; font-size: .98rem; }
.offer-price { color: var(--wine); font-weight: 900; font-size: 2.15rem; letter-spacing: -.02em; line-height: 1; }
.offer-save { display: inline-flex; align-items: center; gap: 8px; background: rgba(31,157,91,.12); color: #14784f; border: 1px solid rgba(31,157,91,.3); font-weight: 700; font-size: .92rem; padding: 6px 13px; border-radius: 999px; }
.offer-save b { font-weight: 900; }
.offer-off { display: inline-flex; align-items: center; background: var(--wine); color: #fff; font-weight: 800; font-size: .72rem; letter-spacing: .01em; padding: 2px 8px; border-radius: 6px; }

@media (max-width: 520px) { .offer-save { align-self: center; } }
.coupon-note { margin: 0 0 16px; padding: 11px 14px; border-radius: 12px; font-size: .9rem; color: #1c854a; background: rgba(31,157,91,.10); border: 1px solid rgba(31,157,91,.28); }

.hero-proof { margin: 18px 0 0; max-width: 46ch; border-left: 3px solid var(--gold); padding: 2px 0 2px 16px; }
.hero-proof .hp-stars { display: inline-flex; gap: 2px; color: var(--gold); margin-bottom: 6px; }
.hero-proof .hp-stars .ic { width: 17px; height: 17px; }
.hero-proof .hp-quote { margin: 0 0 6px; font-size: .98rem; line-height: 1.45; color: var(--on-dark); font-style: italic; }
.hero-proof .hp-author { font-size: .82rem; color: var(--on-dark-soft); font-weight: 600; }

.hero-by { margin: 6px 0 18px; font-size: .92rem; color: var(--on-dark-soft); line-height: 1.5; max-width: 48ch; }

.hero-video { position: relative; margin: 0 auto 18px; width: fit-content; }
.hero-video video { display: block; max-height: 460px; max-width: 100%; border-radius: 18px; border: 1px solid rgba(255,255,255,.14); box-shadow: 0 18px 48px rgba(0,0,0,.5); background: #000; }
.hero-video .hv-sound { position: absolute; bottom: 12px; right: 12px; border: 0; cursor: pointer; background: rgba(0,0,0,.6); color: #fff; font-weight: 700; font-size: .82rem; padding: 7px 12px; border-radius: 999px; backdrop-filter: blur(4px); }

.auth-line { display: flex; align-items: baseline; flex-wrap: wrap; gap: 8px 26px; margin: 8px 0 22px; }
.auth-line--center { justify-content: center; }
.auth-item { display: inline-flex; align-items: baseline; gap: 7px; font-size: .92rem; color: var(--on-dark-soft); white-space: nowrap; }
.auth-item b { font-family: var(--font-head); font-size: 1.6rem; font-weight: 700; color: var(--gold); line-height: 1; letter-spacing: -.01em; }
.auth-stars { color: var(--gold); font-size: .95rem; letter-spacing: 1px; }

.brief-flash { animation: briefFlash 1.25s ease-out; }
@keyframes briefFlash {
  0%   { outline: 0 solid rgba(227,178,97,0);   outline-offset: 5px; }
  22%  { outline: 3px solid rgba(227,178,97,.95); outline-offset: 5px; }
  100% { outline: 0 solid rgba(227,178,97,0);   outline-offset: 5px; }
}
@media (prefers-reduced-motion: reduce) { .brief-flash { animation: none; } }

.urgency-bar { position: sticky; top: 0; z-index: 60; background: linear-gradient(90deg, #b01228, #d11f38); color: #fff; text-align: center; font-weight: 700; font-size: .9rem; letter-spacing: .2px; padding: 8px 14px; box-shadow: 0 2px 12px rgba(0,0,0,.28); }
.urgency-bar b { font-variant-numeric: tabular-nums; }
body.has-urgency .topbar { top: 37px; }

.online-now { display: inline-flex; align-items: center; gap: 8px; font-size: .82rem; font-weight: 600; color: #6b5b58; margin: 4px 0 14px; }
.online-now b { color: #14784f; font-weight: 800; }
.online-dot { width: 9px; height: 9px; border-radius: 50%; background: #1aa06d; flex: none; box-shadow: 0 0 0 0 rgba(26,160,109,.6); animation: onlinePulse 1.8s infinite; }
@keyframes onlinePulse { 0% { box-shadow: 0 0 0 0 rgba(26,160,109,.5); } 70% { box-shadow: 0 0 0 7px rgba(26,160,109,0); } 100% { box-shadow: 0 0 0 0 rgba(26,160,109,0); } }
@media (prefers-reduced-motion: reduce) { .online-dot { animation: none; } }

.hero-cta { width: auto; align-self: flex-start; margin: 4px 0 6px; padding-left: 28px; padding-right: 28px; font-size: 1.05rem; }
.hero-risk { margin: 0 0 4px; font-size: .82rem; color: var(--on-dark-soft); }
.nav-cta { padding: 8px 16px; font-size: .9rem; }
.foot-contact { margin-top: 10px; font-size: .9rem; }
.foot-contact .ic { width: 14px; height: 14px; color: var(--gold); vertical-align: -2px; }
.foot-contact a { color: var(--gold); font-weight: 600; }

.lp-proof { padding: 6px 0 26px; }
.lp-proof .auth-line { margin: 0 auto 18px; }
.proof-line { color: var(--on-dark); max-width: 46ch; margin: 0 auto 20px; font-size: 1.05rem; line-height: 1.55; }

.bump-modal { position: fixed; inset: 0; z-index: 90; display: flex; align-items: center; justify-content: center; padding: 22px; background: rgba(0,0,0,.6); backdrop-filter: blur(3px); }
.bump-card { background: var(--card); border-radius: 18px; max-width: 380px; width: 100%; padding: 26px 24px; text-align: center; box-shadow: var(--shadow); }
.bump-card .bump-emoji { font-size: 34px; line-height: 1; }
.bump-card h3 { margin: 10px 0 6px; font-family: var(--font-head); color: var(--ink); }
.bump-card p { color: var(--ink-soft); font-size: .95rem; line-height: 1.5; margin: 0 0 18px; }
.bump-card .btn { width: 100%; }
.bump-card .btn + .btn { margin-top: 8px; }

.lp-guarantee-card {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 16px;
  background: var(--card); color: var(--ink);
  border: 2px solid var(--gold); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 40px 32px;
  max-width: 560px; margin: 0 auto;
}
.lp-guarantee-card > div { width: 100%; }
.lp-guarantee-icon {
  flex: none; display: grid; place-items: center; width: 56px; height: 56px; border-radius: 16px;
  color: #fff; background: linear-gradient(135deg, var(--wine), var(--wine-light));
  box-shadow: var(--shadow-glow);
}
.lp-guarantee-icon .ic { width: 28px; height: 28px; }
.lp-guarantee-card h2 { color: var(--ink); text-shadow: none; font-size: 1.55rem; margin: 2px 0 0; }
.lp-guarantee-card p { color: var(--ink-soft); margin: 10px auto 0; max-width: 46ch; line-height: 1.6; }
.lp-guarantee-card .lp-cta { width: fit-content; margin: 4px auto 0; }

.trust-strip {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 12px 20px;
}

.pay-mark { display: inline-flex; align-items: center; gap: 8px; }
.pay-mark img { display: block; width: auto; }
.pay-logo { height: 26px; }
.pay-glyph { height: 22px; flex: none; }
.pay-name { font-size: .9rem; font-weight: 800; letter-spacing: -.01em; }

.pay-name { color: #2D3277; }

.trust-line {
  display: inline-flex; align-items: center; justify-content: center; flex-wrap: wrap; text-align: center; gap: 7px;
  font-size: .84rem; font-weight: 600; color: var(--ink-soft);
}

@media (max-width: 560px) { .trust-line { width: 100%; } }
.trust-line .ic { width: 15px; height: 15px; color: var(--success); flex: none; }

.trust-strip--dark .pay-name { color: var(--on-dark); }
.trust-strip--dark .trust-line { color: var(--on-dark-soft); }
.trust-strip--dark .trust-line .ic { color: var(--gold); }

.hero-seals { margin: 22px 0 6px; }
@media (min-width: 760px) {
  .hero-seals { margin: 30px 0 10px; }
}

.foot-strip { margin: 6px 0 14px; }
.foot-strip .pay-glyph { height: 18px; }
.foot-strip .pay-name { font-size: .84rem; }

.lp-testi { padding-bottom: 52px; }
.lp-testi .lp-sub { margin-top: 6px; }

.testi-carousel { position: relative; margin-top: 26px; }
.testi-viewport { overflow: hidden; width: 100%; min-width: 0; }
.testi-track {
  list-style: none; margin: 0; padding: 6px 0; display: flex;
  transition: transform .5s cubic-bezier(.22,.61,.36,1); will-change: transform;
}

.testi-slide { flex: 0 0 100%; max-width: 100%; padding: 0 6px; box-sizing: border-box; }

.testi-slide .lp-testi-card {
  height: 100%; display: flex; flex-direction: column; margin: 0;
  background: var(--card); color: var(--ink);
  border: 1px solid rgba(255,255,255,.6); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 20px 18px;
}
.lp-stars { display: flex; gap: 3px; margin-bottom: 12px; }
.lp-stars .ic { width: 18px; height: 18px; color: var(--gold); }
.testi-slide .lp-testi-card blockquote {
  margin: 0 0 16px; font-size: .96rem; line-height: 1.5; color: var(--ink);
  font-style: italic; flex: 1;
}

.testi-nav { display: flex; align-items: center; justify-content: center; gap: 14px; margin-top: 18px; }

.testi-foot { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.testi-ava {
  position: relative; width: 46px; height: 46px; flex: none; border-radius: 50%;
  display: grid; place-items: center; overflow: hidden;
  color: #fff; font-weight: 800; font-size: 1.1rem;
  background: linear-gradient(135deg, var(--wine), var(--gold));
  box-shadow: 0 6px 16px -6px rgba(180,56,82,.55);
}
.testi-ava-initial { position: relative; z-index: 0; }
.testi-ava-photo { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: 0; transition: opacity .2s; z-index: 1; }
.testi-ava-photo.is-loaded { opacity: 1; }
.testi-who { display: flex; flex-direction: column; line-height: 1.25; }
.testi-name { font-weight: 800; color: var(--ink); font-size: .98rem; }
.testi-city { font-size: .82rem; color: var(--wine-deep); font-weight: 600; }

.testi-arrow {
  flex: none; width: 44px; height: 44px; border-radius: 50%; cursor: pointer;
  display: grid; place-items: center; color: var(--on-dark);
  background: var(--glass-bg); border: 1px solid var(--glass-bd);
  transition: background .15s, transform .12s, border-color .15s;
}
.testi-arrow:hover { background: rgba(255,255,255,.22); border-color: var(--on-dark); }
.testi-arrow:active { transform: scale(.94); }
.testi-arrow:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(224,184,115,.55); }
.testi-arrow .ic { width: 22px; height: 22px; }

.testi-dots { display: flex; justify-content: center; align-items: center; gap: 9px; flex-wrap: wrap; }
.testi-dot {
  width: 9px; height: 9px; padding: 0; border: none; border-radius: 999px; cursor: pointer;
  background: var(--on-dark-faint); transition: width .2s, background .2s;
}
.testi-dot:hover { background: var(--on-dark-soft); }
.testi-dot.is-active { width: 26px; background: var(--gold); }
.testi-dot:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(224,184,115,.5); }
@media (prefers-reduced-motion: reduce) { .testi-track { transition: none; } }

.lp-faq-list { margin-top: 24px; display: grid; gap: 10px; }
.lp-faq-item {
  background: var(--card); color: var(--ink);
  border: 1px solid rgba(255,255,255,.6); border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm); overflow: hidden;
  align-self: start;
  transition: box-shadow .2s, border-color .2s;
}
.lp-faq-item[open] { box-shadow: var(--shadow); border-color: var(--gold); }
.lp-faq-item summary {
  list-style: none; cursor: pointer; padding: 18px 52px 18px 22px; position: relative;
  font-weight: 700; font-size: 1.08rem; color: var(--ink); line-height: 1.4;
}
.lp-faq-item summary::-webkit-details-marker { display: none; }
.lp-faq-item summary::after {
  content: ''; position: absolute; right: 17px; top: 50%;
  width: 10px; height: 10px; margin-top: -6px;
  border-right: 2.2px solid var(--wine); border-bottom: 2.2px solid var(--wine);
  transform: rotate(45deg); transition: transform .2s ease;
}
.lp-faq-item[open] summary::after { transform: rotate(-135deg); margin-top: -3px; }
.lp-faq-item summary:focus-visible { outline: none; box-shadow: inset 0 0 0 3px rgba(180,56,82,.25); }
.lp-faq-a { padding: 0 22px 18px; }
.lp-faq-a p { margin: 0; color: var(--ink-soft); line-height: 1.62; font-size: 1.02rem; }

@media (min-width: 760px) {
  .lp-faq .container.narrow { max-width: 720px; }
  .lp-faq-list { grid-template-columns: 1fr; gap: 12px; }
}

.foot-trust {
  display: flex; flex-wrap: wrap; gap: 14px 22px; justify-content: center;
  padding-bottom: 18px; margin-bottom: 16px; border-bottom: 1px solid var(--on-dark-faint);
}
.foot-trust-item {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--on-dark-soft); font-size: .84rem; font-weight: 600; text-decoration: none;
}
a.foot-trust-item:hover { color: var(--on-dark); }
.foot-trust-item .ic { width: 16px; height: 16px; color: var(--gold); flex: none; }
.foot-links { margin-bottom: 4px; }
.foot-cnpj { margin-top: 6px; font-size: .74rem; opacity: .65; }

@media (min-width: 760px) {
  .lp { padding: 56px 0; }
  .lp-steps { grid-template-columns: repeat(3, 1fr); gap: 28px; }

  .lp-steps::before {
    content: ''; position: absolute; top: 33px; left: 17%; right: 17%; height: 2px; z-index: 0;
    background: linear-gradient(90deg, transparent, rgba(227,178,97,.55), transparent);
  }
  .lp-ex-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; max-width: 760px; }
}

@media (min-width: 700px) {
  .testi-slide { flex-basis: 50%; max-width: 50%; }

  .testi-slide .lp-testi-card { padding: 26px 24px; }
  .testi-slide .lp-testi-card blockquote { font-size: 1.04rem; line-height: 1.62; margin-bottom: 18px; }
  .lp-stars .ic { width: 19px; height: 19px; }

  .testi-carousel { padding: 0 4px; }
  .testi-nav { gap: 0; margin-top: 18px; }
  .testi-arrow {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
    background: #fff; color: var(--wine); border-color: var(--line);
    box-shadow: var(--shadow-sm);
  }
  .testi-arrow:hover { background: #fff; border-color: var(--wine); color: var(--wine-deep); }
  .testi-arrow:active { transform: translateY(-50%) scale(.94); }
  .testi-prev { left: -6px; }
  .testi-next { right: -6px; }
}
@media (min-width: 1040px) {
  .testi-slide { flex-basis: 33.3333%; max-width: 33.3333%; }
}

@media (max-width: 699px) {

  .lp .container { padding: 0 14px; }
  .lp h2 { font-size: 1.5rem; }
  .lp .lp-sub { font-size: .98rem; }

  .lp-guarantee-card { flex-direction: column; gap: 14px; padding: 22px 18px; }
  .lp-guarantee-icon { width: 50px; height: 50px; }
  .lp-guarantee-card h2 { font-size: 1.3rem; }

  .lp-step { padding: 20px 18px; }
  .lp-ex-card { padding: 18px 16px; }

  .chip { font-size: .84rem; padding: 8px 13px; }

  .testi-arrow { width: 42px; height: 42px; }
  .testi-arrow .ic { width: 21px; height: 21px; }
  .testi-nav { gap: 16px; }
}

.btn-gold { color: #43290A; background: linear-gradient(135deg, #F0D18A, var(--gold)); box-shadow: 0 14px 34px -16px rgba(224,184,115,.7); }
.btn-gold:hover { filter: brightness(1.04); transform: translateY(-1px); }

.ocard { padding: 22px 22px 10px; }
.ohead { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.ohead-t { min-width: 0; }
.oname { font-size: 1.24rem; margin: 0 0 3px; color: var(--ink); overflow-wrap: anywhere; }
.ometa { color: var(--ink-soft); font-size: .84rem; margin: 0; }
.ostatus { flex: none; font-size: .72rem; font-weight: 700; padding: 5px 12px; border-radius: 999px; white-space: nowrap; margin-top: 3px; }
.ostatus.ok { background: var(--teal-soft); color: var(--teal); }
.ostatus.exp { background: rgba(32,23,26,.07); color: var(--ink-soft); }
.dlist { list-style: none; margin: 16px 0 0; padding: 0; }
.drow { display: flex; align-items: center; gap: 14px; padding: 15px 0; border-top: 1px solid var(--line); }
.drow:first-child { border-top: 0; padding-top: 6px; }
.dchip { flex: none; width: 44px; height: 44px; border-radius: 13px; display: grid; place-items: center; }
.dchip .ic { width: 21px; height: 21px; }
.dchip-wine { background: rgba(180,56,82,.11); color: var(--wine-deep); }
.dchip-teal { background: var(--teal-soft); color: var(--teal); }
.dchip-gold { background: rgba(224,184,115,.22); color: #9A6A1C; }
.dmeta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.dtitle { font-weight: 700; font-size: 1rem; color: var(--ink); line-height: 1.25; }
.dsub { font-size: .8rem; color: var(--ink-soft); line-height: 1.32; }
.dact { flex: none; display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.dtag { font-size: .82rem; color: var(--ink-soft); font-weight: 600; white-space: nowrap; }
.oexp { margin: 14px 0 6px; }
@media (max-width: 460px) {
  .drow { flex-wrap: wrap; }
  .dact { width: 100%; padding-left: 58px; justify-content: flex-start; }
}
