@property --border-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
:root {
  --bg1: #0a0312;
  --pink: #ff6fae;
  --magenta: #ff2d8a;
  --cream: #fff7ec;
  --gold: #ffd700;
  --lavender: #c4a8ff;
  --text: #fff8fb;
  --muted: rgba(255,248,251,.7);
  --border: rgba(255,255,255,.1);
  --radius: 34px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Be Vietnam Pro',system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg1);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* === LOCK SCREEN === */
.lock-screen{position:fixed;inset:0;z-index:300;display:grid;place-items:center;background:var(--bg1);padding:20px}
.lock-screen.hidden{display:none}
.lock-card{text-align:center;width:min(380px,100%);padding:40px 32px;border-radius:28px;background:linear-gradient(160deg,rgba(255,255,255,.1),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(20px)}
.lock-icon{font-size:56px;margin-bottom:16px;filter:drop-shadow(0 0 20px rgba(255,111,174,.3))}
.lock-card h2{font-family:Quicksand,'Be Vietnam Pro',sans-serif;font-size:22px;line-height:1.3;margin-bottom:10px;font-weight:700}
.lock-sub{color:rgba(255,255,255,.4);font-size:13px;margin-bottom:24px}
.lock-input{width:100%;padding:16px;text-align:center;font-size:28px;letter-spacing:.3em;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:16px;color:var(--text);font-family:inherit;transition:border-color .2s ease}
.lock-input:focus{outline:none;border-color:rgba(255,111,174,.4);box-shadow:0 0 0 3px rgba(255,111,174,.1)}
.lock-btn{width:100%;margin-top:16px;padding:16px}
.lock-error{color:#ff6b6b;font-size:13px;margin-top:12px;min-height:20px}

/* === TOAST === */
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-120px);padding:16px 28px;border-radius:16px;background:rgba(255,77,166,.15);border:1px solid rgba(255,111,174,.3);backdrop-filter:blur(14px);color:var(--text);font-weight:600;font-size:14px;z-index:55;transition:transform .5s cubic-bezier(.16,1,.3,1);pointer-events:none;white-space:nowrap;max-width:90vw;text-overflow:ellipsis;overflow:hidden}
.toast.show{transform:translateX(-50%) translateY(0)}

/* === DAILY QUOTE === */
.daily-quote{font-family:'Charm',cursive;font-size:clamp(16px,3vw,20px);color:rgba(255,255,255,.45);margin:0 auto 20px;max-width:500px;font-style:italic;min-height:28px}

/* === ADMIN LINK === */
.admin-link{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;text-decoration:none;font-size:18px;color:rgba(255,255,255,.25);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);transition:all .2s ease;z-index:5}
.admin-link:hover{color:rgba(255,255,255,.6);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}

/* === LOADER === */
#loader{position:fixed;inset:0;z-index:200;display:grid;place-items:center;background:var(--bg1);transition:opacity 1s ease,visibility 1s ease}
#loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-content{text-align:center}
.loader-heart-svg{margin-bottom:24px}
.heart-path{stroke-dasharray:300;stroke-dashoffset:300;animation:drawH 2s ease forwards;filter:drop-shadow(0 0 12px rgba(255,77,166,.6))}
.heart-fill-path{opacity:0;animation:fillH .6s ease 1.6s forwards}
@keyframes drawH{to{stroke-dashoffset:0}}
@keyframes fillH{to{opacity:1}}
.loader-text{color:var(--muted);font-size:14px;font-weight:500;animation:loaderF 1.5s ease infinite alternate}
@keyframes loaderF{from{opacity:.4}to{opacity:1}}

/* === SOUND === */
.sound-toggle{position:fixed;top:20px;right:20px;z-index:50;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);backdrop-filter:blur(12px);color:rgba(255,255,255,.6);cursor:pointer;display:grid;place-items:center;transition:all .25s ease;opacity:0;transform:translateY(-10px)}
.sound-toggle.visible{opacity:1;transform:translateY(0);transition:opacity .6s ease .5s,transform .6s ease .5s,background .25s ease,border-color .25s ease}
.sound-toggle:hover{background:rgba(255,255,255,.12);border-color:rgba(255,111,174,.3);color:var(--pink)}

