/* (truncated for brevity in tool output) Full CSS from earlier step */
:root{
  --bg-1:#FFE8F3; --bg-2:#FDECF8; --text:#4B3B47; --muted:#7c6b78;
  --primary:#ff8fbd; --primary-2:#ff79ad; --ring:#f7b4d0; --glass:rgba(255,255,255,.55);
  --shadow:0 10px 30px rgba(255, 143, 189, .25);
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;font-family:"Quicksand",system-ui,-apple-system,Segoe UI,Roboto,Arial;color:var(--text);
background: radial-gradient(1200px 600px at 10% 0%, var(--bg-1), transparent),
            radial-gradient(900px 600px at 90% 20%, #fff5fb, transparent),
            linear-gradient(135deg, var(--bg-1), var(--bg-2)); overflow-x:hidden;}
a{color:inherit;text-decoration:none} img{max-width:100%;display:block}
.glass{background:var(--glass);backdrop-filter: blur(12px);-webkit-backdrop-filter: blur(12px);
border:1px solid rgba(255,255,255,.6);border-radius:18px;box-shadow:var(--shadow)}
.nav{position:sticky;top:0;z-index:10;margin:16px;padding:12px 18px;display:flex;align-items:center;gap:16px;justify-content:space-between}
.nav .brand{font-weight:700}.nav nav{display:flex;gap:14px}.nav nav a{padding:8px 12px;border-radius:14px;opacity:.8}
.nav nav a.active,.nav nav a:hover{background:rgba(255,255,255,.6);opacity:1}
.pill{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:999px;border:none;cursor:pointer;font-weight:700;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}
.pill:hover{transform:translateY(-1px)}.pill.primary{background:var(--primary);color:#fff}.pill.primary:hover{background:var(--primary-2)}
.pill.ghost{background:rgba(255,255,255,.7)}.pill.cta{background:linear-gradient(180deg, var(--primary), var(--primary-2)); color:white}
.hero{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;padding:clamp(24px,4vw,64px);align-items:center}
@media (max-width:900px){.hero{grid-template-columns:1fr;padding-top:32px}}
.headline{font-size:clamp(28px,4vw,42px);margin:0 0 10px}.highlight{background:linear-gradient(90deg,#f89ec6,#f8b7d4);-webkit-background-clip:text;color:transparent}.sub{color:var(--muted)}
.cta-row{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.countdown{margin:18px 0 10px;padding:16px;display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center}
.ring{position:relative;width:140px;height:140px}.ring-svg{width:140px;height:140px;transform:rotate(-90deg)}
.ring .track{fill:none;stroke:#ffe3ef;stroke-width:12}.ring .progress{fill:none;stroke:var(--ring);stroke-width:12;stroke-linecap:round;stroke-dasharray:339.292;stroke-dashoffset:339.292}
.ring .time{position:absolute;inset:0;display:grid;place-items:center}.ring .num{font-size:42px;font-weight:700;color:#e16095}.ring .label{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--muted)}
.detail{display:flex;gap:18px;font-size:18px}.detail span{font-weight:700;color:#e16095}.detail small{display:block;font-size:11px;color:var(--muted)}
.art{position:relative;min-height:380px}.tree{position:relative;width:260px;margin:auto;filter:drop-shadow(0 8px 20px rgba(232,96,149,.25))}
.layer{width:0;height:0;border-left:130px solid transparent;border-right:130px solid transparent;transform-origin:50% 0}
.layer-1{border-bottom:110px solid #ffd0e3;margin:40px auto 0;animation:sway 4s ease-in-out infinite}
.layer-2{border-bottom:120px solid #ffc1da;margin:-20px auto 0;transform:scale(.85);animation:sway 4.2s ease-in-out infinite}
.layer-3{border-bottom:130px solid #ffb3d1;margin:-30px auto 0;transform:scale(.72);animation:sway 4.4s ease-in-out infinite}
.trunk{width:34px;height:46px;background:linear-gradient(#c58aa2,#a06b83);border-radius:6px;margin:6px auto 0}
.star{width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-bottom:18px solid #ffd37f;position:absolute;left:calc(50% - 12px);top:18px;filter:drop-shadow(0 3px 6px rgba(0,0,0,.15));transform-origin:50% 100%;animation:twinkle 2.4s ease-in-out infinite}
@keyframes sway{0%,100%{transform:rotate(0deg)}50%{transform:rotate(2.2deg)}}@keyframes twinkle{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.orn{position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:inset -4px -6px 12px rgba(0,0,0,.1),inset 5px 5px 12px rgba(255,255,255,.7)}
.o1{top:130px;left:70px;background:#ffe08b}.o2{top:115px;right:60px;background:#ff9abb}.o3{top:190px;left:40px;background:#ffd2e8}.o4{top:180px;right:50px;background:#ffdca9}.o5{top:235px;left:95px;background:#ffc3da}.o6{top:255px;right:85px;background:#fff1f7}
.float-heart,.float-star{position:absolute;font-size:28px;color:#ff94bb;user-select:none;animation:float 3.8s ease-in-out infinite}
.float-heart{left:10px;top:30px}.float-star{right:40px;bottom:0;animation-duration:4.5s}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.quick{margin:24px;padding:14px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.tools{display:grid;gap:16px;margin:24px;grid-template-columns:1fr 1fr}
@media (max-width:900px){.tools{grid-template-columns:1fr}}
.tool{padding:16px}.tool h3{margin:6px 0 8px}.tool .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.tool textarea,.tool input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.06);background:rgba(255,255,255,.7);outline:none}
.tool input{max-width:260px}.tiny{font-size:.9rem;color:var(--muted)}
.result{background:rgba(255,255,255,.65);border:1px solid rgba(0,0,0,.05);padding:12px;border-radius:12px;min-height:80px;margin-top:8px;white-space:pre-wrap}
.wish-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}
@media (max-width:700px){.wish-list{grid-template-columns:1fr}}
.wish{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:radial-gradient(120px 80px at 10% -10%, #fff3fa, transparent),radial-gradient(120px 80px at 110% 120%, #ffe1ef, transparent),rgba(255,255,255,.75);border:1px solid rgba(0,0,0,.05)}
.wish a{text-decoration:underline}.wish .spacer{flex:1}.wish .del{background:transparent;border:none;cursor:pointer;font-size:18px;opacity:.6}
.wish.done{opacity:.55;text-decoration:line-through}
.snow-layer,.sparkle-layer{pointer-events:none;position:fixed;inset:0;z-index:-1}
@keyframes fall{0%{transform:translateY(-10vh) translateX(0) rotate(0deg);opacity:0}10%{opacity:.7}100%{transform:translateY(110vh) translateX(var(--drift,0px)) rotate(360deg);opacity:.9}}
.sparkle-layer::before,.sparkle-layer::after{content:"";position:absolute;inset:-10% -10% -10% -10%;background-image:radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.75), transparent 50%),radial-gradient(2px 2px at 80% 20%, rgba(255,255,255,.6), transparent 50%),radial-gradient(2px 2px at 40% 70%, rgba(255,255,255,.8), transparent 50%),radial-gradient(2px 2px at 70% 80%, rgba(255,255,255,.5), transparent 50%);animation:sparkle 9s linear infinite;opacity:.4}
.sparkle-layer::after{animation-duration:11s;opacity:.25}@keyframes sparkle{0%{transform:translateY(0)}100%{transform:translateY(12px)}}
dialog{border:none;padding:0}.dialog{padding:20px;max-width:420px}.dialog::backdrop{background:rgba(0,0,0,.25)}
