:root{color:#2b2522;background:#f6f1e9;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f6f1e9;--surface: #fffaf3;--surface-strong: #ffffff;--text: #2b2522;--muted: #756b64;--faint: #eee4d8;--line: #e2d6c8;--primary: #d84f67;--primary-strong: #a82e46;--accent: #227f78;--gold: #c77b2d;--ink: #3d4c74;--danger: #c54646;--shadow: 0 24px 70px rgba(55, 39, 30, .12);--shadow-soft: 0 12px 34px rgba(55, 39, 30, .08);--focus: 0 0 0 4px rgba(216, 79, 103, .14);--radius: 8px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);background:linear-gradient(180deg,#fbf7f0,#f6f1e9 48%,#eef6f2),repeating-linear-gradient(90deg,rgba(255,255,255,.28) 0 1px,transparent 1px 72px)}button,input,textarea,select{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.7}img{display:block;max-width:100%}.theme-mint{--primary: #2c9a8b;--primary-strong: #157165;--accent: #d98b35}.theme-sun{--primary: #d98b35;--primary-strong: #af6518;--accent: #2c9a8b}.theme-ink{--primary: #485a88;--primary-strong: #31416e;--accent: #d9576b}.onboarding{display:grid;grid-template-columns:minmax(360px,500px) minmax(0,1fr);gap:28px;min-height:100vh;padding:32px;background:linear-gradient(115deg,rgba(216,79,103,.12),transparent 34%),linear-gradient(320deg,rgba(34,127,120,.13),transparent 44%),var(--bg)}.auth-panel,.panel{border:1px solid rgba(226,214,200,.86);border-radius:var(--radius);background:#fffaf3e6;box-shadow:var(--shadow)}.auth-panel{align-self:center;padding:32px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand-lockup,.sidebar-brand,.topbar,.topbar-actions,.panel-title,.panel-title>div,.button-row,.status,.toggle,.section-header,.member-pill,.wish-actions,.journal-head{display:flex;align-items:center}.brand-lockup{gap:16px;margin-bottom:26px}.brand-lockup p,.topbar p,.section-header p,.sidebar-brand span,.metric-card span,.memory-card span,.list-row span,.journal-card small,.letter-card p,.empty-state span,.share-card .copied{color:var(--muted)}.brand-lockup p,.topbar p,.section-header p{margin:0 0 4px}.brand-lockup h1,.section-header h1,.public-hero h1{margin:0;letter-spacing:0}.brand-lockup h1{max-width:7.8em;font-size:3.2rem;line-height:.96;text-wrap:balance;word-break:normal;line-break:loose}.logo-mark{display:grid;flex:0 0 auto;place-items:center;width:56px;height:56px;border-radius:50%;color:#fff;background:linear-gradient(135deg,var(--primary),#c67937);box-shadow:0 16px 34px #a82e463d}.logo-mark.small{width:38px;height:38px}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:6px;border-radius:var(--radius);background:#ebe0d4;margin-bottom:20px}.segmented button,.primary,.ghost,.text-button,.icon-button,.theme-picker button,.logout{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:var(--radius)}.segmented button{color:var(--muted);background:transparent}.segmented button.active{color:var(--text);background:#fff;box-shadow:var(--shadow-soft)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid label{display:grid;gap:7px;min-width:0;color:#4a403c;font-size:.92rem;font-weight:700}.form-grid input,.form-grid textarea,.form-grid select{width:100%;min-height:44px;border:1px solid rgba(207,191,174,.9);border-radius:var(--radius);padding:10px 12px;color:var(--text);background:#ffffffe0;outline:none;transition:border-color .16s ease,box-shadow .16s ease}.form-grid textarea{min-height:108px;resize:vertical}.form-grid input:focus,.form-grid textarea:focus,.form-grid select:focus{border-color:var(--primary);box-shadow:var(--focus)}.form-fields{min-width:0;margin:0;padding:0;border:0}.panel.form-grid>.form-fields{display:contents}.form-grid.form-fields{display:grid}.form-fields:disabled input,.form-fields:disabled textarea,.form-fields:disabled select{color:var(--muted);background:#efe7df7a}.read-only-hint,.read-only-inline{color:#7b4d18;background:#d98b351f}.read-only-hint{display:flex;align-items:center;gap:8px;padding:11px 12px;border:1px solid rgba(217,139,53,.34);border-radius:var(--radius);font-weight:800}.read-only-inline{margin:0 0 12px;padding:9px 10px;border-radius:var(--radius);font-weight:800}.span-2,.theme-picker,.panel-title{grid-column:1 / -1}.primary,.ghost{min-width:128px;padding:0 16px;font-weight:800;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease}.primary{color:#fff;background:linear-gradient(135deg,var(--primary),#c47a35);box-shadow:0 12px 24px #a82e4633}.primary:hover{transform:translateY(-1px);background:linear-gradient(135deg,var(--primary-strong),#a55c20);box-shadow:0 16px 30px #a82e463d}.ghost{color:var(--primary-strong);border:1px solid rgba(210,194,178,.95);background:#ffffffd1}.ghost:hover{transform:translateY(-1px);border-color:#d84f675c;box-shadow:var(--shadow-soft)}.ghost.light{color:#fff;border-color:#ffffff6b;background:#ffffff29;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.wide{width:100%}.auth-preview{position:relative;display:grid;align-content:end;justify-items:stretch;min-height:calc(100vh - 56px);overflow:hidden;border-radius:var(--radius)}.preview-photo{position:relative;justify-self:stretch;min-height:min(690px,calc(100vh - 132px));overflow:hidden;border-radius:var(--radius);border:1px solid rgba(255,255,255,.5);box-shadow:0 32px 80px #2c1f162e;background:url(/assets/couple-hero.png) center / cover no-repeat}.preview-photo:after{position:absolute;inset:0;content:"";background:linear-gradient(90deg,rgba(30,21,15,.52),rgba(30,21,15,.08) 52%,transparent)}.preview-photo img{width:100%;height:100%;min-height:min(690px,calc(100vh - 132px));object-fit:cover}.preview-strip{position:relative;z-index:1;justify-self:stretch;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:-70px 24px 0}.auth-preview .metric-card{min-height:116px;color:#fdf8f2;border-color:#ffffff2e;background:#231b179e;box-shadow:0 20px 44px #231b1738;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.auth-preview .metric-card span,.auth-preview .metric-card svg{color:#fdf8f2c2}.app-shell{display:grid;grid-template-columns:250px minmax(0,1fr);min-height:100vh;background:linear-gradient(115deg,rgba(216,79,103,.08),transparent 28%),linear-gradient(315deg,rgba(34,127,120,.11),transparent 38%),var(--bg)}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;gap:22px;height:100vh;padding:22px;color:#fffaf3db;border-right:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(61,76,116,.24),transparent 34%),#2d2623;box-shadow:18px 0 42px #2c1f1614}.sidebar-brand{gap:12px}.sidebar-brand strong,.sidebar-brand span{display:block;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-brand strong{color:#fffaf3}.sidebar nav{display:grid;gap:7px}.sidebar nav button,.logout{justify-content:flex-start;width:100%;padding:0 12px;color:#fffaf3a8;background:transparent}.sidebar nav button.active{color:#fffaf3;background:linear-gradient(135deg,#d84f6757,#c77b2d3d);box-shadow:inset 0 0 0 1px #ffffff14}.sidebar nav button:hover{color:#fffaf3;background:#fffaf314}.logout{margin-top:auto;color:#ffb0ae}.workspace{min-width:0;padding:28px 42px 46px}.topbar{justify-content:space-between;gap:16px;margin-bottom:22px}.topbar h2{margin:0;font-size:2rem;line-height:1.12;text-wrap:balance}.topbar p{color:var(--gold);font-size:.82rem;font-weight:900;letter-spacing:.03em}.topbar-actions{gap:10px}.member-pill{gap:8px;min-height:40px;padding:0 12px;color:#3d312c;border:1px solid rgba(210,194,178,.86);border-radius:999px;background:#ffffffc2;box-shadow:var(--shadow-soft)}.mobile-logout{display:none;color:var(--danger)}.demo-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;padding:12px 14px;border:1px solid rgba(217,139,53,.34);border-radius:var(--radius);color:#744512;background:linear-gradient(135deg,#c77b2d24,#ffffff8c)}.demo-banner>div,.form-actions,.row-actions,.action-stack,.letter-actions{display:flex;align-items:center;gap:8px}.demo-banner>div{min-width:0;font-weight:800}.demo-banner span{min-width:0}.icon-button{width:40px;height:40px;color:var(--text);border:1px solid rgba(210,194,178,.88);background:#ffffffd1;box-shadow:0 8px 20px #37271e0f;transition:transform .16s ease,border-color .16s ease,color .16s ease}.icon-button:hover{transform:translateY(-1px);color:var(--primary-strong);border-color:#d9576b59}.icon-button.danger:hover{color:var(--danger);border-color:#c5464659}.tab-stack{display:grid;gap:18px}.hero-dashboard{position:relative;display:grid;align-items:end;min-height:390px;overflow:hidden;border:1px solid rgba(255,255,255,.52);border-radius:var(--radius);color:#fff;background:url(/assets/couple-hero.png) center / cover no-repeat;box-shadow:0 30px 80px #37271e29}.hero-dashboard:after,.public-hero:after{position:absolute;inset:0;content:"";background:linear-gradient(90deg,#1e150fc7,#1e150f4d 48%,#1e150f0f),linear-gradient(0deg,rgba(30,21,15,.35),transparent 58%)}.hero-dashboard img,.public-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.hero-dashboard>div{position:relative;z-index:1;max-width:680px;padding:52px}.hero-dashboard p,.public-hero span{margin:0 0 8px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.hero-dashboard h1{margin:0 0 12px;font-size:5.6rem;line-height:.95;letter-spacing:0;text-shadow:0 16px 44px rgba(0,0,0,.28)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-card{position:relative;overflow:hidden;display:grid;gap:9px;min-height:128px;padding:18px;border:1px solid rgba(226,214,200,.86);border-radius:var(--radius);background:#fffaf3eb;box-shadow:var(--shadow-soft)}.metric-card:before{position:absolute;inset:0 0 auto;height:3px;content:"";background:linear-gradient(90deg,var(--primary),var(--accent),var(--gold))}.metric-card svg{color:var(--primary)}.metric-card strong{font-size:2rem;line-height:1.05;white-space:nowrap}.two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.panel{min-width:0;padding:20px;box-shadow:var(--shadow-soft)}.panel-title{justify-content:space-between;gap:12px;margin-bottom:16px}.panel-title>div{gap:8px;min-width:0}.panel-title strong{min-width:0;overflow-wrap:anywhere}.panel-title svg,.section-header svg{color:var(--primary)}.text-button{min-height:32px;padding:0 10px;color:var(--primary-strong);background:#d84f671a}.section-header{gap:12px;min-width:0}.section-header h1{font-size:2.5rem;line-height:1.08;text-wrap:balance}.next-card,.mood-line,.list-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.next-card{padding:18px;border-radius:var(--radius);background:linear-gradient(135deg,#d84f671f,#ffffff8c),#ffffff9e}.next-card span,.next-card strong{grid-column:1}.next-card b{grid-column:2;grid-row:1 / span 2;color:var(--primary-strong);font-size:1.5rem}.mood-line{padding:16px;border:1px solid rgba(226,214,200,.86);border-radius:var(--radius);background:#ffffffc7}.mood-line div{display:grid;gap:6px}.mood-line b{display:grid;place-items:center;width:54px;height:54px;border-radius:50%;color:#fff;background:linear-gradient(135deg,var(--accent),var(--ink))}.memory-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.memory-card{position:relative;overflow:hidden;border:1px solid rgba(226,214,200,.88);border-radius:var(--radius);background:#ffffffdb;box-shadow:var(--shadow-soft);transition:transform .16s ease,box-shadow .16s ease}.memory-card:hover{transform:translateY(-2px);box-shadow:0 18px 42px #37271e1f}.memory-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;background:url(/assets/couple-hero.png) center / cover no-repeat}.memory-card>div:not(.card-action){display:grid;gap:8px;padding:16px}.memory-card strong{font-size:1.05rem}.memory-card p{min-height:44px;margin:0;color:#4c423e;line-height:1.55}.card-action{position:absolute;top:10px;right:10px}.action-stack{flex-direction:column}.tag-row{display:flex;flex-wrap:wrap;gap:6px}.tag-row small{padding:4px 8px;border-radius:999px;color:var(--primary-strong);background:#d84f671a}.list-panel,.journal-list,.letter-grid,.wish-board,.mood-history,.public-anniversaries,.public-moods{display:grid;gap:12px}.list-row{grid-template-columns:auto 1fr auto;padding:14px;border:1px solid rgba(226,214,200,.86);border-radius:var(--radius);background:#ffffffc7;box-shadow:0 8px 22px #37271e0d}.list-row>div:nth-child(2){display:grid;gap:5px}.date-badge{display:grid;place-items:center;width:72px;height:72px;border-radius:var(--radius);color:var(--primary-strong);background:linear-gradient(180deg,#d84f6721,#c77b2d1a)}.date-badge span,.date-badge b{color:inherit}.wish-board{grid-template-columns:repeat(3,minmax(0,1fr))}.wish-card{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:112px;padding:16px;border:1px solid rgba(226,214,200,.86);border-radius:var(--radius);background:#fffc;box-shadow:0 8px 22px #37271e0d}.wish-card>div:first-child{display:grid;gap:8px}.wish-card span{color:var(--gold);font-weight:800}.wish-card.done{color:var(--muted);background:#227f781c}.wish-card.done strong{text-decoration:line-through}.journal-list{grid-template-columns:repeat(2,minmax(0,1fr))}.journal-card,.letter-card{padding:18px;border:1px solid rgba(226,214,200,.86);border-radius:var(--radius);background:#ffffffd1;box-shadow:0 8px 22px #37271e0d}.journal-head{justify-content:space-between;gap:12px}.journal-head>div{display:grid;gap:5px}.journal-head span{color:var(--primary);font-weight:800}.journal-card p{color:#443936;line-height:1.75}.form-actions{flex-wrap:wrap}.mood-form .form-grid{margin-bottom:12px}.range-value{color:var(--primary-strong);font-weight:900}.mood-history{margin-top:14px}.mood-chip,.public-anniversary{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:#fff}.mood-chip>div:first-child,.public-anniversary>div:last-child{display:grid;gap:5px;min-width:0}.mood-chip p{margin:0;color:#443936;line-height:1.55}.mood-chip span,.public-anniversary span{color:var(--muted)}.letter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.letter-card{position:relative;display:grid;gap:10px;min-height:210px;padding-bottom:66px}.letter-card h3,.letter-card p{margin:0}.letter-stamp{display:inline-flex;align-items:center;gap:7px;width:fit-content;padding:7px 10px;border-radius:999px;color:var(--primary-strong);background:#d84f671a;font-weight:800}.letter-actions{position:absolute;right:12px;bottom:12px}.letter-actions .icon-button{position:static}.share-card{display:grid;gap:14px}.code-box,.link-box{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;border:1px dashed rgba(216,79,103,.42);border-radius:var(--radius);background:linear-gradient(135deg,#d84f6717,#227f780f),#ffffff8a}.code-box span,.link-box span{min-width:0;overflow:hidden;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.code-box span{font-size:1.7rem}.toggle-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}.toggle{gap:9px;min-height:40px;font-weight:800}.toggle input{position:absolute;opacity:0;pointer-events:none}.toggle span{position:relative;width:44px;height:24px;border-radius:999px;background:#d4c7b9;transition:background .16s ease}.toggle span:after{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;content:"";background:#fff;transition:transform .16s ease}.toggle input:checked+span{background:var(--primary)}.toggle input:checked+span:after{transform:translate(20px)}.toggle.disabled{color:var(--muted);cursor:not-allowed;opacity:.72}.toggle.disabled span{background:#d7cec6}.theme-picker{display:flex;flex-wrap:wrap;gap:8px;min-width:0;padding:0;border:0}.theme-picker legend{width:100%;margin-bottom:4px;color:#4a403c;font-size:.92rem;font-weight:700}.theme-picker button{min-height:38px;padding:0 10px;color:var(--muted);border:1px solid rgba(210,194,178,.9);background:#ffffffd1}.theme-picker button.active{color:var(--text);border-color:var(--primary)}.theme-picker i{display:block;width:14px;height:14px;border-radius:50%}.status{gap:8px;margin-bottom:14px;padding:10px 12px;border-radius:var(--radius);font-weight:800}.status.success{color:#1c6e5c;background:#227f781f}.status.error{color:var(--danger);background:#c546461a}.empty-state{display:grid;place-items:center;gap:10px;min-height:168px;border:1px dashed rgba(207,191,174,.9);border-radius:var(--radius);background:#ffffff85}.public-page{min-height:100vh;background:linear-gradient(180deg,#f7f0e8,#f6f1e9 54%,#eef6f2),var(--bg)}.public-hero{position:relative;display:grid;align-items:end;min-height:78vh;overflow:hidden;color:#fff;background:url(/assets/couple-hero.png) center / cover no-repeat}.public-hero>div{position:relative;z-index:1;max-width:780px;padding:72px}.public-hero h1{margin-bottom:14px;font-size:5.6rem;line-height:.96;text-wrap:balance;text-shadow:0 16px 44px rgba(0,0,0,.3)}.public-hero p{max-width:620px;margin:0 0 24px;font-size:1.22rem;line-height:1.6}.public-content{display:grid;gap:18px;width:min(1160px,calc(100% - 32px));margin:-54px auto 0;padding-bottom:48px;position:relative;z-index:2}.timeline{display:grid;gap:12px}.timeline article{display:grid;gap:5px;padding-left:16px;border-left:3px solid var(--primary)}.timeline time{color:var(--muted);font-weight:800}.public-wishes,.public-anniversaries,.public-moods{grid-template-columns:repeat(2,minmax(0,1fr))}.error-page,.loading-page{display:grid;place-items:center;padding:24px}.error-page .panel,.loading-page{text-align:center}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1040px){.metric-grid,.memory-grid,.wish-board,.letter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.app-shell{grid-template-columns:88px minmax(0,1fr)}.sidebar{padding:16px}.sidebar-brand div:last-child,.sidebar nav button,.logout{font-size:0}.sidebar nav button,.logout{justify-content:center;padding:0}.workspace{padding:24px 28px 42px}.hero-dashboard h1,.public-hero h1{font-size:4rem}}@media(max-width:820px){.onboarding,.app-shell,.two-column,.journal-list{grid-template-columns:1fr}.onboarding{padding:14px;gap:18px}.auth-preview{min-height:auto}.preview-photo,.preview-photo img{min-height:340px}.preview-strip{display:none}.app-shell{padding-bottom:74px}.sidebar{position:fixed;z-index:10;inset:auto 10px 10px;display:block;height:62px;padding:8px;overflow-x:auto;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);background:#2d2623f0;box-shadow:0 18px 48px #2d262338}.sidebar-brand,.logout{display:none}.sidebar nav{display:flex;min-width:max-content;gap:6px}.sidebar nav button{width:48px;height:46px}.topbar{align-items:flex-start}.topbar h2{font-size:1.55rem}.member-pill{display:none}.mobile-logout{display:inline-flex}.demo-banner{align-items:flex-start;flex-direction:column}.section-header h1{font-size:2rem}.hero-dashboard{min-height:330px}.hero-dashboard>div,.public-hero>div{padding:30px}.hero-dashboard h1{font-size:3rem}.public-hero{min-height:68vh}.public-hero h1{font-size:2.65rem}.public-hero p{font-size:1rem}}@media(max-width:620px){.form-grid,.metric-grid,.memory-grid,.wish-board,.letter-grid,.public-wishes,.public-anniversaries,.public-moods,.toggle-grid,.preview-strip{grid-template-columns:1fr}.workspace{padding:18px 14px 92px}.auth-panel,.panel{padding:14px}.brand-lockup{align-items:flex-start;gap:12px}.brand-lockup h1{max-width:8.4em;font-size:2.05rem}.brand-lockup p{font-size:.9rem}.logo-mark{width:50px;height:50px}.hero-dashboard{min-height:300px}.hero-dashboard h1{font-size:2.55rem}.metric-card{min-height:112px}.metric-card strong{font-size:1.5rem}.metric-grid{grid-template-columns:repeat(4,minmax(132px,1fr));overflow-x:auto;padding-bottom:4px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.metric-grid .metric-card{scroll-snap-align:start}.list-row{grid-template-columns:auto 1fr}.list-row .row-actions{grid-column:1 / -1;width:100%}.list-row .icon-button,.row-actions,.letter-actions{width:100%}.row-actions .icon-button,.letter-actions .icon-button{flex:1}.code-box,.link-box{grid-template-columns:1fr}.public-content{width:min(100% - 24px,1160px);margin-top:-32px}.public-hero>div{padding-bottom:32px}.code-box .icon-button,.link-box .icon-button{width:100%}}
