:root{color:#27201f;background:#fbf8f4;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: #fbf8f4;--surface: #fffdfa;--surface-strong: #ffffff;--text: #2d2725;--muted: #776d68;--faint: #efe7df;--line: #e7ded5;--primary: #d9576b;--primary-strong: #b8324b;--accent: #2c9a8b;--gold: #d98b35;--ink: #485a88;--danger: #c54646;--shadow: 0 18px 50px rgba(66, 45, 35, .12);--radius: 8px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}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:28px;background:linear-gradient(135deg,rgba(217,87,107,.12),transparent 32%),linear-gradient(315deg,rgba(44,154,139,.12),transparent 38%),var(--bg)}.auth-panel,.panel{border:1px solid var(--line);border-radius:var(--radius);background:#fffdfae0;box-shadow:var(--shadow)}.auth-panel{align-self:center;padding:28px}.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:24px}.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{font-size:clamp(2rem,6vw,4.1rem);line-height:1.02}.logo-mark{display:grid;flex:0 0 auto;place-items:center;width:56px;height:56px;border-radius:50%;color:#fff;background:var(--primary);box-shadow:0 14px 30px #d9576b40}.logo-mark.small{width:38px;height:38px}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:5px;border-radius:var(--radius);background:var(--faint);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:0 8px 20px #422d2314}.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 var(--line);border-radius:var(--radius);padding:10px 12px;color:var(--text);background:#fff;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:0 0 0 4px #d9576b1f}.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}.primary{color:#fff;background:var(--primary)}.primary:hover{background:var(--primary-strong)}.ghost{color:var(--primary-strong);border:1px solid var(--line);background:#fff}.ghost.light{color:#fff;border-color:#ffffff6b;background:#ffffff29;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.wide{width:100%}.auth-preview{display:grid;align-content:end;min-height:calc(100vh - 56px);overflow:hidden;border-radius:var(--radius)}.preview-photo{min-height:62vh;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow)}.preview-photo img{width:100%;height:100%;min-height:62vh;object-fit:cover}.preview-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}.app-shell{display:grid;grid-template-columns:250px minmax(0,1fr);min-height:100vh;background:linear-gradient(135deg,rgba(217,87,107,.1),transparent 28%),linear-gradient(315deg,rgba(44,154,139,.1),transparent 34%),var(--bg)}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;gap:22px;height:100vh;padding:22px;border-right:1px solid var(--line);background:#fffdfac7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.sidebar-brand{gap:12px}.sidebar-brand strong,.sidebar-brand span{display:block;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar nav{display:grid;gap:7px}.sidebar nav button,.logout{justify-content:flex-start;width:100%;padding:0 12px;color:var(--muted);background:transparent}.sidebar nav button.active{color:var(--primary-strong);background:#d9576b1f}.logout{margin-top:auto;color:var(--danger)}.workspace{min-width:0;padding:24px clamp(18px,4vw,42px) 42px}.topbar{justify-content:space-between;gap:16px;margin-bottom:18px}.topbar h2{margin:0;font-size:clamp(1.35rem,3vw,2.1rem)}.topbar-actions{gap:10px}.member-pill{gap:8px;min-height:40px;padding:0 12px;border:1px solid var(--line);border-radius:999px;background:#fff}.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:#7b4d18;background:#d98b351f}.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 var(--line);background:#fff}.icon-button:hover{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:340px;overflow:hidden;border-radius:var(--radius);color:#fff;box-shadow:var(--shadow)}.hero-dashboard:after,.public-hero:after{position:absolute;inset:0;content:"";background:linear-gradient(90deg,rgba(28,19,18,.72),rgba(28,19,18,.28),transparent)}.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:clamp(24px,6vw,52px)}.hero-dashboard p,.public-hero span{margin:0 0 8px;font-weight:900;text-transform:uppercase}.hero-dashboard h1{margin:0 0 12px;font-size:clamp(2.4rem,8vw,6.6rem);line-height:.95;letter-spacing:0}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-card{display:grid;gap:9px;min-height:128px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:#fffdfae6;box-shadow:0 10px 26px #422d2312}.metric-card svg{color:var(--primary)}.metric-card strong{font-size:clamp(1.3rem,3vw,2rem);line-height:1.05}.two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.panel{min-width:0;padding:18px}.panel-title{justify-content:space-between;gap:12px;margin-bottom:16px}.panel-title>div{gap:8px}.panel-title svg,.section-header svg{color:var(--primary)}.text-button{min-height:32px;padding:0 10px;color:var(--primary-strong);background:#d9576b1a}.section-header{gap:12px;min-width:0}.section-header h1{font-size:clamp(1.7rem,4vw,3.2rem)}.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:#d9576b1a}.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 var(--line);border-radius:var(--radius);background:#fff}.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:var(--accent)}.memory-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.memory-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:0 12px 28px #422d2314}.memory-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover}.memory-card>div:not(.card-action){display:grid;gap:8px;padding:14px}.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:#d9576b1a}.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 var(--line);border-radius:var(--radius);background:#fff}.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:#d9576b1a}.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 var(--line);border-radius:var(--radius);background:#fff}.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:#2c9a8b1a}.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 var(--line);border-radius:var(--radius);background:#fff}.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:#d9576b1a;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(217,87,107,.42);border-radius:var(--radius);background:#d9576b14}.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:#d7cec6;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 var(--line);background:#fff}.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:#2c9a8b1f}.status.error{color:var(--danger);background:#c546461a}.empty-state{display:grid;place-items:center;gap:10px;min-height:168px;border:1px dashed var(--line);border-radius:var(--radius);background:#ffffff8c}.public-page{min-height:100vh;background:var(--bg)}.public-hero{position:relative;display:grid;align-items:end;min-height:82vh;overflow:hidden;color:#fff}.public-hero>div{position:relative;z-index:1;max-width:780px;padding:clamp(28px,8vw,72px)}.public-hero h1{margin-bottom:14px;font-size:clamp(3rem,9vw,7rem);line-height:.96}.public-hero p{max-width:620px;margin:0 0 24px;font-size:clamp(1rem,2vw,1.35rem);line-height:1.6}.public-content{display:grid;gap:18px;width:min(1160px,calc(100% - 32px));margin:-44px 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}}@media(max-width:820px){.onboarding,.app-shell,.two-column,.journal-list{grid-template-columns:1fr}.onboarding{padding:14px}.auth-preview{min-height:auto}.preview-photo,.preview-photo img{min-height:320px}.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 var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.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}.member-pill{display:none}.mobile-logout{display:inline-flex}.demo-banner{align-items:flex-start;flex-direction:column}}@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}.hero-dashboard{min-height:300px}.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:calc(100% - 24px);margin-top:14px}.public-hero>div{padding-bottom:32px}.code-box .icon-button,.link-box .icon-button{width:100%}}
