:root{--ink:#172023;--paper:#f6f3ed;--cream:#ede7dd;--sage:#63766d;--rose:#b87870;--wine:#653f42;--line:rgba(23,32,35,.13);--white:#fff;--shadow:0 24px 70px rgba(53,43,37,.11)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:var(--ink);background:var(--paper);font-family:"Noto Serif SC","Songti SC",Georgia,serif;line-height:1.7}a{color:inherit;text-decoration:none}button,input{font:inherit}main{min-height:72vh}.site-header{height:82px;display:flex;align-items:center;justify-content:space-between;gap:32px;padding:0 clamp(24px,5vw,84px);border-bottom:1px solid var(--line);background:rgba(246,243,237,.92);backdrop-filter:blur(14px);position:relative;z-index:5}.brand{display:flex;align-items:center;gap:12px;flex:0 0 auto;min-width:max-content;white-space:nowrap;font-weight:700;letter-spacing:.06em}.brand>span{display:block;white-space:nowrap;writing-mode:horizontal-tb}.brand-logo{width:44px;height:44px;flex:0 0 44px;object-fit:contain;display:block}.site-header nav{display:flex;gap:26px;align-items:center;flex:0 1 auto;font-family:system-ui,sans-serif;font-size:14px}.site-header nav a:hover{color:var(--rose)}.nav-login{border:1px solid var(--ink);padding:8px 17px;border-radius:99px}.nav-form{display:inline}.nav-form button{border:0;background:none;cursor:pointer;color:inherit;padding:0}.hero{min-height:650px;display:grid;grid-template-columns:1.2fr .8fr;gap:8vw;align-items:center;padding:80px clamp(24px,8vw,140px);overflow:hidden}.eyebrow{font:600 11px/1.4 system-ui,sans-serif;letter-spacing:.22em;color:var(--sage);text-transform:uppercase}.hero h1,.love-hero h1{font-size:clamp(48px,6.3vw,92px);line-height:1.08;letter-spacing:-.05em;margin:25px 0}.hero h1 em,.love-hero h1 em{font-weight:400;color:var(--rose)}.hero-lead{font-size:18px;max-width:650px;color:#58605f}.hero-actions{display:flex;gap:12px;margin-top:34px}.button{display:inline-flex;justify-content:center;align-items:center;padding:12px 24px;border-radius:99px;border:1px solid var(--ink);font:600 14px/1 system-ui,sans-serif;cursor:pointer}.button.primary{background:var(--ink);color:var(--white)}.button.ghost{background:transparent}.button.warm{background:var(--rose);border-color:var(--rose);color:white}.hero-card{min-height:430px;border-radius:240px 240px 26px 26px;background:#1c282a;color:white;display:flex;flex-direction:column;justify-content:flex-end;padding:50px;position:relative;box-shadow:var(--shadow);overflow:hidden}.moon{position:absolute;width:118px;height:118px;border-radius:50%;background:#e8d6b8;top:100px;left:50%;transform:translateX(-50%);box-shadow:0 0 60px rgba(232,214,184,.3)}.hero-card p{opacity:.6;font:12px system-ui;letter-spacing:.14em;text-transform:uppercase}.hero-card strong{font-size:25px;line-height:1.5}.hero-orbit{position:absolute;border:1px solid rgba(255,255,255,.14);border-radius:50%;left:50%;top:160px;transform:translate(-50%,-50%)}.orbit-one{width:260px;height:260px}.orbit-two{width:380px;height:380px}.section-pad{padding:75px clamp(24px,8vw,140px)}.section-heading{display:flex;justify-content:space-between;align-items:end;margin-bottom:35px}.section-heading h2,.split-feature h2,.panel h2{margin:8px 0;font-size:clamp(30px,3vw,48px);line-height:1.2}.section-heading>a,.panel-head>a{color:var(--rose);font:600 13px system-ui}.card-grid{display:grid;gap:22px}.card-grid.three{grid-template-columns:repeat(3,1fr)}.card-grid.two{grid-template-columns:repeat(2,1fr)}.content-card,.file-card,.panel{padding:32px;background:rgba(255,255,255,.55);border:1px solid var(--line);border-radius:18px}.content-card h2,.content-card h3{font-size:24px;line-height:1.35}.content-card p,.file-card p,.muted{color:#68706e}.content-card time,.file-card small,.memory-card time{font:12px system-ui;color:#8d8c86}.tag{display:inline-flex;padding:5px 10px;border-radius:99px;background:var(--cream);font:11px system-ui;color:var(--sage)}.empty>span{font-size:44px;color:var(--rose);opacity:.5}.split-feature{margin:35px clamp(24px,5vw,84px) 90px;padding:65px clamp(30px,6vw,90px);border-radius:28px;background:var(--wine);color:white;display:flex;justify-content:space-between;align-items:end}.split-feature p{max-width:650px;opacity:.72}.lock-pill{padding:10px 17px;border:1px solid rgba(255,255,255,.4);border-radius:99px}.page-head{padding:90px clamp(24px,12vw,210px) 65px;background:var(--cream)}.page-head h1{font-size:clamp(42px,5vw,72px);max-width:900px;line-height:1.18;margin:17px 0}.page-head>p:last-child{color:#68706e;font-size:18px}.metric-row{display:grid;grid-template-columns:repeat(3,1fr);margin:-26px clamp(24px,8vw,140px) 0;background:white;border-radius:18px;box-shadow:var(--shadow)}.metric-row div{padding:28px;text-align:center;border-right:1px solid var(--line)}.metric-row div:last-child{border:0}.metric-row strong{display:block;font-size:32px}.metric-row span{font:12px system-ui;color:#777}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:25px}.panel-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);margin-bottom:12px}.panel h2{font-size:25px}.list-row{display:flex;justify-content:space-between;gap:20px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}.list-row p{margin:3px 0;color:#777}.list-row time,.list-row>a{font:12px system-ui;color:var(--rose)}.article{max-width:800px;margin:0 auto;padding:100px 24px}.article h1{font-size:clamp(40px,6vw,70px);line-height:1.2}.article-lead{font-size:21px;color:#666;border-left:3px solid var(--rose);padding-left:22px}.article-body{font-size:18px;margin-top:55px}.file-card{display:grid;grid-template-columns:auto 1fr;gap:20px}.file-card>.button{grid-column:2;justify-self:start}.file-icon{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:var(--ink);color:white}.love-hero{min-height:620px;padding:100px clamp(24px,9vw,160px);display:flex;flex-direction:column;justify-content:center;background:radial-gradient(circle at 72% 35%,rgba(239,190,180,.55),transparent 26%),linear-gradient(135deg,#f5ede7,#e9dcd5);position:relative;overflow:hidden}.love-hero:after{content:"♡";position:absolute;right:8%;font-size:35vw;color:rgba(255,255,255,.3);line-height:1}.love-hero>*{position:relative;z-index:1}.love-hero h1{max-width:950px}.love-section{background:#f8f5f0}.anniversary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.anniversary-row article{padding:34px;border-top:1px solid var(--rose);background:white}.anniversary-row strong{font-size:60px;color:var(--rose);line-height:1}.anniversary-row span{margin-left:6px;color:#888}.memory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.memory-card{background:white;border-radius:160px 160px 14px 14px;overflow:hidden;box-shadow:0 15px 40px rgba(80,55,48,.08)}.memory-card img,.photo-placeholder{width:100%;aspect-ratio:4/5;object-fit:cover}.photo-placeholder{display:grid;place-items:center;background:linear-gradient(145deg,#dac6bc,#f0e5df);font-size:50px;color:white}.memory-card>div:last-child{padding:22px}.memory-card h3{margin:7px 0}.memory-card p{color:#777;font-size:14px}.love-bottom{display:grid;grid-template-columns:1fr 1fr;gap:24px;background:#eee2dc}.wish-row{display:flex;gap:12px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line)}.check{width:25px;height:25px;border-radius:50%;border:1px solid var(--rose);background:white;color:white;cursor:pointer}.check.done{background:var(--rose)}.strike{text-decoration:line-through;color:#999}.letter-panel blockquote{margin:20px 0;padding:20px;background:#f8f0eb;border-radius:10px;font-size:18px}.letter-panel cite{font:12px system-ui;color:#888}.login-wrap{min-height:75vh;display:grid;place-items:center;padding:60px 20px;background:radial-gradient(circle at 30% 20%,#ead6cd,transparent 30%)}.login-card{width:min(440px,100%);padding:46px;background:white;border-radius:24px;box-shadow:var(--shadow)}.login-card h1{font-size:42px;margin:10px 0}.stack-form{display:grid;gap:18px;margin-top:30px}.stack-form label{display:grid;gap:7px;font:13px system-ui;color:#666}.stack-form input{width:100%;padding:12px;border:1px solid var(--line);border-radius:9px}.form-error,.messages{color:#8c3333}.messages{position:fixed;z-index:10;top:90px;right:20px;background:white;padding:8px 22px;border-radius:10px;box-shadow:var(--shadow)}footer{display:flex;justify-content:space-between;padding:42px clamp(24px,5vw,84px);border-top:1px solid var(--line);font:12px system-ui;color:#777}
@media(max-width:900px){.site-header{height:auto;min-height:76px;align-items:flex-start;padding-top:18px;padding-bottom:18px}.site-header nav{gap:12px;flex-wrap:wrap;justify-content:flex-end}.hero{grid-template-columns:1fr;padding-top:55px}.hero-card{min-height:360px}.card-grid.three,.card-grid.two,.dashboard-grid,.love-bottom{grid-template-columns:1fr}.memory-grid{grid-template-columns:repeat(2,1fr)}.anniversary-row{grid-template-columns:1fr}.split-feature{align-items:flex-start;flex-direction:column;gap:20px}.metric-row{margin-top:25px}}
@media(max-width:580px){.brand>span:last-child{display:none}.site-header nav a{font-size:12px}.hero h1,.love-hero h1{font-size:45px}.hero{padding-left:22px;padding-right:22px}.hero-card{padding:32px}.section-heading{align-items:flex-start;gap:15px}.memory-grid{grid-template-columns:1fr}.metric-row{grid-template-columns:1fr}.metric-row div{border-right:0;border-bottom:1px solid var(--line)}footer{display:block}.file-card{grid-template-columns:1fr}.file-card>.button{grid-column:1}}
