*{box-sizing:border-box}:root{--pink-50:#fff7fb;--pink-100:#ffeaf4;--pink-200:#ffd7e8;--pink-300:#f8b8d2;--rose:#d86592;--rose-dark:#9b3f63;--ink:#5d3f4d;--paper:#fffcfde0;--shadow:0 24px 70px #bf537e33}html{min-height:100%}body{min-height:100dvh;color:var(--ink);background:radial-gradient(circle at 12% 14%,#ffd8e9e6,#0000 28%),radial-gradient(circle at 86% 20%,#ffeef6f2,#0000 30%),linear-gradient(135deg,#fff8fc 0%,#ffe6f1 55%,#fff6fa 100%);margin:0;font-family:Comfortaa,system-ui,sans-serif;overflow-x:hidden}button,input,select{font:inherit}button{-webkit-tap-highlight-color:transparent}.page{place-items:center;min-height:100dvh;padding:28px 16px;display:grid;position:relative}.paper-card{background:linear-gradient(90deg, #ffffff2e 29px, #d8659229 30px, transparent 31px), repeating-linear-gradient(0deg, transparent 0 33px, #d8659213 34px), var(--paper);width:min(820px,100%);min-height:620px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid #d865922e;border-radius:36px;padding:34px;position:relative;overflow:hidden}.paper-card:before,.paper-card:after{content:"";filter:blur(.2px);opacity:.75;border-radius:999px;position:absolute}.paper-card:before{background:#ffd6e7;width:180px;height:180px;top:-60px;right:-60px}.paper-card:after{background:#ffe8f3;width:130px;height:130px;bottom:-42px;left:-42px}.stitch{pointer-events:none;border:2px dashed #d8659238;border-radius:28px;position:absolute;inset:14px}.top-label,.progress,section,.back{z-index:2;position:relative}.top-label{color:var(--rose-dark);background:#ffffffa6;border-radius:999px;align-items:center;gap:8px;padding:9px 14px;font-size:13px;display:inline-flex;box-shadow:0 7px 22px #d865921a}.progress{background:#ffd7e8a8;border-radius:999px;height:7px;margin:20px 0 38px;overflow:hidden}.progress span{border-radius:inherit;background:linear-gradient(90deg,#ffc4dc,#d86592);height:100%;transition:width .7s cubic-bezier(.2,.8,.2,1);display:block}.center{text-align:center;flex-direction:column;align-items:center;display:flex}h1,h2,h3{color:var(--rose-dark);margin:0;font-family:Caveat,cursive;font-weight:700;line-height:.98}h1{max-width:650px;font-size:clamp(48px,8vw,88px)}h2{text-align:center;font-size:clamp(43px,6vw,72px)}h3{font-size:48px}.subtitle{color:#5d3f4dc2;max-width:560px;margin:20px auto 0;line-height:1.75}.heart-seal,.step-icon{width:88px;height:88px;color:var(--rose);background:linear-gradient(145deg,#fff,#ffe0ee);border-radius:30px;place-items:center;margin:0 auto 24px;animation:2.6s ease-in-out infinite pulse;display:grid;transform:rotate(-6deg);box-shadow:0 16px 30px #d865922e}.heart-seal.big{width:100px;height:100px}.step-icon{transform:rotate(5deg)}.button-row{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:16px;max-width:650px;min-height:166px;margin:38px auto 0;padding:8px 18px 22px;display:flex;position:relative}.btn{cursor:pointer;color:var(--rose-dark);background:#ffffffd1;border:0;border-radius:999px;padding:17px 29px;transition:transform .38s cubic-bezier(.18,.9,.28,1.25),box-shadow .25s,background .25s,opacity .25s;box-shadow:0 12px 30px #99416424}.btn:hover{box-shadow:0 16px 34px #99416433}.btn.yes{color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#ec8ab1,#cf5e8b);font-weight:700}.btn.yes:hover{transform:translateY(-3px)scale(1.035)}.btn:disabled{opacity:.46;cursor:not-allowed;transform:none}.btn.escape{will-change:transform;min-width:116px;position:relative}.btn.escape em{white-space:nowrap;color:var(--rose);opacity:.9;font-family:Caveat,cursive;font-size:22px;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)}.wide{width:min(420px,100%);margin:30px auto 0;display:block}.back,.soft-btn,.link-btn{color:var(--rose-dark);cursor:pointer;background:0 0;border:0}.back{align-items:center;gap:7px;margin-bottom:8px;display:inline-flex}.date-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;max-width:560px;margin:34px auto 0;display:grid}label{color:var(--rose-dark);gap:10px;font-weight:600;display:grid}input,select{width:100%;color:var(--ink);background:#ffffffbd;border:1px solid #d8659238;border-radius:22px;outline:none;padding:18px 17px;box-shadow:0 12px 28px #d8659217}input:focus,select:focus{border-color:#d865928c;box-shadow:0 0 0 5px #d865921f}select{cursor:pointer}.place-list{gap:18px;max-width:610px;margin:32px auto 0;padding:4px 18px 10px;display:grid;position:relative}.place-card,.escape.place{width:100%;min-height:72px;color:var(--ink);cursor:pointer;background:#ffffffb3;border:1px solid #d8659238;border-radius:26px;justify-content:center;align-items:center;gap:12px;padding:17px 20px;transition:transform .22s,border .22s,background .22s,box-shadow .22s;display:flex;box-shadow:0 14px 28px #d865921a}.place-card:hover{transform:translateY(-3px);box-shadow:0 18px 34px #d8659229}.place-card.chosen{background:#ffe5f0d1;border-color:#cf5e8bb8}.sticker{text-align:left;background:#fff1aa;border-radius:18px;width:min(490px,100%);margin:30px auto 0;padding:40px 34px 32px;position:relative;transform:rotate(-1.8deg);box-shadow:0 25px 50px #805d252e,inset 0 -22px 35px #d9a63e14}.sticker p{margin:12px 0;font-size:18px;line-height:1.65}.tiny-note{color:var(--rose-dark);text-align:center;font-family:Caveat,cursive;font-size:28px!important}.tape{background:#ffffff8c;border:1px solid #fffc;width:86px;height:28px;position:absolute;top:-14px;box-shadow:0 4px 10px #0000000a}.tape.left{left:28px;transform:rotate(-8deg)}.tape.right{right:32px;transform:rotate(7deg)}.edit-row{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:28px;display:flex}.soft-btn{background:#ffffffa6;border-radius:999px;align-items:center;gap:7px;padding:12px 16px;display:inline-flex;box-shadow:0 9px 22px #d865921a}.link-btn{opacity:.72;margin-top:18px;text-decoration:underline}.float-layer{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.float-layer span{color:#d8659247;font-family:Caveat,cursive;font-size:var(--size,20px);bottom:-40px;left:var(--left);animation:floatUp var(--duration) linear infinite;animation-delay:var(--delay);position:absolute}.fade-in{animation:.65s both fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:rotate(-6deg)scale(1)}50%{transform:rotate(-2deg)scale(1.05)}}@keyframes floatUp{0%{opacity:0;transform:translateY(0)rotate(0)}14%{opacity:1}to{opacity:0;transform:translateY(-115vh)rotate(260deg)}}@media (width<=700px){body{background:radial-gradient(circle at 15% 5%,#ffd2e6f2,#0000 32%),radial-gradient(circle at 88% 11%,#ffeff7f2,#0000 34%),linear-gradient(150deg,#fff9fc 0%,#ffe7f2 62%,#fff8fb 100%)}.page{padding:max(10px, env(safe-area-inset-top)) 10px max(14px, env(safe-area-inset-bottom));align-items:start}.paper-card{background:linear-gradient(90deg, #ffffff2e 23px, #d8659221 24px, transparent 25px), repeating-linear-gradient(0deg, transparent 0 28px, #d8659212 29px), var(--paper);border-radius:30px;width:100%;min-height:calc(100dvh - 24px);padding:22px 17px 24px;box-shadow:0 18px 44px #bf537e2e}.paper-card:before{opacity:.65;width:122px;height:122px;top:-36px;right:-42px}.paper-card:after{opacity:.55;width:92px;height:92px;bottom:-26px;left:-32px}.stitch{border-radius:23px;inset:10px}.top-label{white-space:nowrap;max-width:calc(100% - 8px);padding:8px 12px;font-size:11.5px}.top-label svg{flex:none;width:15px;height:15px}.progress{height:6px;margin:17px 0 25px}.heart-seal,.step-icon{border-radius:25px;width:72px;height:72px;margin-bottom:18px}.heart-seal svg{width:39px;height:39px}.step-icon svg{width:27px;height:27px}.heart-seal.big{width:80px;height:80px}h1{letter-spacing:-.01em;max-width:100%;font-size:clamp(43px,14.6vw,62px);line-height:.95}h2{font-size:clamp(42px,13vw,58px);line-height:.98}h3{font-size:39px}.subtitle{max-width:94%;margin-top:14px;font-size:13.5px;line-height:1.65}.button-row{align-content:flex-start;gap:12px;width:100%;max-width:360px;min-height:230px;margin-top:24px;padding:4px 12px 34px;overflow:visible}.first-row .yes{flex:0 0 min(220px,100%);order:1;margin-bottom:6px}.first-row .escape{order:2}.btn{min-height:52px;padding:15px 22px;font-size:14px}.btn.escape{min-width:102px}.btn.escape em{white-space:normal;max-width:160px;font-size:20px;line-height:1}.date-grid{grid-template-columns:1fr;gap:14px;max-width:100%;margin-top:26px}label{gap:8px;font-size:14px}input,select{border-radius:19px;min-height:55px;padding:15px 14px;font-size:15px}.wide{width:100%;max-width:360px;margin-top:22px}.back{background:#ffffff73;border-radius:999px;margin:-2px 0 10px;padding:9px 7px}.place-list{gap:12px;width:100%;max-width:100%;margin-top:24px;padding:4px 8px 16px;overflow:visible}.place-card,.escape.place{text-align:left;border-radius:22px;justify-content:flex-start;gap:10px;min-height:66px;padding:15px;font-size:13.7px;line-height:1.35}.place-card svg,.escape.place svg{flex:none}.escape.place em{left:58%}.sticker{border-radius:16px;width:min(100%,360px);margin-top:22px;padding:34px 21px 24px;transform:rotate(-1deg)}.sticker p{overflow-wrap:anywhere;font-size:15.5px;line-height:1.55}.tiny-note{font-size:24px!important}.tape{width:68px;height:23px;top:-11px}.tape.left{left:20px}.tape.right{right:22px}.edit-row{flex-direction:column;align-items:stretch;gap:10px;width:100%;margin-top:22px}.soft-btn{justify-content:center;min-height:46px}.link-btn{min-height:42px}.float-layer span{opacity:.75}}@media (width<=390px){.page{padding-inline:7px}.paper-card{border-radius:26px;padding:20px 14px 22px}.stitch{border-radius:21px;inset:8px}.top-label{padding-inline:10px;font-size:10.8px}.progress{margin-bottom:22px}h1{font-size:clamp(40px,14vw,54px)}h2{font-size:clamp(39px,12.5vw,52px)}.subtitle{font-size:12.8px}.button-row{min-height:220px;padding-inline:8px}.btn{padding:14px 19px;font-size:13.5px}.place-card,.escape.place{padding:14px 13px;font-size:13px}}@media (height<=720px) and (width<=700px){.paper-card{min-height:auto}.heart-seal,.step-icon{width:66px;height:66px;margin-bottom:14px}.progress{margin-bottom:18px}.button-row{min-height:205px;margin-top:18px}.subtitle{margin-top:10px}}
