*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;
  background:#1a1a1a;color:#1a1a1a;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  padding-bottom:96px;
}
img{max-width:100%;height:auto;display:block}
button{font:inherit;cursor:pointer}

:root{
  --migrol-red:#a4091e;
  --migrol-red-dark:#730b0e;
  --migrol-yellow:#fdd804;
  --migrol-green:#376e2e;
  --ink:#1a1a1a;
  --muted:#5c5c5c;
  --line:#e8e8e6;
  --max:480px;
}

/* ── Header ── */
.top{
  position:relative;z-index:50;
  max-width:var(--max);margin:0 auto;
  padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.top-logo-migrol{height:24px;width:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.35))}
.top-logo-card{
  height:22px;width:auto;
  background:#fff;border-radius:4px;padding:3px 6px;
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}

/* ── Hero with Migrol station photo ── */
.hero-visual{
  position:relative;
  min-height:min(92vh,820px);
  background:
    linear-gradient(180deg,rgba(20,8,8,.5) 0%,rgba(115,11,14,.75) 45%,rgba(164,9,30,.9) 100%),
    url("../assets/teaser-promotion.png") center 30%/cover no-repeat;
  background-color:#730b0e;
  color:#fff;
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(20,8,8,.55) 0%,rgba(115,11,14,.72) 42%,rgba(164,9,30,.88) 100%),
    linear-gradient(90deg,rgba(0,0,0,.25) 0%,transparent 60%);
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;
  padding:0 20px 32px;
}

