body,html{background:#b9e0ff}.demo-stage{min-height:100dvh;background:radial-gradient(900px 500px at 80% -10%,var(--sun) 0,transparent 55%),radial-gradient(700px 500px at 10% 110%,var(--lilac) 0,transparent 60%),linear-gradient(160deg,var(--peach) 0,var(--coral) 55%,#E8A5C7 100%);display:flex;align-items:center;justify-content:center;padding:24px;font-family:Nunito,ui-rounded,system-ui,sans-serif;color:var(--ink)}.phone{width:390px;height:780px;max-height:calc(100dvh - 48px);background:var(--cream);border-radius:44px;overflow:hidden;position:relative;box-shadow:0 40px 80px rgba(42,26,46,.35),0 0 0 10px #1a0f1e,0 0 0 12px rgba(255,255,255,.1);display:flex;flex-direction:column}.phone:before{content:"";position:absolute;top:10px;left:50%;transform:translateX(-50%);width:110px;height:28px;background:#1a0f1e;border-radius:999px;z-index:30}@media (max-width:500px){body,html{height:100dvh;overflow:hidden;overscroll-behavior:none}.demo-stage{padding:0;background:#b9e0ff;min-height:100dvh}.phone{width:100vw;height:100dvh;max-height:none;border-radius:0;box-shadow:none;background:#b9e0ff}.phone:before{display:none}}.screen{flex:1 1;display:flex;flex-direction:column;position:relative;overflow:hidden;animation:screenIn .45s cubic-bezier(.2,.7,.2,1)}@keyframes screenIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.status-bar{height:48px;flex-shrink:0}.phone h1{font-family:Fraunces,Georgia,serif;font-weight:800;letter-spacing:-.02em;line-height:1;margin:0}.phone p{margin:0}.phone .lede{font-size:15px;color:var(--sub);line-height:1.45;font-weight:600}.btn-primary{background:var(--ink);color:#fff;border:none;padding:16px 24px;border-radius:999px;font-weight:800;font-size:16px;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 12px 28px rgba(42,26,46,.22);transition:transform .15s,box-shadow .15s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(42,26,46,.28)}.btn-primary:active{transform:translateY(0)}.btn-ghost{background:transparent;color:var(--sub);border:none;padding:12px 16px;font-family:inherit;font-weight:700;font-size:14px;cursor:pointer}.splash{align-items:center;justify-content:center;background:radial-gradient(600px 400px at 50% 30%,var(--peach),transparent 70%),linear-gradient(180deg,var(--cream),#ffe9d1);padding:40px;text-align:center}.splash .logo-bloom{font-family:Fraunces,serif;font-weight:800;font-size:72px;letter-spacing:-.03em;animation:bloom 1.1s cubic-bezier(.2,.8,.2,1);display:flex;align-items:center;gap:10px}.splash .logo-bloom .paw{display:inline-block;flex-shrink:0;align-self:center;transform:translateY(2px)}.splash .tag{margin-top:14px;font-size:16px;color:var(--sub);font-weight:700;letter-spacing:.02em;animation:fadeUp .8s .4s both}@keyframes bloom{0%{opacity:0;transform:scale(.7)}60%{opacity:1;transform:scale(1.08)}to{transform:scale(1)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.welcome{background:var(--cream);padding:0}.welcome-yard{position:relative;height:48%;min-height:300px;overflow:hidden;background:#b9e0ff}.welcome-yard canvas{display:block;width:100%!important;height:100%!important}.welcome-yard .status-bar{position:absolute;top:0;left:0;right:0;z-index:10}.welcome-sheet{flex:1 1;padding:28px 28px 32px;display:flex;flex-direction:column;justify-content:flex-end}.welcome-sheet h1{font-size:40px;line-height:1.05}.welcome-sheet h1 em{color:var(--coral);font-style:italic;font-weight:700}.welcome-sheet .lede{margin-top:14px;margin-bottom:24px}.welcome-sheet .actions{display:flex;flex-direction:column;gap:8px}.capture{background:#1a0f1e;color:#fff}.capture .viewfinder{flex:1 1;position:relative;margin:16px;border-radius:32px;overflow:hidden;background:radial-gradient(circle at 50% 45%,#3a2a3e 0,#1a0f1e 70%);display:flex;align-items:center;justify-content:center}.capture .viewfinder:after{content:"";position:absolute;inset:24px;border:2px solid rgba(255,255,255,.6);border-radius:20px;-webkit-mask:linear-gradient(#000 0 0) top left /28px 2px no-repeat,linear-gradient(#000 0 0) top left /2px 28px no-repeat,linear-gradient(#000 0 0) top right /28px 2px no-repeat,linear-gradient(#000 0 0) top right /2px 28px no-repeat,linear-gradient(#000 0 0) bottom left /28px 2px no-repeat,linear-gradient(#000 0 0) bottom left /2px 28px no-repeat,linear-gradient(#000 0 0) bottom right /28px 2px no-repeat,linear-gradient(#000 0 0) bottom right /2px 28px no-repeat;mask:linear-gradient(#000 0 0) top left /28px 2px no-repeat,linear-gradient(#000 0 0) top left /2px 28px no-repeat,linear-gradient(#000 0 0) top right /28px 2px no-repeat,linear-gradient(#000 0 0) top right /2px 28px no-repeat,linear-gradient(#000 0 0) bottom left /28px 2px no-repeat,linear-gradient(#000 0 0) bottom left /2px 28px no-repeat,linear-gradient(#000 0 0) bottom right /28px 2px no-repeat,linear-gradient(#000 0 0) bottom right /2px 28px no-repeat}.capture .pet-silhouette{font-size:180px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4));animation:petBreath 3s ease-in-out infinite}@keyframes petBreath{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.capture .hint{top:20px;background:rgba(255,255,255,.14);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:700;white-space:nowrap;color:#fff}.capture .hint,.capture .species{position:absolute;left:50%;transform:translateX(-50%)}.capture .species{bottom:24px;display:flex;gap:8px}.capture .species button{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 14px;border-radius:999px;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.capture .species button.on{background:#fff;color:var(--ink);border-color:#fff}.capture .controls{height:130px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;flex-shrink:0}.capture .shutter{width:72px;height:72px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.3);box-shadow:inset 0 0 0 4px #fff;cursor:pointer;transition:transform .1s}.capture .shutter:active{transform:scale(.94)}.capture .back-x,.capture .flip{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center}.generating{background:linear-gradient(180deg,var(--cream),#fff);align-items:center;justify-content:center;padding:32px;text-align:center}.generating .orb{width:200px;height:200px;border-radius:50%;background:conic-gradient(from 0deg,var(--peach),var(--coral),var(--lilac),var(--sky),var(--mint),var(--peach));filter:blur(.5px);animation:orbSpin 2.4s linear infinite;position:relative;box-shadow:0 30px 80px rgba(255,154,139,.4)}.generating .orb:after{content:"";position:absolute;inset:14px;background:radial-gradient(circle at 35% 30%,#fff,#fff9 60%,#fff0);border-radius:50%;mix-blend-mode:overlay}@keyframes orbSpin{to{transform:rotate(1turn)}}.generating h1{font-size:30px;margin-top:32px}.generating .sub{margin-top:8px;color:var(--sub);font-weight:700;font-size:14px}.generating .dots:after{content:"";animation:dots 1.4s steps(4) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.reveal{background:var(--cream);padding:0}.reveal .reveal-yard{position:relative;height:44%;min-height:280px;overflow:hidden;background:#b9e0ff}.reveal .reveal-yard canvas{display:block;width:100%!important;height:100%!important}.reveal .reveal-yard .progress{top:58px;z-index:10}.reveal .reveal-yard .status-bar{position:absolute;top:0;left:0;right:0;z-index:10}.reveal .reveal-yard .sparkle{position:absolute;font-size:22px;z-index:5;animation:twinkle 1.6s infinite;pointer-events:none}.reveal .reveal-yard .sp1{top:30%;left:18%;animation-delay:0s}.reveal .reveal-yard .sp2{top:32%;right:20%;animation-delay:.3s}.reveal .reveal-yard .sp3{bottom:22%;left:26%;animation-delay:.6s}.reveal .reveal-yard .sp4{bottom:20%;right:28%;animation-delay:.9s}.reveal .avatar-wrap{position:relative;animation:revealPop .7s cubic-bezier(.2,.8,.2,1);margin-top:30px}.reveal .avatar-bob{animation:avatarIdle 2.8s ease-in-out infinite}@keyframes avatarIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.reveal .avatar-shadow{position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);width:110px;height:18px;background:rgba(0,0,0,.22);border-radius:50%;filter:blur(6px);animation:shadowPulse 2.8s ease-in-out infinite}@keyframes shadowPulse{0%,to{transform:translateX(-50%) scale(1);opacity:.35}50%{transform:translateX(-50%) scale(.85);opacity:.25}}.reveal .reveal-sheet{flex:1 1;padding:24px 28px 28px;display:flex;flex-direction:column}@keyframes revealPop{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.1)}to{transform:scale(1)}}.reveal .sparkle{position:absolute;font-size:22px;animation:twinkle 1.6s infinite;pointer-events:none}.reveal .sparkle:first-child{top:10%;left:-10%;animation-delay:0s}.reveal .sparkle:nth-child(2){top:30%;right:-8%;animation-delay:.3s}.reveal .sparkle:nth-child(3){bottom:10%;left:5%;animation-delay:.6s}.reveal .sparkle:nth-child(4){bottom:20%;right:0;animation-delay:.9s}.reveal h1{font-size:28px;text-align:center}.reveal .label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:800;color:var(--sub);text-align:center;margin-bottom:6px}.reveal .name-input{width:100%;background:#fff;border:2px solid var(--line);border-radius:20px;padding:16px 18px;font-family:Fraunces,serif;font-weight:800;font-size:22px;color:var(--ink);margin:14px 0 16px;outline:none;transition:border-color .15s;text-align:center}.reveal .name-input:focus{border-color:var(--coral)}.reveal .name-input::placeholder{color:#c9bcc6;font-style:italic}.wizard{background:var(--cream);padding:0}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.wiz-yard{position:relative;height:32%;min-height:200px;overflow:hidden;background:#b9e0ff}.wiz-yard canvas{display:block;width:100%!important;height:100%!important}.wiz-yard .progress{top:58px;z-index:10}.wiz-yard .status-bar{position:absolute;top:0;left:0;right:0;z-index:10}.wiz-yard .close-x{z-index:15}.wiz-name-tag-floating{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(255,255,255,.95);padding:4px 12px;border-radius:999px;font-size:11px;font-weight:800;color:var(--ink);white-space:nowrap;box-shadow:0 4px 12px rgba(42,26,46,.15);z-index:10;pointer-events:none}.wiz-avatar{position:relative;margin-bottom:14px;animation:wizAvatarIn .5s cubic-bezier(.2,.8,.2,1)}@keyframes wizAvatarIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.wiz-avatar .avatar-shadow{position:absolute;left:50%;bottom:-4px;transform:translateX(-50%);width:80px;height:14px;background:rgba(0,0,0,.22);border-radius:50%;filter:blur(5px);animation:shadowPulse 2.8s ease-in-out infinite}.wiz-avatar .avatar-bob{animation:avatarIdle 2.8s ease-in-out infinite}.wiz-name-tag{position:absolute;top:-6px;left:50%;transform:translateX(-50%);background:rgba(255,255,255,.95);padding:4px 12px;border-radius:999px;font-size:11px;font-weight:800;color:var(--ink);white-space:nowrap;box-shadow:0 4px 12px rgba(42,26,46,.15)}.wiz-sheet{flex:1 1;padding:24px;display:flex;flex-direction:column;overflow-y:auto}.wiz-sheet h1{font-size:26px;line-height:1.1}.wiz-sheet h1 em{color:var(--coral);font-style:italic;font-weight:700}.wiz-body{flex:1 1;display:flex;flex-direction:column;justify-content:center;padding:18px 0 12px;gap:12px}.wiz-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:8px}.wiz-actions .btn-primary{flex:1 1}.chip{background:#fff;border:2px solid var(--line);border-radius:18px;padding:14px 16px;font-family:inherit;font-weight:800;font-size:15px;color:var(--ink);cursor:pointer;transition:border-color .15s,transform .1s,box-shadow .15s,background .15s;text-align:left;display:inline-flex;align-items:center;gap:10px}.chip:hover{border-color:#d6c8b7}.chip:active{transform:scale(.97)}.chip.on{border-color:var(--ink);background:var(--ink);color:#fff;box-shadow:0 10px 22px rgba(42,26,46,.25)}.chip.on .chip-hint,.chip.on .chip-sub{color:rgba(255,255,255,.7)}.chip-emoji{font-size:18px}.chip-hint{font-size:11px;letter-spacing:.04em}.chip-hint,.chip-sub{font-weight:700;color:var(--sub)}.chip-sub{font-size:12px;margin-left:auto}.chip-label{font-size:15px;font-weight:800}.chip-xl{flex:1 1;justify-content:center;padding:22px;font-size:20px;flex-direction:column;gap:4px}.chip-xl .chip-emoji{font-size:28px}.chip-wide{width:100%;justify-content:flex-start}.chip-md{padding:10px 14px;font-size:14px}.chip-md,.chip-sm{border-radius:999px}.chip-sm{padding:8px 12px;font-size:13px;font-weight:700}.chip-row{display:flex;gap:10px}.chip-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.chip-grid .chip{flex-direction:column;align-items:flex-start;gap:2px}.chip-wrap{display:flex;flex-wrap:wrap;gap:8px}.date-input{width:100%;background:#fff;border:2px solid var(--line);border-radius:18px;padding:14px 16px;font-family:inherit;font-weight:700;font-size:16px;color:var(--ink);outline:none;transition:border-color .15s}.date-input:focus{border-color:var(--coral)}.or-divider{display:flex;align-items:center;gap:10px;color:var(--sub);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin:6px 0}.or-divider:after,.or-divider:before{content:"";flex:1 1;height:1px;background:var(--line)}.home{background:var(--cream)}.yard{flex:1 1;position:relative;overflow:hidden;background:#b9e0ff}.yard canvas{display:block;width:100%!important;height:100%!important}.reveal-yard .sun,.yard .sun{position:absolute;top:28px;right:30px;width:52px;height:52px;border-radius:50%;background:radial-gradient(circle,#fff6c9,var(--sun));box-shadow:0 0 40px rgba(255,179,71,.6)}.reveal-yard .cloud,.yard .cloud{position:absolute;background:rgba(255,255,255,.8);border-radius:999px;filter:blur(.5px)}.reveal-yard .cloud.c1,.yard .cloud.c1{width:70px;height:18px;top:40px;left:24px}.reveal-yard .cloud.c2,.yard .cloud.c2{width:50px;height:14px;top:68px;left:70px;opacity:.7}.reveal-yard .cloud.c3,.yard .cloud.c3{width:40px;height:12px;top:50px;right:110px;opacity:.6}.reveal-yard .tree,.yard .tree{position:absolute;bottom:44%;font-size:34px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.pet-token{position:absolute;transform-origin:50% 90%;pointer-events:auto;cursor:pointer;transition:filter .15s;will-change:transform}.pet-token:active{filter:brightness(1.08)}.pet-token .shadow{bottom:-4px;width:56px;height:10px;background:rgba(0,0,0,.22);border-radius:50%;filter:blur(4px)}.pet-token .name-tag,.pet-token .shadow{position:absolute;left:50%;transform:translateX(-50%)}.pet-token .name-tag{top:-22px;background:rgba(255,255,255,.95);padding:3px 10px;border-radius:999px;font-size:10px;font-weight:800;color:var(--ink);white-space:nowrap;box-shadow:0 4px 10px rgba(42,26,46,.15);pointer-events:none;opacity:0;transition:opacity .2s}.pet-token.show-name .name-tag,.pet-token:hover .name-tag{opacity:1}.home-menu{position:absolute;right:calc(20px + env(safe-area-inset-right, 0px));bottom:calc(20px + env(safe-area-inset-bottom, 0px));width:44px;height:44px;z-index:20}.home-menu-trigger{width:44px;height:44px;border-radius:50%;background:linear-gradient(155deg,var(--sun) 0,var(--coral) 55%,var(--lilac) 100%);color:#fff;border:none;font-size:22px;font-weight:900;line-height:1;cursor:pointer;box-shadow:0 10px 22px rgba(255,154,139,.55),inset 0 1px 0 rgba(255,255,255,.5);transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .18s;display:grid;place-items:center;padding:0}.home-menu-trigger:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(255,154,139,.65),inset 0 1px 0 rgba(255,255,255,.5)}.home-menu-trigger:active{transform:scale(.94)}.home-menu.open .home-menu-trigger{background:var(--ink);box-shadow:0 10px 22px rgba(42,26,46,.4);transform:rotate(90deg)}.home-menu-item{position:absolute;right:0;bottom:0;display:flex;align-items:center;gap:8px;padding:6px 14px 6px 8px;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.6);border-radius:999px;font-family:inherit;font-weight:800;font-size:13px;color:var(--ink);cursor:pointer;box-shadow:0 6px 16px rgba(42,26,46,.15);transform:translateY(0) scale(.6);opacity:0;pointer-events:none;transition:transform .25s cubic-bezier(.2,.8,.2,1),opacity .18s;white-space:nowrap}.home-menu-item .icon{width:28px;height:28px;border-radius:50%;background:var(--cream);display:grid;place-items:center;font-size:15px;flex-shrink:0}.home-menu.open .home-menu-item{transform:translateY(calc(var(--i) * -52px)) scale(1);opacity:1;pointer-events:auto}.home-menu-item:hover{background:#fff}.home-menu-item:active{transform:scale(.97)}.tabbar{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);background:rgba(255,255,255,.85);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.6);box-shadow:0 14px 36px rgba(42,26,46,.18);border-radius:999px;gap:4px;padding:8px;z-index:20}.tabbar,.tabbar .tab{display:flex;align-items:center}.tabbar .tab{background:none;border:none;font-family:inherit;font-weight:800;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--sub);cursor:pointer;flex-direction:column;justify-content:center;gap:2px;padding:8px 14px;border-radius:999px;transition:background .15s,color .15s}.tabbar .tab .icon{font-size:20px;line-height:1}.tabbar .tab.active{color:var(--ink);background:#fff;box-shadow:0 4px 12px rgba(42,26,46,.1)}.toast{position:absolute;top:60px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:10px 18px;border-radius:999px;font-size:13px;font-weight:700;box-shadow:0 10px 30px rgba(42,26,46,.3);z-index:40;animation:toastIn .3s cubic-bezier(.2,.8,.2,1)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.progress{position:absolute;top:58px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10}.progress .p{width:18px;height:4px;border-radius:2px;background:rgba(42,26,46,.15);transition:background .3s,width .3s}.progress .p.on{background:var(--ink);width:28px}.close-x{position:absolute;top:56px;left:20px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.8);border:1px solid var(--line);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;cursor:pointer;font-size:16px;z-index:15;color:var(--ink)}.capture .close-x{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.2);color:#fff}.bottom-pad{padding-bottom:24px;flex-shrink:0}.install-prompt{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);display:flex;align-items:center;gap:12px;padding:10px 14px 10px 12px;background:rgba(255,255,255,.97);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.6);border-radius:18px;box-shadow:0 18px 44px rgba(42,26,46,.22);z-index:100;font-family:Nunito,ui-rounded,system-ui,sans-serif;max-width:calc(100vw - 24px);animation:install-in .4s cubic-bezier(.2,.8,.2,1)}@keyframes install-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.install-icon{width:44px;height:44px;border-radius:12px;background:radial-gradient(circle at 50% 35%,#FFE8C5 0,#FFD6A5 100%);display:grid;place-items:center;flex-shrink:0}.install-body{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:0}.install-title{font-family:Fraunces,Georgia,serif;font-weight:800;font-size:14px;color:var(--ink);letter-spacing:-.01em;line-height:1.1}.install-hint{font-size:12px;color:var(--sub);font-weight:700;display:flex;align-items:center;gap:4px;flex-wrap:wrap}.install-hint .install-share{color:#007aff;display:inline-flex;align-items:center;vertical-align:middle}.install-hint b{color:var(--ink);font-weight:800}.install-cta{background:var(--ink);color:#fff;border:none;padding:6px 14px;border-radius:999px;font-family:inherit;font-weight:800;font-size:12px;cursor:pointer;letter-spacing:.02em}.install-cta:hover{background:#000}.install-close{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--ink);color:#fff;border:2px solid #fff;font-size:11px;font-weight:800;cursor:pointer;display:grid;place-items:center;line-height:1}