/* === NEBULA === */
.nebula{position:fixed;inset:0;z-index:0;transition:background 2s ease;background:radial-gradient(ellipse 80% 60% at 15% 50%,rgba(120,0,100,.5) 0%,transparent 60%),radial-gradient(ellipse 70% 50% at 85% 25%,rgba(60,0,140,.45) 0%,transparent 55%),radial-gradient(ellipse 90% 70% at 50% 90%,rgba(160,20,80,.35) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 70% 60%,rgba(200,50,120,.2) 0%,transparent 50%);animation:nebS 25s ease-in-out infinite alternate}
.nebula.mood-story{background:radial-gradient(ellipse 80% 60% at 20% 40%,rgba(140,0,120,.5) 0%,transparent 60%),radial-gradient(ellipse 70% 50% at 80% 30%,rgba(80,0,160,.45) 0%,transparent 55%),radial-gradient(ellipse 90% 70% at 45% 85%,rgba(180,30,100,.4) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 65% 55%,rgba(220,60,140,.25) 0%,transparent 50%)}
.nebula.mood-question{background:radial-gradient(ellipse 85% 65% at 50% 50%,rgba(180,0,100,.55) 0%,transparent 55%),radial-gradient(ellipse 60% 45% at 20% 30%,rgba(100,0,180,.4) 0%,transparent 50%),radial-gradient(ellipse 70% 55% at 80% 70%,rgba(200,40,120,.45) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 40% 80%,rgba(255,80,160,.2) 0%,transparent 50%)}
.nebula.mood-yes{background:radial-gradient(ellipse 80% 60% at 30% 40%,rgba(200,50,120,.5) 0%,transparent 55%),radial-gradient(ellipse 70% 50% at 70% 25%,rgba(180,80,40,.35) 0%,transparent 50%),radial-gradient(ellipse 90% 70% at 50% 80%,rgba(220,60,140,.45) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 60%,rgba(255,150,80,.2) 0%,transparent 50%)}
.nebula.mood-no{background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(30,30,80,.6) 0%,transparent 60%),radial-gradient(ellipse 70% 50% at 20% 30%,rgba(20,20,60,.5) 0%,transparent 55%),radial-gradient(ellipse 90% 70% at 80% 80%,rgba(40,20,60,.4) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 60% 40%,rgba(60,30,80,.3) 0%,transparent 50%)}
@keyframes nebS{0%{transform:scale(1) rotate(0);opacity:1}33%{transform:scale(1.06) rotate(1.5deg);opacity:.9}66%{transform:scale(.97) rotate(-1deg);opacity:1}100%{transform:scale(1.04) rotate(.8deg);opacity:.95}}

.vignette{position:fixed;inset:0;z-index:0;background:radial-gradient(ellipse at center,transparent 35%,rgba(5,1,10,.75) 100%);pointer-events:none}
#particles{position:fixed;inset:0;z-index:1;pointer-events:none}