.urgency{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:0 -4px 18px;
  padding:14px 16px;
  border-radius:16px;
  background:linear-gradient(135deg,#ff2d2d 0%,var(--migrol-red) 45%,#8a0616 100%);
  box-shadow:0 8px 32px rgba(255,45,45,.45),0 0 0 2px rgba(255,255,255,.25) inset;
  animation:urgencyGlow 2.2s ease-in-out infinite;
}
@keyframes urgencyGlow{
  0%,100%{box-shadow:0 8px 32px rgba(255,45,45,.4),0 0 0 2px rgba(255,255,255,.2) inset}
  50%{box-shadow:0 10px 40px rgba(255,80,80,.65),0 0 0 2px rgba(255,255,255,.35) inset}
}
.urgency-pulse{
  width:10px;height:10px;border-radius:50%;background:#fff;flex-shrink:0;
  animation:blink 1s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
.urgency-text{
  font-size:clamp(15px,4.2vw,18px);font-weight:800;letter-spacing:-.2px;
  text-align:center;line-height:1.25;
}
.urgency-text strong{
  font-size:1.35em;font-weight:900;
  display:inline-block;min-width:1.4em;
  text-shadow:0 2px 8px rgba(0,0,0,.25);
}

.hero-kicker{
  font-size:11px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;
  color:rgba(255,255,255,.85);margin-bottom:10px;
}
.hero-visual h1{
  font-size:clamp(34px,9vw,44px);font-weight:900;line-height:1.02;
  letter-spacing:-1.5px;margin-bottom:12px;
  text-shadow:0 2px 16px rgba(0,0,0,.35);
}
.hero-visual h1 em{font-style:normal;color:var(--migrol-yellow)}

.hero-lead{
  font-size:16px;line-height:1.55;color:rgba(255,255,255,.92);
  margin-bottom:20px;max-width:36em;
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.hero-lead strong{color:#fff}

/* ── Stock bar ── */
.stock-bar{
  background:rgba(255,255,255,.97);
  border-radius:16px;padding:14px 16px;margin-bottom:16px;
  box-shadow:0 8px 28px rgba(0,0,0,.18);
  color:var(--ink);
}
.stock-bar--hot{border:2px solid rgba(255,45,45,.35)}
.stock-bar-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;gap:8px}
.stock-bar-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.9px;color:var(--migrol-red)}
.stock-bar-count{font-size:14px;color:var(--ink);font-weight:600}
.stock-bar-count strong{color:var(--migrol-red);font-size:clamp(28px,7vw,34px);font-weight:900;letter-spacing:-1px;line-height:1}
.stock-bar-count span{font-size:13px;font-weight:600;color:var(--muted);margin-left:4px}
.stock-track{height:10px;background:#f0ece8;border-radius:100px;overflow:hidden}
.stock-fill{
  height:100%;width:1.9%;border-radius:100px;
  background:linear-gradient(90deg,#ff4444,var(--migrol-red));
  transition:width .6s ease;
  box-shadow:0 0 8px rgba(164,9,30,.5);
}
.stock-note{font-size:12px;color:var(--migrol-red);font-weight:700;margin-top:8px;line-height:1.35}

/* ── Price card (glass) ── */
.price-card{
  background:rgba(255,255,255,.98);
  border-radius:22px;
  box-shadow:0 16px 48px rgba(0,0,0,.22);
  padding:22px 20px 20px;
  border:1px solid rgba(255,255,255,.6);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.price-tag{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.9px;
  color:var(--migrol-green);margin-bottom:10px;
}
.price-row{display:flex;align-items:flex-end;gap:12px;margin-bottom:8px}
.price-old{
  font-size:20px;font-weight:600;color:#aaa;
  text-decoration:line-through;letter-spacing:-.5px;
}
.price-new{
  font-size:clamp(42px,11vw,52px);font-weight:900;
  color:var(--migrol-red);letter-spacing:-2px;line-height:1;
}
.price-currency{font-size:.55em;font-weight:800;vertical-align:super;margin-right:2px}
.price-note{font-size:13px;color:var(--muted);line-height:1.45;margin-bottom:12px}
.price-save{
  display:inline-block;
  background:#fff0f2;color:var(--migrol-red);
  font-size:12px;font-weight:800;letter-spacing:.3px;
  padding:6px 12px;border-radius:100px;
  border:1.5px solid rgba(164,9,30,.15);
  margin-bottom:16px;
}

.btn-pay{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;border:none;border-radius:14px;
  background:linear-gradient(180deg,#c50e24 0%,var(--migrol-red) 100%);
  color:#fff;
  font-size:17px;font-weight:800;letter-spacing:-.2px;
  padding:17px 22px;
  box-shadow:0 8px 28px rgba(164,9,30,.4);
  transition:transform .12s,opacity .12s,box-shadow .12s;
}
.btn-pay--hero{margin-top:4px}
.btn-pay:active{transform:scale(.98);opacity:.92}
.btn-pay:disabled{opacity:.65;transform:none;cursor:wait}
.btn-pay svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}

/* ── Page body ── */
.page{
  background:#f5f5f3;
  border-radius:24px 24px 0 0;
  margin-top:-20px;position:relative;z-index:3;
  max-width:var(--max);margin-left:auto;margin-right:auto;
  padding-top:8px;
}

.cards-wrap{
  padding:28px 20px 8px;
}
.cards-wrap img{
  width:100%;border-radius:18px;
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}
.cards-caption{
  text-align:center;font-size:11px;color:#888;margin-top:10px;line-height:1.4;
}

.delivery{
  margin:16px 0 0;
  padding:22px 20px;background:#fff;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;gap:14px;align-items:flex-start;
}
.delivery-icon{color:var(--migrol-red);flex-shrink:0;margin-top:2px}
.delivery h2{font-size:15px;font-weight:800;margin-bottom:6px;color:var(--ink)}
.delivery p{font-size:13px;line-height:1.5;color:var(--muted)}

.perks{
  padding:28px 20px;
  background:#fff;border-bottom:1px solid var(--line);
}
.perks h2{
  font-size:13px;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  color:var(--migrol-red);margin-bottom:18px;
}
.perk{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.perk:last-child{border-bottom:none;padding-bottom:0}
.perk-icon{
  flex-shrink:0;min-width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:900;padding:0 6px;
}
.perk-icon--y{background:#fff8cc;color:#8a7200}
.perk-icon--r{background:#fff0f2;color:var(--migrol-red);font-size:12px}
.perk-icon--g{background:#edf7ea;color:var(--migrol-green);font-size:11px}
.perk h3{font-size:15px;font-weight:700;margin-bottom:3px;color:var(--ink)}
.perk p{font-size:13px;line-height:1.45;color:var(--muted)}

.steps{
  padding:28px 20px;
  background:linear-gradient(180deg,#fafaf8,#fff);
}
.steps h2{
  font-size:13px;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  color:var(--migrol-red);margin-bottom:14px;
}
.steps ol{padding-left:20px;color:var(--muted);font-size:14px;line-height:1.55}
.steps li{margin-bottom:10px}
.steps li:last-child{margin-bottom:0}
.steps strong{color:var(--ink)}

.valid{padding:20px 20px 28px;text-align:center}
.valid p{font-size:13px;color:var(--muted);line-height:1.5}

.cta-inline{padding:0 20px 36px}
.cta-sub{text-align:center;font-size:12px;color:#999;margin-top:10px}

.pay-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:200;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--line);
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  display:flex;align-items:center;gap:14px;
  transform:translateY(0);
  transition:transform .28s ease;
  box-shadow:0 -4px 24px rgba(0,0,0,.08);
  max-width:var(--max);margin:0 auto;
}
@media(min-width:600px){.pay-bar{left:50%;transform:translateX(-50%);width:100%;max-width:520px}}
.pay-bar--hidden{transform:translateY(110%)}
@media(min-width:600px){.pay-bar--hidden{transform:translateX(-50%) translateY(110%)}}
.pay-bar-info{flex:1;min-width:0}
.pay-bar-label{font-size:11px;color:var(--migrol-red);font-weight:800;text-transform:uppercase;letter-spacing:.4px}
.pay-bar-label span{font-size:14px}
.pay-bar-price{font-size:22px;font-weight:900;color:var(--migrol-red);letter-spacing:-1px;line-height:1.1}
.pay-bar-old{font-size:12px;color:#aaa;text-decoration:line-through;font-weight:600;margin-left:6px}
.pay-bar .btn-pay{
  width:auto;flex-shrink:0;padding:14px 18px;font-size:14px;
  border-radius:12px;min-width:132px;
}

.foot{padding:24px 20px 40px;text-align:center}
.foot-logo{margin:0 auto 12px;opacity:.7;height:18px;width:auto}
.foot p{font-size:11px;line-height:1.55;color:#999}

@media(min-width:600px){
  body{padding-bottom:0;background:#111}
  .top{max-width:520px}
  .hero-visual{max-width:520px;margin:0 auto;border-radius:0}
  .hero-inner{max-width:none}
  .page{max-width:520px;border-radius:24px 24px 0 0;margin-top:-24px}
  .pay-bar{display:none}
  .cta-inline{padding-bottom:44px}
}
