/* ==========================================================
   1 BUCK  —  LuckyRaffle-style  |  coin bg  |  product collage
   ========================================================== */

:root {
  --gold: #F5C542;
  --gold-h: #E0B12F;
  --gold-glow: rgba(245,197,66,.25);
  --navy: #0E223A;
  --navy-deep: #0A1A2C;
  --cream: #F4F1EB;
  --white: #FFFFFF;
  --dark: #1E1E1E;
  --muted: #6B7280;
  --border: #E5E7EB;
  --ok: #22c55e;
  --err: #ef4444;
  --blue: #3b82f6;
  --head: 'Rajdhani', sans-serif;
  --body: 'Open Sans', sans-serif;
  --r: 14px;
  --r-sm: 8px;
  --r-pill: 999px;
}

/* --- reset --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);font-size:15px;line-height:1.6;color:var(--dark);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

.wrap{max-width:1200px;margin:0 auto;padding:0 16px}
@media(min-width:768px){.wrap{padding:0 24px}}
body.locked{overflow:hidden}

/* =========================  HEADER  ========================= */
.header{position:sticky;top:0;z-index:100;background:var(--white);border-bottom:1px solid var(--border);height:64px;overflow:visible}
.header-row{display:flex;align-items:center;justify-content:space-between;height:100%}
.brand{display:flex;align-items:center;text-decoration:none;position:relative;z-index:101}
.brand-circle{
  width:85px;height:85px;border-radius:50%;
  overflow:hidden;
  position:relative;
  top:24px;
  flex-shrink:0;
  background:var(--gold);
  border:3px solid rgba(255,255,255,.85);
  box-shadow:0 4px 24px rgba(0,0,0,.35);
}
@media(min-width:768px){.brand-circle{width:110px;height:110px;top:30px;border-width:4px}}
@media(min-width:1024px){.brand-circle{width:128px;height:128px;top:34px}}
.brand-circle img{width:100%;height:100%;object-fit:cover;transform:scale(1.5)}
.nav{display:none;gap:24px}
@media(min-width:768px){.nav{display:flex}}
.nav-link{font-size:14px;font-weight:500;color:var(--muted);transition:color .15s}
.nav-link:hover{color:var(--dark)}
.header-right{display:flex;align-items:center;gap:8px}
.burger{display:flex;flex-direction:column;gap:5px;padding:6px}
@media(min-width:768px){.burger{display:none}}
.burger span{display:block;width:20px;height:2px;background:var(--dark);border-radius:2px;transition:transform .25s,opacity .2s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* drawer */
.drawer{position:fixed;inset:64px 0 0;z-index:99;background:var(--white);padding:24px 20px;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.drawer.open{transform:translateX(0)}
@media(min-width:768px){.drawer{display:none!important}}
.drawer-link{font-size:17px;font-weight:500;color:var(--dark);padding:14px 0;border-bottom:1px solid var(--border)}
.drawer-btns{display:flex;flex-direction:column;gap:8px;margin-top:24px}

/* =========================  BUTTONS  ========================= */
.btn-primary{background:var(--gold);color:var(--navy);font-weight:700;border-radius:var(--r-pill);transition:background .15s,box-shadow .15s,transform .1s}
.btn-primary:hover{background:var(--gold-h);box-shadow:0 4px 16px var(--gold-glow)}
.btn-primary:active{transform:scale(.97)}
.btn-outline{background:var(--white);color:var(--dark);font-weight:600;border:1.5px solid var(--dark);border-radius:var(--r-pill);transition:background .15s}
.btn-outline:hover{background:#f9f9f7}
.btn-ghost{background:transparent;color:#fff;font-weight:600;border:1.5px solid rgba(255,255,255,.3);border-radius:var(--r-pill);transition:background .15s,border-color .15s}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
.btn-sm{font-size:13px;padding:7px 18px}
.btn-lg{font-size:16px;padding:14px 36px}
.btn-full{width:100%;display:flex;justify-content:center;padding:12px 0}
.header-right .btn-outline,.header-right .btn-primary{display:none}
@media(min-width:768px){.header-right .btn-outline,.header-right .btn-primary{display:inline-flex}}

/* =========================  HERO  ========================= */
.hero{
  background:linear-gradient(160deg,#0d1f36 0%,#0e2340 30%,#122a4a 60%,#0f2540 100%);
  color:var(--white);
  padding:56px 0 0;
  overflow:hidden;
  position:relative;
  min-height:580px;
}
@media(min-width:768px){.hero{padding:72px 0 0;min-height:640px}}

/* radial glow behind text */
.hero::before{
  content:'';position:absolute;
  top:-10%;left:50%;transform:translateX(-50%);
  width:800px;height:600px;
  background:radial-gradient(ellipse,rgba(245,197,66,.06) 0%,transparent 60%);
  pointer-events:none;
}

.hero-inner{position:relative;z-index:10;text-align:center;padding-bottom:24px}
.hero-title{font-family:var(--head);font-size:clamp(30px,6vw,54px);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin-bottom:16px}
.highlight-box{display:inline-block;background:var(--gold);color:var(--navy);padding:2px 16px;border-radius:var(--r-sm);font-weight:700}
.hero-sub{font-size:15px;color:#90A4AE;max-width:460px;margin:0 auto 28px;line-height:1.65}
@media(min-width:768px){.hero-sub{font-size:16px}}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
@media(max-width:479px){.hero-actions{flex-direction:column;align-items:stretch;padding:0 20px}}
.hero-payments{display:flex;flex-direction:column;gap:6px;align-items:center}
.pay-label{font-size:11px;color:#607D8B;text-transform:uppercase;letter-spacing:.06em}
.pay-icons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.pay-badge{font-size:10px;font-weight:700;padding:4px 10px;background:rgba(255,255,255,.1);border-radius:var(--r-sm);color:#90A4AE}
.pay-badge--light{background:#f3f4f6;color:var(--dark)}

/* =========================  FLOATING COINS  ========================= */
.coin{
  position:absolute;z-index:5;
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(140deg,#FFDF6F 0%,#F5C542 40%,#D4A82E 100%);
  box-shadow:0 4px 20px rgba(245,197,66,.35), inset 0 -3px 6px rgba(180,140,20,.3), inset 0 3px 6px rgba(255,240,180,.5);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.coin span{font-weight:800;font-size:20px;color:rgba(140,90,0,.55);text-shadow:0 1px 0 rgba(255,240,180,.4)}

/* positions + float animations */
.coin--1{width:56px;height:56px;top:8%;left:6%;transform:rotate(-18deg);animation:coinFloat 4s ease-in-out infinite}
.coin--1 span{font-size:24px}
.coin--2{width:40px;height:40px;top:14%;right:8%;transform:rotate(22deg);animation:coinFloat 3.5s ease-in-out .5s infinite}
.coin--2 span{font-size:17px}
.coin--3{width:52px;height:52px;top:50%;left:3%;transform:rotate(10deg);animation:coinFloat 4.5s ease-in-out 1s infinite}
.coin--3 span{font-size:22px}
.coin--4{width:36px;height:36px;top:38%;right:4%;transform:rotate(-28deg);animation:coinFloat 3.8s ease-in-out .3s infinite}
.coin--4 span{font-size:15px}
.coin--5{width:44px;height:44px;bottom:28%;left:12%;transform:rotate(15deg);animation:coinFloat 4.2s ease-in-out .8s infinite}
.coin--5 span{font-size:19px}
.coin--6{width:32px;height:32px;bottom:20%;right:14%;transform:rotate(-12deg);animation:coinFloat 3.6s ease-in-out 1.2s infinite}
.coin--6 span{font-size:14px}
.coin--7{width:42px;height:42px;top:5%;left:44%;transform:rotate(30deg);animation:coinFloat 4s ease-in-out .6s infinite}
.coin--7 span{font-size:18px}

@keyframes coinFloat{
  0%,100%{transform:translateY(0) rotate(var(--coin-r,0deg))}
  50%{transform:translateY(-12px) rotate(var(--coin-r,0deg))}
}

/* hide some coins on small screens */
@media(max-width:600px){.coin--3,.coin--5,.coin--6,.coin--7{display:none}}

/* dots */
.dot{position:absolute;border-radius:50%;pointer-events:none;z-index:4}
.dot--1{width:8px;height:8px;background:rgba(245,197,66,.35);top:22%;left:18%;animation:coinFloat 3s ease-in-out .4s infinite}
.dot--2{width:6px;height:6px;background:rgba(100,180,220,.35);top:12%;right:22%;animation:coinFloat 3.5s ease-in-out .9s infinite}
.dot--3{width:10px;height:10px;background:rgba(245,197,66,.25);bottom:35%;right:10%;animation:coinFloat 4s ease-in-out 1.5s infinite}
.dot--4{width:7px;height:7px;background:rgba(100,180,220,.3);bottom:25%;left:8%;animation:coinFloat 3.2s ease-in-out .2s infinite}

/* CTA banner coins */
.cta-banner{position:relative;overflow:hidden}
.coin--c1{width:44px;height:44px;top:12%;left:5%;transform:rotate(-20deg);animation:coinFloat 4s ease-in-out infinite}
.coin--c1 span{font-size:18px}
.coin--c2{width:36px;height:36px;bottom:15%;right:6%;transform:rotate(25deg);animation:coinFloat 3.5s ease-in-out .6s infinite}
.coin--c2 span{font-size:15px}
.coin--c3{width:28px;height:28px;top:20%;right:18%;transform:rotate(-10deg);animation:coinFloat 3.8s ease-in-out 1s infinite}
.coin--c3 span{font-size:12px}

/* =========================  PAYMENT IMAGE  ========================= */
.payments-img{
  height:56px;width:auto;display:inline-block;
  border-radius:6px;
}
.hero-payments .payments-img{
  height:56px;margin:0 auto;
  background:rgba(255,255,255,.9);padding:5px 14px;border-radius:9px;
}
.payments-img--mid{height:52px}
.payments-img--footer{
  height:52px;margin:0 auto;
  background:rgba(255,255,255,.1);padding:5px 14px;border-radius:9px;
}
.footer-payments{text-align:center;padding:20px 0 16px;border-top:1px solid rgba(255,255,255,.06)}

/* =========================  CARD TIMER  ========================= */
.card-timer{
  display:flex;align-items:center;justify-content:center;gap:2px;
  background:var(--navy);color:var(--white);
  border-radius:var(--r-sm);
  padding:6px 8px;margin-bottom:8px;
  font-family:var(--head);
}
.timer-unit{display:flex;flex-direction:column;align-items:center;min-width:26px}
.timer-num{font-size:15px;font-weight:700;line-height:1.1}
.timer-lbl{font-size:8px;color:#90A4AE;font-weight:500;text-transform:uppercase;letter-spacing:.05em}
.timer-sep{font-size:14px;font-weight:700;color:var(--gold);align-self:flex-start;line-height:1.1;padding-top:1px}
.card-timer.urgent{background:#7f1d1d}
.card-timer.urgent .timer-num{color:#fca5a5}

/* =========================  PRODUCT COLLAGE  ========================= */
.hero-collage{
  position:relative;z-index:8;
  width:100%;max-width:900px;margin:0 auto;
  height:160px;
  pointer-events:none;
}
@media(min-width:600px){.hero-collage{height:200px}}
@media(min-width:900px){.hero-collage{height:240px}}

.collage-item{
  position:absolute;
  background:var(--white);border-radius:10px;overflow:hidden;
  box-shadow:0 6px 24px rgba(0,0,0,.22);
  transition:transform .3s;
  pointer-events:auto;
}
.collage-item img{width:100%;height:100%;object-fit:contain;padding:4px}

/* 7 positions — tightly packed, overlapping, no visible gaps */
.collage-item:nth-child(1){width:110px;height:110px;left:0%;bottom:0;transform:rotate(-8deg);z-index:3}
.collage-item:nth-child(2){width:105px;height:105px;left:11%;bottom:0;transform:rotate(4deg);z-index:4}
.collage-item:nth-child(3){width:120px;height:120px;left:23%;bottom:0;transform:rotate(-2deg);z-index:5}
.collage-item:nth-child(4){width:130px;height:130px;left:calc(50% - 65px);transform:rotate(1deg);bottom:0;z-index:7}
.collage-item:nth-child(5){width:118px;height:118px;right:22%;bottom:0;transform:rotate(3deg);z-index:5}
.collage-item:nth-child(6){width:108px;height:108px;right:10%;bottom:0;transform:rotate(-5deg);z-index:4}
.collage-item:nth-child(7){width:112px;height:112px;right:0%;bottom:0;transform:rotate(7deg);z-index:3}

@media(min-width:600px){
  .collage-item:nth-child(1){width:135px;height:135px}
  .collage-item:nth-child(2){width:125px;height:125px;left:12%}
  .collage-item:nth-child(3){width:145px;height:145px;left:24%}
  .collage-item:nth-child(4){width:160px;height:160px;left:calc(50% - 80px)}
  .collage-item:nth-child(5){width:142px;height:142px;right:23%}
  .collage-item:nth-child(6){width:128px;height:128px;right:11%}
  .collage-item:nth-child(7){width:132px;height:132px}
}
@media(min-width:900px){
  .collage-item:nth-child(1){width:150px;height:150px;left:0%}
  .collage-item:nth-child(2){width:140px;height:140px;left:11%}
  .collage-item:nth-child(3){width:160px;height:160px;left:23%}
  .collage-item:nth-child(4){width:175px;height:175px;left:calc(50% - 87px)}
  .collage-item:nth-child(5){width:155px;height:155px;right:22%}
  .collage-item:nth-child(6){width:142px;height:142px;right:10%}
  .collage-item:nth-child(7){width:148px;height:148px;right:0%}
}

.collage-item:hover{transform:scale(1.06) rotate(0deg)!important;z-index:20;box-shadow:0 12px 40px rgba(0,0,0,.3)}
.collage-price{
  position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--navy);
  font-family:var(--head);font-size:11px;font-weight:700;
  padding:2px 10px;border-radius:var(--r-pill);white-space:nowrap;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}

/* =========================  STATS  ========================= */
.stats{padding:32px 0}
.stats-row{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;text-align:center}
@media(min-width:640px){.stats-row{gap:64px}}
.stat-num{display:block;font-family:var(--head);font-size:28px;font-weight:700;color:var(--dark)}
@media(min-width:640px){.stat-num{font-size:34px}}
.stat-label{font-size:13px;color:var(--muted)}

/* =========================  SECTIONS  ========================= */
.section{padding:40px 0}
@media(min-width:768px){.section{padding:56px 0}}
.section--alt{background:var(--white)}
.section-title{font-family:var(--head);font-size:26px;font-weight:700;color:var(--dark);margin-bottom:24px}
@media(min-width:768px){.section-title{font-size:30px}}
.section-title--center{text-align:center}
.section-head-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.section-head-row .section-title{margin-bottom:0}

/* filter tabs */
.filter-tabs{display:flex;gap:6px}
.tab{padding:6px 16px;border-radius:var(--r-pill);font-size:13px;font-weight:600;border:1.5px solid var(--border);color:var(--muted);background:var(--white);transition:all .15s}
.tab.active,.tab:hover{background:var(--dark);color:var(--white);border-color:var(--dark)}

/* =========================  SCROLL ROW  ========================= */
.scroll-row{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;-webkit-overflow-scrolling:touch}
.scroll-row::-webkit-scrollbar{height:4px}
.scroll-row::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}
.scroll-row>.card{min-width:240px;max-width:260px;flex-shrink:0;scroll-snap-align:start}

/* =========================  GRID  ========================= */
.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
@media(min-width:1000px){.grid{grid-template-columns:repeat(4,1fr)}}

/* =========================  CARD  ========================= */
.card{background:var(--white);border-radius:var(--r);overflow:hidden;border:1.5px solid var(--border);transition:transform .2s,box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.08);border-color:#d1d5db}
.card-img-wrap{position:relative;padding-top:100%;background:#f9f9f7;overflow:hidden}
.card-img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:10px;transition:transform .3s}
.card:hover .card-img-wrap img{transform:scale(1.04)}
.draw-badge{position:absolute;top:10px;left:10px;background:var(--navy);color:var(--white);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 10px;border-radius:var(--r-sm)}
.sold-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--ok);margin-bottom:4px}
.sold-badge svg{width:14px;height:14px}
.entered-badge{position:absolute;top:10px;right:10px;background:var(--ok);color:#fff;font-size:10px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill)}
.card-body{padding:12px 14px 14px}
.card-name{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:2px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
.card-retail{font-size:12px;color:var(--muted);margin-bottom:10px}
.card-prog{height:5px;background:#E5E7EB;border-radius:var(--r-pill);overflow:hidden;margin-bottom:12px}
.card-prog-fill{height:100%;border-radius:var(--r-pill);transition:width .5s}
.card-prog-fill.lo{background:var(--blue)}
.card-prog-fill.mid{background:#f59e0b}
.card-prog-fill.hi{background:var(--err)}
.card-bottom{display:flex;align-items:center;gap:8px}
.enter-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;background:var(--gold);color:var(--navy);font-weight:700;font-size:13px;padding:10px 0;border-radius:var(--r-pill);transition:background .15s,box-shadow .15s,transform .1s;min-height:42px}
.enter-btn:hover{background:var(--gold-h);box-shadow:0 3px 12px var(--gold-glow)}
.enter-btn:active{transform:scale(.97)}
.enter-btn.done{background:var(--ok);color:#fff}
.enter-btn.done:hover{background:#16a34a}
.cart-icon-btn{width:42px;height:42px;border-radius:var(--r-pill);background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .15s;flex-shrink:0}
.cart-icon-btn:hover{background:#17304e}

/* =========================  PAY STRIP  ========================= */
.pay-strip{padding:16px 0}
.pay-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:14px 20px}
.pay-strip-label{font-size:13px;font-weight:600;color:var(--dark)}
.pay-strip-icons{display:flex;gap:6px;flex-wrap:wrap}

/* =========================  STEPS  ========================= */
.steps{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.steps{grid-template-columns:repeat(3,1fr);gap:20px}}
.step-card{background:var(--cream);border-radius:var(--r);padding:28px 22px;text-align:center}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--gold);color:var(--navy);font-family:var(--head);font-weight:700;font-size:18px;margin-bottom:16px}
.step-label{font-family:var(--head);font-size:18px;font-weight:700;margin-bottom:6px;color:var(--dark)}
.step-desc{font-size:14px;color:var(--muted);line-height:1.6}

/* =========================  CTA BANNER  ========================= */
.cta-banner{background:linear-gradient(160deg,#0d1f36,#122a4a,#0f2540);padding:56px 0;color:var(--white)}
.cta-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px;position:relative;z-index:10}
@media(min-width:768px){.cta-inner{flex-direction:row;text-align:left;justify-content:space-between}}
.cta-title{font-family:var(--head);font-size:clamp(22px,4vw,32px);font-weight:700;line-height:1.15}
.cta-checks{display:flex;flex-wrap:wrap;gap:8px 24px;font-size:14px}
.cta-checks li::before{content:'✓ ';color:var(--gold);font-weight:700}

/* =========================  FOOTER  ========================= */
.footer{background:var(--navy-deep);color:#B0BEC5;padding:40px 0 20px}
.footer-inner{display:grid;grid-template-columns:1fr;gap:28px;margin-bottom:28px}
@media(min-width:640px){.footer-inner{grid-template-columns:repeat(3,1fr)}}
.footer-heading{font-family:var(--head);font-size:15px;font-weight:700;color:var(--white);margin-bottom:10px}
.footer-list li{margin-bottom:6px}
.footer-list a{font-size:14px;color:#90A4AE;transition:color .15s}
.footer-list a:hover{color:var(--gold)}
.footer-copy{text-align:center;font-size:12px;color:#607D8B}

/* =========================  TOAST  ========================= */
.toast{position:fixed;top:76px;right:16px;z-index:300;background:var(--ok);color:#fff;padding:10px 22px;border-radius:var(--r-sm);font-size:14px;font-weight:600;opacity:0;transform:translateX(100%);transition:opacity .25s,transform .25s;max-width:320px}
.toast.show{opacity:1;transform:translateX(0)}
.toast.bad{background:var(--err)}

/* =========================  BACK TO TOP  ========================= */
.back-to-top{
  position:fixed;bottom:24px;right:24px;z-index:200;
  width:46px;height:46px;border-radius:50%;
  background:var(--gold);color:var(--navy);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  opacity:0;transform:translateY(20px);
  transition:opacity .25s,transform .25s,background .15s;
  pointer-events:none;
}
.back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.back-to-top:hover{background:var(--gold-h);box-shadow:0 6px 24px var(--gold-glow)}
.back-to-top:active{transform:scale(.93)}

/* =========================  PASSWORD GATE  ========================= */
.pw-gate{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(160deg,#0d1f36 0%,#0e2340 40%,#122a4a 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .4s,visibility .4s;
}
.pw-gate.hidden{opacity:0;visibility:hidden;pointer-events:none}
.pw-box{text-align:center;max-width:340px;padding:24px}
.pw-logo{width:120px;height:120px;border-radius:50%;margin:0 auto 24px;object-fit:cover;transform:scale(1.5)}
.pw-text{color:#90A4AE;font-size:15px;margin-bottom:20px}
.pw-input{
  width:100%;padding:12px 16px;border:1.5px solid rgba(255,255,255,.15);
  border-radius:var(--r-pill);background:rgba(255,255,255,.06);
  color:#fff;font-size:15px;text-align:center;
  outline:none;transition:border-color .15s;
}
.pw-input:focus{border-color:var(--gold)}
.pw-input::placeholder{color:#607D8B}
.pw-btn{width:100%;margin-top:12px}
.pw-error{color:var(--err);font-size:13px;margin-top:12px;opacity:0;transition:opacity .2s}
.pw-error.show{opacity:1}

/* =========================  ENTRANCE ANIMATIONS  ========================= */
/* hide coins + dots + products until entrance starts */
.hero.entrance .coin{opacity:0;animation:none!important}
.hero.entrance .dot{opacity:0;animation:none!important}
.hero.entrance .collage-item{opacity:0}

/* coin fly-in from off-screen with spin */
.hero.entrance .coin.pop-in{animation:coinFlyIn .6s cubic-bezier(.36,.07,.19,.97) forwards!important}

@keyframes coinFlyIn{
  0%  {opacity:0;transform:translate(var(--cx,0),var(--cy,0)) scale(0) rotate(0deg)}
  30% {opacity:1;transform:translate(0,0) scale(1.6) rotate(220deg)}
  50% {transform:translate(0,0) scale(.65) rotate(310deg)}
  65% {transform:translate(0,0) scale(1.3) rotate(350deg)}
  80% {transform:translate(0,0) scale(.9) rotate(358deg)}
  100%{opacity:1;transform:translate(0,0) scale(1) rotate(360deg)}
}

/* fast bounce after landing */
.hero.entrance .coin.fast-float{animation:coinFastBounce .4s ease-in-out infinite alternate!important}

@keyframes coinFastBounce{
  0%  {transform:translateY(0) scale(1)}
  100%{transform:translateY(-18px) scale(1.1)}
}

/* dot fade-in */
.hero.entrance .dot.fade-in{animation:dotFadeIn .6s ease forwards!important}
@keyframes dotFadeIn{
  0%{opacity:0;transform:scale(0)}
  60%{opacity:1;transform:scale(1.3)}
  100%{opacity:1;transform:scale(1)}
}

/* product fly-in from off-screen */
.collage-item.fly-in{animation:productFlyIn .7s cubic-bezier(.22,.61,.36,1) both!important}

@keyframes productFlyIn{
  0%  {opacity:0;transform:translate(var(--fx,0),var(--fy,0)) rotate(var(--fr,0deg)) scale(.1)}
  70% {opacity:1;transform:translate(0,0) rotate(var(--tr,0deg)) scale(1.07)}
  85% {transform:translate(0,0) rotate(var(--tr,0deg)) scale(.97)}
  100%{opacity:1;transform:translate(0,0) rotate(var(--tr,0deg)) scale(1)}
}