/* === ORBS === */
.bg{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden;transition:translate .12s ease-out}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.28;will-change:transform}
.orb-1{width:420px;height:420px;background:radial-gradient(circle,#ff4da6,#cc0066);top:-8%;left:-10%;animation:d1 14s ease-in-out infinite alternate}
.orb-2{width:320px;height:320px;background:radial-gradient(circle,#ffb347,#ff6723);bottom:3%;right:-8%;animation:d2 16s ease-in-out infinite alternate}
.orb-3{width:250px;height:250px;background:radial-gradient(circle,#a78bfa,#7c3aed);top:40%;right:10%;animation:d3 18s ease-in-out infinite alternate}
.orb-4{width:200px;height:200px;background:radial-gradient(circle,#f472b6,#be185d);bottom:25%;left:5%;animation:d4 15s ease-in-out infinite alternate}
.orb-5{width:180px;height:180px;background:radial-gradient(circle,#67e8f9,#0891b2);top:10%;right:30%;animation:d5 20s ease-in-out infinite alternate;opacity:.15}
@keyframes d1{to{transform:translate(50px,40px) scale(1.12)}}
@keyframes d2{to{transform:translate(-40px,-50px) scale(1.08)}}
@keyframes d3{to{transform:translate(-25px,35px) scale(1.18)}}
@keyframes d4{to{transform:translate(40px,-25px) scale(.92)}}
@keyframes d5{to{transform:translate(-30px,20px) scale(1.1)}}

/* === PETALS === */
#petalLayer{position:fixed;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.petal{position:absolute;top:-20px;width:var(--size,10px);height:var(--size,10px);background:radial-gradient(circle at 30% 30%,rgba(255,182,206,.85),rgba(255,130,170,.3));border-radius:50% 0 50% 50%;animation:petalF var(--dur,8s) linear forwards;opacity:0;filter:blur(.3px)}
@keyframes petalF{0%{transform:translateY(0) translateX(0) rotate(0) scale(.8);opacity:0}8%{opacity:.7}50%{transform:translateY(50vh) translateX(var(--sway,30px)) rotate(200deg) scale(1);opacity:.5}100%{transform:translateY(110vh) translateX(calc(var(--sway,30px)*-.6)) rotate(400deg) scale(.6);opacity:0}}

/* === SHELL === */
.shell{min-height:100vh;display:grid;place-items:center;padding:32px 20px;position:relative;z-index:3;perspective:900px}
.shell.dashboard{place-items:start center;padding-top:32px;padding-bottom:60px}

/* === CARDS === */
.card{width:min(680px,100%);display:none;padding:clamp(36px,7vw,64px);border-radius:var(--radius);background:linear-gradient(160deg,rgba(255,255,255,.13) 0%,rgba(255,255,255,.04) 100%);box-shadow:0 40px 120px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.07),inset 0 1px 0 rgba(255,255,255,.15),inset 0 -1px 0 rgba(0,0,0,.2);backdrop-filter:blur(28px) saturate(1.4);-webkit-backdrop-filter:blur(28px) saturate(1.4);text-align:center;position:relative;overflow:hidden;transition:transform .15s ease;transform-style:preserve-3d}
.card::before{content:'';position:absolute;inset:0;border-radius:var(--radius);padding:1.5px;background:conic-gradient(from var(--border-angle),transparent 20%,rgba(255,111,174,.7) 33%,rgba(196,168,255,.6) 50%,rgba(255,200,112,.5) 66%,transparent 80%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:borderSpin 4s linear infinite;pointer-events:none}
@keyframes borderSpin{to{--border-angle:360deg}}
.card::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 50% 80%,rgba(255,111,174,.06) 0%,transparent 50%);pointer-events:none}
.card.visible{display:block;animation:cardIn .9s cubic-bezier(.16,1,.3,1) forwards}
.card.leaving{animation:cardOut .4s cubic-bezier(.5,0,1,1) forwards}
@keyframes cardIn{from{transform:translateY(40px) scale(.92);opacity:0;filter:blur(10px)}to{transform:translateY(0) scale(1);opacity:1;filter:blur(0)}}
@keyframes cardOut{from{transform:translateY(0) scale(1);opacity:1;filter:blur(0)}to{transform:translateY(-30px) scale(.96);opacity:0;filter:blur(6px)}}

/* Yes dashboard card */
.yes-screen{width:min(780px,100%);overflow:visible}

/* === TYPOGRAPHY === */
.eyebrow{color:var(--lavender);text-transform:uppercase;letter-spacing:.3em;font-size:11px;font-weight:800;margin-bottom:24px;text-shadow:0 0 20px rgba(196,168,255,.4)}
h1,h2{font-family:Quicksand,'Be Vietnam Pro',sans-serif;line-height:1.15;margin-bottom:22px}
h1{font-size:clamp(30px,7vw,58px);font-weight:700;text-shadow:0 0 40px rgba(255,111,174,.2),0 2px 20px rgba(0,0,0,.3)}
h2{font-size:clamp(26px,6vw,48px);font-weight:700;text-shadow:0 0 30px rgba(255,111,174,.15),0 2px 16px rgba(0,0,0,.3)}
.glow-text{text-shadow:0 0 10px rgba(255,111,174,.6),0 0 40px rgba(255,111,174,.3),0 0 80px rgba(255,111,174,.12);animation:tGlow 3s ease-in-out infinite alternate}
@keyframes tGlow{from{text-shadow:0 0 10px rgba(255,111,174,.6),0 0 40px rgba(255,111,174,.25),0 0 80px rgba(255,111,174,.08)}to{text-shadow:0 0 18px rgba(255,111,174,.8),0 0 55px rgba(255,111,174,.4),0 0 110px rgba(255,111,174,.18)}}
.gradient-text{background:linear-gradient(135deg,#ff8ab8,#ffd0dc,#ffcc70,#c4a8ff,#ff8ab8);background-size:400% 400%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradS 5s ease infinite;filter:drop-shadow(0 2px 10px rgba(255,111,174,.3))}
@keyframes gradS{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.lead,.line,.quote{font-size:clamp(16px,3vw,20px);line-height:1.75;color:var(--muted);margin:0 auto 24px;max-width:550px}
.lead em{color:var(--pink);font-style:normal;font-weight:700;text-shadow:0 0 12px rgba(255,111,174,.3)}
.quote{font-family:'Charm',cursive;font-size:clamp(18px,3.5vw,23px);color:rgba(255,255,255,.5)}
.quote em{color:var(--pink);font-style:normal;text-shadow:0 0 12px rgba(255,111,174,.3)}
.tiny{color:rgba(255,255,255,.35);font-size:13px;margin-top:26px}
.next-milestone{font-size:13px;color:rgba(255,255,255,.45);margin-bottom:8px;min-height:20px}
.next-milestone em{color:var(--gold);font-style:normal;font-weight:700;text-shadow:0 0 10px rgba(255,215,0,.3)}

/* === BUTTONS === */
.btn{border:0;border-radius:999px;padding:17px 38px;font-weight:800;font-size:16px;cursor:pointer;color:#2b0b18;background:var(--cream);box-shadow:0 8px 36px rgba(0,0,0,.3);transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:inherit}
.btn span{position:relative;z-index:1}
.btn::after{content:'';position:absolute;top:-50%;left:-100%;width:60%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-20deg);transition:left .6s ease}
.btn:hover::after{left:140%}
.btn:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 18px 56px rgba(0,0,0,.35);filter:brightness(1.08)}
.btn:active{transform:translateY(0) scale(.97)}
.primary,.yes{background:linear-gradient(135deg,#ff4da6,#ff6fae,#ffd0dc);background-size:200% 200%;animation:btnG 3s ease infinite;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2)}
@keyframes btnG{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.glow{box-shadow:0 8px 36px rgba(255,77,166,.35),0 0 60px rgba(255,111,174,.15),inset 0 1px 0 rgba(255,255,255,.25)}
.glow:hover{box-shadow:0 18px 60px rgba(255,77,166,.45),0 0 90px rgba(255,111,174,.2),inset 0 1px 0 rgba(255,255,255,.25)}
.no{background:linear-gradient(135deg,#b8b8c8,#d8d8e2);font-size:14px;padding:14px 24px}
.ghost{color:var(--text);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px)}
.ghost:hover{background:rgba(255,255,255,.14)}
.actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}

/* === STORY / TYPING === */
.story .line{opacity:0;transform:translateY(14px)}
.story .line.typed{opacity:1;transform:translateY(0);transition:opacity .5s ease,transform .5s ease}
.story .line.typing{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}
.story .line.typing::after{content:'|';color:var(--pink);font-weight:300;animation:blink .5s step-end infinite;margin-left:1px;text-shadow:0 0 8px rgba(255,111,174,.5)}
@keyframes blink{50%{opacity:0}}
.story #questionBtn{margin-top:20px;opacity:0;transform:translateY(14px);pointer-events:none}
.story #questionBtn.show{opacity:1;transform:translateY(0);pointer-events:auto;transition:opacity .7s ease .15s,transform .7s ease .15s}
.progress{height:3px;border-radius:999px;background:rgba(255,255,255,.06);margin-bottom:34px;overflow:hidden}
.progress span{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--magenta),var(--pink),var(--lavender));background-size:200% 100%;transition:width .6s cubic-bezier(.4,0,.2,1);animation:progS 2s ease infinite;box-shadow:0 0 12px rgba(255,111,174,.4)}
@keyframes progS{0%,100%{background-position:0% 0}50%{background-position:100% 0}}

/* === HEART === */
.heart-wrapper{position:relative;display:inline-block;margin-bottom:20px}
.heart-glow{position:absolute;inset:-55px;background:radial-gradient(circle,rgba(255,77,166,.4) 0%,rgba(255,111,174,.1) 40%,transparent 70%);border-radius:50%;animation:hGlow 2s ease-in-out infinite;pointer-events:none}
@keyframes hGlow{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.4);opacity:.85}}
.heart-ring{position:absolute;inset:-30px;border:2px solid rgba(255,111,174,.15);border-radius:50%;animation:hRing 2s ease-in-out infinite;pointer-events:none}
@keyframes hRing{0%,100%{transform:scale(.8);opacity:.7}50%{transform:scale(1.5);opacity:0}}
.heart{font-size:90px;filter:drop-shadow(0 8px 32px rgba(255,77,166,.5)) drop-shadow(0 0 60px rgba(255,111,174,.2));position:relative}
.idle{animation:pulse 1.1s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}
.spark-heart{font-size:100px;margin-bottom:18px;filter:drop-shadow(0 8px 40px rgba(255,77,166,.5)) drop-shadow(0 0 80px rgba(255,111,174,.25));animation:sparkP 1.5s ease-in-out infinite}
@keyframes sparkP{0%,100%{transform:scale(1) rotate(0)}25%{transform:scale(1.12) rotate(-4deg)}75%{transform:scale(1.06) rotate(4deg)}}

/* === COUNTER === */
.counter{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:28px auto;max-width:480px}
.counter-item{padding:22px 10px;border-radius:22px;background:linear-gradient(160deg,rgba(255,255,255,.12),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(10px);position:relative;overflow:hidden;transition:border-color .3s ease,box-shadow .3s ease}
.counter-item:hover{border-color:rgba(255,111,174,.3);box-shadow:0 0 20px rgba(255,111,174,.1)}
.counter-item::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,111,174,.06) 100%);pointer-events:none}
.counter-item strong{display:block;font-size:clamp(26px,6vw,46px);font-family:Quicksand,sans-serif;font-weight:700;line-height:1;background:linear-gradient(to bottom,#fff,rgba(255,255,255,.65));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 8px rgba(255,255,255,.15))}
.counter-item span{display:block;margin-top:8px;color:rgba(255,255,255,.4);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em}
@keyframes digitPop{0%{transform:scale(1)}40%{transform:scale(1.22)}100%{transform:scale(1)}}

/* === MILESTONES === */
.milestones{margin-top:16px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.milestone{padding:7px 15px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:rgba(255,255,255,.35);transition:all .35s ease}
.milestone.reached{background:linear-gradient(135deg,rgba(255,77,166,.2),rgba(255,111,174,.08));border-color:rgba(255,111,174,.35);color:var(--pink);text-shadow:0 0 8px rgba(255,111,174,.3)}
.milestone.reached::before{content:'~ '}
.milestone.next{border-color:rgba(255,215,0,.25);color:rgba(255,215,0,.7);animation:msG 2.5s ease-in-out infinite}
@keyframes msG{0%,100%{box-shadow:0 0 0 rgba(255,215,0,0)}50%{box-shadow:0 0 18px rgba(255,215,0,.15)}}

/* === DASHBOARD TABS === */
.dash-tabs{display:flex;gap:4px;margin:32px 0 20px;background:rgba(255,255,255,.06);border-radius:999px;padding:4px;border:1px solid rgba(255,255,255,.06)}
.dash-tab{flex:1;padding:11px 20px;border-radius:999px;border:0;background:transparent;color:rgba(255,255,255,.5);font-weight:700;font-size:14px;cursor:pointer;transition:all .25s ease;font-family:inherit}
.dash-tab.active{background:rgba(255,111,174,.15);color:var(--pink);box-shadow:0 0 16px rgba(255,111,174,.1)}
.dash-tab:hover:not(.active){color:rgba(255,255,255,.75)}
.dash-panel{display:none}
.dash-panel.visible{display:block;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.empty-state{color:rgba(255,255,255,.35);font-size:14px;padding:40px 20px;text-align:center}

.add-btn{display:block;width:100%;margin-top:16px;padding:14px;border-radius:16px;border:2px dashed rgba(255,255,255,.12);background:transparent;color:rgba(255,255,255,.4);font-size:14px;font-weight:700;cursor:pointer;transition:all .25s ease;font-family:inherit}
.add-btn:hover{border-color:rgba(255,111,174,.3);color:var(--pink);background:rgba(255,111,174,.05)}

/* === TIMELINE === */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--pink),var(--lavender),rgba(255,111,174,.1));border-radius:999px}
.tl-item{position:relative;margin-bottom:20px;padding:16px 18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:16px;text-align:left;transition:border-color .2s ease}
.tl-item:hover{border-color:rgba(255,111,174,.2)}
.tl-item::before{content:'';position:absolute;left:-24px;top:20px;width:10px;height:10px;border-radius:50%;background:var(--pink);box-shadow:0 0 10px rgba(255,111,174,.5)}
.tl-emoji{font-size:22px;margin-bottom:2px}
.tl-date{font-size:11px;color:rgba(255,255,255,.35);margin-bottom:4px;font-weight:600}
.tl-title{font-size:15px;font-weight:700;margin-bottom:4px}
.tl-desc{font-size:13px;color:var(--muted);line-height:1.6}
.tl-del{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;border:0;background:rgba(255,255,255,.06);color:rgba(255,255,255,.3);cursor:pointer;font-size:14px;display:grid;place-items:center;transition:all .2s ease;opacity:0}
.tl-item:hover .tl-del{opacity:1}
.tl-del:hover{background:rgba(255,60,60,.2);color:#ff6b6b}

/* === GALLERY === */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.gal-item{border-radius:16px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:all .25s ease;position:relative}
.gal-item:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.3);border-color:rgba(255,111,174,.2)}
.gal-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.gal-info{padding:10px 12px}
.gal-caption{font-size:12px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gal-date{font-size:11px;color:rgba(255,255,255,.35)}
.gal-del{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;border:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);color:rgba(255,255,255,.6);cursor:pointer;font-size:12px;display:grid;place-items:center;transition:all .2s ease;opacity:0}
.gal-item:hover .gal-del{opacity:1}
.gal-del:hover{background:rgba(255,60,60,.6);color:#fff}

/* === MODALS === */
.modal{position:fixed;inset:0;z-index:100;display:none;place-items:center}
.modal.open{display:grid;animation:fadeIn .25s ease}
.modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px)}
.modal-box{position:relative;width:min(440px,90vw);max-height:85vh;overflow-y:auto;padding:32px;border-radius:24px;background:linear-gradient(160deg,rgba(30,15,40,.95),rgba(20,8,30,.98));border:1px solid rgba(255,255,255,.1);box-shadow:0 40px 100px rgba(0,0,0,.5)}
.modal-box h3{font-family:Quicksand,'Be Vietnam Pro',sans-serif;font-size:22px;font-weight:700;margin-bottom:24px;text-align:center}

/* === FORMS === */
.form-label{display:block;margin-bottom:16px;text-align:left}
.form-label span{display:block;font-size:12px;font-weight:700;color:rgba(255,255,255,.5);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em}
.form-input{width:100%;padding:12px 16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:var(--text);font-family:inherit;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;resize:vertical}
.form-input:focus{outline:none;border-color:rgba(255,111,174,.4);box-shadow:0 0 0 3px rgba(255,111,174,.1)}
.form-input::placeholder{color:rgba(255,255,255,.25)}
.form-input[type="date"]{color-scheme:dark}
.form-sm{max-width:80px;text-align:center;font-size:20px;padding:8px}
.form-row{display:flex;gap:12px}
.form-grow{flex:1}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}
.form-actions .btn{padding:12px 28px;font-size:14px}

/* Photo upload */
.photo-upload{position:relative}
.photo-upload input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2}
.photo-placeholder{padding:32px;border:2px dashed rgba(255,255,255,.12);border-radius:14px;color:rgba(255,255,255,.35);font-size:14px;text-align:center;transition:border-color .2s ease}
.photo-upload:hover .photo-placeholder{border-color:rgba(255,111,174,.3);color:var(--pink)}
.photo-preview{display:none;width:100%;max-height:200px;object-fit:cover;border-radius:14px}
.photo-preview.show{display:block}
.photo-placeholder.hidden{display:none}

/* === LIGHTBOX === */
.lightbox{position:fixed;inset:0;z-index:150;display:none;place-items:center}
.lightbox.open{display:grid;animation:fadeIn .25s ease}
.lightbox-bg{position:absolute;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px)}
.lightbox-body{position:relative;max-width:90vw;max-height:85vh;text-align:center}
.lightbox-body img{max-width:100%;max-height:80vh;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-caption{margin-top:12px;color:rgba(255,255,255,.7);font-size:14px}
.lightbox-close{position:fixed;top:20px;right:20px;width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.1);color:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;transition:background .2s ease;z-index:2}
.lightbox-close:hover{background:rgba(255,255,255,.2)}

/* === BROKEN HEART === */
.broken-heart{font-size:100px;margin-bottom:12px}
.no-screen.visible .broken-heart span{display:inline-block;animation:shatter 1.1s ease both}
@keyframes shatter{0%{transform:scale(1);filter:none;opacity:1}35%{transform:scale(1.25) rotate(-6deg);filter:drop-shadow(0 0 24px rgba(255,255,255,.4))}100%{transform:translateY(35px) rotate(18deg) scale(.55);opacity:.15;filter:grayscale(1) blur(1.5px)}}

/* === FLASH === */
#flashOverlay{position:fixed;inset:0;z-index:20;background:rgba(255,200,220,.9);opacity:0;pointer-events:none}
#flashOverlay.flash{animation:scFlash .7s ease-out forwards}
@keyframes scFlash{0%{opacity:.7}100%{opacity:0}}

/* === FLOAT/SHARD/SPARKLE === */
#floatLayer{position:fixed;inset:0;pointer-events:none;z-index:15;overflow:hidden}
.float{position:absolute;bottom:-40px;animation:floatUp var(--duration,4s) ease-in forwards;filter:drop-shadow(0 0 8px rgba(255,111,174,.3))}
@keyframes floatUp{0%{opacity:.9;transform:translateY(0) rotate(0) scale(1)}100%{opacity:0;transform:translateY(-115vh) rotate(var(--rot,25deg)) scale(.4)}}
.shard{position:absolute;left:50%;top:50%;color:#ff9bb8;animation:shard 1.8s ease-out forwards}
@keyframes shard{to{transform:translate(var(--x),var(--y)) rotate(var(--r));opacity:0}}
.sparkle{position:fixed;pointer-events:none;z-index:5;width:6px;height:6px;border-radius:50%;background:radial-gradient(circle,rgba(255,220,240,1),rgba(255,111,174,.6));box-shadow:0 0 10px rgba(255,111,174,.5),0 0 20px rgba(255,111,174,.2);animation:sparkleF .7s ease-out forwards}
@keyframes sparkleF{0%{transform:scale(1);opacity:1}100%{transform:scale(0) translateY(-25px);opacity:0}}

/* === RESPONSIVE === */
@media(max-width:520px){
  .card{border-radius:26px;padding:clamp(22px,5vw,40px)}
  .counter{grid-template-columns:repeat(2,1fr);gap:10px}
  .milestones{gap:6px}.milestone{font-size:11px;padding:5px 11px}
  .orb{filter:blur(60px);opacity:.18}.nebula{opacity:.7}
  .sound-toggle{top:14px;right:14px;width:38px;height:38px}
  .gallery{grid-template-columns:repeat(2,1fr);gap:8px}
  .yes-screen{padding:clamp(20px,4vw,32px)}
  .btn{padding:15px 28px;font-size:15px;width:100%}
  .actions{flex-direction:column;gap:10px}
  .actions .btn{width:100%}
  .dash-tabs{margin:24px 0 16px}
  .dash-tab{padding:10px 14px;font-size:13px}
  .tl-del,.gal-del{opacity:1}
  .modal-box{padding:24px;border-radius:20px}
  .form-row{flex-direction:column;gap:0}
  .form-sm{max-width:100%}
  .lock-card{padding:32px 24px}
  .lock-input{font-size:24px;padding:14px}
  .admin-link{top:10px;right:10px;width:32px;height:32px;font-size:14px}
  h1{font-size:clamp(26px,6vw,48px)}
  h2{font-size:clamp(22px,5vw,40px)}
  .lead,.line{font-size:clamp(15px,3.5vw,18px)}
}
