:root{--page:#f5f7f6;--surface:#fff;--surface-soft:#f9faf8;--paper:#fffdf9;--ink:#20242a;--muted:#647076;--line:#e0e5e1;--line-strong:#cfd8d2;--rose:#d95f76;--coral:#e98167;--teal:#218579;--amber:#d99a2b;--blue:#496f9e;--violet:#7f6aaa;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-soft:cubic-bezier(.16, 1, .3, 1);--shadow-sm:0 8px 22px #24342e0f;--shadow-md:0 16px 38px #24342e1a;--shadow-lg:0 28px 70px #29383429;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}body{background:linear-gradient(120deg, #ffffffe0, #ecf6f2b8), var(--page);min-width:320px;margin:0}body:before{z-index:-1;content:"";pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#d95f760d 1px,#0000 1px),linear-gradient(0deg,#2185790b 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:52px 52px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000c7,#0000 86%);mask-image:linear-gradient(#000000c7,#0000 86%)}h1,h2,h3,p{overflow-wrap:anywhere}h1,h2,h3{color:var(--ink);letter-spacing:0;font-weight:820;line-height:1.08}h1{font-size:clamp(32px,6vw,56px)}h2{margin:0;font-size:clamp(24px,4vw,38px)}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 #21857938}.auth-shell,.app-shell{min-height:100svh}@keyframes panel-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes gentle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes heart-pulse{0%,to{transform:scale(1)}45%{transform:scale(1.08)}}.auth-shell{background:linear-gradient(135deg, #ffffffe6, #f7eeea85), var(--page);grid-template-columns:minmax(0,1.12fr) minmax(360px,.88fr);display:grid}.auth-visual{place-items:center;min-height:100svh;padding:40px;display:grid}.visual-frame{aspect-ratio:4/3;border:1px solid var(--line);width:min(780px,100%);box-shadow:var(--shadow-lg);animation:panel-rise .56s var(--ease-soft) both;border-radius:8px;position:relative;overflow:hidden}.visual-frame:after{content:"";pointer-events:none;background:linear-gradient(125deg,#0000 0 58%,#ffffff52);position:absolute;inset:0}.visual-image,.memory-window{background-image:url(/warm-window.png);background-position:50%;background-size:cover;width:100%;height:100%}.auth-panel{border-left:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);min-height:100svh;animation:panel-rise .64s var(--ease-soft) .12s both;background:#ffffffd1;flex-direction:column;justify-content:center;padding:56px;display:flex}.brand-mark{color:var(--ink);align-items:center;gap:10px;font-weight:750;display:inline-flex}.brand-mark svg{width:22px;height:22px;color:var(--rose);fill:#d95f7624;animation:heart-pulse 4s var(--ease-soft) infinite}.auth-panel h1,.topbar h1{margin:18px 0 8px}.auth-panel h1{font-size:clamp(38px,5vw,56px)}.topbar h1{font-size:clamp(32px,4vw,46px)}.muted,.hero-band p,.empty-state{color:var(--muted)}.auth-form,.entry-form{gap:16px;display:grid}.auth-form{width:min(420px,100%);margin-top:32px}label{color:var(--muted);gap:7px;font-size:14px;font-weight:650;display:grid}input,select,textarea{border:1px solid var(--line-strong);width:100%;color:var(--ink);box-sizing:border-box;font:inherit;background:#fff;border-radius:8px;outline:none;padding:11px 12px;font-size:15px;line-height:1.5}textarea{resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px #21857924}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, var(--ink), #334342);padding:0 18px;font-weight:750;box-shadow:0 10px 24px #20242a21}.primary-button:disabled{cursor:not-allowed;opacity:.56}.primary-button:hover,.ghost-button:hover,.danger-button:hover,.nav-list button:hover,.icon-button:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.primary-button svg,.ghost-button svg,.danger-button svg{width:18px;height:18px}.ghost-button{color:var(--ink);border:1px solid var(--line);background:#ffffffd6;padding:0 14px}.danger-button{color:#9d2c36;background:#d95f761a;margin-top:18px;padding:0 14px}.form-error{color:#9d2c36;margin:0;font-size:14px;font-weight:700}.app-shell{color:var(--ink);background:linear-gradient(135deg, #ffffff57, #e1f0eb5c), var(--page);grid-template-columns:240px minmax(0,1fr);display:grid;position:relative;overflow-x:hidden}.sidebar{border-right:1px solid var(--line);box-sizing:border-box;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffd1;flex-direction:column;height:100svh;padding:28px 20px;display:flex;position:sticky;top:0}.nav-list{gap:8px;margin-top:32px;display:grid}.nav-list button{color:var(--muted);background:0 0;justify-content:flex-start;padding:0 12px;font-weight:700}.nav-list button.active{color:var(--ink);box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fffffff5,#fff9f7e6)}.nav-list svg,.sync-badge svg{width:18px;height:18px}.sync-badge{color:var(--teal);align-items:center;gap:8px;margin-top:auto;font-size:13px;font-weight:800;display:flex}.content{box-sizing:border-box;gap:22px;width:min(1180px,100%);padding:30px;display:grid}.content>*{animation:panel-rise .46s var(--ease-soft) both}.topbar{justify-content:space-between;align-items:center;gap:18px;display:flex}.eyebrow,.soft-label,.entry-type{color:var(--teal);margin:0;font-size:13px;font-weight:800}.soft-label{align-items:center;gap:6px;margin-bottom:12px;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{border:1px solid var(--line);min-height:258px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fffffffa,#fffcf7eb),#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(260px,380px);align-items:stretch;gap:24px;padding:28px;display:grid;position:relative;overflow:hidden}.hero-band:before{content:"";pointer-events:none;background:linear-gradient(90deg,#d95f760f,#0000 34%),linear-gradient(135deg,#0000 62%,#21857914);position:absolute;inset:0}.hero-band>*{z-index:1;position:relative}.hero-band h2{max-width:620px;margin-bottom:14px;font-size:clamp(26px,3vw,38px)}.hero-actions,.button-row{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}.memory-window{border:1px solid var(--line);min-height:206px;animation:gentle-float 7s var(--ease-soft) infinite;border-radius:8px;box-shadow:inset 0 0 0 1px #ffffff5c}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.stat-card,.panel,.photo-card{border:1px solid var(--line);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:transform .22s var(--ease-out), box-shadow .22s var(--ease-out), border-color .22s var(--ease-out);background:#ffffffe0;border-radius:8px}.stat-card:hover,.panel:hover,.photo-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card{box-sizing:border-box;gap:7px;min-height:142px;padding:18px;display:grid}.stat-card svg{width:22px;height:22px;color:var(--coral)}.stat-card span,.stat-card small,.entry-main time,.settings-list dt{color:var(--muted)}.stat-card strong{color:var(--ink);font-size:28px;line-height:1.1}.view-grid,.settings-grid{grid-template-columns:minmax(320px,.82fr) minmax(0,1.18fr);align-items:start;gap:18px;display:grid}.album-grid{grid-template-columns:minmax(300px,380px) minmax(0,1fr)}.panel{padding:20px}.mood-panel{grid-column:1/-1}.panel-title{align-items:center;gap:10px;margin-bottom:18px;display:flex}.panel-title svg{width:20px;height:20px;color:var(--rose)}.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:#fff;border-radius:8px;font-weight:750}.mood-option svg{vertical-align:-3px;width:16px;height:16px;margin-right:4px}.mood-option.selected.rose{background:#d95f761f}.mood-option.selected.teal{background:#2185791f}.mood-option.selected.amber{background:#d99a2b29}.mood-option.selected.blue{background:#496f9e24}.mood-option.selected.coral{background:#e9816724}.mood-option.selected.violet{background:#7f6aaa24}.entry-list{gap:10px;display:grid}.entry-item{border:1px solid var(--line);background:var(--surface-soft);animation:panel-rise .36s var(--ease-soft) both;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:7px 0 5px;font-size:17px}.entry-main p{color:var(--muted);white-space:pre-wrap;margin:0 0 10px}.entry-type{color:var(--rose)}.entry-type.wish{color:var(--amber)}.entry-type.mood{color:var(--blue)}.entry-type.photo{color:var(--teal)}.entry-actions{gap:8px;display:flex}.icon-button{width:38px;height:38px;color:var(--muted);border:1px solid var(--line);background:#fff}.icon-button svg{width:17px;height:17px}.empty-state{border:1px dashed var(--line-strong);border-radius:8px;place-items:center;min-height:180px;margin:0;display:grid}.photo-wall{grid-template-columns:repeat(auto-fill,minmax(210px,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(--surface-soft);width:100%;display:block}.mood-temperature{grid-template-columns:auto minmax(0,1fr) minmax(130px,.45fr);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), #d95f761f 0);width:118px;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:850;line-height:1}.temperature-ring small{color:var(--muted);margin-top:-34px;font-size:12px;font-weight:800}.temperature-copy h3{margin:6px 0;font-size:24px}.temperature-copy p{color:var(--muted)}.mood-sparkline{border:1px solid var(--line);background:linear-gradient(#0000,#21857917),#ffffffb8;border-radius:8px;align-items:end;gap:8px;height:92px;padding:12px;display:flex}.mood-sparkline span{background:linear-gradient(to top, var(--teal), var(--coral));min-width:10px;animation:panel-rise .42s var(--ease-soft) both;border-radius:999px 999px 4px 4px;flex:1}.ritual-layout{grid-template-columns:minmax(0,1fr) minmax(320px,.86fr);align-items:start;gap:18px;display:grid}.ritual-hero{background:linear-gradient(135deg,#fffffff5,#f4fbf8e0),#fff;grid-column:1/-1;padding:30px}.ritual-hero h2{max-width:760px;margin:8px 0 10px;font-size:clamp(28px,4.4vw,48px)}.ritual-hero p,.idea-ticket p,.ritual-card p{color:var(--muted)}.date-idea-card{gap:18px;display:grid}.idea-ticket{border:1px solid var(--line);background:linear-gradient(135deg, #fffdf9f5, #edf9f4bd), var(--paper);border-radius:8px;padding:22px;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(--teal);align-items:center;gap:6px;font-size:13px;font-weight:850;display:inline-flex}.idea-ticket svg{width:16px;height:16px}.idea-ticket h3{margin:12px 0 8px;font-size:clamp(24px,4vw,34px)}.future-letter{grid-row:span 2}.ritual-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.ritual-card{gap:12px;display:grid}.ritual-card-icon{width:42px;height:42px;color:var(--rose);border:1px solid var(--line);background:#d95f7614;border-radius:8px;place-items:center;display:grid}.ritual-card-icon svg{width:20px;height:20px}.ritual-card h3{margin:0;font-size:20px}.photo-placeholder{color:var(--muted);place-items:center;display:grid}.photo-placeholder svg{width:32px;height:32px}.photo-card figcaption{gap:4px;padding:12px;display:grid}.photo-card span{color:var(--muted);font-size:13px}.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:750}@media (width<=980px){.auth-shell,.app-shell{grid-template-columns:1fr}.auth-visual{order:2;min-height:auto;padding:18px}.visual-frame{max-height:260px}.auth-panel{border-left:0;border-top:1px solid var(--line);order:1;min-height:auto;padding:28px 18px 40px}.sidebar{height:auto;padding:16px;position:static}.nav-list{grid-template-columns:repeat(6,minmax(0,1fr));margin-top:16px}.nav-list button{flex-direction:column;justify-content:center;gap:4px;min-height:56px;padding:6px;font-size:13px}.sync-badge{margin-top:14px}.content{padding:18px}.hero-band,.view-grid,.settings-grid,.album-grid,.ritual-layout,.ritual-cards{grid-template-columns:1fr}.future-letter{grid-row:auto}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.topbar{flex-direction:column;align-items: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:16px}.ritual-hero h2{word-break:break-word;font-size:clamp(24px,7vw,32px)}.stats-grid,.field-row,.mood-grid,.entry-item{grid-template-columns:1fr}.entry-actions{justify-content:flex-end}.mood-temperature{grid-template-columns:1fr}.temperature-ring{width:108px}.hero-actions,.button-row{flex-direction:column}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
