html.wcp-locked, html.wcp-locked body { overflow: hidden !important; }
#wcp-gate { position: fixed; inset: 0; z-index: 999999; min-height: 100vh; display: flex; align-items: center; justify-content: center; background-size: cover; background-position: center; font-family: Georgia, 'Times New Roman', serif; }
#wcp-gate:not([style*='background-image']) { background: radial-gradient(circle at 25% 15%, rgba(255,238,232,.85), transparent 28%), linear-gradient(135deg, #3f1d2b, #a56d62 52%, #f7d6cc); }
.wcp-overlay { position: absolute; inset: 0; backdrop-filter: blur(4px); }
.wcp-loader-box { position: absolute; z-index: 4; width: 310px; height: 260px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 22px; animation: wcpLoaderOut .75s ease 2.65s forwards; }
.wcp-envelope { position: relative; width: 230px; height: 148px; filter: drop-shadow(0 30px 35px rgba(0,0,0,.28)); perspective: 900px; animation: wcpEnvelopeLift 2.4s ease forwards; }
.wcp-envelope-back { position: absolute; inset: 0; border-radius: 10px; background: linear-gradient(135deg,#fff8f4,#f2cfc7); }
.wcp-envelope-left, .wcp-envelope-right, .wcp-envelope-bottom, .wcp-envelope-flap { position: absolute; inset: 0; }
.wcp-envelope-left { clip-path: polygon(0 0, 52% 54%, 0 100%); background: #f0bfb4; border-radius: 10px 0 0 10px; }
.wcp-envelope-right { clip-path: polygon(100% 0, 48% 54%, 100% 100%); background: #e8aa9e; border-radius: 0 10px 10px 0; }
.wcp-envelope-bottom { clip-path: polygon(0 100%, 50% 45%, 100% 100%); background: linear-gradient(135deg,#e9afa4,#d99085); border-radius: 0 0 10px 10px; }
.wcp-envelope-flap { transform-origin: top center; clip-path: polygon(0 0, 50% 62%, 100% 0); background: linear-gradient(135deg,#ffdcd4,#dda094); border-radius: 10px 10px 0 0; animation: wcpFlapOpen 1.05s ease .35s forwards; z-index: 6; }
.wcp-letter { position: absolute; left: 20px; right: 20px; bottom: 18px; height: 112px; border-radius: 12px; background: rgba(255,255,255,.98); color: #6b3343; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; box-shadow: 0 12px 28px rgba(77,39,51,.18); transform: translateY(22px); animation: wcpLetterRise 1.15s ease 1.05s forwards; z-index: 3; }
.wcp-letter span { font-size: 22px; line-height: 1.1; font-weight: 700; }
.wcp-letter small { margin-top: 8px; font-family: Arial, sans-serif; text-transform: uppercase; letter-spacing: 1.8px; font-size: 10px; color: #b76e79; }
.wcp-seal { position: absolute; left: 50%; top: 51%; transform: translate(-50%,-50%); width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(135deg,#8b3148,#d6a16d); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; letter-spacing: .5px; z-index: 8; box-shadow: 0 8px 18px rgba(0,0,0,.2); animation: wcpSealPop .55s ease .25s forwards; }
.wcp-loading-text { color: #fff8f4; font-size: 16px; text-align: center; padding: 9px 18px; border-radius: 999px; background: rgba(77,39,51,.45); backdrop-filter: blur(6px); text-shadow: 0 1px 2px rgba(0,0,0,.22); font-family: Arial, sans-serif; }
.wcp-card { position: relative; z-index: 3; width: min(92vw, 440px); padding: 44px 34px 36px; border-radius: 32px; text-align: center; color: #4d2733; background: rgba(255,255,255,.94); box-shadow: 0 35px 100px rgba(0,0,0,.35); opacity: 0; transform: translateY(32px) scale(.96); animation: wcpCardIn .8s ease 3s forwards; border: 1px solid rgba(255,255,255,.55); }
.wcp-ring { width: 66px; height: 66px; margin: -78px auto 18px; border-radius: 50%; background: #fff; color: #b76e79; display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 700; letter-spacing: .5px; box-shadow: 0 12px 30px rgba(0,0,0,.16); }
.wcp-card h2 { margin: 0 0 10px; font-size: 31px; line-height: 1.15; }
.wcp-card p { margin: 0 0 24px; font-family: Arial, sans-serif; color: #73515c; font-size: 15px; }
#wcp-form { display: grid; gap: 12px; }
#wcp-password { border: 1px solid rgba(77,39,51,.22); border-radius: 999px; padding: 15px 18px; font-size: 16px; text-align: center; outline: none; background: #fff; }
#wcp-password:focus { border-color: #b76e79; box-shadow: 0 0 0 4px rgba(183,110,121,.14); }
#wcp-form button { border: 0; border-radius: 999px; padding: 15px 18px; cursor: pointer; color: #fff; background: linear-gradient(135deg,#7d4054,#c58a79); font-size: 16px; letter-spacing: .3px; }
#wcp-form button:disabled { opacity: .7; cursor: wait; }
.wcp-message { min-height: 20px; font-family: Arial, sans-serif; font-size: 14px; color: #b00020; }
.wcp-effect-float .wcp-card { animation-name: wcpCardIn, wcpFloat; animation-duration: .8s, 4s; animation-delay: 3s, 3.8s; animation-fill-mode: forwards, none; animation-iteration-count: 1, infinite; }
.wcp-effect-zoom .wcp-card { animation-name: wcpZoomIn; }
.wcp-effect-glow .wcp-card { box-shadow: 0 0 55px rgba(255,210,215,.8), 0 35px 100px rgba(0,0,0,.35); }
.wcp-effect-slide .wcp-card { transform: translateY(80px); }
#wcp-gate.wcp-unlock { animation: wcpGateOut .65s ease forwards; }
@keyframes wcpFlapOpen { 0% { transform: rotateX(0deg); z-index: 9; } 100% { transform: rotateX(178deg); z-index: 1; } }
@keyframes wcpLetterRise { 0% { transform: translateY(22px); } 100% { transform: translateY(-82px); } }
@keyframes wcpEnvelopeLift { 0%,100% { transform: translateY(0) scale(1); } 55% { transform: translateY(-8px) scale(1.03); } }
@keyframes wcpSealPop { to { transform: translate(-50%,-50%) scale(.72); opacity: 0; } }
@keyframes wcpLoaderOut { to { opacity: 0; transform: scale(.82); visibility: hidden; } }
@keyframes wcpCardIn { to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes wcpZoomIn { from { opacity: 0; transform: scale(.65); } to { opacity: 1; transform: scale(1); } }
@keyframes wcpFloat { 50% { transform: translateY(-10px); } }
@keyframes wcpGateOut { to { opacity: 0; visibility: hidden; } }
@media (max-width: 480px) { .wcp-loader-box { transform: scale(.86); } .wcp-card { padding: 40px 22px 30px; } .wcp-card h2 { font-size: 26px; } }
