*{margin:0;padding:0;box-sizing:border-box;font-family:var(--app-font-family)}:root{--app-font-family:"Segoe UI", Arial, sans-serif;--app-font-size:16px;--app-font-delta:0px;--app-font-weight:normal;--app-font-style:normal;--container-glass-alpha:.12;--button-bg-color:#ff4b7d;--button-glass-alpha:.18;--memory-hover-scale:1.05;--light-gradient-start:#ff7ac6;--light-gradient-middle:#c45cff;--light-gradient-end:#7a8cff;--dark-gradient-start:#0f172a;--dark-gradient-middle:#1e1b4b;--dark-gradient-end:#020617;--timeline-line-color:rgba(255,255,255,.58);--timeline-dot-color:#ff5f8f;--timeline-dot-center:#fff7fb}html,body{min-height:100vh;overflow-x:hidden;transition:background .5s ease;font-size:var(--app-font-size);font-weight:var(--app-font-weight);font-style:var(--app-font-style)}body.light{background:linear-gradient(135deg,var(--light-gradient-start),var(--light-gradient-middle),var(--light-gradient-end));background-size:400% 400%;animation:gradientMove 10s ease infinite;--timeline-line-color:rgba(255,255,255,.68);--timeline-dot-color:#f43f7d;--timeline-dot-center:#fff6fb}body.dark{background:linear-gradient(135deg,var(--dark-gradient-start),var(--dark-gradient-middle),var(--dark-gradient-end));background-size:400% 400%;animation:gradientMove 10s ease infinite;--timeline-line-color:rgba(226,232,255,.56);--timeline-dot-color:#ff5f8f;--timeline-dot-center:#fff8fc}@keyframes gradientMove{0%{background-position:0% 50%}25%{background-position:50% 100%}50%{background-position:100% 50%}75%{background-position:50% 0%}to{background-position:0% 50%}}.container{width:100%;padding:40px;display:flex;flex-direction:column;align-items:center}.title{font-size:36px;font-weight:600;color:#fff;margin-bottom:30px}.glass-card{width:500px;padding:35px;margin:50px auto;border-radius:30px;background:rgba(255,255,255,var(--container-glass-alpha));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.2);box-shadow:0 10px 40px #00000059}body.glass-containers-off .glass-card,body.glass-containers-off .details-panel,body.glass-containers-off .profile-card,body.glass-containers-off .profile-summary-card,body.glass-containers-off .calendar-month,body.glass-containers-off .empty-state,body.glass-containers-off .preview-dialog,body.glass-containers-off .confirm-dialog,body.glass-containers-off .reminder-alert-card,body.glass-containers-off .reminder-popover{background:#1f2038f5;-webkit-backdrop-filter:none;backdrop-filter:none}input,textarea,select{width:100%;padding:12px;margin-bottom:18px;border-radius:15px;border:1px solid rgba(255,255,255,.22);background:#ffffff24;color:#fff;font-size:14px;outline:none;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:inset 0 1px #ffffff1f}input:focus,textarea:focus,select:focus{border:1px solid rgba(255,255,255,.42);background:#fff3}input::placeholder,textarea::placeholder{color:#ffffffa3}select option{background:#242244;color:#fff}body.light input,body.light textarea,body.light select{background:#ffffff47;color:#2c2c2c}body.light input::placeholder,body.light textarea::placeholder{color:#2c2c2c94}input:disabled{opacity:.72}input[type=file]{background:transparent;border:none;color:#fff}body.light input[type=file]{color:#2c2c2c}input[type=file]::file-selector-button{background:#ff4d6d;color:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer;margin-right:10px}button{width:100%;padding:14px;border:none;border-radius:12px;background:var(--button-bg-color);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:.3s}body.button-glass-on button{background:color-mix(in srgb,var(--button-bg-color) calc(var(--button-glass-alpha) * 100%),transparent);border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 30px #0000002e}button:hover{transform:scale(1.05);background:color-mix(in srgb,var(--button-bg-color) 86%,white)}.timeline-btn{margin-top:12px;background:#6c63ff}.timeline-btn:hover{background:#5148e5}.login-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.login-actions button{margin:0}.login-page{width:100%;display:flex;flex-direction:column;align-items:center}.login-card{margin-bottom:22px}.login-brand{width:min(760px,92vw);text-align:center}.login-brand .main-title{margin-top:0;margin-bottom:10px}.login-brand p{color:#ffffffc7;font-size:18px;line-height:1.5}body.light .login-brand p{color:#2c2c2cb3}.login-intro-overlay{position:fixed;inset:0;z-index:20000;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 42%,rgba(255,75,125,.2),transparent 30%),linear-gradient(135deg,#0a081cf5,#191848fa);color:#fff;opacity:1}.remotion-intro-sheen{position:absolute;inset:-20%;background:linear-gradient(115deg,transparent 24%,rgba(255,255,255,.08) 36%,transparent 48%);transform:translate(-30%);animation:introSheen 2.4s ease both}.remotion-intro-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center}.remotion-intro-logo-wrap{width:132px;height:132px;display:flex;align-items:center;justify-content:center;border-radius:34px;background:linear-gradient(135deg,#ff4b7d,#6c63ff);box-shadow:0 26px 70px #ff4b7d52,0 0 0 1px #ffffff47 inset}.remotion-intro-logo{position:relative;width:82px;height:82px}.remotion-intro-heart{position:absolute;top:0;left:50%;color:#fff;font-size:54px;line-height:1;text-shadow:0 10px 24px rgba(0,0,0,.22);transform:translate(-50%)}.remotion-intro-timeline{position:absolute;left:8px;right:8px;bottom:14px;height:5px;border-radius:999px;background:#ffffffeb}.remotion-intro-dot{position:absolute;bottom:7px;width:18px;height:18px;border-radius:50%;background:#fff;border:4px solid #ff4b7d}.remotion-intro-dot.one{left:14px}.remotion-intro-dot.two{right:14px}.remotion-intro-orbit{position:absolute;width:220px;height:220px;border-radius:50%}.remotion-intro-orbit span{position:absolute;width:18px;height:18px;border-radius:50%;background:#ff4b7d;box-shadow:0 0 24px #ff4b7dcc}.remotion-intro-orbit span:nth-child(1){top:0;left:50%}.remotion-intro-orbit span:nth-child(2){right:12px;bottom:48px;background:#7a8cff}.remotion-intro-orbit span:nth-child(3){left:18px;bottom:38px;background:#ffd1df}.remotion-intro-title{margin:28px 0 8px;font-size:54px;font-weight:900;letter-spacing:1px;text-shadow:0 16px 44px rgba(0,0,0,.28)}.remotion-intro-subtitle{margin:0;color:#ffffffc2;font-size:18px}.remotion-intro-line{width:min(420px,72vw);height:4px;margin-top:34px;position:relative;border-radius:999px;background:#ffffff3d}.remotion-intro-line div{height:100%;border-radius:inherit;background:#ff4b7d;box-shadow:0 0 20px #ff4b7db8}.remotion-intro-line i{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:#fff;border:4px solid #ff4b7d}.remotion-intro-kicker,.remotion-intro-footer,.remotion-intro-ambient{display:none}@keyframes introSheen{to{transform:translate(30%)}}.login-intro-scene{position:relative;width:min(620px,90vw);min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden}.login-intro-mark{position:relative;z-index:2;width:132px;height:132px;display:flex;align-items:center;justify-content:center;gap:4px;border-radius:34px;background:linear-gradient(135deg,#ff4b7d,#6c63ff);box-shadow:0 26px 70px #ff4b7d52,0 0 0 1px #ffffff47 inset;animation:introMark 1.05s cubic-bezier(.2,.9,.2,1.1) both}.login-intro-mark span{font-size:42px;font-weight:900;letter-spacing:0}.login-intro-orbit{position:absolute;width:220px;height:220px;border-radius:50%;animation:introOrbit 2.4s linear infinite}.login-intro-orbit span{position:absolute;width:18px;height:18px;border-radius:50%;background:#ff4b7d;box-shadow:0 0 24px #ff4b7dcc}.login-intro-orbit span:nth-child(1){top:0;left:50%}.login-intro-orbit span:nth-child(2){right:12px;bottom:48px;background:#7a8cff}.login-intro-orbit span:nth-child(3){left:18px;bottom:38px;background:#ffd1df}.login-intro-scene h1{margin:28px 0 8px;font-size:48px;font-weight:800;letter-spacing:2px;animation:introTextUp .8s ease .45s both}.login-intro-scene p{color:#ffffffc2;font-size:18px;animation:introTextUp .8s ease .62s both}.login-intro-line{width:min(420px,72vw);height:4px;margin-top:34px;position:relative;border-radius:999px;background:#ffffff3d;overflow:visible;animation:introTextUp .7s ease .82s both}.login-intro-line:before{content:"";position:absolute;inset:0;width:0;border-radius:inherit;background:#ff4b7d;box-shadow:0 0 20px #ff4b7db8;animation:introLine 1.25s ease 1s forwards}.login-intro-line i{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:#fff;border:4px solid #ff4b7d;transform:translate(-50%,-50%) scale(0);animation:introDot .42s ease forwards}.login-intro-line i:nth-child(1){left:0%;animation-delay:1.08s}.login-intro-line i:nth-child(2){left:33%;animation-delay:1.28s}.login-intro-line i:nth-child(3){left:66%;animation-delay:1.48s}.login-intro-line i:nth-child(4){left:100%;animation-delay:1.68s}@keyframes introMark{0%{opacity:0;transform:translateY(24px) scale(.72) rotate(-8deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes introOrbit{to{transform:rotate(360deg)}}@keyframes introTextUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes introLine{to{width:100%}}@keyframes introDot{to{transform:translate(-50%,-50%) scale(1)}}@keyframes introFadeOut{to{opacity:0;visibility:hidden}}.onboarding-overlay{position:fixed;inset:0;z-index:19950;display:grid;place-items:center;padding:clamp(20px,4vw,56px);overflow:hidden;color:#fff;background:radial-gradient(circle at 18% 18%,color-mix(in srgb,var(--onboarding-accent) 24%,transparent),transparent 34%),radial-gradient(circle at 82% 82%,rgba(108,99,255,.2),transparent 36%),linear-gradient(145deg,#070719,#111033 48%,#17154a);animation:onboardingOverlayIn .55s ease both}.onboarding-overlay:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.75),transparent 92%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.75),transparent 92%);pointer-events:none}.onboarding-glow{position:absolute;width:36vw;aspect-ratio:1;border-radius:50%;filter:blur(90px);opacity:.18;pointer-events:none;animation:onboardingGlow 6s ease-in-out infinite alternate}.onboarding-glow-one{top:-20%;right:-10%;background:var(--onboarding-accent)}.onboarding-glow-two{left:-14%;bottom:-24%;background:#6c63ff;animation-delay:-2s}.onboarding-shell{position:relative;width:min(1080px,94vw);min-height:min(650px,82vh);padding:26px;border:1px solid rgba(255,255,255,.16);border-radius:34px;background:#121233d1;box-shadow:0 32px 90px #0000006b;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);overflow:hidden}.onboarding-progress{position:relative;z-index:3;display:grid;grid-template-columns:repeat(6,1fr);gap:9px;width:min(460px,70%);margin:0 auto 24px}.onboarding-progress span{height:4px;border-radius:999px;background:#ffffff29;transition:background .35s ease,box-shadow .35s ease,transform .35s ease}.onboarding-progress span.complete{background:var(--onboarding-accent);box-shadow:0 0 14px color-mix(in srgb,var(--onboarding-accent) 72%,transparent);transform:scaleY(1.18)}.onboarding-stage{min-height:560px;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);align-items:center;gap:clamp(38px,6vw,84px);padding:24px clamp(24px,5vw,68px) 38px}.onboarding-stage.forward{animation:onboardingStepForward .48s cubic-bezier(.2,.8,.2,1) both}.onboarding-stage.backward{animation:onboardingStepBackward .48s cubic-bezier(.2,.8,.2,1) both}.onboarding-visual{position:relative;min-height:430px;display:flex;align-items:center;justify-content:center;isolation:isolate}.onboarding-visual:before,.onboarding-visual:after{content:"";position:absolute;border-radius:50%;pointer-events:none}.onboarding-visual:before{width:350px;height:350px;border:1px solid color-mix(in srgb,var(--onboarding-accent) 42%,transparent);box-shadow:0 0 80px color-mix(in srgb,var(--onboarding-accent) 20%,transparent),inset 0 0 60px #ffffff06;animation:onboardingRing 7s linear infinite}.onboarding-visual:after{width:260px;height:260px;background:radial-gradient(circle,color-mix(in srgb,var(--onboarding-accent) 22%,transparent),transparent 68%);filter:blur(5px)}.onboarding-icon{position:absolute;z-index:2;top:38px;left:50%;width:112px;height:112px;display:flex;align-items:center;justify-content:center;border-radius:30px;background:linear-gradient(145deg,color-mix(in srgb,var(--onboarding-accent) 88%,#fff 12%),#6258f2);border:1px solid rgba(255,255,255,.32);box-shadow:0 24px 60px color-mix(in srgb,var(--onboarding-accent) 34%,transparent),inset 0 1px #ffffff59;font-family:"Segoe UI Emoji","Apple Color Emoji",sans-serif;font-size:54px;line-height:1;transform:translate(-50%);animation:onboardingIconFloat 3.2s ease-in-out infinite}.onboarding-orbit{position:absolute;z-index:3;display:flex;align-items:center;justify-content:center;font-family:"Segoe UI Emoji","Apple Color Emoji",sans-serif;pointer-events:none}.onboarding-orbit.orbit-one{width:50px;height:50px;top:100px;right:11%;border-radius:16px;background:#ffffff1a;font-size:25px;animation:onboardingSatellite 4.8s ease-in-out infinite}.onboarding-orbit.orbit-two{left:12%;bottom:105px;color:var(--onboarding-accent);font-size:32px;text-shadow:0 0 22px var(--onboarding-accent);animation:onboardingSatellite 4.2s ease-in-out -1.5s infinite reverse}.onboarding-welcome-preview,.onboarding-add-form,.onboarding-reminder-list,.onboarding-calendar,.onboarding-export-list,.onboarding-memory-card{position:relative;z-index:2;width:min(340px,88%);margin-top:102px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(145deg,#ffffff24,#ffffff0f);box-shadow:0 24px 60px #00000040;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.onboarding-welcome-preview{height:205px;display:flex;align-items:center;justify-content:space-around;padding:34px;border-radius:32px}.onboarding-welcome-preview span{font-size:50px;animation:onboardingWelcomeEmoji 2.8s ease-in-out infinite alternate}.onboarding-welcome-preview span:last-child{animation-delay:-1.2s}.onboarding-welcome-preview i{width:90px;height:5px;border-radius:999px;background:var(--onboarding-accent);box-shadow:0 0 20px var(--onboarding-accent)}.onboarding-welcome-preview{width:min(370px,90%);height:250px;margin-top:78px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:14px;padding:0;border:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.onboarding-welcome-preview span,.onboarding-welcome-preview i{position:relative;width:100%;height:100%;min-height:0;display:block;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.22);box-shadow:0 20px 44px #05061847,inset 0 1px #ffffff2e;animation:onboardingPhotoFloat 3.6s ease-in-out infinite alternate}.onboarding-welcome-preview span{font-size:0}.onboarding-welcome-preview span:first-child{grid-row:1 / 3;background:radial-gradient(circle at 50% 23%,#ffd1e1 0 9%,transparent 10%),radial-gradient(circle at 47% 38%,#6546d8 0 8%,transparent 9%),linear-gradient(160deg,#ff8db9 0 35%,#8b5cf6 36% 68%,#1d235d 69%);transform:rotate(-4deg)}.onboarding-welcome-preview i{grid-column:2;grid-row:1;background:radial-gradient(circle at 72% 24%,#ffe58a 0 12%,transparent 13%),linear-gradient(145deg,#7dd3fc 0 38%,#22c55e 39% 65%,#14532d 66%);transform:rotate(5deg) translateY(10px)}.onboarding-welcome-preview span:last-child{grid-column:2;grid-row:2;background:radial-gradient(circle at 30% 30%,#fecdd3 0 10%,transparent 11%),radial-gradient(circle at 58% 35%,#fda4af 0 8%,transparent 9%),linear-gradient(145deg,#312e81 0 44%,#f472b6 45% 75%,#fef3c7 76%);transform:rotate(3deg) translateY(-8px);animation-delay:-1.2s}.onboarding-welcome-preview span:before,.onboarding-welcome-preview i:before{position:absolute;left:12px;bottom:10px;padding:5px 9px;border-radius:999px;background:#0a0b1e7a;color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.onboarding-welcome-preview span:first-child:before{content:"Memory"}.onboarding-welcome-preview i:before{content:"Trip"}.onboarding-welcome-preview span:last-child:before{content:"Story"}@keyframes onboardingPhotoFloat{0%{translate:0 0}to{translate:0 -8px}}.onboarding-add-form{display:grid;gap:12px;padding:24px;border-radius:26px}.onboarding-add-form span{padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:13px;color:#ffffffb3;background:#ffffff14}.onboarding-add-form button{padding:13px;pointer-events:none;background:var(--onboarding-accent)}.onboarding-reminder-list,.onboarding-export-list{display:grid;gap:12px;padding:20px;border-radius:26px}.onboarding-reminder-list span,.onboarding-export-list span{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 16px;border-radius:15px;background:#ffffff17}.onboarding-reminder-list small{color:var(--onboarding-accent)}.onboarding-export-list b{color:var(--onboarding-accent);font-size:22px}.onboarding-calendar{padding:22px;border-radius:26px}.onboarding-calendar>strong{display:block;margin-bottom:18px;font-size:20px}.onboarding-calendar>div{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.onboarding-calendar span{aspect-ratio:1;display:grid;place-items:center;border-radius:10px;color:#ffffffb8;background:#ffffff12}.onboarding-calendar span.active{color:#fff;background:var(--onboarding-accent);box-shadow:0 8px 20px color-mix(in srgb,var(--onboarding-accent) 38%,transparent)}.onboarding-memory-card{min-height:230px;padding:16px;border-radius:26px;overflow:hidden}.onboarding-card-image{height:112px;display:grid;place-items:center;margin:-16px -16px 14px;background:linear-gradient(145deg,#272654,var(--onboarding-accent));font-size:54px}.onboarding-favorite{position:absolute;z-index:2;top:12px;right:12px;width:38px;height:38px;display:grid;place-items:center;border-radius:50%;color:#fff;background:var(--onboarding-accent)}.onboarding-card-meta{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px}.onboarding-card-meta span{padding:5px 9px;border-radius:999px;color:#ffffffd6;background:#ffffff1c;font-size:12px}.onboarding-memory-card>strong{font-size:19px}.onboarding-copy{position:relative;z-index:4;max-width:470px}.onboarding-step-count{display:inline-flex;margin-bottom:30px;padding:8px 12px;border:1px solid rgba(255,255,255,.13);border-radius:999px;color:#ffffffa3;background:#ffffff0f;font-size:12px;font-weight:800;letter-spacing:1.2px}.onboarding-eyebrow{margin:0 0 12px;color:var(--onboarding-accent);font-size:13px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase}.onboarding-copy h1{max-width:460px;margin:0;font-family:Poppins,Segoe UI,sans-serif;font-size:clamp(38px,4.2vw,58px);line-height:1.06;letter-spacing:-1.6px}.onboarding-description{margin:24px 0 0;color:#ffffffb3;font-size:17px;line-height:1.75}.onboarding-error{margin-top:18px;padding:11px 13px;border:1px solid rgba(255,95,143,.35);border-radius:12px;color:#ffd7e3;background:#ff4b7d1f;font-size:13px}.onboarding-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:36px}.onboarding-actions button{width:auto;min-width:118px;padding:13px 22px;border-radius:14px;transition:transform .25s ease,background .25s ease,border-color .25s ease,opacity .25s ease}.onboarding-actions button:hover{transform:translateY(-2px)}.onboarding-actions button:disabled{cursor:not-allowed;opacity:.36;transform:none}.onboarding-back{border:1px solid rgba(255,255,255,.16);color:#ffffffc2;background:#ffffff12}.onboarding-back:hover{background:#ffffff1f}.onboarding-next{display:flex;align-items:center;justify-content:center;gap:12px;background:var(--onboarding-accent);box-shadow:0 14px 34px color-mix(in srgb,var(--onboarding-accent) 32%,transparent)}.onboarding-next:hover{background:color-mix(in srgb,var(--onboarding-accent) 84%,white)}.onboarding-next span{font-size:19px}@keyframes onboardingOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes onboardingStepForward{0%{opacity:0;transform:translate(34px) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes onboardingStepBackward{0%{opacity:0;transform:translate(-34px) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes onboardingIconFloat{0%,to{transform:translate(-50%) translateY(0) rotate(-2deg)}50%{transform:translate(-50%) translateY(-10px) rotate(2deg)}}@keyframes onboardingSatellite{0%,to{transform:translate(0) rotate(-8deg)}50%{transform:translate(12px,-16px) rotate(8deg)}}@keyframes onboardingWelcomeEmoji{0%{transform:translateY(5px) rotate(-5deg) scale(.94)}to{transform:translateY(-7px) rotate(5deg) scale(1.06)}}@keyframes onboardingRing{to{transform:rotate(360deg)}}@keyframes onboardingGlow{0%{transform:scale(.86) translate3d(-2%,0,0)}to{transform:scale(1.1) translate3d(4%,-3%,0)}}@media(max-width:760px){.onboarding-overlay{align-items:center;padding:max(14px,env(safe-area-inset-top)) 14px max(14px,env(safe-area-inset-bottom))}.onboarding-shell{width:100%;min-height:0;max-height:calc(100dvh - 28px);padding:18px 14px 16px;border-radius:27px;overflow-y:auto;overscroll-behavior:contain;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.onboarding-progress{width:78%;gap:6px;margin-bottom:10px}.onboarding-progress span{height:3px}.onboarding-stage{min-height:0;display:flex;flex-direction:column;gap:16px;padding:8px 10px 6px}.onboarding-visual{width:100%;min-height:260px}.onboarding-visual:before{width:238px;height:238px}.onboarding-visual:after{width:190px;height:190px}.onboarding-icon{top:8px;width:78px;height:78px;border-radius:22px;font-size:37px}.onboarding-orbit.orbit-one{top:56px;right:7%;width:38px;height:38px;border-radius:12px;font-size:20px}.onboarding-orbit.orbit-two{left:8%;bottom:48px;font-size:24px}.onboarding-welcome-preview,.onboarding-add-form,.onboarding-reminder-list,.onboarding-calendar,.onboarding-export-list,.onboarding-memory-card{width:min(290px,88%);margin-top:68px}.onboarding-welcome-preview{height:145px;padding:22px;border-radius:23px}.onboarding-welcome-preview span{font-size:38px}.onboarding-add-form,.onboarding-reminder-list,.onboarding-export-list{gap:8px;padding:14px;border-radius:20px}.onboarding-add-form span,.onboarding-reminder-list span,.onboarding-export-list span{padding:10px 12px;font-size:12px}.onboarding-add-form button{padding:10px;font-size:12px}.onboarding-calendar{padding:16px;border-radius:20px}.onboarding-calendar>strong{margin-bottom:12px;font-size:15px}.onboarding-calendar>div{gap:5px}.onboarding-calendar span{font-size:11px}.onboarding-memory-card{min-height:176px;padding:12px;border-radius:20px}.onboarding-card-image{height:76px;margin:-12px -12px 10px;font-size:38px}.onboarding-favorite{top:8px;right:8px;width:31px;height:31px}.onboarding-card-meta{margin-bottom:8px}.onboarding-card-meta span{padding:4px 7px;font-size:10px}.onboarding-memory-card>strong{font-size:15px}.onboarding-copy{width:100%;max-width:460px;text-align:center}.onboarding-step-count{margin-bottom:12px;padding:6px 9px;font-size:10px}.onboarding-eyebrow{margin-bottom:7px;font-size:10px;letter-spacing:2px}.onboarding-copy h1{max-width:340px;margin:auto;font-size:clamp(27px,8vw,35px);line-height:1.1;letter-spacing:-.8px}.onboarding-description{max-width:410px;margin:13px auto 0;font-size:13px;line-height:1.55}.onboarding-error{margin:12px auto 0;padding:9px 10px;font-size:11px}.onboarding-actions{justify-content:center;margin-top:18px}.onboarding-actions button{min-width:108px;padding:11px 18px;font-size:13px}}@media(max-width:380px),(max-height:700px)and (max-width:760px){.onboarding-shell{padding-top:13px}.onboarding-visual{min-height:220px}.onboarding-visual:before{width:205px;height:205px}.onboarding-icon{width:68px;height:68px;font-size:32px}.onboarding-welcome-preview,.onboarding-add-form,.onboarding-reminder-list,.onboarding-calendar,.onboarding-export-list,.onboarding-memory-card{width:min(270px,86%);margin-top:58px}.onboarding-copy h1{font-size:25px}.onboarding-description{font-size:12px}}@media(prefers-reduced-motion:reduce){.onboarding-overlay,.onboarding-stage,.onboarding-icon,.onboarding-orbit,.onboarding-visual:before,.onboarding-welcome-preview span,.onboarding-glow{animation:none!important}}.add-memory-btn{margin:10px;padding:10px 20px;border:none;border-radius:10px;background:#98257d;color:#fff;font-weight:700}.top-buttons{position:fixed;top:20px;right:20px;display:flex;gap:8px;z-index:1000}.toggle-btn,.logout-btn{width:var(--top-action-size);height:var(--top-action-size);padding:0;border-radius:50%;border:none;cursor:pointer;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:clamp(18px,calc(var(--top-action-size) - 28px),34px);background:#ffffff83;box-shadow:0 4px 15px #0003}.toggle-btn:hover,.logout-btn:hover{transform:scale(1.1)}.toggle-btn{font-size:0}.toggle-btn:before,.logout-btn:before{display:block;font-size:clamp(18px,calc(var(--top-action-size) - 28px),34px);line-height:1}.logout-btn{font-size:0}.logout-btn:before{content:"🔓"}.logout-confirm-overlay{position:fixed;inset:0;z-index:29950;display:grid;place-items:center;padding:24px;background:#0506148f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:logoutOverlayIn .22s ease both}.logout-confirm-card{position:relative;width:min(440px,calc(100vw - 48px));padding:32px;overflow:hidden;border:1px solid rgba(255,255,255,.2);border-radius:28px;color:#fff;background:radial-gradient(circle at 50% 0,rgba(255,75,125,.16),transparent 40%),#1b1c39f0;box-shadow:0 28px 90px #00000075;text-align:center;animation:logoutConfirmIn .32s cubic-bezier(.2,.82,.2,1) both}.logout-confirm-card:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 38%)}.logout-confirm-icon{position:relative;width:68px;height:68px;display:grid;place-items:center;margin:0 auto 18px;border:1px solid rgba(255,255,255,.24);border-radius:22px;background:linear-gradient(145deg,#ff4b7d,#6c63ff);box-shadow:0 16px 42px #ff4b7d47;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;font-size:31px;line-height:1}.logout-confirm-copy{position:relative}.logout-confirm-copy p{margin:0 0 8px;color:#ff7aa3;font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase}.logout-confirm-copy h2{margin:0;font-family:Poppins,Segoe UI,Arial,sans-serif;font-size:26px;line-height:1.2;letter-spacing:-.4px}.logout-confirm-copy span{display:block;max-width:350px;margin:14px auto 0;color:#ffffffad;font-size:14px;line-height:1.55}.logout-confirm-actions{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}.logout-confirm-actions button{min-height:46px;padding:12px 18px;border-radius:14px;font-size:14px;transition:transform .22s ease,background .22s ease,border-color .22s ease,box-shadow .22s ease}.logout-confirm-actions button:hover{transform:translateY(-2px)}.logout-cancel-btn,body.button-glass-on .logout-cancel-btn{border:1px solid rgba(255,255,255,.18);color:#ffffffd1;background:#ffffff14;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.logout-cancel-btn:hover,body.button-glass-on .logout-cancel-btn:hover{background:#ffffff24}.logout-confirm-btn,body.button-glass-on .logout-confirm-btn{border:1px solid rgba(255,117,153,.56);color:#fff;background:linear-gradient(135deg,#ff4b7d,#ee386c);box-shadow:0 12px 28px #ff4b7d40;-webkit-backdrop-filter:none;backdrop-filter:none}.logout-confirm-btn:hover,body.button-glass-on .logout-confirm-btn:hover{background:linear-gradient(135deg,#ff5f8f,#f02f68);box-shadow:0 15px 34px #ff4b7d52}body.light .logout-confirm-overlay{background:#301b4361}body.light .logout-confirm-card{border-color:#ffffff70;color:#2e2140;background:radial-gradient(circle at 50% 0,rgba(255,75,125,.17),transparent 42%),#fff6fff0;box-shadow:0 28px 80px #461c5b47}body.light .logout-confirm-copy span{color:#2e2140a8}body.light .logout-cancel-btn,body.light.button-glass-on .logout-cancel-btn{border-color:#482d5d29;color:#49375e;background:#4a2f6012}body.light .logout-cancel-btn:hover,body.light.button-glass-on .logout-cancel-btn:hover{background:#4a2f601f}.logout-overlay{position:fixed;inset:0;z-index:30000;display:grid;place-items:center;background:#05061485;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:logoutOverlayIn .22s ease both}.logout-card{min-width:210px;padding:22px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;border-radius:22px;background:#1f2038c7;border:1px solid rgba(255,255,255,.22);color:#fff;box-shadow:0 24px 70px #0000006b;text-transform:uppercase;letter-spacing:.08em}.logout-card strong{font-size:14px}.logout-spinner{width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.22);border-top-color:#ff4b7d;animation:logoutSpin .8s linear infinite}@keyframes logoutOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes logoutConfirmIn{0%{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes logoutSpin{to{transform:rotate(360deg)}}@media(max-width:760px){.logout-confirm-overlay{align-items:center;padding:max(16px,env(safe-area-inset-top)) 16px max(16px,env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px)}.logout-confirm-card{width:min(360px,100%);padding:25px 20px 20px;border-radius:24px}.logout-confirm-icon{width:56px;height:56px;margin-bottom:15px;border-radius:18px;font-size:26px}.logout-confirm-copy p{margin-bottom:7px;font-size:10px}.logout-confirm-copy h2{font-size:21px}.logout-confirm-copy span{max-width:290px;margin-top:11px;font-size:12px;line-height:1.5}.logout-confirm-actions{gap:10px;margin-top:21px}.logout-confirm-actions button{min-height:42px;padding:10px 14px;border-radius:12px;font-size:13px}}.toggle-btn,.logout-btn{color:transparent}.toggle-btn:before,.logout-btn:before{color:#fff}body.top-actions-left .top-buttons{left:20px;right:auto;flex-direction:row-reverse}body.dark .toggle-btn:before{content:"☀"}body.light .toggle-btn:before{content:"☾"}.timeline-container{width:100%;display:flex;flex-direction:column;align-items:center}.timeline-title{color:#fff}.timeline-controls{width:min(820px,94vw);display:flex;align-items:center;justify-content:center;gap:12px;margin:10px 0 6px;position:relative;z-index:5}.timeline-controls-shell{position:relative;width:min(820px,94vw);display:flex;justify-content:center}.timeline-search-shell{width:56px;height:56px;display:grid;grid-template-columns:56px 0fr;align-items:center;overflow:hidden;border-radius:18px;background:rgba(255,255,255,var(--container-glass-alpha));border:1px solid rgba(255,255,255,.22);box-shadow:0 12px 30px #0000002e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transition:grid-template-columns .36s ease,width .36s ease,background .25s ease,box-shadow .25s ease}.timeline-search-shell.open{width:min(320px,42vw);grid-template-columns:56px 1fr;background:#ffffffe6;box-shadow:0 16px 36px #00000038}.timeline-search-shell.open .timeline-icon-control{background:#ff2f6d;box-shadow:none}.timeline-search{min-width:0;height:56px;margin-bottom:0;padding:0 18px 0 8px;border:0;border-radius:0;background:transparent;color:#242244;opacity:0;transform:translate(-8px);transition:opacity .24s ease,transform .24s ease}.timeline-search::placeholder{color:#2422449e;opacity:1}.timeline-search-shell.open .timeline-search{opacity:1;transform:translate(0)}.timeline-search:focus{border:0;background:transparent}.timeline-filter-menu{position:relative}.filter-toggle,.timeline-icon-control,.timeline-action-btn,.timeline-toolbar button{width:56px;height:56px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:16px;font-size:24px;line-height:1}.timeline-icon-control{margin-bottom:0;flex:0 0 auto;background:#2563eb;box-shadow:none;transition:transform .25s ease,background .25s ease,box-shadow .25s ease}.timeline-icon-control:hover,.timeline-icon-control.active{background:#ff2f6d;box-shadow:0 14px 30px #ff2f6d59}.filter-icon-control{font-size:0}.filter-funnel-icon{position:relative;width:28px;height:26px;display:block}.filter-funnel-icon:before{content:"";position:absolute;left:2px;top:2px;width:24px;height:15px;background:#fff;clip-path:polygon(0 0,100% 0,62% 58%,62% 100%,38% 100%,38% 58%)}.filter-funnel-icon:after{content:"";position:absolute;left:10px;bottom:2px;width:8px;height:6px;border-radius:0 0 3px 3px;background:#fff}.filter-toggle{background:#2563eb;margin-bottom:0;transition:transform .25s ease,background .25s ease,box-shadow .25s ease}.timeline-action-btn{flex:0 0 auto;margin-bottom:0;background:#2563eb;transition:transform .25s ease,background .25s ease,box-shadow .25s ease}.timeline-action-btn:hover,.filter-toggle:hover,.timeline-action-btn.active{background:#ff2f6d;box-shadow:0 14px 30px #ff2f6d59}.export-image-btn{font-size:0}.export-image-btn:before{content:"📥";font-size:22px;font-weight:800}.timeline-action-btn[title=Settings]{font-size:0}.timeline-action-btn[title=Settings]:before{content:"⚙";font-size:25px}.filter-toggle.active{background:#ff2f6d}.timeline-filter-popover{position:absolute;top:68px;right:0;width:min(320px,86vw);padding:16px;display:grid;gap:14px;border-radius:20px;background:rgba(31,32,56,calc(.5 + var(--container-glass-alpha)));border:1px solid rgba(255,255,255,.22);box-shadow:0 18px 48px #00000052;color:#fff;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:filterPop .22s ease both}@keyframes filterPop{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.timeline-filter-section{display:flex;flex-wrap:wrap;gap:8px}.timeline-filter-section span{width:100%;color:#ffffffb8;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.timeline-filter-section button{width:auto;min-width:72px;padding:9px 12px;border-radius:999px;background:#ffffff1f;border:1px solid rgba(255,255,255,.14);box-shadow:none;color:#fff;font-size:14px}.timeline-filter-section button:hover,.timeline-filter-section button.selected{transform:translateY(-2px);background:#ff4b7d}.timeline-toolbar{width:min(300px,90vw);display:grid;grid-template-columns:repeat(4,56px);justify-content:center;gap:12px;margin:12px 0 8px}.timeline-export-popover{position:absolute;top:calc(100% + 4px);left:50%;z-index:60;width:min(292px,86vw);margin:0;padding:7px;display:grid;gap:5px;border:1px solid rgba(255,255,255,.2);border-radius:16px;background:#191937f0;box-shadow:0 22px 56px #03041275;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transform:translate(-50%);animation:exportMenuPop .18s ease-out both}@keyframes exportMenuPop{0%{opacity:0;transform:translate(-50%,-8px) scale(.97)}to{opacity:1;transform:translate(-50%) scale(1)}}.timeline-export-popover button{width:100%;min-height:48px;margin:0;padding:8px 11px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;border-radius:11px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);box-shadow:none;text-align:left}.timeline-export-popover button:hover{transform:translateY(-2px);background:#ff4b7d3d}.timeline-export-popover strong{color:#fff;font-size:13px}.timeline-export-popover small{color:#ffffffa8;font-size:10px}.export-selection-bar{position:sticky;top:18px;z-index:50;width:min(720px,92vw);margin:0 auto 18px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(255,255,255,.2);border-radius:15px;background:#1b1c3af0;color:#fff;box-shadow:0 18px 46px #03041266;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.export-selection-bar>div:first-child{display:grid;gap:1px;font-size:13px}.export-selection-bar span{color:#ffffffad;font-size:11px}.export-selection-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.export-selection-actions button,.export-filter-actions button{width:auto;min-width:82px;margin:0;padding:8px 11px;border-radius:10px;box-shadow:none;font-size:11px}.export-cancel-btn{background:#ffffff1f}.export-confirm-btn{background:#ff4b7d}.export-confirm-btn:disabled{cursor:not-allowed;opacity:.46;transform:none}.export-filter-overlay{position:fixed;inset:0;z-index:1500;padding:24px;display:flex;align-items:center;justify-content:center;background:#040514bd;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.export-filter-dialog{width:min(560px,94vw);padding:26px;display:grid;gap:19px;border:1px solid rgba(255,255,255,.2);border-radius:26px;background:linear-gradient(145deg,#2b2b52fa,#191a37fa);color:#fff;box-shadow:0 30px 80px #00000080}.export-filter-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.export-filter-heading span{color:#ff7ca5;font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.export-filter-heading h3{margin:5px 0 0;color:#fff;font-size:28px}.export-filter-heading button{width:38px;height:38px;margin:0;padding:0;border-radius:50%;background:#ffffff1a;box-shadow:none}.export-filter-dialog label{display:grid;gap:8px;color:#ffffffc2;font-size:13px;font-weight:700}.export-filter-dialog select,.export-filter-dialog input[type=date]{width:100%;margin:0;padding:12px 14px;border:1px solid rgba(255,255,255,.14);border-radius:13px;background:#ffffff1a;color:#fff;color-scheme:dark}.export-filter-dialog option{background:#25264b;color:#fff}.export-date-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}.export-filter-dialog .export-favorite-option{display:flex;align-items:center;gap:10px;color:#fff}.export-favorite-option input{width:20px;height:20px;margin:0;accent-color:#ff4b7d}.export-filter-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.reminder-menu{position:fixed;top:20px;right:calc(20px + ((var(--top-action-size) + 8px) * 2));z-index:1000}.reminder-icon-btn{position:relative;overflow:visible;width:var(--top-action-size);height:var(--top-action-size);padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff85;box-shadow:0 4px 15px #0003;font-size:clamp(18px,calc(var(--top-action-size) - 28px),34px)}body.top-actions-left .reminder-menu{left:calc(20px + ((var(--top-action-size) + 8px) * 2));right:auto}.reminder-icon-btn:hover{transform:scale(1.1)}.reminder-icon-btn span{position:absolute;top:-9px;right:-7px;z-index:5;min-width:22px;height:22px;padding:0 6px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:#ff4d6d;color:#fff;border:2px solid rgba(255,255,255,.85);font-size:12px;font-weight:800;line-height:1;pointer-events:none}.reminder-popover{width:280px;margin-top:12px;margin-left:calc((280px - var(--top-action-size)) * -1);padding:16px;border-radius:18px;background:rgba(31,32,56,calc(.5 + var(--container-glass-alpha)));border:1px solid rgba(255,255,255,.22);color:#fff;box-shadow:0 16px 46px #00000052;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}body.top-actions-left .reminder-popover{margin-left:0}.reminder-popover h3{margin:0 0 12px;font-size:20px}.reminder-popover p{margin:0;color:#ffffffc7}.reminder-popover-item{width:100%;padding:11px 12px;border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:#ffffff1f;color:#fff;box-shadow:none;text-align:left}.reminder-popover-item+.reminder-popover-item{margin-top:8px}.reminder-popover-item strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reminder-popover-item small{flex:0 0 auto;color:#ffffffb8}.reminder-pagination{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}.reminder-pagination button{width:36px;height:36px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff24;box-shadow:none;font-size:22px}.reminder-pagination button:disabled{opacity:.42;cursor:not-allowed}.reminder-pagination span{color:#ffffffc2;font-size:13px;font-weight:700}.reminder-alert-overlay{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;padding:24px;background:#0a081c94;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:reminderFade .22s ease both}.reminder-alert-card{width:min(460px,92vw);padding:28px;border-radius:24px;background:rgba(255,255,255,var(--container-glass-alpha));border:1px solid rgba(255,255,255,.26);color:#fff;text-align:center;box-shadow:0 24px 70px #0000006b;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);animation:reminderLift .28s ease both}.reminder-alert-icon{width:64px;height:64px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;border-radius:20px;background:#2563eb;box-shadow:0 16px 34px #2563eb57;font-size:30px}.reminder-alert-kicker{margin:0 0 8px;color:#ffffffb8;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.reminder-alert-card h3{margin:0 0 12px;font-size:30px;line-height:1.1;overflow-wrap:anywhere}.reminder-alert-card p{line-height:1.6;color:#ffffffdb}.reminder-alert-actions{display:grid;grid-template-columns:1fr 1.35fr;gap:12px;margin-top:22px}.reminder-alert-actions button{padding:13px 14px;border-radius:14px;transition:transform .25s ease,background .25s ease,box-shadow .25s ease}.reminder-ignore-btn{background:#ffffff29;border:1px solid rgba(255,255,255,.22)}.reminder-ignore-btn:hover{background:#ffffff40}.reminder-tomorrow-btn{background:#ff4b7d;box-shadow:0 12px 26px #ff4b7d47}.reminder-tomorrow-btn:hover{background:#ff2f6d;box-shadow:0 16px 34px #ff2f6d57}@keyframes reminderFade{0%{opacity:0}to{opacity:1}}@keyframes reminderLift{0%{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.timeline{position:relative;width:min(1500px,92vw);max-width:1500px;margin-top:40px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));column-gap:18px;row-gap:54px;overflow:visible}.timeline:after{content:none}.timeline-virtual-spacer{grid-column:1 / -1;width:100%;pointer-events:none}.timeline-item{padding:34px 0 0;position:relative;width:100%;overflow:visible;contain-intrinsic-size:320px}.timeline-item:hover{z-index:20}.timeline-item.left,.timeline-item.right{left:0}.timeline-item:after{content:"";position:absolute;z-index:2;width:9px;height:9px;top:9px;left:50%;transform:translate(-50%);border-radius:50%;background:var(--timeline-dot-center);border:1px solid var(--timeline-dot-color);box-shadow:0 0 4px #ff4b7d29}.timeline-item.right:after{left:50%}.timeline-item:before{content:"";position:absolute;z-index:1;top:13px;left:-9px;right:-9px;height:2px;border-radius:999px;background:var(--timeline-line-color);box-shadow:none}.timeline-card{position:relative;min-height:240px;border-radius:16px;background:#1f2038;border:1px solid rgba(255,255,255,.24);color:#fff;overflow:hidden;box-shadow:0 20px 45px #0304126b,inset 0 1px #ffffff29;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;cursor:pointer;isolation:isolate}.timeline-card:hover{transform:translateY(-8px) scale(var(--memory-hover-scale));border-color:#ff74a694;box-shadow:0 26px 60px #03041280,0 0 34px #ff4b7d47}.timeline-item.selection-mode .timeline-card{cursor:pointer}.timeline-item.selection-mode .favorite-btn,.timeline-item.selection-mode .memory-actions{display:none}.timeline-item.selected-memory .timeline-card{border-color:#ff4b7d;box-shadow:0 24px 54px #0304127a,0 0 0 3px #ff4b7d38,0 0 34px #ff4b7d52}.memory-select-check{position:absolute;top:12px;right:12px;z-index:6;width:34px;height:34px;margin:0;padding:0;border:2px solid rgba(255,255,255,.9);border-radius:10px;background:#08091c9e;color:#fff;box-shadow:0 8px 20px #00000047;font-size:19px;line-height:1}.memory-select-check.selected{background:#ff4b7d;border-color:#ff9fbb}body.memory-hover-off .timeline-card:hover{transform:none;border-color:#ffffff3d;box-shadow:0 20px 45px #0304126b,inset 0 1px #ffffff29}body.memory-hover-off .timeline-card:hover img{transform:scale(1.02);filter:saturate(1.05) contrast(1.03)}body.card-size-small .timeline{width:min(1320px,92vw);column-gap:14px;row-gap:44px}body.card-size-small .timeline-card{min-height:190px}body.card-size-small .memory-card-overlay h3{font-size:18px}body.card-size-large .timeline{width:min(1680px,94vw);grid-template-columns:repeat(4,minmax(0,1fr));column-gap:22px;row-gap:64px}body.card-size-large .timeline-card{min-height:310px}body.card-size-large .memory-card-overlay h3{font-size:26px}.memory-photo-wrap{position:absolute;inset:0;display:grid;gap:2px}.memory-photo-wrap:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,#07081814,#0708186b 44%,#070818e0),radial-gradient(circle at 18% 12%,rgba(255,75,125,.28),transparent 35%)}.timeline-card img,.memory-photo-placeholder{width:100%;height:100%;min-height:0}.memory-photo-wrap.collage-2{grid-template-columns:1fr 1fr}.memory-photo-wrap.collage-3{grid-template-columns:1.2fr 1fr;grid-template-rows:1fr 1fr}.memory-photo-wrap.collage-3 img:first-child{grid-row:1 / 3}.memory-photo-wrap.collage-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.timeline-card img{display:block;object-fit:cover;transform:scale(1.02);filter:saturate(1.05) contrast(1.03);transition:transform .55s ease,filter .55s ease}.timeline-card:hover img{transform:scale(1.1);filter:saturate(1.16) contrast(1.06) brightness(1.04)}.memory-photo-placeholder{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 20%,rgba(255,75,125,.55),transparent 30%),linear-gradient(135deg,#363657,#17182d);color:#ffffffd1;font-size:94px;font-weight:800}.memory-card-overlay{position:absolute;inset:auto 0 0;z-index:2;padding:64px 14px 14px;display:flex;flex-direction:column;gap:10px}.memory-card-kicker{display:flex;align-items:center;justify-content:space-between;gap:8px}.memory-card-kicker span,.memory-card-kicker small{width:auto;max-width:45%;padding:6px 9px;border-radius:999px;background:#ffffff2e;color:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:inset 0 1px #ffffff2e;font-size:11px;font-weight:700}.memory-card-kicker small{max-width:48%;color:#ffffffe0;font-weight:600;white-space:nowrap}.memory-card-overlay h3{color:#fff;font-size:22px;line-height:1.05;text-shadow:0 3px 18px rgba(0,0,0,.55);overflow-wrap:anywhere}.memory-actions{display:flex;gap:10px;opacity:0;transform:translateY(8px);transition:opacity .25s ease,transform .25s ease}.timeline-card:hover .memory-actions,.timeline-card:focus-within .memory-actions{opacity:1;transform:translateY(0)}.memory-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px}.memory-meta span{padding:5px 10px;border-radius:999px;background:#ffffff29;font-size:13px}.card-description{margin:8px 0}.card-description ul,.details-description ul{padding-left:20px}.favorite-btn{width:42px;height:42px;padding:0;border-radius:50%;background:#ffffff38;color:#fff;font-size:24px;line-height:1}.favorite-btn.active{background:#ff4d6d}.timeline-card .favorite-btn{position:absolute;top:12px;right:12px;z-index:3;width:38px;height:38px;font-size:22px;background:#0c0d1e6b;border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 10px 24px #00000040}.timeline-card .favorite-btn:hover{transform:scale(1.08);background:#ffffff3d}.timeline-card .favorite-btn.active{background:#ff4d6d;color:#fff}.memory-actions button{width:34px;height:34px;flex:0 0 34px;padding:0;border:none;border-radius:50%;font-size:13px;background:#ffffff2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.memory-actions button:first-child{background:#4dbb62db}.memory-actions button:last-child{background:#ff4d6de6}.empty-state{width:min(520px,90vw);margin-top:36px;padding:28px;border-radius:24px;background:rgba(255,255,255,var(--container-glass-alpha));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.22);box-shadow:0 12px 35px #00000047;color:#fff;text-align:center}.empty-state h3{font-size:28px;margin-bottom:10px}.empty-state p{font-size:16px;margin-bottom:18px}body.light .empty-state{background:#fff3;color:#2c2c2c}.calendar-view{width:min(920px,92vw);margin-top:28px;display:grid;gap:22px}.calendar-month{padding:22px;border-radius:22px;background:rgba(255,255,255,var(--container-glass-alpha));border:1px solid rgba(255,255,255,.2);color:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.calendar-month h3{margin-bottom:14px}.calendar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.calendar-memory{min-height:86px;padding:14px;text-align:left;background:#ffffff24}.calendar-memory{position:relative}.calendar-memory.selected{background:#ff4b7d;box-shadow:0 0 0 3px #ff4b7d33}.calendar-memory i{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.86);border-radius:7px;color:#fff;font-style:normal;font-size:14px}.calendar-memory span{display:block;font-size:26px;margin-bottom:8px}body.light .calendar-month{background:#fff3;color:#2c2c2c}.details-page,.profile-page{width:100%;display:flex;flex-direction:column;align-items:center}.details-panel,.profile-card{width:min(860px,92vw);padding:30px;margin:36px auto 12px;border-radius:26px;background:rgba(255,255,255,var(--container-glass-alpha));border:1px solid rgba(255,255,255,.22);box-shadow:0 12px 38px #00000052;color:#fff;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.story-panel{padding:0;overflow:hidden;position:relative}.details-back-btn,.preview-back-btn{display:none}.story-hero{position:relative;min-height:560px;overflow:hidden}.story-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0506141a,#0506145c 46%,#050614e6)}.story-hero img,.story-hero .memory-photo-placeholder{width:100%;height:100%;min-height:560px;object-fit:cover}.story-hero-content{position:absolute;left:26px;right:84px;bottom:26px;z-index:2;color:#fff}.story-hero-content h2{font-size:48px;line-height:1;margin:10px 0;text-shadow:0 8px 30px rgba(0,0,0,.45)}.story-body{padding:28px 30px 8px}.story-panel .details-favorite{position:absolute;top:22px;right:22px;z-index:3}.details-header{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px}.details-header h2{font-size:34px}.details-description{font-size:18px;line-height:1.6;margin-bottom:20px}.details-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.details-gallery img{width:100%;height:min(72vh,760px);max-height:760px;object-fit:contain;object-position:center;background:#07081859;border-radius:14px}.details-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}.details-actions button:nth-child(2){background:#e11a3f00}.details-favorite{flex:0 0 auto}.details-meta-row{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0 18px}.details-meta-row span,.details-meta-row a{padding:8px 11px;border-radius:999px;background:#ffffff29;color:inherit;text-decoration:none}.gallery-image-button{padding:0;background:#07081859;border-radius:14px;overflow:hidden}body.light .details-panel,body.light .profile-card,body.light .profile-summary-card{background:#ffffff38;color:#2c2c2c}body.light .profile-eyebrow,body.light .profile-info-list span{color:#2c2c2ca8}body.light .profile-info-tile{background:linear-gradient(145deg,#ffffff7a,#ffffff3d);border-color:#ffffff6b;box-shadow:inset 0 1px #ffffff52,0 10px 24px #532d8214}body.light .profile-info-list strong{color:#2c2c2c}.profile-grid{width:min(900px,90vw);display:grid;grid-template-columns:1fr 1fr;gap:16px}.settings-card{grid-column:1 / -1}.settings-field{display:block;margin-bottom:16px;color:inherit;font-weight:700}.settings-field span{display:block;margin-bottom:8px}.segmented-setting{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}.segmented-setting button{margin:0;background:#ffffff24;border:1px solid rgba(255,255,255,.18);box-shadow:none}.segmented-setting button.active,.segmented-setting button:hover{background:#ff4b7d}.settings-section-title{margin:22px 0 12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.16);color:#ffffffd1;font-size:13px;font-weight:800;text-transform:uppercase}body.light .settings-section-title{color:#2c2c2cad;border-color:#2c2c2c1f}.settings-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.settings-row.two-column{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-toggle{margin:0 0 16px;padding:12px 14px;display:flex;align-items:center;gap:12px;border-radius:14px;background:#ffffff1f;border:1px solid rgba(255,255,255,.14);font-weight:700}.settings-toggle input{width:20px;height:20px;margin:0;accent-color:#ff4b7d}.settings-field input[type=range]{padding:0;margin-bottom:0;accent-color:#ff4b7d}.settings-color-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.settings-color-grid label{display:grid;gap:8px;font-weight:700}.settings-color-field{display:grid;grid-template-columns:1fr 74px;align-items:center;gap:12px;margin-bottom:16px;font-weight:700}.settings-color-grid span{font-size:13px}.settings-color-grid input[type=color],.settings-color-field input[type=color]{height:46px;padding:4px;margin:0;cursor:pointer}.settings-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px}.settings-actions button{padding:11px;font-size:14px}.settings-sound-control{display:grid;grid-template-columns:minmax(0,1fr) 42px;gap:8px;align-items:end}.settings-sound-control select{min-width:0;height:44px;min-height:44px;margin:0;padding-block:9px}.settings-sound-control button{width:42px;height:42px;min-height:42px;margin:0;padding:0;display:grid;place-items:center;border-radius:14px;font-size:15px;line-height:1;box-shadow:0 10px 22px #00000029}.settings-save-actions{display:grid;grid-template-columns:repeat(2,minmax(0,180px));gap:10px;align-items:center;justify-content:center;width:100%;margin-inline:auto}.settings-save-actions button{width:100%}.settings-reset-btn{background:var(--button-bg-color);border:1px solid rgba(255,255,255,.2)}.settings-actions button,.settings-save-actions button,.settings-sound-control button,.profile-grid>.profile-card:not(.settings-card) form button[type=submit],.password-card button,.profile-back-btn{background:var(--button-bg-color)}body.button-glass-on .settings-actions button,body.button-glass-on .settings-save-actions button,body.button-glass-on .settings-sound-control button,body.button-glass-on .profile-grid>.profile-card:not(.settings-card) form button[type=submit],body.button-glass-on .password-card button,body.button-glass-on .profile-back-btn{background:color-mix(in srgb,var(--button-bg-color) calc(var(--button-glass-alpha) * 100%),transparent);border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 30px #0000002e}.settings-actions button:hover,.settings-save-actions button:hover,.settings-sound-control button:hover,.profile-grid>.profile-card:not(.settings-card) form button[type=submit]:hover,.password-card button:hover,.profile-back-btn:hover{background:color-mix(in srgb,var(--button-bg-color) 86%,white)}.settings-backup-input{display:none}.profile-summary-card{width:min(900px,90vw);margin:36px auto 0;padding:32px;display:flex;flex-direction:column;gap:22px;align-items:center;justify-content:center;border-radius:26px;background:rgba(255,255,255,var(--container-glass-alpha));border:1px solid rgba(255,255,255,.24);box-shadow:0 16px 44px #00000057;color:#fff;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);text-align:center}.profile-avatar{width:92px;height:92px;border-radius:24px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff4b7d,#6c63ff);color:#fff;font-size:42px;font-weight:800;box-shadow:0 14px 32px #00000047}.profile-summary-content{width:min(660px,100%);min-width:0}.profile-eyebrow{margin-bottom:6px;color:#ffffffbd;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.profile-summary-content h1{margin:0 0 18px;text-align:center;font-size:34px;line-height:1.1;overflow-wrap:anywhere}.profile-info-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.profile-info-tile{min-width:0;min-height:84px;padding:14px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:18px;background:linear-gradient(145deg,#ffffff2b,#ffffff17);border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px #ffffff29}.profile-info-email{grid-column:1 / -1;min-height:78px}.profile-info-list span{display:block;margin-bottom:5px;color:#ffffffb8;font-size:12px;font-weight:700}.profile-info-list strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;font-size:20px;line-height:1.18}.profile-card{width:100%}.profile-card h2{margin-bottom:18px}.profile-grid>.profile-card:not(.settings-card) form{display:flex;flex-direction:column;align-items:center}.profile-grid>.profile-card:not(.settings-card) input{width:100%;min-height:44px;margin-bottom:14px;padding:10px 13px}.profile-grid>.profile-card:not(.settings-card) form button[type=submit]{width:min(260px,100%);min-height:42px;margin-top:2px;padding:10px 18px}.settings-device-note{margin:-7px 0 22px;padding:12px 14px;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:#ffffff14;color:#ffffffc2;font-size:13px;line-height:1.5}body.light .settings-device-note{border-color:#2c2c2c1a;background:#fff3;color:#2c2c2cb8}.profile-stats{display:flex;gap:12px;margin-bottom:18px}.profile-stats span{padding:10px 12px;border-radius:12px;background:#ffffff29}.profile-back-btn{width:min(320px,90vw)}.rich-toolbar{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}.rich-toolbar button{padding:8px;font-size:14px}.rich-editor{width:100%;min-height:82px;padding:10px 12px;margin-bottom:11px;border-radius:10px;background:#ffffff24;border:1px solid rgba(255,255,255,.22);color:#fff;outline:none;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:inset 0 1px #ffffff1f}.rich-editor:empty:before{content:attr(data-placeholder);color:#ffffffa3}body.light .rich-editor{background:#ffffff47;color:#2c2c2c}body.light .rich-editor:empty:before{color:#2c2c2c94}.carousel-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#050512d6;padding:28px;touch-action:pan-y;cursor:grab;-webkit-user-select:none;user-select:none}.carousel-overlay:active{cursor:grabbing}.carousel-overlay img{max-width:88vw;max-height:82vh;object-fit:contain;object-position:center;border-radius:18px}.preview-overlay{position:fixed;inset:0;z-index:9997;display:flex;align-items:center;justify-content:center;padding:26px;background:#050614c7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.preview-dialog{position:relative;width:min(1120px,94vw);max-height:88vh;display:grid;grid-template-columns:1fr .82fr;overflow:hidden;border-radius:24px;background:rgba(31,32,56,calc(.5 + var(--container-glass-alpha)));border:1px solid rgba(255,255,255,.2);color:#fff;box-shadow:0 24px 70px #0000007a}.preview-close{position:absolute;top:14px;right:14px;z-index:2;width:auto;padding:9px 12px;background:#00000057}.preview-media{position:relative;min-height:620px;display:flex;align-items:center;justify-content:center;background:#0000003d;overflow:hidden;touch-action:pan-y;cursor:grab;-webkit-user-select:none;user-select:none}.preview-media:active{cursor:grabbing}.preview-media img{width:100%;height:100%;min-height:0;object-fit:contain;object-position:center}.preview-carousel-image{animation:previewImageIn .32s ease both}.preview-image-nav{position:absolute;top:50%;width:auto;height:auto;min-width:0;min-height:0;margin:0;padding:0;overflow:visible;display:flex;align-items:center;justify-content:center;border-radius:0;background:transparent;background-color:transparent!important;border:0;outline:0;color:#fff;font-size:44px;font-family:Arial,sans-serif;line-height:1;text-shadow:0 8px 20px rgba(0,0,0,.45);box-shadow:none;appearance:none;-webkit-appearance:none;-webkit-backdrop-filter:none;backdrop-filter:none;opacity:0;pointer-events:none;transform:translateY(-50%) scale(.92);transition:opacity .24s ease,color .24s ease,transform .24s ease}.preview-media:hover .preview-image-nav,.preview-media:focus-within .preview-image-nav{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1)}.preview-image-nav:hover{background:transparent;color:#ff5f8f;box-shadow:none;transform:translateY(-50%) scale(1.06)}.preview-image-nav.left{left:16px}.preview-image-nav.right{right:16px}body.button-glass-on .preview-image-nav,body.button-glass-on .carousel-nav,.preview-image-nav,.carousel-nav{width:auto!important;min-width:0!important;padding:0!important;border:0!important;border-radius:0!important;background:transparent!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.preview-image-count{position:absolute;left:50%;bottom:18px;padding:7px 12px;border-radius:999px;background:#08081885;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:13px;font-weight:800;transform:translate(-50%);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.preview-image-info-wrap{position:relative;display:inline-flex}.preview-actions .preview-image-info-btn{font-family:Poppins,Segoe UI,sans-serif;font-size:17px;font-weight:900;line-height:1;color:#fff}.preview-image-info-popover{position:absolute;left:0;right:auto;bottom:calc(100% + 12px);z-index:30;width:238px;padding:13px;border-radius:16px;background:#0d0e22e6;border:1px solid rgba(255,255,255,.18);color:#fff;box-shadow:0 18px 42px #00000057;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);animation:previewInfoIn .18s ease both}.preview-image-info-title{display:block;margin:0 0 10px;font-size:14px;letter-spacing:.04em;text-transform:uppercase}.preview-image-info-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:7px 0;border-top:1px solid rgba(255,255,255,.08);font-size:12px}.preview-image-info-row span{color:#ffffff9e}.preview-image-info-row strong{max-width:118px;color:#fff;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes previewInfoIn{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes previewImageIn{0%{opacity:0;transform:translate(18px) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}.preview-content{padding:64px 26px 26px;overflow:auto;display:flex;flex-direction:column}.preview-content h3{margin:16px 0 12px;font-size:34px}.preview-description{margin:18px 0;line-height:1.6;color:#ffffffd1}.preview-actions{display:flex;justify-content:flex-end;align-items:center;gap:9px;margin-top:auto;padding-top:20px}.preview-actions button{width:40px;height:40px;padding:0;border-radius:50%;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;background:#ffffff24;border:1px solid rgba(255,255,255,.16);box-shadow:none}.preview-actions button:hover{background:#ffffff38}.preview-actions button.active{background:#ff4d6d6b}.preview-actions button:last-child{background:#ff4d6d7a}.preview-actions button:last-child:hover{background:#ff4d6d9e}body.button-glass-on .preview-actions .preview-image-info-btn{background:color-mix(in srgb,var(--button-bg-color) calc(var(--button-glass-alpha) * 100%),transparent);border-color:#ffffff38;box-shadow:0 12px 30px #0000002e}body.button-glass-on .preview-actions .preview-image-info-btn:hover{background:color-mix(in srgb,var(--button-bg-color) min(calc(var(--button-glass-alpha) * 100% + 10%),92%),transparent)}.preview-confirm{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:24px;background:#08081894;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.preview-confirm-dialog{width:min(380px,92%);padding:24px;border-radius:22px;background:#ffffff24;border:1px solid rgba(255,255,255,.24);color:#fff;text-align:center;box-shadow:0 18px 48px #0000005c}.preview-confirm-dialog h3{font-size:24px;margin-bottom:10px}.preview-confirm-dialog p{font-size:15px;line-height:1.5;margin-bottom:20px;color:#ffffffdb}.carousel-close,.carousel-nav{position:absolute;width:auto}.carousel-close{top:24px;right:24px;padding:10px 16px}.carousel-nav{top:50%;transform:translateY(-50%);width:auto;height:auto;min-width:0;min-height:0;margin:0;border-radius:0;background:transparent;background-color:transparent!important;border:0;outline:0;color:#fff;font-size:58px;line-height:1;padding:0;box-shadow:none;appearance:none;-webkit-appearance:none;text-shadow:0 10px 24px rgba(0,0,0,.48);transition:color .22s ease,transform .22s ease}.carousel-nav:hover{background:transparent;color:#ff5f8f;box-shadow:none;transform:translateY(-50%) scale(1.08)}.carousel-nav.left{left:28px}.carousel-nav.right{right:28px}.container.public-route-container{min-height:100vh;padding:0;display:block}.public-share-page{position:relative;isolation:isolate;width:100%;min-height:100vh;padding:clamp(28px,5vw,72px);overflow:hidden;color:#f8f7ff;background:radial-gradient(circle at 15% 10%,rgba(255,75,125,.24),transparent 28%),radial-gradient(circle at 88% 22%,rgba(122,140,255,.2),transparent 30%),linear-gradient(145deg,#090a20,#17173d 48%,#0b1028)}.public-share-page:before,.public-share-page:after{content:"";position:fixed;z-index:-1;border-radius:50%;filter:blur(10px);pointer-events:none}.public-share-page:before{width:280px;height:280px;top:-120px;right:-80px;background:#ff4b7d33}.public-share-page:after{width:340px;height:340px;left:-170px;bottom:-180px;background:#6c63ff33}.public-share-header{width:min(1180px,100%);margin:0 auto clamp(28px,4vw,48px);text-align:center}.public-share-brand{display:inline-flex;align-items:center;gap:10px;color:#ffffffd1;font-size:14px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.public-share-mark{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:linear-gradient(135deg,#ff4b7d,#6c63ff);color:#fff;box-shadow:0 12px 28px #00000047}.public-share-header>p{margin:24px 0 8px;color:#ffffffa8;font-size:15px}.public-share-header h1{margin:0;font-size:clamp(36px,6vw,68px);line-height:1.02;letter-spacing:-.04em}.public-share-grid{width:min(1180px,100%);margin:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));gap:24px}.public-share-single .public-share-grid{display:block}.public-memory-card{overflow:hidden;border-radius:30px;background:#ffffff17;border:1px solid rgba(255,255,255,.16);box-shadow:0 24px 70px #00000057;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.public-share-single .public-memory-card{display:grid;grid-template-columns:minmax(300px,1.2fr) minmax(280px,.8fr)}.public-memory-copy{padding:clamp(24px,4vw,52px)}.public-share-single .public-memory-copy{grid-column:2;grid-row:1;display:flex;flex-direction:column;justify-content:center}.public-memory-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:22px;color:#ffffffad;font-size:13px;font-weight:700}.public-memory-meta span{padding:7px 11px;border-radius:999px;background:#ffffff1f;color:#fff}.public-memory-card h2{margin:0 0 18px;font-size:clamp(28px,4vw,48px);line-height:1.05;overflow-wrap:anywhere}.public-memory-description{color:#ffffffc7;font-size:17px;line-height:1.7}.public-memory-gallery{display:grid;gap:8px;padding:0 18px 18px}.public-share-single .public-memory-gallery{grid-column:1;grid-row:1;min-height:clamp(420px,68vh,760px);padding:0}.public-memory-gallery.multiple{grid-template-columns:repeat(2,minmax(0,1fr))}.public-memory-gallery img{width:100%;height:320px;display:block;object-fit:cover;border-radius:18px}.public-share-single .public-memory-gallery img{height:100%;min-height:420px;border-radius:0}.public-share-single .public-memory-gallery.multiple img{min-height:260px}.public-share-footer{width:min(1180px,100%);margin:34px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);color:#ffffff80;text-align:center;font-size:13px}.public-share-state{width:min(520px,90vw);min-height:calc(100vh - 144px);margin:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.public-share-state h1{margin:22px 0 10px}.public-share-state p{color:#ffffffad}@media(max-width:820px){.public-share-single .public-memory-card{grid-template-columns:1fr}.public-share-single .public-memory-copy,.public-share-single .public-memory-gallery{grid-column:1}.public-share-single .public-memory-copy{grid-row:2}.public-share-single .public-memory-gallery{grid-row:1;min-height:340px}.public-share-single .public-memory-gallery img{min-height:340px}}@media(max-width:520px){.public-share-page{padding:24px 16px 36px}.public-share-header>p{margin-top:18px}.public-memory-card{border-radius:22px}.public-memory-meta{align-items:flex-start;flex-direction:column}.public-memory-gallery.multiple{grid-template-columns:1fr}}.load-more-sentinel{min-height:80px;width:min(320px,90vw);display:flex;align-items:center;justify-content:center;color:#fff}@media(max-width:760px){.timeline-controls,.timeline-toolbar,.details-actions,.profile-grid{grid-template-columns:1fr}.timeline{width:min(520px,92vw);gap:18px}.timeline:after{content:none}.timeline-item,.timeline-item.right{left:0;width:100%;padding:34px 0 0}.timeline-card{min-height:220px;border-radius:16px}.memory-card-overlay{padding:64px 14px 14px}.memory-card-overlay h3{font-size:22px}.story-hero,.story-hero img,.story-hero .memory-photo-placeholder{min-height:420px}.story-hero-content{left:18px;right:18px;bottom:18px}.story-hero-content h2{font-size:34px}.preview-dialog{grid-template-columns:1fr;overflow:auto}.preview-media{min-height:320px}.preview-content{padding:24px 18px 20px}.timeline-controls{flex-wrap:wrap}.timeline-search-shell.open{width:calc(90vw - 136px);min-width:190px}.timeline-filter-popover{right:-68px}.reminder-alert-actions{grid-template-columns:1fr}.profile-summary-card{grid-template-columns:1fr;justify-items:center;text-align:center;transform:none}.profile-summary-content h1{text-align:center;font-size:30px}.profile-info-list{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-info-list strong{white-space:normal;overflow-wrap:anywhere}.settings-row,.settings-color-grid,.settings-actions{grid-template-columns:1fr}}@media(max-width:1280px){.timeline{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:1040px){.timeline{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:760px){.timeline{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:520px){.login-actions{grid-template-columns:1fr}.login-brand .main-title{font-size:32px;letter-spacing:2px}.login-brand p{font-size:15px}.login-intro-mark,.remotion-intro-logo-wrap{width:108px;height:108px;border-radius:28px}.login-intro-mark span{font-size:34px}.remotion-intro-logo{width:68px;height:68px}.remotion-intro-heart{font-size:44px}.login-intro-orbit,.remotion-intro-orbit{width:180px;height:180px}.login-intro-scene h1{font-size:34px}.remotion-intro-title{font-size:36px}.login-intro-scene p,.remotion-intro-subtitle{font-size:15px}.timeline{grid-template-columns:1fr}.timeline-card{min-height:240px}.date-input-row,.select-input-row,.title-format-row{grid-template-columns:1fr}}@media(max-width:760px){.login-intro-overlay.mobile{width:100vw;min-width:100vw;background:#08081d}.login-intro-overlay.mobile>div{width:100%!important;height:100%!important}.login-intro-overlay.mobile>div,.login-intro-overlay.mobile>div>div,.login-intro-overlay.mobile video,.login-intro-overlay.mobile canvas{max-width:none!important}.remotion-intro-frame.mobile{width:100%!important;height:100%!important;padding:calc(34px + env(safe-area-inset-top)) 24px calc(28px + env(safe-area-inset-bottom))}.remotion-intro-frame.mobile .remotion-intro-sheen{inset:-10% -80%;opacity:.72;background:linear-gradient(118deg,transparent 36%,rgba(255,255,255,.07) 45%,transparent 54%)}.remotion-intro-frame.mobile .remotion-intro-content{width:100%;margin-top:-2vh}.remotion-intro-frame.mobile .remotion-intro-logo-wrap{width:126px;height:126px;border-radius:34px;box-shadow:0 28px 72px #ff4b7d59,0 0 0 10px #ffffff06,0 0 0 1px #ffffff47 inset}.remotion-intro-frame.mobile .remotion-intro-logo{width:78px;height:78px}.remotion-intro-frame.mobile .remotion-intro-heart{font-size:52px}.remotion-intro-frame.mobile .remotion-intro-timeline{bottom:13px;height:5px}.remotion-intro-frame.mobile .remotion-intro-dot{bottom:6px;width:18px;height:18px}.remotion-intro-frame.mobile .remotion-intro-title{max-width:330px;margin:34px 0 10px;font-size:42px;line-height:1.04;letter-spacing:-1px;text-wrap:balance}.remotion-intro-frame.mobile .remotion-intro-subtitle{max-width:290px;font-size:15px;line-height:1.55;letter-spacing:.01em}.remotion-intro-frame.mobile .remotion-intro-line{width:min(280px,76vw);height:4px;margin-top:34px}.remotion-intro-frame.mobile .remotion-intro-line i{width:15px;height:15px;border-width:3px}.remotion-intro-frame.mobile .remotion-intro-kicker{position:absolute;top:calc(34px + env(safe-area-inset-top));left:0;right:0;z-index:2;display:block;margin:0;color:#ffffff8a;font-size:11px;font-weight:800;letter-spacing:.16em;text-align:center;text-transform:uppercase}.remotion-intro-frame.mobile .remotion-intro-footer{position:absolute;left:0;right:0;bottom:calc(30px + env(safe-area-inset-bottom));z-index:2;display:block;color:#ffffff61;font-size:9px;font-weight:800;letter-spacing:.22em;text-align:center}.remotion-intro-frame.mobile .remotion-intro-ambient{position:absolute;display:block;border:1px solid rgba(255,255,255,.06);border-radius:50%;pointer-events:none}.remotion-intro-frame.mobile .remotion-intro-ambient.top{width:310px;height:310px;top:-156px;right:-148px;background:radial-gradient(circle,rgba(108,99,255,.12),transparent 66%)}.remotion-intro-frame.mobile .remotion-intro-ambient.bottom{width:360px;height:360px;left:-205px;bottom:-196px;background:radial-gradient(circle,rgba(255,75,125,.1),transparent 68%)}}@media(max-width:380px){.remotion-intro-frame.mobile .remotion-intro-logo-wrap{width:112px;height:112px;border-radius:30px}.remotion-intro-frame.mobile .remotion-intro-logo{width:70px;height:70px}.remotion-intro-frame.mobile .remotion-intro-heart{font-size:46px}.remotion-intro-frame.mobile .remotion-intro-title{margin-top:30px;font-size:36px}}.preview-overlay{padding:clamp(18px,3vw,34px)}.preview-dialog{width:min(1240px,96vw);height:min(760px,88dvh);max-height:88dvh;grid-template-columns:minmax(0,1.08fr) minmax(360px,.82fr);overflow:hidden;border-radius:26px}.preview-media{min-width:0;min-height:0;height:100%;padding:22px;background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.07),transparent 44%),#060718b8}.preview-media img{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;object-position:center!important;border-radius:16px;box-shadow:0 18px 46px #00000047}.preview-content{min-width:0;min-height:0;padding:34px 28px 24px;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;overflow:hidden}.preview-content h3{margin:22px 0 10px;font-size:clamp(30px,3vw,42px);line-height:1.08;overflow-wrap:anywhere}.preview-description{min-height:0;margin:18px -6px 0 0;padding:0 14px 14px 0;overflow:auto;color:#fffc;font-size:16px;line-height:1.7;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) transparent}.preview-description.empty,.details-description.empty{color:#ffffff7a;font-style:italic}.preview-description p,.details-description p{margin:0 0 12px}.preview-actions{position:relative;z-index:2;margin-top:0;padding-top:18px;justify-content:flex-start;border-top:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,transparent,rgba(22,22,50,.22))}.preview-actions button{width:44px;height:44px;min-height:44px;flex:0 0 44px;font-family:Segoe UI Symbol,Arial Unicode MS,sans-serif;font-size:21px}.preview-actions button span{display:block;line-height:1}.story-panel{width:min(980px,94vw)}.story-hero{min-height:0;height:min(680px,72dvh);display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(255,255,255,.08),transparent 48%),#050616ad}.story-hero img,.story-hero .memory-photo-placeholder{width:100%;height:100%;min-height:0;object-fit:contain;object-position:center!important}.story-hero:after{background:linear-gradient(180deg,transparent 52%,rgba(5,6,20,.82) 100%)}.story-body{padding:28px 30px 18px}.details-description{margin:0}.details-actions{margin:0;padding:18px 30px 28px;border-top:1px solid rgba(255,255,255,.1)}@media(max-width:760px){.preview-overlay{padding:12px;align-items:center;overflow:hidden}.preview-dialog{width:100%;height:calc(100dvh - 24px);max-height:calc(100dvh - 24px);margin:0;grid-template-columns:1fr;grid-template-rows:minmax(240px,44dvh) minmax(0,1fr);overflow:hidden;border-radius:20px}.preview-media{width:100%;height:auto;min-height:0;padding:12px}.preview-media img{border-radius:12px}.preview-content{padding:18px 16px 14px;grid-template-rows:auto auto minmax(0,1fr) auto}.preview-content h3{margin:14px 0 6px;font-size:27px}.preview-description{margin-top:10px;padding-bottom:10px;font-size:15px;line-height:1.6}.preview-actions{padding-top:12px;justify-content:center;flex-wrap:nowrap;gap:8px}.preview-actions button{width:42px;height:42px;min-height:42px;flex-basis:42px}.story-panel{width:100%}.story-hero,.story-hero img,.story-hero .memory-photo-placeholder{min-height:0;height:min(56dvh,480px)}.story-hero img{object-fit:contain}.story-hero-content{left:16px;right:64px;bottom:16px}.story-hero-content h2{font-size:30px}.story-body{padding:20px 18px 12px}.details-actions{padding:14px 18px 20px}}@media(max-width:380px){.preview-dialog{grid-template-rows:minmax(210px,40dvh) minmax(0,1fr)}.preview-actions{gap:6px}.preview-actions button{width:38px;height:38px;min-height:38px;flex-basis:38px;font-size:18px}}.hidden{opacity:0;transform:translateY(60px)}.show{opacity:1;transform:translateY(0);transition:all .8s ease}.hearts{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:-1}.hearts span{position:absolute;bottom:-50px;font-size:22px;animation:parallaxHearts linear infinite}@keyframes parallaxHearts{0%{transform:translateY(0);opacity:0}20%{opacity:1}to{transform:translateY(-120vh);opacity:0}}@keyframes floatCard{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.page{width:100%;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.page-show{opacity:1;transform:none}.toast{position:fixed;top:20px;left:20px;background:#000000d9;color:#fff;padding:12px 18px;border-radius:10px;font-size:14px;z-index:9999}.trash-page{width:100%;min-height:100vh;padding:58px 24px 70px;display:flex;flex-direction:column;align-items:center;gap:12px;color:#fff}.trash-hero,.trash-actions-panel,.trash-selection-bar{width:min(1180px,92vw)}.trash-hero{position:relative;min-height:72px;padding:0 0 4px;display:flex;align-items:center;justify-content:center;text-align:center}.trash-title-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:12px}.trash-hero h1{margin:0;font-size:clamp(36px,5vw,58px);line-height:1}.trash-info-wrap{position:relative;display:inline-flex;align-items:center}.trash-info-btn{width:30px;height:30px;min-height:30px;padding:0;border-radius:50%;background:#ffffff24;border:1px solid rgba(255,255,255,.24);color:#fff;font-family:Georgia,Times New Roman,serif;font-size:17px;font-weight:800;line-height:1}.trash-info-bubble{position:absolute;z-index:20;top:calc(100% + 10px);right:0;width:min(360px,80vw);padding:12px 14px;border-radius:16px;background:#0e0f26f0;border:1px solid rgba(255,255,255,.18);color:#ffffffdb;box-shadow:0 18px 46px #00000057;font-size:13px;font-weight:700;line-height:1.45;opacity:0;pointer-events:none;transform:translateY(-6px) scale(.98);transition:opacity .2s ease,transform .2s ease;text-align:left}.trash-info-wrap:hover .trash-info-bubble,.trash-info-bubble.show{opacity:1;transform:translateY(0) scale(1)}.trash-actions-panel{padding:0 0 4px;display:flex;align-items:center;justify-content:space-between;gap:18px}.trash-count{display:flex;align-items:baseline;gap:10px}.trash-actions-panel strong{font-size:30px}.trash-actions-panel span{color:#ffffffb8}.trash-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.trash-actions button,.trash-selection-bar button,.trash-card-actions button,.confirm-recover-btn{width:auto;min-height:40px;padding:0 16px;border-radius:14px;background:#39229a}.trash-actions button.active,.trash-selection-bar button:not(.danger):hover,.trash-card-actions button:not(.danger):hover,.confirm-recover-btn{background:#22a65a}.trash-actions button:disabled,.trash-selection-bar button:disabled{opacity:.48;cursor:not-allowed}.trash-selection-bar{width:min(1180px,92vw);min-height:34px;padding:2px 0;display:flex;align-items:center;flex-wrap:wrap;gap:10px}.trash-selection-bar label,.trash-check{display:flex;align-items:center;gap:8px;font-weight:800}.trash-selection-bar input,.trash-check input{width:18px;height:18px;accent-color:#ff4b7d}.trash-selection-bar .danger,.trash-card-actions .danger{background:#ff4d6d}.trash-selection-dock{position:fixed;z-index:120;left:50%;bottom:24px;transform:translate(-50%);padding:8px;display:flex;align-items:center;gap:8px;border-radius:16px;background:#121330e6;border:1px solid rgba(255,255,255,.2);box-shadow:0 16px 44px #04051661;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.trash-selection-dock button{width:auto;min-width:104px;min-height:38px;padding:0 18px;border-radius:12px;background:#22a65a}.trash-selection-dock button.danger{background:#ff4d6d}.trash-selection-dock button:disabled{opacity:.48;cursor:not-allowed}.trash-page.selection-mode{padding-bottom:110px}.trash-grid{width:min(1180px,92vw);display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.trash-card{position:relative;min-width:0;aspect-ratio:1;padding:10px;border-radius:20px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;border:1px solid rgba(255,255,255,.22);background:#0c0d1e73;box-shadow:0 20px 44px #05061847;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.trash-card.selected{border-color:#ff7aa0;box-shadow:0 0 0 3px #ff4b7d2e,0 24px 60px #05061847}.trash-card:hover{transform:translateY(-4px);border-color:#ff7aa07a}.trash-thumb{position:absolute;inset:0;width:100%;height:100%;border-radius:inherit;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#30215f,#151632)}.trash-thumb img{width:100%;height:100%;object-fit:cover}.trash-thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0506160a,#05061673 48%,#050616e6),radial-gradient(circle at 18% 16%,rgba(255,75,125,.28),transparent 36%)}.trash-thumb strong{font-size:42px;color:#fffc}.trash-copy{position:relative;z-index:1;min-width:0;display:flex;flex-direction:column;gap:7px}.trash-meta{display:flex;align-items:center;flex-direction:column;align-items:flex-start;gap:5px}.trash-meta span,.trash-meta time{width:max-content;max-width:100%;padding:4px 8px;border-radius:999px;background:#ffffff29;color:#ffffffc7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:11px;font-weight:800}.trash-copy h2{margin:2px 0 0;color:#fff;font-size:21px;line-height:1.05;text-shadow:0 4px 18px rgba(0,0,0,.45);overflow-wrap:anywhere}.trash-card-actions{position:relative;z-index:1;margin-top:10px;display:flex;gap:8px}.trash-card-actions button{flex:0 0 34px;width:34px;height:34px;min-height:34px;padding:0;border-radius:50%;display:grid;place-items:center;font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",sans-serif;font-size:17px;line-height:1;text-align:center}.trash-check{position:absolute;z-index:2;top:10px;left:10px;padding:0;border-radius:0;background:none;-webkit-backdrop-filter:none;backdrop-filter:none}.trash-empty{margin-top:12px}.trash-confirm-dialog .confirm-recover-btn:hover{background:#1b934e}body.light .trash-page{color:#2a2140}body.light .trash-selection-dock{background:#ffffffe6;border-color:#442e672e;box-shadow:0 16px 40px #4e30742e}body.light .trash-info-btn{background:#ffffff70;color:#2a2140}body.light .trash-info-bubble{background:#fffffff2;color:#2a2140}body.light .trash-actions-panel span{color:#2c2140b8}body.light .trash-meta span,body.light .trash-meta time{background:#ffffff6b;color:#fff}.confirm-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:#0808187a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9998}.confirm-dialog{width:min(420px,92vw);padding:26px;border-radius:24px;background:rgba(255,255,255,var(--container-glass-alpha));border:1px solid rgba(255,255,255,.25);box-shadow:0 18px 50px #00000061;color:#fff;text-align:center}.confirm-dialog h3{font-size:26px;margin-bottom:12px}.confirm-dialog p{font-size:16px;line-height:1.5;margin-bottom:22px}.confirm-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.confirm-actions button{width:100%;min-width:0;min-height:46px;padding:12px}.cancel-delete-btn{background:#6c63ff}.cancel-delete-btn:hover{background:#5148e5}.confirm-delete-btn{background:#ff4d6d}.confirm-delete-btn:hover{background:#ff2f6d}body.light .confirm-overlay{background:#3c145a47}body.light .confirm-dialog{background:#ffffff47;color:#2c2c2c}body.dark .confirm-dialog{background:#ffffff1f;color:#fff}body.hearts-slow .hearts span{animation-duration:calc(var(--heart-speed, 1s) * 1.6)}body.hearts-fast .hearts span{animation-duration:calc(var(--heart-speed, 1s) * .55)}.hearts{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:-1}.hearts span{position:absolute;bottom:-50px;font-size:22px;opacity:.8;animation:parallaxHearts linear infinite}@keyframes parallaxHearts{0%{transform:translateY(0) scale(1);opacity:0}20%{opacity:1}to{transform:translateY(-120vh) scale(1.5);opacity:0}}.hearts span:nth-child(1){left:10%;--heart-speed:14s;animation-duration:var(--heart-speed)}.hearts span:nth-child(2){left:20%;--heart-speed:18s;animation-duration:var(--heart-speed)}.hearts span:nth-child(3){left:30%;--heart-speed:22s;animation-duration:var(--heart-speed)}.hearts span:nth-child(4){left:40%;--heart-speed:12s;animation-duration:var(--heart-speed)}.hearts span:nth-child(5){left:55%;--heart-speed:20s;animation-duration:var(--heart-speed)}.hearts span:nth-child(6){left:70%;--heart-speed:16s;animation-duration:var(--heart-speed)}.hearts span:nth-child(7){left:85%;--heart-speed:24s;animation-duration:var(--heart-speed)}.hearts span:nth-child(8){left:95%;--heart-speed:19s;animation-duration:var(--heart-speed)}body.hearts-slow .hearts span{animation-duration:calc(var(--heart-speed) * 1.6)}body.hearts-fast .hearts span{animation-duration:calc(var(--heart-speed) * .55)}body.hearts-fixed .hearts span{animation:none;opacity:.45}@keyframes glassFloat{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.days-counter{font-size:22px;font-weight:600;margin:15px 0;text-align:center;letter-spacing:.5px}body.dark .days-counter{color:#ff4b7d}body.light .days-counter{color:#2c2c2c}.memory-text{color:#ff4b7d;font-size:22px;font-weight:600;margin:15px 0}@media(max-width:760px){html,body{min-height:100%}body{background-attachment:fixed}.container{width:100%;max-width:none;min-height:100dvh;margin:0;padding:calc(16px + env(safe-area-inset-top)) 16px calc(28px + env(safe-area-inset-bottom))}.page,.login-page,.timeline-container,.profile-page,.add-memory-page{min-width:0}.glass-card{width:100%;max-width:500px;margin:28px auto 18px;padding:24px 20px;border-radius:24px}.glass-card h2{margin-bottom:18px;font-size:28px;line-height:1.2}input,textarea,select{min-height:48px;margin-bottom:14px;padding:12px 14px;border-radius:13px;font-size:16px}button{min-height:46px;padding:12px 14px;border-radius:12px;font-size:15px}button:hover{transform:none}.login-page{justify-content:center;padding:4vh 0 3vh}.login-card{margin:0 auto 24px}.login-actions{grid-template-columns:1fr 1fr;gap:10px}.login-card>.timeline-btn{margin-top:10px}.login-brand{width:100%;padding:0 8px}.login-brand .main-title{margin:0;padding:8px 0;font-size:clamp(30px,9vw,38px);line-height:1.15;letter-spacing:2px}.login-brand p{max-width:420px;margin:8px auto 0;font-size:15px;line-height:1.55}.top-buttons{top:max(12px,env(safe-area-inset-top));right:12px;gap:7px}body.top-actions-left .top-buttons{left:12px;right:auto}.toggle-btn,.logout-btn,.reminder-icon-btn{width:46px;height:46px;min-height:46px;font-size:20px}.toggle-btn:before{font-size:20px}.reminder-menu{top:max(12px,env(safe-area-inset-top));right:118px}body.top-actions-left .reminder-menu{left:118px;right:auto}.reminder-popover{position:fixed;top:66px;left:16px;right:16px;width:auto;max-height:calc(100dvh - 90px);margin:0;overflow:auto}:root{--top-action-size:38px}.top-buttons .toggle-btn,.top-buttons .logout-btn,.reminder-icon-btn{width:38px;height:38px;min-height:38px;padding:0;display:flex;align-items:center;justify-content:center;font-size:17px;line-height:1}.top-buttons .toggle-btn:before,.top-buttons .logout-btn:before{font-size:17px;line-height:1}.timeline-container{padding-top:24px}.timeline-title{margin:-2px 0 8px;font-family:Poppins,Segoe UI,Arial,sans-serif;font-size:clamp(25px,7.2vw,30px);font-weight:800;line-height:1.15;text-align:center}.timeline-controls-shell{width:100%;max-width:360px}.timeline-controls{width:100%;margin:0;display:grid;grid-template-columns:repeat(7,40px);justify-content:center;gap:7px}.timeline-search-shell{width:40px;height:40px;grid-column:1 / -1;justify-self:center;grid-template-columns:40px 0fr;border-radius:12px}.timeline-search-shell.open{width:min(286px,100%);min-width:0;grid-column:1 / -1;grid-row:1;justify-self:center;grid-template-columns:40px 1fr}.timeline-search{height:40px;min-height:40px;padding:0 12px 0 4px;font-size:15px}.filter-toggle,.timeline-icon-control,.timeline-action-btn,.timeline-toolbar button{width:40px;height:40px;min-height:40px;border-radius:12px;font-size:18px}.export-image-btn:before{font-size:20px}.filter-funnel-icon{transform:scale(.76)}.timeline-filter-popover{position:fixed;top:108px;left:16px;right:16px;width:auto;max-height:calc(100dvh - 148px);padding:16px;overflow:auto}.timeline-export-popover{top:calc(100% + 8px);width:min(252px,calc(100vw - 36px));padding:6px;gap:5px;border-radius:15px}.timeline-export-popover button{min-height:42px;padding:7px 10px;border-radius:10px}.timeline-export-popover strong{font-size:12px}.timeline-export-popover small{font-size:9px;line-height:1.15}.timeline{width:100%;margin-top:26px;grid-template-columns:1fr;gap:20px}.timeline-item,.timeline-item.right{padding-top:26px}.timeline-item:after{top:3px;width:8px;height:8px;border-width:1px;box-shadow:0 0 3px #ff4b7d1f}.timeline-item:before{top:7px;left:0;right:0;height:1px}.timeline-card,body.card-size-small .timeline-card,body.card-size-large .timeline-card{min-height:260px;border-radius:18px}.timeline-card:hover,body.memory-hover-off .timeline-card:hover{transform:none}.memory-actions{display:none;opacity:0;transform:none}.memory-card-overlay{padding:72px 16px 16px}.memory-card-overlay h3{font-size:24px}.export-selection-bar{top:70px;width:100%;padding:12px;align-items:stretch;flex-direction:column}.export-selection-actions{display:grid;grid-template-columns:repeat(3,1fr)}.export-selection-actions button{min-width:0}.calendar-view{width:100%}.calendar-month{padding:16px;border-radius:18px}.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.calendar-memory{min-width:0;min-height:78px;padding:11px;overflow-wrap:anywhere}.profile-page{padding-top:58px}.profile-summary-card{width:100%;margin:0 auto 18px;padding:20px 16px;gap:12px;border-radius:22px}.profile-avatar{width:76px;height:76px;border-radius:21px;font-size:34px}.profile-eyebrow{margin-bottom:4px;font-size:11px}.profile-summary-content h1{margin-bottom:12px;font-size:26px}.profile-info-list{width:100%;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.profile-info-tile{min-height:66px;padding:9px 8px;border-radius:13px}.profile-info-email{grid-column:1 / -1;min-height:64px}.profile-info-list strong{font-size:clamp(15px,4.6vw,20px)}.profile-info-email strong{white-space:normal;overflow-wrap:anywhere;font-size:clamp(14px,4vw,18px)}.profile-grid{width:100%;gap:16px}.profile-card,.details-panel{width:100%;margin:0;padding:18px 16px;border-radius:22px}.profile-card h2{margin-bottom:16px;font-size:25px}.settings-field{margin-bottom:10px}.settings-field span{margin-bottom:6px;font-size:14px}.profile-card input,.settings-field input,.settings-field select{min-height:46px;padding:10px 12px;font-size:15px}.settings-toggle{min-height:52px;margin-bottom:10px;padding:9px 11px;gap:10px}.settings-row,.settings-row.two-column,.settings-color-grid{grid-template-columns:1fr;gap:0}.settings-color-grid{gap:9px}.settings-color-grid label{grid-template-columns:1fr 58px;align-items:center;gap:8px}.settings-color-grid input[type=color],.settings-color-field input[type=color]{height:40px}.settings-section-title{margin:16px 0 9px;padding-top:12px;font-size:12px}.settings-actions{grid-template-columns:1fr 1fr}.settings-save-actions{grid-template-columns:repeat(2,minmax(0,1fr));width:min(100%,360px)}.settings-reset-btn{width:100%}.profile-back-btn{width:100%;max-width:360px;margin-top:18px}.add-memory-page{padding-top:58px}.add-memory-page .glass-card{width:100%;margin:0 auto 14px;padding:22px 18px}.date-input-row,.select-input-row,.title-format-row{grid-template-columns:1fr;gap:0}.add-memory-page .main-title{margin:8px 0 0;padding:8px;font-size:30px;letter-spacing:2px}.preview-overlay,.confirm-overlay,.export-filter-overlay{padding:16px;align-items:flex-start;overflow:auto}.preview-dialog{width:100%;max-height:none;margin:auto 0;border-radius:20px}.preview-media{min-height:280px;height:min(52dvh,420px)}.preview-image-nav{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1)}.preview-content{padding:20px 16px}.preview-content h3{font-size:28px}.preview-actions{justify-content:center;flex-wrap:wrap}.export-filter-dialog{width:100%;margin:auto 0;padding:20px 16px;border-radius:20px}.export-date-fields{grid-template-columns:1fr}.export-filter-actions{display:grid;grid-template-columns:1fr 1fr}.export-filter-actions button{width:100%}.confirm-dialog{width:100%;padding:22px 18px;border-radius:20px}.toast{top:max(12px,env(safe-area-inset-top));left:50%;width:calc(100% - 32px);max-width:420px;padding:11px 14px;text-align:center;transform:translate(-50%)}}@media(max-width:420px){.container{padding-right:12px;padding-left:12px}.glass-card{padding:22px 16px}.login-actions{grid-template-columns:1fr}.timeline-controls{grid-template-columns:repeat(7,38px);gap:6px}.timeline-controls:has(.timeline-search-shell.open){grid-template-columns:repeat(7,38px)}.timeline-search-shell{width:38px;height:38px;grid-template-columns:38px 0fr}.timeline-search-shell.open{width:min(280px,100%);grid-template-columns:38px 1fr}.filter-toggle,.timeline-icon-control,.timeline-action-btn{width:38px;height:38px;min-height:38px}.export-image-btn:before{font-size:19px}.calendar-grid,.settings-actions{grid-template-columns:1fr}}@media(max-width:360px){.profile-info-list{grid-template-columns:1fr}.profile-info-email{grid-column:auto}}.add-memory-page{display:flex;flex-direction:column;align-items:center}.add-memory-page .glass-card{width:min(500px,92vw);padding:24px 28px;margin:18px auto 10px;border-radius:24px}.add-memory-page .glass-card h2{margin-bottom:14px;font-size:24px}.add-memory-page input,.add-memory-page textarea{padding:9px 12px;margin-bottom:11px;border-radius:10px}.title-format-row{display:grid;grid-template-columns:7fr 3fr;gap:12px;align-items:start;margin-bottom:11px}.title-format-row input,.title-format-row select{height:44px;min-height:44px;padding:8px 12px;margin-bottom:0;border-radius:12px;font-size:15px}.format-select{cursor:pointer}.date-input-row,.select-input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:11px}.date-input-row label,.select-input-row label{margin-bottom:0}.date-input-row span,.select-input-row span{display:block;margin-bottom:6px;color:#fff;font-weight:600}body.light .date-input-row span,body.light .select-input-row span{color:#2c2c2c}.date-input-row input,.select-input-row select{margin-bottom:0}.add-memory-page textarea{height:62px;resize:none}.add-memory-page label{display:block;margin-bottom:6px}.file-label{color:#fff;font-weight:600}body.light .file-label{color:#2c2c2c}.add-memory-page input[type=file]{padding:6px 0;margin-bottom:8px}.upload-helper{display:flex;justify-content:space-between;gap:12px;align-items:center;margin:-2px 0 12px;color:#ffffffb8;font-size:13px;line-height:1.45}body.light .upload-helper{color:#2c2c2cad}.add-memory-page .upload-helper button{width:auto;min-width:0;min-height:0;margin:0;padding:7px 12px;flex:0 0 auto;border-radius:999px;background:#ff4b7d2e;border:1px solid rgba(255,255,255,.18);color:#fff;font-size:12px;box-shadow:none}body.light .add-memory-page .upload-helper button{border-color:#2c2c2c1f;color:#2c2c2c;background:#ff4b7d1f}.selected-files-panel{margin:-2px 0 13px;padding:12px;border:1px solid rgba(255,255,255,.12);border-radius:16px;background:#ffffff0f}body.light .selected-files-panel{border-color:#2c2c2c1a;background:#ffffff5c}.selected-files-header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:9px;color:#fff}body.light .selected-files-header{color:#2c2c2c}.selected-files-header small{color:#ffffff8c;font-size:12px}body.light .selected-files-header small{color:#2c2c2c80}.selected-files-list{display:grid;grid-template-columns:1fr;gap:7px;max-height:128px;overflow:auto;padding-right:3px}.selected-files-list span{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:8px 10px;border-radius:11px;background:#0e0e2c47;color:#ffffffdb;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.light .selected-files-list span{background:#ffffff73;color:#2c2c2cc7}.selected-files-list small{flex:0 0 auto;color:#ffffff85}body.light .selected-files-list small{color:#2c2c2c80}.add-memory-page button{padding:11px}.add-memory-page .timeline-btn{margin-top:8px}.main-title{margin-top:20px;padding:17px;font-size:38px;font-weight:400;color:#f8f8f8;text-align:center;letter-spacing:4px;font-family:Poppins,sans-serif}@media(max-width:760px){.add-memory-page{padding-top:58px}.add-memory-page .glass-card{width:100%;margin:0 auto 14px;padding:22px 18px}.date-input-row,.select-input-row,.title-format-row{grid-template-columns:1fr;gap:0}.add-memory-page .main-title{margin:8px 0 0;padding:8px;font-size:30px;letter-spacing:2px}}button,input,textarea,select{font-family:var(--app-font-family);font-size:var(--app-font-size);font-weight:var(--app-font-weight);font-style:var(--app-font-style)}.toggle-btn,.logout-btn{font-size:0}.timeline-title,.profile-summary-content h1,.profile-card h2,.details-header h2,.memory-card-overlay h3{font-size:calc(var(--heading-font-size, 22px) + var(--app-font-delta))}.timeline-title{--heading-font-size:36px}.profile-summary-content h1,.details-header h2{--heading-font-size:34px}.profile-card h2{--heading-font-size:24px}.memory-card-overlay h3{--heading-font-size:22px}@media(max-width:760px){:root{--mobile-action-size:38px}body{min-height:100dvh;background-size:cover}.container{min-height:100dvh;height:auto;padding-top:calc(12px + env(safe-area-inset-top))}.page{min-height:0}.top-buttons{top:max(12px,env(safe-area-inset-top));right:12px;gap:6px}body.top-actions-left .top-buttons{left:12px;right:auto;flex-direction:row}.toggle-btn,.logout-btn,.reminder-icon-btn{width:var(--mobile-action-size);height:var(--mobile-action-size);min-height:var(--mobile-action-size);padding:0;display:flex;align-items:center;justify-content:center;line-height:1;text-align:center;vertical-align:middle;position:relative;overflow:hidden}.toggle-btn,.logout-btn{font-size:0;color:transparent}.toggle-btn:before,.logout-btn:before{position:absolute;inset:0;width:100%;height:100%;display:grid;place-items:center;margin:auto;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;font-size:18px;line-height:1;text-align:center;transform:none!important}.reminder-icon-btn{font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;font-size:0;line-height:1;transform:none;overflow:visible}.reminder-icon-btn:before{content:"🔔";position:absolute;inset:0;width:100%;height:100%;display:grid;place-items:center;font-size:18px;line-height:1;transform:none}body.dark .toggle-btn:before,body.light .toggle-btn:before{transform:none!important}.logout-btn:before{transform:none!important}.reminder-icon-btn{padding-top:0;overflow:visible}.reminder-icon-btn span{top:-8px;right:-6px;min-width:19px;height:19px;padding:0 5px;font-size:10px;border-width:2px}.reminder-icon-btn>:not(span){line-height:1}.reminder-menu{top:max(12px,env(safe-area-inset-top));right:calc(26px + var(--mobile-action-size) + var(--mobile-action-size))}body.top-actions-left .reminder-menu{left:calc(26px + var(--mobile-action-size) + var(--mobile-action-size));right:auto}.timeline-container{padding-top:calc(var(--mobile-action-size) + 10px)}.profile-page,.details-page,.add-memory-page{padding-top:calc(var(--mobile-action-size) + 34px)}.timeline-title{--heading-font-size:27px;margin:-4px 0 10px;font-family:Poppins,Segoe UI,Arial,sans-serif;font-weight:800;line-height:1.12}.timeline{width:100%;max-width:720px;margin-top:24px;align-items:start;column-gap:10px;row-gap:20px}body.card-size-small .timeline{width:100%;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:8px;row-gap:14px}body.card-size-medium .timeline{grid-template-columns:repeat(2,minmax(0,1fr))}body.card-size-large .timeline{width:100%;grid-template-columns:1fr}.timeline-item,.timeline-item.right{min-width:0;padding-top:18px}.timeline-item:before{top:7px;height:1px}.timeline-item:after{top:3px;width:8px;height:8px;border-width:1px;box-shadow:0 0 3px #ff4b7d1f}.timeline-card,body.card-size-small .timeline-card,body.card-size-medium .timeline-card,body.card-size-large .timeline-card{width:100%;min-height:0;height:auto}body.card-size-small .timeline-card{aspect-ratio:.78;border-radius:13px}body.card-size-medium .timeline-card{aspect-ratio:.86;border-radius:16px}body.card-size-large .timeline-card{aspect-ratio:1.22;max-height:430px;border-radius:20px}body.card-size-small .memory-card-overlay{gap:5px;padding:38px 7px 8px}body.card-size-small .memory-card-kicker{align-items:flex-start;flex-direction:column;gap:4px}body.card-size-small .memory-card-kicker span,body.card-size-small .memory-card-kicker small{max-width:100%;padding:3px 5px;font-size:8px}body.card-size-small .memory-card-overlay h3{font-size:clamp(11px,3.2vw,15px)}body.card-size-small .timeline-card .favorite-btn{top:7px;right:7px;width:28px;height:28px;min-height:28px;font-size:16px}body.card-size-small .memory-actions{gap:5px}body.card-size-small .memory-actions button{width:26px;height:26px;min-height:26px;flex-basis:26px;font-size:10px}body.card-size-medium .memory-card-overlay{padding:52px 11px 11px}body.card-size-medium .memory-card-overlay h3{font-size:clamp(16px,4.5vw,21px)}.story-panel{display:flex;flex-direction:column}.story-hero,.story-hero img,.story-hero .memory-photo-placeholder{width:100%;min-height:0;height:clamp(280px,48dvh,420px)}.story-hero img{object-fit:cover}.story-body{padding:22px 18px 8px}.details-description{margin-bottom:12px;font-size:calc(15px + var(--app-font-delta))}.details-actions{grid-template-columns:repeat(2,minmax(0,1fr));padding:14px 18px 18px}.preview-media{height:clamp(260px,44dvh,390px);min-height:0}.profile-summary-content h1{--heading-font-size:27px}.profile-card h2{--heading-font-size:23px}.settings-device-note{margin-bottom:18px}.settings-field span,.settings-toggle,.settings-color-field,.settings-color-grid label{font-size:calc(14px + var(--app-font-delta))}}@media(max-width:380px){body.card-size-small .timeline{column-gap:6px}body.card-size-small .memory-actions{display:none}}.calendar-view{width:min(1180px,94vw);margin-top:34px;gap:20px}.calendar-month{padding:22px;overflow:hidden;border-radius:24px;content-visibility:auto;contain-intrinsic-size:290px;background:linear-gradient(145deg,#ffffff1f,#fff1);border:1px solid rgba(255,255,255,.18);box-shadow:0 18px 44px #04051638,inset 0 1px #ffffff1f}.calendar-month-heading{margin-bottom:18px;display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.calendar-month-heading h3{margin:3px 0 0;color:inherit;font-size:24px;line-height:1.1}.calendar-month-kicker{color:#ffffff85;font-size:10px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.calendar-month-count{flex:0 0 auto;padding:7px 11px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff14;color:#ffffffb8;font-size:11px;font-weight:700}.calendar-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:11px}.calendar-memory{position:relative;min-width:0;min-height:76px;margin:0;padding:10px 38px 10px 10px;display:grid;grid-template-columns:58px minmax(0,1fr);align-items:center;gap:11px;overflow:hidden;border:1px solid rgba(255,255,255,.13);border-radius:15px;background:#14153b75;box-shadow:0 10px 24px #05061829,inset 0 1px #ffffff14;color:#fff;text-align:left;transition:transform .22s ease,border-color .22s ease,background .22s ease,box-shadow .22s ease}.calendar-memory:hover{transform:translateY(-3px);border-color:#ff6f9d7a;background:#352a769e;box-shadow:0 14px 30px #0405163d}.calendar-memory-thumbnail{position:relative;width:58px;height:58px;margin:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.16);border-radius:12px;overflow:hidden;background:linear-gradient(145deg,#ff4b7ddb,#6c63ffdb);box-shadow:0 8px 18px #100c3047}.calendar-memory-thumbnail:after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff1f}.calendar-memory-thumbnail img{width:100%;height:100%;display:block;object-fit:cover}.calendar-memory-thumbnail.empty strong{color:#fff;font-size:24px;line-height:1}.calendar-memory-copy{min-width:0;margin:0}.calendar-memory-copy strong,.calendar-memory-copy small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-memory-copy strong{font-size:14px;line-height:1.25}.calendar-memory-meta{margin-top:7px;display:flex;align-items:center;gap:6px;overflow:hidden}.calendar-memory-meta small,.calendar-memory-meta time{min-width:0;padding:4px 7px;border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#ffffff17;color:#ffffffad;font-size:8px;font-weight:800;line-height:1;white-space:nowrap}.calendar-memory-meta small{max-width:46%;overflow:hidden;text-overflow:ellipsis}.calendar-memory-meta time{color:#ffffffd1}.calendar-memory-arrow{position:absolute;right:12px;top:50%;margin:0;color:#ffffff6b;font-size:16px;transform:translateY(-50%)}.calendar-memory>i{position:absolute;top:6px;right:6px;z-index:2;width:20px;height:20px;border-width:1px;border-radius:6px;background:#090a20b8;font-size:11px}.calendar-memory.selected{border-color:#ff8cae;background:linear-gradient(145deg,#ff4b7db8,#6c63ffb8);box-shadow:0 0 0 3px #ff4b7d26}body.light .calendar-month{background:linear-gradient(145deg,#ffffff5c,#fff3);border-color:#ffffff57;color:#28233d}body.light .calendar-month-kicker{color:#2c2c2c7a}body.light .calendar-month-count{border-color:#2c2c2c1a;background:#ffffff42;color:#2c2c2ca6}body.light .calendar-memory{border-color:#ffffff47;background:#433486b8}.small-cards-view{width:min(1320px,94vw);margin-top:34px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;align-items:stretch}.small-container-memory{min-height:72px;padding:9px 30px 9px 9px;grid-template-columns:52px minmax(0,1fr);gap:9px;border-radius:14px;background:#14153b80;content-visibility:auto;contain-intrinsic-size:72px}.small-container-memory .calendar-memory-thumbnail{width:52px;height:52px;border-radius:11px}.small-container-memory .calendar-memory-copy strong{font-size:13px}.small-container-memory .calendar-memory-meta{margin-top:6px;gap:4px}.small-container-memory .calendar-memory-meta small,.small-container-memory .calendar-memory-meta time{padding:3px 5px;font-size:7px}@media(max-width:1040px){.calendar-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.small-cards-view{grid-template-columns:repeat(5,minmax(0,1fr))}}@media(max-width:760px){body.memory-hover-off .timeline-card,.timeline-card{box-shadow:0 10px 24px #03041247;transition:border-color .22s ease}.timeline-card:hover,body.memory-hover-off .timeline-card:hover{box-shadow:0 10px 24px #03041247;transform:none}.glass-card,.timeline-filter-popover,.timeline-export-popover,.reminder-popover,.profile-summary-card,.profile-card,.settings-card,.preview-dialog,.calendar-month,.export-selection-bar{-webkit-backdrop-filter:none;backdrop-filter:none}.hearts span:nth-child(n+4){display:none}.hearts span{animation-duration:24s!important;opacity:.46}.calendar-view{width:100%;margin-top:26px;gap:15px}.small-cards-view{width:100%;margin-top:26px;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.calendar-month{padding:15px;border-radius:20px}.calendar-month-heading{margin-bottom:13px;align-items:center}.calendar-month-heading h3{font-size:19px}.calendar-month-kicker{font-size:8px}.calendar-month-count{padding:6px 9px;font-size:9px}.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.calendar-memory{min-height:68px;padding:8px 27px 8px 8px;grid-template-columns:48px minmax(0,1fr);gap:8px;border-radius:13px}.calendar-memory-thumbnail{width:48px;height:52px;border-radius:10px}.calendar-memory-thumbnail.empty strong{font-size:20px}.calendar-memory-copy strong{font-size:12px}.calendar-memory-meta{margin-top:5px;gap:4px}.calendar-memory-meta small,.calendar-memory-meta time{padding:3px 5px;font-size:7px}.calendar-memory-arrow{right:8px;font-size:13px}.calendar-memory:hover{transform:none}.small-container-memory{min-height:66px;padding:8px 24px 8px 8px;grid-template-columns:44px minmax(0,1fr);gap:8px;border-radius:13px}.small-container-memory .calendar-memory-thumbnail{width:44px;height:48px;border-radius:10px}}@media(max-width:380px){.calendar-month{padding:12px}.calendar-month-count{display:none}.calendar-memory{grid-template-columns:44px minmax(0,1fr);padding-right:8px}.calendar-memory-thumbnail{width:44px;height:48px}.calendar-memory-arrow{display:none}.small-cards-view{gap:8px}.small-container-memory{padding-right:8px}}@media(max-width:760px){.preview-overlay{padding:12px;align-items:center;overflow:hidden}.preview-dialog{width:100%;height:calc(100dvh - 24px);max-height:calc(100dvh - 24px);margin:0;grid-template-columns:1fr;grid-template-rows:minmax(240px,44dvh) minmax(0,1fr);overflow:hidden}.preview-media{width:100%;height:auto;min-height:0;padding:12px}.preview-media img{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;object-position:center!important}.preview-image-info-popover{left:auto;right:50%;bottom:calc(100% + 10px);width:min(220px,calc(100vw - 42px));padding:11px;border-radius:14px;transform:translate(50%);animation:previewInfoMobileIn .18s ease both}.preview-image-info-row{gap:10px;padding:6px 0;font-size:11px}@keyframes previewInfoMobileIn{0%{opacity:0;transform:translate(50%) translateY(6px) scale(.98)}to{opacity:1;transform:translate(50%) translateY(0) scale(1)}}.preview-content{min-height:0;padding:18px 16px 14px;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;overflow:hidden}.preview-description{min-height:0;overflow:auto}.preview-actions{margin-top:0;padding-top:12px;justify-content:center;flex-wrap:nowrap}.story-hero,.story-hero img,.story-hero .memory-photo-placeholder{width:100%;min-height:0;height:min(56dvh,480px)}.story-hero img{object-fit:contain;object-position:center!important}.details-back-btn{position:absolute;top:12px;left:12px;z-index:6;width:36px;height:36px;min-height:36px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:#0a0b1eb8;color:#fff;box-shadow:0 12px 30px #00000057;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:20px;line-height:36px;text-align:center}.details-back-btn:hover{transform:none;background:#ff4b7dd1}.preview-back-btn{position:absolute;top:12px;left:12px;z-index:8;width:36px;height:36px;min-height:36px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:#0a0b1eb8;color:#fff;box-shadow:0 12px 30px #00000057;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:20px;line-height:36px;text-align:center}.preview-back-btn:hover{transform:none;background:#ff4b7dd1}.upload-helper,.selected-files-header{align-items:flex-start;flex-direction:column;gap:7px}.add-memory-page .upload-helper button{align-self:flex-start}}@media(max-width:380px){.preview-dialog{grid-template-rows:minmax(210px,40dvh) minmax(0,1fr)}}.profile-grid,.profile-summary-card{width:min(1180px,90vw)}.settings-card{padding:26px 28px 28px}.settings-card .settings-row,.settings-sound-control{align-items:end}.settings-sound-control select{height:44px;min-height:44px;margin:0}.settings-sound-control button{width:42px;height:42px;min-height:42px;margin:0 0 1px;padding:0;place-self:end}.settings-sound-control button:first-letter{line-height:1}.profile-grid>.profile-card:not(.settings-card){padding:24px 26px 26px;display:flex;flex-direction:column}.profile-grid>.profile-card:not(.settings-card) form button[type=submit]{width:min(240px,100%);min-height:40px;padding:9px 16px}.profile-grid>.profile-card:not(.settings-card) form{flex:1}.profile-grid>.profile-card:not(.settings-card) form button[type=submit]{margin-top:auto}.profile-back-btn{width:min(260px,90vw);min-height:40px}.profile-danger-zone{width:100%;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:center}.profile-danger-btn{width:100%;min-height:40px;padding:9px 14px;border-radius:12px;font-size:14px;font-weight:800}.profile-danger-warning,.profile-danger-delete{background:linear-gradient(135deg,#be123ce6,#7f1d1ddb)!important;border:1px solid rgba(255,255,255,.2)!important;color:#fff!important;box-shadow:0 14px 28px #7f1d1d38!important;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.profile-danger-warning:hover,.profile-danger-delete:hover{background:linear-gradient(135deg,#dc2626eb,#881337e0)!important;box-shadow:0 16px 34px #7f1d1d4d!important}.profile-mobile-desktop-note{display:none}.profile-delete-account-row{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:8px;align-items:center}.profile-delete-info-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.profile-delete-info-btn{width:34px;height:34px;min-height:34px;padding:0;border-radius:50%;font-family:Poppins,Segoe UI,sans-serif;font-size:15px;font-weight:900;background:#3b1cb9f2}.profile-delete-info-bubble{position:absolute;right:0;bottom:calc(100% + 10px);width:260px;padding:12px;border-radius:14px;background:#0c0d1ef0;border:1px solid rgba(255,255,255,.18);color:#fff;box-shadow:0 16px 34px #00000047;font-size:12px;line-height:1.45;opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:4}.profile-delete-info-wrap:hover .profile-delete-info-bubble,.profile-delete-info-bubble.show{opacity:1;transform:translateY(0);pointer-events:auto}.profile-danger-confirm-actions button{min-width:0;width:100%}@media(min-width:1200px){.profile-page{width:100vw;margin-left:calc(50% - 50vw);padding-right:80px;padding-left:80px}.profile-summary-card,.profile-grid{width:min(1180px,100%);max-width:1180px;margin-left:auto;margin-right:auto;justify-self:center;align-self:center}.profile-summary-card{transform:none}}@media(min-width:900px){.settings-card form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:22px;row-gap:16px;align-items:start}.settings-device-note,.settings-section-title,.settings-card .settings-row,.settings-actions,.settings-color-grid,.settings-save-actions{grid-column:1 / -1}.settings-card .settings-field,.settings-card .settings-toggle,.settings-card .settings-color-field,.settings-card .segmented-setting{margin-bottom:0}.settings-card .settings-field select,.settings-card .settings-field input:not([type=checkbox]):not([type=color]),.settings-card .settings-color-field input:not([type=color]){width:100%}.settings-card .settings-section-title{margin:6px 0 0}.settings-card .settings-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.settings-card .settings-row.two-column{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-card .settings-sound-row{grid-template-columns:repeat(3,minmax(0,1fr))}.settings-actions{grid-template-columns:repeat(2,minmax(0,1fr));max-width:760px;margin:0 auto}.settings-color-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.settings-save-actions{margin-top:4px}}@media(max-width:760px){.profile-summary-card,.profile-grid{width:min(100%,430px)}.settings-card{padding:18px 16px}.settings-card form{display:block;width:100%}.settings-card .settings-field,.settings-card .settings-toggle,.settings-card .settings-color-field,.settings-card .segmented-setting{width:100%;max-width:none;margin:0 0 12px;text-align:left}.settings-card .settings-field>span,.settings-card .settings-section-title{text-align:left}.settings-card .settings-field select,.settings-card .settings-field input:not([type=checkbox]):not([type=color]),.settings-card .settings-color-field input:not([type=color]){width:100%}.settings-card .settings-row,.settings-card .settings-row.two-column{display:grid;grid-template-columns:1fr;gap:0}.settings-card .segmented-setting{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.profile-mobile-desktop-note{display:block;margin:0 0 16px;padding:12px 14px;border-radius:16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.16);color:#ffffffd1;font-size:13px;line-height:1.45;text-align:left}.settings-actions,.settings-save-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:100%;max-width:none}.settings-color-grid{display:grid;grid-template-columns:1fr;gap:10px}.settings-color-grid label,.settings-color-field{display:grid;grid-template-columns:minmax(0,1fr) 58px;gap:10px;align-items:center}.settings-sound-control{grid-template-columns:minmax(0,1fr) 40px;align-items:center;gap:8px}.settings-sound-control select{height:42px;min-height:42px}.settings-sound-control button{width:40px;height:40px;min-height:40px;border-radius:12px;margin:0;align-self:center}.profile-grid>.profile-card:not(.settings-card){padding:18px 16px}.profile-grid>.profile-card:not(.settings-card) form button[type=submit],.profile-back-btn{width:min(220px,100%)}.profile-danger-zone{grid-template-columns:1fr;gap:9px}.profile-delete-info-bubble{right:0;width:min(260px,78vw)}}@media(max-width:760px){.timeline-filter-popover{position:fixed;z-index:1200;top:clamp(285px,36dvh,430px);left:50%;right:auto;width:min(318px,calc(100vw - 42px));max-height:min(330px,calc(100dvh - 330px));padding:12px;gap:10px;border-radius:18px;transform:translate(-50%);animation:mobileFilterPop .2s ease both;overflow:auto}@keyframes mobileFilterPop{0%{opacity:0;transform:translate(-50%,-8px) scale(.97)}to{opacity:1;transform:translate(-50%) scale(1)}}.timeline-filter-section{gap:7px}.timeline-filter-section span{font-size:10px;letter-spacing:.12em}.timeline-filter-section button{min-width:0;min-height:38px;padding:8px 12px;border-radius:999px;font-size:13px;line-height:1}.reminder-popover{position:fixed;z-index:1200;top:max(64px,calc(env(safe-area-inset-top) + 58px));left:12px;right:auto;width:min(300px,calc(100vw - 24px));max-height:min(300px,calc(100dvh - 92px));margin:0;padding:12px;border-radius:17px;overflow:auto}body.top-actions-left .reminder-popover{left:12px;right:auto}body:not(.top-actions-left) .reminder-popover{left:auto;right:12px}.reminder-popover h3{margin-bottom:9px;font-size:17px}.reminder-popover p{font-size:13px;line-height:1.35}.reminder-popover-item{min-height:42px;padding:9px 10px;gap:9px;border-radius:11px;font-size:13px}.reminder-popover-item+.reminder-popover-item{margin-top:6px}.reminder-popover-item small{font-size:12px}.reminder-pagination{margin-top:9px}.reminder-pagination button{width:30px;height:30px;min-height:30px;font-size:18px}body.card-size-medium .timeline{column-gap:12px;row-gap:18px}body.card-size-medium .timeline-card{aspect-ratio:.98;border-radius:15px}body.card-size-medium .memory-card-overlay{gap:7px;padding:48px 10px 10px}body.card-size-medium .memory-card-kicker{gap:5px;align-items:flex-start;flex-wrap:wrap;justify-content:flex-start}body.card-size-medium .memory-card-kicker span,body.card-size-medium .memory-card-kicker small{max-width:100%;padding:4px 7px;font-size:9.5px;line-height:1.1}body.card-size-medium .memory-card-overlay h3{font-size:clamp(15px,4.1vw,19px)}body.card-size-medium .timeline-card .favorite-btn{top:9px;right:9px;width:38px;height:38px;min-height:38px;font-size:22px}body.card-size-medium .memory-actions{gap:8px}body.card-size-medium .memory-actions button{width:38px;height:38px;min-height:38px;flex-basis:38px;font-size:15px}body.light .hearts span{opacity:.98;filter:saturate(1.38) brightness(1.12) drop-shadow(0 5px 13px rgba(255,45,104,.24))}.trash-page{min-height:100dvh;padding:56px 10px 34px;gap:12px}.trash-hero,.trash-actions-panel,.trash-selection-bar,.trash-grid{width:100%}.trash-hero,.trash-actions-panel,.trash-selection-bar,.trash-card{-webkit-backdrop-filter:none;backdrop-filter:none}.trash-hero{min-height:76px;padding:0 0 6px}.trash-hero h1{font-size:34px}.trash-title-wrap{gap:9px}.trash-info-btn{width:26px;height:26px;min-height:26px;font-size:15px}.trash-info-bubble{right:50%;width:min(278px,calc(100vw - 34px));padding:10px 12px;font-size:12px;transform:translate(50%,-6px) scale(.98)}.trash-info-wrap:hover .trash-info-bubble,.trash-info-bubble.show{transform:translate(50%) scale(1)}.trash-actions-panel{padding:0;justify-content:center}.trash-count{display:none}.trash-actions{width:auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.trash-actions button,.trash-selection-bar button,.trash-card-actions button{min-height:36px;padding:0 9px;border-radius:12px;font-size:11px}.trash-selection-bar{width:auto;min-height:28px;padding:0;gap:7px;align-self:center;background:none;border:0}.trash-selection-bar span,.trash-selection-bar label{font-size:12px}.trash-selection-bar input{width:16px;height:16px}.trash-selection-dock{bottom:max(14px,env(safe-area-inset-bottom));width:auto;padding:6px;gap:6px;border-radius:14px}.trash-selection-dock button{min-width:78px;min-height:34px;padding:0 13px;border-radius:10px;font-size:12px}.trash-page.selection-mode{padding-bottom:94px}.trash-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.trash-card{width:100%;aspect-ratio:.78;padding:7px;border-radius:14px}.trash-card:hover{transform:none}.trash-thumb{width:100%;height:100%;border-radius:inherit}.trash-meta{gap:4px}.trash-meta span{display:none}.trash-meta time{padding:3px 6px;font-size:8px}.trash-copy{gap:5px}.trash-copy h2{font-size:clamp(12px,3.6vw,15px);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.trash-card-actions{margin-top:7px;gap:6px}.trash-card-actions button{width:28px;height:28px;min-height:28px;flex-basis:28px;padding:0;font-size:14px}.trash-check{top:6px;left:6px;padding:0}.trash-check input{width:15px;height:15px}.trash-empty{width:100%;margin-top:6px;padding:22px 16px;border-radius:20px}}body:not(.button-glass-on) .top-buttons .toggle-btn,body:not(.button-glass-on) .top-buttons .logout-btn,body:not(.button-glass-on) .reminder-menu .reminder-icon-btn,body:not(.button-glass-on) .timeline-controls .filter-toggle,body:not(.button-glass-on) .timeline-controls .timeline-icon-control,body:not(.button-glass-on) .timeline-controls .timeline-action-btn,body:not(.button-glass-on) .timeline-toolbar button,body:not(.button-glass-on) .preview-actions button:not(:last-child),body:not(.button-glass-on) .preview-actions .preview-image-info-btn{background:var(--button-bg-color)!important;border-color:color-mix(in srgb,var(--button-bg-color) 68%,white)!important;box-shadow:0 12px 26px #0000002e!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}body:not(.button-glass-on) .top-buttons .toggle-btn:hover,body:not(.button-glass-on) .top-buttons .logout-btn:hover,body:not(.button-glass-on) .reminder-menu .reminder-icon-btn:hover,body:not(.button-glass-on) .timeline-controls .filter-toggle:hover,body:not(.button-glass-on) .timeline-controls .timeline-icon-control:hover,body:not(.button-glass-on) .timeline-controls .timeline-action-btn:hover,body:not(.button-glass-on) .timeline-toolbar button:hover,body:not(.button-glass-on) .preview-actions button:not(:last-child):hover,body:not(.button-glass-on) .preview-actions .preview-image-info-btn:hover{background:color-mix(in srgb,var(--button-bg-color) 86%,white)!important;border-color:color-mix(in srgb,var(--button-bg-color) 78%,white)!important}body:not(.button-glass-on) .preview-actions button:last-child{background:#ff4d6d7a;border-color:#ffffff2e}body:not(.button-glass-on) .preview-actions button:last-child:hover{background:#ff4d6d9e}.mobile-popover-backdrop{display:none}@media(max-width:760px){.mobile-popover-backdrop{position:fixed;inset:0;z-index:1190;display:block;pointer-events:none;background:#0304127a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}body.light .mobile-popover-backdrop{background:#ffffff61}.timeline-filter-popover,.reminder-popover{border-color:#ffffff47!important;background:#121330d6!important;box-shadow:0 24px 70px #0000006b,inset 0 1px #ffffff1f!important;-webkit-backdrop-filter:blur(22px) saturate(1.15)!important;backdrop-filter:blur(22px) saturate(1.15)!important}body.light .timeline-filter-popover,body.light .reminder-popover{background:#ffffffc7!important;color:#25213d;border-color:#5048842e!important;box-shadow:0 24px 70px #48368042,inset 0 1px #ffffffb8!important}body.light .timeline-filter-section span,body.light .reminder-popover p{color:#25213dad}body.light .timeline-filter-section button,body.light .reminder-popover-item{background:#584baad6;border-color:#ffffff47;color:#fff}.preview-image-info-popover{position:fixed;left:16px;right:16px;bottom:calc(env(safe-area-inset-bottom) + 92px);z-index:2200;width:auto;max-width:none;transform:none;animation:previewInfoSheetIn .18s ease both}@keyframes previewInfoSheetIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-theme-colors{grid-template-columns:1fr}.settings-card .mobile-theme-colors label{min-height:76px;display:grid;grid-template-columns:minmax(0,1fr) 88px;align-items:center;gap:14px}.settings-card .mobile-theme-colors input[type=color]{justify-self:end}body.light .timeline-filter-section button.selected{background:linear-gradient(135deg,#ff4b7d,#e11d63)!important;border-color:#ffffffb8!important;color:#fff!important;box-shadow:0 10px 24px #e11d6347,inset 0 1px #ffffff57!important}body.light .timeline-filter-section button.selected:after{content:"";display:inline-block;width:6px;height:6px;margin-left:7px;border-radius:50%;background:#fff;box-shadow:0 0 8px #fffc;vertical-align:middle}.onboarding-welcome-preview{width:min(290px,88%);height:170px;margin-top:66px;gap:10px;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.onboarding-welcome-preview span,.onboarding-welcome-preview i{border-radius:18px}.onboarding-welcome-preview span:first-child,.onboarding-welcome-preview i,.onboarding-welcome-preview span:last-child{font-size:0}.settings-tip-bubble{width:min(310px,calc(100vw - 34px));margin:10px auto 0;padding:10px 11px 10px 14px;border-radius:16px;background:#0f102ae0;border:1px solid rgba(255,255,255,.22);color:#fff;box-shadow:0 16px 42px #03041257;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}}.settings-tip-bubble{position:absolute;top:calc(100% + 12px);right:calc(50% - 281px);z-index:65;width:292px;padding:11px 11px 11px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-radius:16px;background:#0f102ae6;border:1px solid rgba(255,255,255,.2);color:#fff;box-shadow:0 18px 48px #0304125c;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);animation:settingsTipIn .2s ease both}.settings-tip-bubble:before{content:"";position:absolute;top:-7px;right:36px;width:14px;height:14px;background:inherit;border-left:1px solid rgba(255,255,255,.2);border-top:1px solid rgba(255,255,255,.2);transform:rotate(45deg)}.settings-tip-bubble span{position:relative;z-index:1;font-size:13px;font-weight:700;line-height:1.35}.settings-tip-bubble button{position:relative;z-index:1;flex:0 0 auto;width:31px;height:31px;min-height:31px;padding:0;border-radius:50%;background:var(--button-bg-color);border:1px solid color-mix(in srgb,var(--button-bg-color) 68%,white);color:#fff;box-shadow:none;font-size:15px;line-height:1}body.light .settings-tip-bubble{background:#ffffffe0;border-color:#322c5824;color:#25213d;box-shadow:0 18px 44px #48368033}@keyframes settingsTipIn{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:760px){.settings-tip-bubble{position:relative;top:auto;right:auto;width:min(310px,calc(100vw - 34px));margin:10px auto 0;padding:10px 11px 10px 14px;border-radius:16px}.settings-tip-bubble:before{right:24px}}body{margin:0;font-family:Segoe UI,Arial,sans-serif;background:linear-gradient(135deg,#1e1e2f,#2b2b45);color:#fff}.container{max-width:900px;margin:auto;padding:30px}h1{text-align:center;margin-bottom:30px}.card{background:#2e2e48;padding:25px;border-radius:12px;margin-bottom:30px;box-shadow:0 5px 15px #0000004d}input,textarea{width:100%;padding:10px;margin-top:8px;margin-bottom:15px;border-radius:6px;border:none;outline:none}button{background:#ff4b7d;color:#fff;border:none;padding:10px 18px;border-radius:6px;cursor:pointer;font-weight:700}button:hover{background:#ff2a63}.memory-card{background:#38385a;padding:20px;border-radius:10px;margin-bottom:20px}
