:root{
  --bg:#050914;--panel:#0b1224d9;--line:#263453;--gold:#f4c26b;--purple:#7b57ff;--purple2:#aa6cff;--text:#f8fbff;--muted:#a9b2ca;
}
*{box-sizing:border-box} body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#18215c 0,#050914 46%,#03050c 100%);font-family:Inter,system-ui,sans-serif;color:var(--text);display:flex;justify-content:center}
.phone-shell{width:min(100%,430px);min-height:100vh;position:relative;overflow:hidden;background:linear-gradient(180deg,#08132c 0,#060912 48%,#050712 100%);border-radius:0 0 34px 34px;box-shadow:0 0 60px #000}
.phone-shell:before{content:"";position:absolute;inset:0;background:url('bg-glow.png') top center/cover no-repeat;opacity:.65;pointer-events:none}.hero,.form-wrap,.tabs{position:relative;z-index:1}.hero{padding:18px 24px 24px;min-height:300px}.statusbar{display:flex;justify-content:space-between;font-weight:800;margin-bottom:28px}.brand-row{display:flex;align-items:center;justify-content:space-between}.logo{width:86px;filter:drop-shadow(0 0 18px #6d75ff)}
.anniversary{position:relative;text-align:center;color:#d7cbff;text-shadow:0 0 20px #744cff}.anniversary b{font-family:Playfair Display,serif;font-size:112px;line-height:.75}.anniversary span{position:absolute;right:-18px;top:0;color:var(--gold);font-weight:800}.anniversary em{display:block;margin-top:-8px;padding:4px 14px;border-radius:999px;background:linear-gradient(90deg,#b37b2f,#ffd078,#9a631e);color:#221100;font-weight:800;font-style:normal;font-size:12px;letter-spacing:.08em}
.title-block{margin-top:-36px;text-align:left}.title-block p{letter-spacing:.42em;color:var(--gold);font-size:22px;margin:0 0 2px 68px}.title-block h1{font-size:31px;margin:0;letter-spacing:.11em}.title-block div{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:10px 0}.title-block span{display:block;text-align:center;letter-spacing:.16em;color:#d7d9e8;font-size:12px}.title-block strong{display:block;text-align:center;color:var(--gold);font-family:cursive;font-size:16px;margin-top:8px;font-weight:500}
.tabs{display:flex;margin:-14px 25px 0}.tab{flex:1;border:1px solid #2b3350;background:#151821;color:#ccc;padding:20px 10px;font-weight:800;font-size:18px}.tab:first-child{border-radius:11px 0 0 0}.tab:last-child{border-radius:0 11px 0 0}.tab.active{background:linear-gradient(135deg,#7d5dff,#2d43e2);color:white;box-shadow:0 0 25px #5a4bff99}.form-wrap{padding:0 13px 24px}.card{border:1px solid #34405f;border-radius:16px;padding:22px 14px;margin-bottom:18px;background:linear-gradient(145deg,#0d172bdc,#09101fcc);box-shadow:inset 0 1px 0 #ffffff12,0 12px 25px #0008}.vip-card{border-color:#6d3ca0;background:linear-gradient(145deg,#15142edd,#09101fcc)}.card-title{display:flex;align-items:center;gap:12px;margin-bottom:20px}.card-title span{width:44px;height:44px;display:grid;place-items:center;border-radius:50%;border:1px solid #6957ff;color:#a99cff}.card-title h2{font-size:18px;color:#a99cff;letter-spacing:.07em;margin:0}.vip-card h2,.vip-card .card-title span{color:#d47aff;border-color:#7c36b2}
.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}label{display:block;color:#fff;font-size:15px;margin-bottom:14px}input,select{width:100%;height:45px;border:1px solid #34405a;border-radius:8px;background:#08101e;color:#fff;padding:0 16px;margin-top:8px;font:inherit;outline:none}input::placeholder{color:#8790a7}select{appearance:none;background:#08101e url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='white'%3E%3Cpath d='M4 7l5 5 5-5'/%3E%3C/svg%3E") right 14px center/18px no-repeat}.input-wa,.input-suffix{display:flex;align-items:center;margin-top:8px;border:1px solid #34405a;border-radius:8px;background:#08101e}.input-wa input,.input-suffix input{border:0;margin:0;background:transparent}.input-wa span{padding-right:18px;color:#4cff65}.input-suffix span{padding-right:14px;font-size:13px;color:white}.conditional{border:1px dashed #33415e;border-radius:10px;padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px}.conditional p{grid-column:1/-1;margin:0}.radio-card{height:47px;border:1px solid #34405a;border-radius:8px;display:flex;align-items:center;gap:10px;padding:0 12px;margin:0;background:#08101e}.radio-card input{margin-left:auto;width:20px;height:20px;order:2}.submit{width:calc(100% - 24px);margin:4px 12px 12px;height:58px;border:0;border-radius:15px;background:linear-gradient(135deg,#8f5cff,#2039e9);color:white;font-weight:900;font-size:18px;letter-spacing:.12em;box-shadow:0 0 26px #604bff}.secure{text-align:center;color:#8790a7;margin:0;font-size:13px}
.confetti:before,.confetti:after{content:"";position:absolute;inset:0;background:radial-gradient(circle,#f6c568 1px,transparent 2px) 0 0/44px 44px;opacity:.35;animation:float 8s linear infinite}@keyframes float{to{transform:translateY(35px)}}@media(max-width:380px){.grid.two{grid-template-columns:1fr}.anniversary b{font-size:86px}.title-block{margin-top:-16px}.title-block h1{font-size:26px}.conditional{grid-template-columns:1fr}}

/* Tab-panel mode: default hanya panel aktif yang tampil */
.guest-panel{display:none;opacity:0;transform:translateY(24px) scale(.98)}
.guest-panel.active{display:block;opacity:1;transform:translateY(0) scale(1)}

/* WOW motion layer */
.phone-shell:after{content:"";position:absolute;inset:-30%;background:conic-gradient(from 180deg,transparent 0 20%,#7657ff33 28%,transparent 38%,transparent 58%,#f4c26b26 66%,transparent 76%);animation:auroraSpin 14s linear infinite;pointer-events:none;mix-blend-mode:screen;opacity:.8}.hero{animation:heroRise .9s cubic-bezier(.16,1,.3,1) both}.logo{animation:logoPulse 3.2s ease-in-out infinite}.anniversary{animation:numberFloat 3.8s ease-in-out infinite}.tab{position:relative;overflow:hidden;transition:.35s ease;transform:translateZ(0)}.tab:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,#ffffff66 45%,transparent 70%);transform:translateX(-130%);opacity:.55}.tab.active:after{animation:shine 2.4s ease-in-out infinite}.tab:active{transform:scale(.97)}.card{position:relative;overflow:hidden;animation:cardEntrance .7s cubic-bezier(.16,1,.3,1) both}.card:before{content:"";position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(120deg,transparent,#ffffff22,transparent,#7b57ff35,transparent);transform:translateX(-120%);animation:borderSweep 4s ease-in-out infinite;pointer-events:none}.submit{position:relative;overflow:hidden;transition:.25s ease;animation:buttonGlow 2.8s ease-in-out infinite}.submit:after{content:"";position:absolute;top:0;bottom:0;width:80px;left:-100px;background:linear-gradient(90deg,transparent,#fff8,transparent);transform:skewX(-18deg);animation:buttonShine 2.2s ease-in-out infinite}.submit:active{transform:scale(.98)}input,select,.input-wa,.input-suffix,.radio-card{transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease}.field-focus input,.field-focus select,input:focus,select:focus,.input-wa:focus-within,.input-suffix:focus-within{border-color:#8b78ff;box-shadow:0 0 0 3px #7b57ff22,0 0 18px #7b57ff33;transform:translateY(-1px)}.radio-card:hover{border-color:#8b78ff;box-shadow:0 0 16px #7b57ff22;transform:translateY(-1px)}

@keyframes auroraSpin{to{transform:rotate(360deg)}}
@keyframes heroRise{from{opacity:0;transform:translateY(-22px) scale(.98);filter:blur(8px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes logoPulse{0%,100%{filter:drop-shadow(0 0 16px #6d75ff)}50%{filter:drop-shadow(0 0 30px #8d83ff)}}
@keyframes numberFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes shine{0%{transform:translateX(-130%)}45%,100%{transform:translateX(130%)}}
@keyframes cardEntrance{from{opacity:0;transform:translateY(28px) scale(.97);filter:blur(8px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}
@keyframes borderSweep{0%,55%{transform:translateX(-120%)}100%{transform:translateX(120%)}}
@keyframes buttonGlow{0%,100%{box-shadow:0 0 26px #604bff}50%{box-shadow:0 0 42px #836dff,0 0 18px #f4c26b55}}
@keyframes buttonShine{0%,40%{left:-120px}100%{left:120%}}


/* Conditional stay option animation */
.conditional[hidden]{display:none!important}
.conditional.show{display:grid;will-change:transform,opacity,max-height;overflow:hidden}
.conditional.hide{overflow:hidden;pointer-events:none}

/* v5 conditional stay visibility override */
.conditional.conditional-stay{display:none;overflow:hidden}
.conditional.conditional-stay.show{display:grid!important}
.conditional.conditional-stay.hide{display:none!important}
.conditional.conditional-stay[hidden]{display:none!important}

/* v6 Premium success modal + e-ticket */
.success-backdrop{position:fixed;inset:0;z-index:99;display:grid;place-items:center;padding:18px;background:rgba(2,5,16,.72);backdrop-filter:blur(14px);opacity:0;pointer-events:none;transition:.35s ease}
.success-backdrop.show{opacity:1;pointer-events:auto}
.confetti-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.success-modal{width:min(100%,390px);position:relative;border:1px solid rgba(157,126,255,.55);border-radius:22px;padding:58px 18px 18px;background:linear-gradient(145deg,rgba(20,17,47,.94),rgba(6,11,27,.96));box-shadow:0 0 0 1px rgba(255,255,255,.06) inset,0 28px 80px rgba(0,0,0,.72),0 0 42px rgba(123,87,255,.52);text-align:center;overflow:hidden;animation:successPop .7s cubic-bezier(.16,1,.3,1) both}
.success-modal:before{content:"";position:absolute;inset:-2px;background:radial-gradient(circle at 50% 0,rgba(168,108,255,.45),transparent 35%),radial-gradient(circle at 10% 20%,rgba(244,194,107,.18),transparent 22%),radial-gradient(circle at 90% 28%,rgba(19,223,255,.16),transparent 24%);pointer-events:none}.success-modal>*{position:relative;z-index:1}
.success-close{position:absolute;right:14px;top:12px;width:34px;height:34px;border:1px solid rgba(255,255,255,.18);border-radius:50%;background:rgba(255,255,255,.06);color:#fff;font-size:24px;line-height:1;z-index:3}.success-check{position:absolute;left:50%;top:-42px;transform:translateX(-50%);width:92px;height:92px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle,#0b1c37,#0c1025);border:2px solid #8d63ff;box-shadow:0 0 34px #7b57ff,0 0 14px #12f7ff inset;animation:checkPulse 2.2s ease-in-out infinite}.success-check span{font-size:48px;color:#19f2e5;text-shadow:0 0 16px #19f2e5}.success-label{margin:2px 0 0;color:#b9a8ff;font-weight:900;letter-spacing:.12em}.success-modal h2{font-size:32px;margin:2px 0 12px;letter-spacing:.03em}.success-subtitle{font-size:12px;color:#c5c9dc}.success-code{margin:8px auto 14px;padding:12px;border:1px dashed rgba(244,194,107,.7);border-radius:10px;max-width:250px;color:#ffd66f;background:rgba(255,255,255,.045);font-weight:900;font-size:24px;letter-spacing:.04em;text-shadow:0 0 16px rgba(244,194,107,.5)}.success-note{font-size:13px;line-height:1.55;color:#d7dbeb;margin:0 auto 12px;max-width:280px}.success-info{display:grid;gap:8px;text-align:left;margin:12px 0;padding:12px;border-radius:14px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08)}.success-info div{display:flex;justify-content:space-between;gap:12px;font-size:12px}.success-info span{color:#b9bed2}.success-info b{color:#fff;text-align:right}.ticket-preview{margin:12px auto;padding:14px;border:1px solid rgba(168,108,255,.55);border-radius:14px;background:linear-gradient(160deg,rgba(15,17,48,.95),rgba(41,18,77,.8));box-shadow:0 0 24px rgba(123,87,255,.25) inset}.ticket-head{display:flex;align-items:center;justify-content:space-between}.ticket-head img{width:44px;filter:drop-shadow(0 0 12px #7b57ff)}.ticket-head span{color:#f4c26b;font-weight:900;font-size:12px}.ticket-preview small{display:block;color:#c9bfff;letter-spacing:.16em;margin-top:8px}.ticket-preview strong{display:block;color:#ffd66f;font-size:22px;margin:8px 0}.fake-qr{width:92px;height:92px;margin:8px auto 0;border:8px solid #fff;background:#fff;box-shadow:0 0 18px rgba(255,255,255,.25);image-rendering:pixelated}.success-primary,.success-secondary{width:100%;height:48px;border-radius:10px;font-weight:900;font-size:14px}.success-primary{border:0;background:linear-gradient(135deg,#9b5cff,#273df0);color:#fff;box-shadow:0 0 28px rgba(123,87,255,.5)}.success-secondary{margin-top:9px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.045);color:#fff}@keyframes successPop{from{opacity:0;transform:translateY(42px) scale(.92);filter:blur(12px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes checkPulse{0%,100%{box-shadow:0 0 34px #7b57ff,0 0 14px #12f7ff inset;transform:translateX(-50%) scale(1)}50%{box-shadow:0 0 54px #9b5cff,0 0 26px #12f7ff inset;transform:translateX(-50%) scale(1.04)}}

/* v7 fix: QR tampil jelas + tombol modal bisa diklik */
.success-backdrop{z-index:9999!important;pointer-events:auto!important}
.success-modal{z-index:10000!important;pointer-events:auto!important;overflow:visible!important}
.success-modal:before{z-index:0!important;pointer-events:none!important}
.success-modal>*{position:relative;z-index:2!important;pointer-events:auto!important}
.confetti-canvas{z-index:1!important;pointer-events:none!important}
.success-close,.success-primary,.success-secondary{position:relative;z-index:9!important;pointer-events:auto!important;cursor:pointer;touch-action:manipulation}
.fake-qr{display:grid!important;grid-template-columns:repeat(var(--qr-cells,17),1fr);grid-template-rows:repeat(var(--qr-cells,17),1fr);gap:0;width:98px!important;height:98px!important;padding:6px;border:0!important;background:#fff!important;border-radius:4px;box-shadow:0 0 18px rgba(255,255,255,.32)}
.fake-qr i{display:block;background:#fff}.fake-qr i.on{background:#050914}


/* v8 modal click + QR final fix */
.success-backdrop{
  z-index:2147483000!important;
  pointer-events:auto!important;
  overflow-y:auto!important;
  align-items:start!important;
  place-items:start center!important;
  padding:76px 14px 22px!important;
}
.success-modal{
  width:min(100%,390px)!important;
  max-height:none!important;
  overflow:visible!important;
  transform:none;
}
.success-close{
  position:absolute!important;
  right:14px!important;
  top:14px!important;
  z-index:50!important;
  pointer-events:auto!important;
}
.success-check{
  pointer-events:none!important;
  z-index:4!important;
}
.success-primary,.success-secondary{
  position:relative!important;
  z-index:60!important;
  pointer-events:auto!important;
  cursor:pointer!important;
  -webkit-tap-highlight-color:transparent;
}
.fake-qr{
  display:grid!important;
  grid-template-columns:repeat(17,1fr)!important;
  grid-template-rows:repeat(17,1fr)!important;
  width:118px!important;
  height:118px!important;
  padding:8px!important;
  margin:10px auto 0!important;
  background:#fff!important;
  border-radius:7px!important;
  box-shadow:0 0 22px rgba(255,255,255,.45)!important;
}
.fake-qr i{display:block!important;background:#fff!important;min-width:1px;min-height:1px}
.fake-qr i.on{background:#050914!important}

/* =========================
   VERSION 2.0 FINAL OVERRIDE
   Real QR + premium modal layout
========================= */
.success-backdrop{
  position:fixed!important;
  inset:0!important;
  z-index:2147483000!important;
  display:flex!important;
  justify-content:center!important;
  align-items:flex-start!important;
  padding:72px 14px 28px!important;
  overflow-y:auto!important;
  background:rgba(2,5,16,.78)!important;
  backdrop-filter:blur(18px)!important;
  pointer-events:auto!important;
}
.success-backdrop.closing{opacity:0!important;transition:.25s ease!important}
.confetti-canvas{position:fixed!important;inset:0!important;z-index:1!important;pointer-events:none!important}
.success-modal{
  position:relative!important;
  z-index:10!important;
  width:min(100%,410px)!important;
  padding:64px 18px 20px!important;
  border-radius:26px!important;
  overflow:visible!important;
  text-align:center!important;
  background:linear-gradient(155deg,rgba(56,35,96,.96),rgba(6,12,29,.98) 56%,rgba(12,27,54,.96))!important;
  border:1px solid rgba(167,120,255,.68)!important;
  box-shadow:0 34px 90px rgba(0,0,0,.72),0 0 54px rgba(124,83,255,.48),inset 0 1px 0 rgba(255,255,255,.12)!important;
  pointer-events:auto!important;
}
.success-close{
  position:absolute!important;
  top:16px!important;
  right:16px!important;
  z-index:30!important;
  width:38px!important;
  height:38px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:50%!important;
  border:1px solid rgba(255,255,255,.22)!important;
  background:rgba(255,255,255,.09)!important;
  color:#fff!important;
  font-size:28px!important;
  cursor:pointer!important;
  pointer-events:auto!important;
  line-height:1!important;
}
.success-check{
  top:-48px!important;
  left:50%!important;
  width:98px!important;
  height:98px!important;
  z-index:20!important;
  pointer-events:none!important;
}
.success-primary,.success-secondary{
  position:relative!important;
  z-index:25!important;
  pointer-events:auto!important;
  cursor:pointer!important;
  touch-action:manipulation!important;
}
.success-primary:disabled{opacity:.75;cursor:wait!important}
.ticket-preview{
  width:100%!important;
  max-width:340px!important;
  margin:14px auto!important;
  padding:18px 16px 20px!important;
  border-radius:18px!important;
  background:
    radial-gradient(circle at 50% 0,rgba(143,92,255,.32),transparent 34%),
    linear-gradient(160deg,rgba(15,17,48,.98),rgba(42,18,77,.95) 62%,rgba(9,11,31,.98))!important;
  border:1px solid rgba(168,108,255,.68)!important;
  box-shadow:0 0 24px rgba(123,87,255,.24) inset,0 16px 34px rgba(0,0,0,.25)!important;
}
.ticket-preview:before{content:"";position:absolute;inset:0;background:radial-gradient(circle,#f6c568 1px,transparent 2px) 0 0/42px 42px;opacity:.18;pointer-events:none;border-radius:inherit}.ticket-preview>*{position:relative;z-index:1}.ticket-head img{width:54px!important}.ticket-preview small{font-size:13px!important}.ticket-preview strong{font-size:25px!important;color:#ffd66f!important}.qr-box{
  width:154px!important;
  height:154px!important;
  margin:12px auto 8px!important;
  padding:10px!important;
  display:grid!important;
  place-items:center!important;
  background:#fff!important;
  border-radius:14px!important;
  box-shadow:0 0 26px rgba(255,255,255,.38),0 0 34px rgba(143,92,255,.26)!important;
}
.qr-box canvas,.qr-box img{display:block!important;width:132px!important;height:132px!important;image-rendering:pixelated!important;border-radius:4px!important}
.ticket-mini{font-size:11px!important;color:#d7d9ee!important;line-height:1.4!important;margin:6px 0 0!important}.fake-qr{display:none!important}
@media(max-width:380px){.success-backdrop{padding-top:58px!important}.success-modal{padding-left:14px!important;padding-right:14px!important}.success-info div{font-size:11px}.ticket-preview{max-width:310px!important}.success-code{font-size:22px!important}}
@media print{body>*:not(.success-backdrop){display:none!important}.success-backdrop{position:static!important;background:#050914!important;padding:0!important}.success-modal{box-shadow:none!important;border:0!important}.success-modal>*:not(.ticket-preview){display:none!important}.ticket-preview{display:block!important;width:360px!important;margin:0 auto!important}}


/* v2.1 QR FIX: qrcodejs membuat canvas + img tersembunyi. Jangan paksa img bawaan tampil karena akan dobel/overflow. */
.qr-box{
  overflow:hidden!important;
  width:154px!important;
  height:154px!important;
  min-width:154px!important;
  min-height:154px!important;
  max-width:154px!important;
  max-height:154px!important;
}
.qr-box canvas{
  display:block!important;
  width:132px!important;
  height:132px!important;
  max-width:132px!important;
  max-height:132px!important;
  image-rendering:pixelated!important;
  border-radius:4px!important;
}
.qr-box img:not(.qr-fallback){
  display:none!important;
  width:0!important;
  height:0!important;
  visibility:hidden!important;
  position:absolute!important;
  left:-9999px!important;
}
.qr-box img.qr-fallback{
  display:block!important;
  width:132px!important;
  height:132px!important;
  max-width:132px!important;
  max-height:132px!important;
  object-fit:contain!important;
  border-radius:4px!important;
}
.success-backdrop,.success-modal{pointer-events:auto!important}
.confetti-canvas{pointer-events:none!important;z-index:1!important}
.success-modal{z-index:50!important}

/* v2.2 form required feedback */
.is-invalid{border-color:#ff5574!important;box-shadow:0 0 0 3px rgba(255,85,116,.18),0 0 24px rgba(255,85,116,.2)!important}
.radio-card.is-invalid{border-color:#ff5574!important;background:rgba(255,85,116,.12)!important}
