:root{--page:#f4f2ee;--paper:#fffdfa;--paper-soft:#faf7f3;--ink:#23262a;--ink-soft:#3d4346;--muted:#6f7778;--line:#e1ded7;--line-strong:#cec8bd;--rose:#d85375;--rose-soft:#fde9ee;--fern:#28766c;--fern-soft:#e6f4ef;--sky:#557da2;--lavender:#8270a8;--saffron:#c58b2d;--coral:#e47f67;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-soft:cubic-bezier(.16, 1, .3, 1);--shadow-sm:0 10px 28px #2c322e12;--shadow-md:0 18px 50px #2c322e1f;--shadow-lg:0 34px 90px #2c322e2b;color:var(--ink);background:var(--page);letter-spacing:0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}html{background:var(--page)}body{background:linear-gradient(115deg, #fffdfaf0, #eaf4efb8), var(--page);min-width:320px;margin:0}body:before{z-index:-1;content:"";pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#d8537509 1px,#0000 1px),linear-gradient(0deg,#28766c09 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:64px 64px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:fixed;inset:0}h1,h2,h3,p{overflow-wrap:anywhere}h1,h2,h3{color:var(--ink);letter-spacing:0;font-weight:720;line-height:1.12}h1{font-size:38px}h2{margin:0;font-size:28px}h3,p{margin:0}button,input,select,textarea{letter-spacing:0}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #28766c2e}@media (width<=720px){h1{font-size:32px}h2{font-size:24px}}.auth-shell,.app-shell{min-height:100svh}@keyframes soft-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes quiet-drift{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.auth-shell{background:linear-gradient(135deg, #fffdfaf5, #e6f4efc7), var(--page);grid-template-columns:minmax(0,1.08fr) minmax(430px,.92fr);display:grid}.auth-visual{align-content:center;gap:24px;min-height:100svh;padding:52px;display:grid}.auth-story{max-width:680px;animation:soft-enter .52s var(--ease-soft) both}.auth-kicker,.eyebrow,.soft-label,.entry-type{color:var(--fern);letter-spacing:0;font-size:12px;font-weight:780}.auth-story h2{max-width:640px;margin:10px 0 12px;font-size:42px;line-height:1.08}.auth-story p,.muted,.topbar-note,.hero-band p,.empty-state{color:var(--muted)}.visual-frame{aspect-ratio:16/10;width:min(820px,100%);box-shadow:var(--shadow-lg);animation:soft-enter .56s var(--ease-soft) 80ms both;background:#fff;border:1px solid #e1ded7eb;border-radius:8px;position:relative;overflow:hidden}.visual-frame:after{content:"";pointer-events:none;background:linear-gradient(120deg,#fff3,#0000 54%);position:absolute;inset:0}.visual-image,.memory-window{background-image:url(/warm-window.png);background-position:50%;background-size:cover;width:100%;height:100%}.visual-caption{z-index:1;min-height:40px;color:var(--ink);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-sm);background:#fffdfac7;border:1px solid #ffffffad;border-radius:8px;align-items:center;gap:8px;padding:0 12px;font-size:14px;font-weight:680;display:inline-flex;position:absolute;bottom:18px;left:18px}.visual-caption svg{width:18px;height:18px;color:var(--rose)}.auth-panel{-webkit-backdrop-filter:blur(26px);backdrop-filter:blur(26px);min-height:100svh;animation:soft-enter .56s var(--ease-soft) .11s both;background:#fffdfac7;border-left:1px solid #cec8bdbf;flex-direction:column;justify-content:center;padding:64px;display:flex}.brand-mark{color:var(--ink);align-items:center;gap:10px;font-weight:760;display:inline-flex}.brand-mark svg{width:23px;height:23px;color:var(--rose);fill:#d853751f}.brand-mark small{color:var(--muted);margin-top:1px;font-size:11px;font-weight:640;display:block}.auth-panel h1,.topbar h1{margin:16px 0 8px}.auth-panel h1{max-width:500px;font-size:44px;line-height:1.05}.auth-form,.entry-form{gap:14px;display:grid}.auth-form{width:min(430px,100%);margin-top:30px}label{color:var(--muted);gap:7px;font-size:13px;font-weight:690;display:grid}input,select,textarea{border:1px solid var(--line-strong);width:100%;color:var(--ink);box-sizing:border-box;font:inherit;transition:border-color .16s var(--ease-out), box-shadow .16s var(--ease-out), background .16s var(--ease-out);background:#ffffffd1;border-radius:8px;outline:none;padding:12px 13px;font-size:15px;line-height:1.5}textarea{resize:vertical}input:focus,select:focus,textarea:focus{background:#fff;border-color:#28766cb8;box-shadow:0 0 0 4px #28766c1a}button{font:inherit;border:0}.primary-button,.ghost-button,.danger-button,.nav-list button,.icon-button,.notice{cursor:pointer;min-height:42px;transition:transform .18s var(--ease-out), box-shadow .18s var(--ease-out), border-color .18s var(--ease-out), background .18s var(--ease-out);border-radius:8px;justify-content:center;align-items:center;gap:8px;display:inline-flex}.primary-button{color:#fff;background:linear-gradient(135deg,#263331,#377f72);padding:0 18px;font-weight:740;box-shadow:0 14px 28px #28766c33}.primary-button:disabled{cursor:not-allowed;opacity:.56}.ghost-button{color:var(--ink);border:1px solid var(--line);background:#fffdfacc;padding:0 14px}.danger-button{color:#a13242;background:#d853751a;margin-top:18px;padding:0 14px}.primary-button:hover,.ghost-button:hover,.danger-button:hover,.icon-button:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.primary-button svg,.ghost-button svg,.danger-button svg{width:18px;height:18px}.form-error{color:#a13242;margin:0;font-size:14px;font-weight:720}.app-shell{color:var(--ink);background:linear-gradient(135deg, #fffdfadb, #e6f4ef9e), var(--page);grid-template-columns:292px minmax(0,1fr);display:grid;overflow-x:hidden}.sidebar{box-sizing:border-box;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#fffdfacc;border-right:1px solid #cec8bdb8;flex-direction:column;height:100svh;padding:28px 20px;display:flex;position:sticky;top:0}.couple-card{background:linear-gradient(150deg, #ffffffeb, #fde9ee7a), var(--paper);box-shadow:var(--shadow-sm);border:1px solid #e1ded7f2;border-radius:8px;gap:8px;margin-top:26px;padding:18px;display:grid}.couple-avatar{width:max-content;margin-bottom:7px;display:inline-flex}.couple-avatar span{color:#fff;background:var(--rose);width:38px;height:38px;box-shadow:var(--shadow-sm);border:2px solid #fff;border-radius:50%;place-items:center;font-weight:780;display:grid}.couple-avatar span+span{background:var(--fern);margin-left:-10px}.couple-card p,.couple-card small{color:var(--muted);margin:0}.couple-card strong{color:var(--ink);font-size:20px;line-height:1.22}.nav-list{gap:8px;margin-top:22px;display:grid}.nav-list button{color:#657073;background:0 0;justify-content:flex-start;padding:0 12px;font-weight:700}.nav-list button:hover{color:var(--ink);background:#ffffffad}.nav-list button.active{color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff}.nav-list svg,.sync-badge svg,.sync-pill svg{width:18px;height:18px}.sync-badge{color:var(--fern);align-items:center;gap:8px;margin-top:auto;font-size:13px;font-weight:760;display:inline-flex}.content{box-sizing:border-box;gap:20px;width:100%;padding:34px 42px 60px;display:grid}.content>*{animation:soft-enter .42s var(--ease-soft) both}.topbar{justify-content:space-between;align-items:end;gap:18px;display:flex}.topbar h1{font-size:36px;font-weight:740;line-height:1.06}.topbar-note{margin-top:4px;font-size:15px}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.sync-pill{min-height:42px;color:var(--fern);background:#e6f4efd1;border:1px solid #28766c2e;border-radius:8px;align-items:center;gap:8px;padding:0 12px;font-size:13px;font-weight:760;display:inline-flex}.soft-label{align-items:center;gap:6px;margin-bottom:14px;display:inline-flex}.soft-label svg{width:16px;height:16px}.notice{min-height:36px;color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;justify-self:start;padding:0 14px}.hero-band{min-height:316px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fffdfafa 0%,#fde9ee94 54%,#e6f4efb8 100%),#fff;border:1px solid #e1ded7eb;border-radius:8px;grid-template-columns:minmax(420px,620px) minmax(300px,1fr);align-items:stretch;gap:28px;padding:34px;display:grid;position:relative;overflow:hidden}.hero-band:before{content:"";pointer-events:none;background:linear-gradient(#0000,#28766c14);height:46%;position:absolute;inset:auto 0 0}.hero-band>*{z-index:1;position:relative}.hero-copy{flex-direction:column;justify-content:center;min-width:0;display:flex}.hero-band h2{max-width:620px;margin:0 0 16px;font-size:34px;font-weight:760;line-height:1.08}.hero-actions,.button-row{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.hero-visual{min-height:248px;position:relative}.memory-window{min-height:248px;box-shadow:inset 0 0 0 1px #ffffff75, var(--shadow-sm);animation:quiet-drift 9s var(--ease-soft) infinite;border:1px solid #e1ded7e6;border-radius:8px}.hero-note{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);max-width:260px;box-shadow:var(--shadow-sm);background:#fffdfad1;border:1px solid #ffffffb8;border-radius:8px;gap:3px;padding:12px;display:grid;position:absolute;bottom:16px;right:16px}.hero-note span{color:var(--fern);font-size:12px;font-weight:760}.hero-note strong{color:var(--ink);font-size:16px}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.stat-card,.panel,.photo-card{box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:transform .18s var(--ease-out), box-shadow .18s var(--ease-out), border-color .18s var(--ease-out);background:#fffdfadb;border:1px solid #e1ded7f0;border-radius:8px}.stat-card:hover,.panel:hover,.photo-card:hover{box-shadow:var(--shadow-md);border-color:#cec8bdf2;transform:translateY(-1px)}.stat-card{align-items:center;gap:14px;min-height:116px;padding:16px;display:flex}.stat-icon{width:42px;height:42px;color:var(--rose);background:var(--rose-soft);border:1px solid #d8537529;border-radius:8px;flex:none;place-items:center;display:grid}.stat-icon svg{width:20px;height:20px}.stat-card:nth-child(2) .stat-icon{color:var(--sky);background:#557da21c;border-color:#557da229}.stat-card:nth-child(3) .stat-icon{color:var(--fern);background:var(--fern-soft);border-color:#28766c29}.stat-card:nth-child(4) .stat-icon{color:var(--saffron);background:#c58b2d21;border-color:#c58b2d2e}.stat-card span,.stat-card small,.entry-main time,.settings-list dt{color:var(--muted)}.stat-card strong{color:var(--ink);font-size:30px;font-weight:760;line-height:1.06;display:block}.view-grid,.settings-grid{grid-template-columns:minmax(360px,.82fr) minmax(0,1.18fr);align-items:start;gap:16px;display:grid}.today-grid{grid-template-columns:minmax(420px,.9fr) minmax(0,1.1fr)}.album-grid{grid-template-columns:minmax(320px,390px) minmax(0,1fr)}.panel{padding:20px}.mood-panel{grid-column:1/-1}.panel-title{align-items:center;gap:9px;margin-bottom:16px;display:flex}.panel-title svg{width:20px;height:20px;color:var(--rose)}.panel-title h2{font-size:24px;font-weight:760}.field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.entry-form.compact{gap:12px}.mood-grid{grid-template-columns:repeat(auto-fit,minmax(86px,1fr));gap:8px;display:grid}.mood-option{min-height:42px;color:var(--ink);border:1px solid var(--line);cursor:pointer;background:#ffffffc2;border-radius:8px;font-weight:720}.mood-option svg{vertical-align:-3px;width:16px;height:16px;margin-right:4px}.mood-option.selected.rose{background:#d853751f}.mood-option.selected.teal{background:#28766c1f}.mood-option.selected.amber{background:#c58b2d26}.mood-option.selected.blue{background:#557da221}.mood-option.selected.coral{background:#e47f6721}.mood-option.selected.violet{background:#8270a821}.entry-list{gap:10px;display:grid}.entry-item{animation:soft-enter .32s var(--ease-soft) both;background:#faf7f3c7;border:1px solid #e1ded7e0;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:14px;display:grid}.entry-item.done{opacity:.66}.entry-main h3{margin:6px 0 5px;font-size:17px;font-weight:760}.entry-main p{color:var(--muted);white-space:pre-wrap;margin:0 0 9px}.entry-type{color:var(--rose)}.entry-type.wish{color:var(--saffron)}.entry-type.mood{color:var(--sky)}.entry-type.photo{color:var(--fern)}.entry-actions{gap:7px;display:flex}.icon-button{width:36px;height:36px;color:var(--muted);border:1px solid var(--line);background:#fff}.icon-button svg{width:16px;height:16px}.empty-state{border:1px dashed var(--line-strong);background:#ffffff6b;border-radius:8px;place-items:center;min-height:164px;margin:0;display:grid}.photo-wall{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.photo-card{margin:0;overflow:hidden}.photo-card img,.photo-placeholder{aspect-ratio:4/3;object-fit:cover;background:var(--paper-soft);width:100%;display:block}.photo-placeholder{color:var(--muted);place-items:center;display:grid}.photo-placeholder svg{width:30px;height:30px}.photo-card figcaption{gap:4px;padding:12px;display:grid}.photo-card span{color:var(--muted);font-size:13px}.mood-temperature{grid-template-columns:auto minmax(0,1fr) minmax(220px,.42fr);align-items:center;gap:22px;display:grid}.temperature-ring{aspect-ratio:1;background:radial-gradient(circle at center, #fff 0 58%, transparent 59%), conic-gradient(var(--rose) var(--temperature), #d853751f 0);width:112px;box-shadow:inset 0 0 0 1px #ffffffb8, var(--shadow-sm);border-radius:50%;place-items:center;display:grid}.temperature-ring span{color:var(--ink);font-size:30px;font-weight:780;line-height:1}.temperature-ring small{color:var(--muted);margin-top:-30px;font-size:12px;font-weight:760}.temperature-copy h3{margin:5px 0;font-size:22px;font-weight:760}.temperature-copy p{color:var(--muted)}.mood-sparkline{border:1px solid var(--line);background:#faf7f3c7;border-radius:8px;align-items:end;gap:7px;height:86px;padding:12px;display:flex}.mood-sparkline span{background:linear-gradient(to top, var(--fern), var(--coral));min-width:9px;animation:soft-enter .36s var(--ease-soft) both;border-radius:999px 999px 4px 4px;flex:1}.ritual-layout{grid-template-columns:minmax(0,1fr) minmax(360px,.78fr);align-items:start;gap:16px;display:grid}.ritual-hero{background:linear-gradient(135deg,#fffdfaf5,#e6f4efd1),#fff;grid-column:1/-1;padding:34px}.ritual-hero h2{max-width:800px;margin:6px 0 10px;font-size:38px;font-weight:760}.ritual-hero p,.idea-ticket p,.ritual-card p{color:var(--muted)}.date-idea-card{gap:16px;display:grid}.idea-ticket{border:1px solid var(--line);background:linear-gradient(135deg, #fffdfaf5, #e6f4efb8), var(--paper);border-radius:8px;padding:20px;position:relative;overflow:hidden}.idea-ticket:before,.idea-ticket:after{content:"";background:var(--page);border-radius:50%;width:18px;height:18px;position:absolute;top:50%;transform:translateY(-50%)}.idea-ticket:before{left:-9px}.idea-ticket:after{right:-9px}.idea-ticket span{color:var(--fern);align-items:center;gap:6px;font-size:13px;font-weight:780;display:inline-flex}.idea-ticket svg{width:16px;height:16px}.idea-ticket h3{margin:10px 0 8px;font-size:30px;font-weight:760}.future-letter{grid-row:span 2}.ritual-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.ritual-card{gap:11px;display:grid}.ritual-card-icon{width:42px;height:42px;color:var(--rose);background:var(--rose-soft);border:1px solid #d8537529;border-radius:8px;place-items:center;display:grid}.ritual-card-icon svg{width:19px;height:19px}.ritual-card h3{margin:0;font-size:19px;font-weight:760}.settings-list{gap:14px;margin:0;display:grid}.settings-list div{border-bottom:1px solid var(--line);justify-content:space-between;gap:18px;padding-bottom:12px;display:flex}.settings-list dt,.settings-list dd{margin:0}.settings-list dd{color:var(--ink);text-align:right;font-weight:720}@media (width>=1800px){.content{padding-left:64px;padding-right:64px}}@media (width<=1120px){.auth-shell,.app-shell{grid-template-columns:1fr}.auth-visual{order:2;min-height:auto;padding:24px}.auth-story h2{font-size:34px}.visual-frame{max-height:320px}.auth-panel{border-left:0;border-top:1px solid var(--line);order:1;min-height:auto;padding:32px 22px 42px}.sidebar{height:auto;padding:18px;position:static}.couple-card{display:none}.nav-list{grid-template-columns:repeat(6,minmax(0,1fr));margin-top:18px}.nav-list button{flex-direction:column;justify-content:center;gap:4px;min-height:54px;padding:6px;font-size:13px}.sync-badge{margin-top:14px}.content{padding:24px 18px 40px}.hero-band,.view-grid,.settings-grid,.album-grid,.ritual-layout{grid-template-columns:1fr}.hero-band{min-height:auto}.ritual-cards{grid-template-columns:1fr}.future-letter{grid-row:auto}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.brand-mark small{display:none}.topbar{flex-direction:column;align-items:flex-start}.topbar h1{font-size:32px}.topbar-actions{justify-content:flex-start}.nav-list{grid-template-columns:repeat(3,minmax(0,1fr))}.nav-list button{min-height:50px;font-size:12px}.hero-band,.ritual-hero,.panel{padding:18px}.hero-band h2,.ritual-hero h2{word-break:break-word;font-size:31px}.hero-visual,.memory-window{min-height:210px}.hero-note{max-width:220px;bottom:12px;right:12px}.stats-grid,.field-row,.mood-grid{grid-template-columns:1fr}.stat-card{min-height:96px}.entry-item{grid-template-columns:1fr}.entry-actions{justify-content:flex-end}.mood-temperature{grid-template-columns:1fr}.temperature-ring{width:104px}.hero-actions,.button-row{flex-direction:column}.auth-story h2,.auth-panel h1{font-size:32px}}@media (width<=420px){.content,.sidebar{padding-left:14px;padding-right:14px}.hero-band h2,.ritual-hero h2{font-size:28px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
