:root{--sea:#1f6f78;--sea-deep:#13474d;--sand:#f4ece0;--foam:#eafaf7;--ink:#2a3d3a;--soft:#5c6b68;--gold:#d8a657;--shell:#fff;--paper:#fbf7ef;--rule:#e7ddc9;--tom:#1f6f78;--val:#c4727f;--font-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-hand:"Caveat",cursive}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}button,input,textarea{font-family:var(--font-ui)}body{font-family:var(--font-ui);color:var(--ink);background:var(--sand);line-height:1.6;-webkit-font-smoothing:antialiased}.app{max-width:720px;margin:0 auto;min-height:100vh}.topbar{position:sticky;top:0;z-index:40;background:linear-gradient(180deg,#3a9aa0,#1f6f78);color:#fff;padding:18px 22px;box-shadow:0 2px 16px #1f6f782e}.topbar h1{font-size:1.5rem;font-weight:800;letter-spacing:-.01em}.topbar .sub{font-size:.85rem;opacity:.9;font-weight:300}.countdown{margin-top:8px;font-size:.8rem;background:#ffffff29;display:inline-block;padding:4px 12px;border-radius:20px}.tabs{display:flex;gap:6px;padding:12px 16px;background:var(--foam);position:sticky;top:0;z-index:30;border-bottom:1px solid rgba(31,111,120,.1)}.tab{flex:1;text-align:center;padding:9px 6px;border-radius:12px;font-size:.85rem;font-weight:600;color:var(--soft);background:transparent;border:none;cursor:pointer}.tab.active{background:var(--sea);color:#fff}.section{padding:22px 18px}.label{letter-spacing:.22em;text-transform:uppercase;font-size:.68rem;color:var(--gold);font-weight:700;margin-bottom:10px}.entry{border-radius:14px;padding:14px 18px 16px;margin-bottom:12px;box-shadow:0 6px 22px #1f6f7814;border:1px solid rgba(31,111,120,.07);border-left:4px solid var(--tom);background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 28px,var(--rule) 28px 29px);background-position:0 40px}.entry.by-val{border-left-color:var(--val)}.entry .meta{font-family:var(--font-ui);display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.entry .who{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--tom)}.entry.by-val .who{color:var(--val)}.entry .date{font-size:.7rem;color:var(--soft)}.entry h3{font-family:var(--font-hand);font-size:1.6rem;line-height:1.2;color:var(--sea-deep);margin-bottom:2px}.entry p{font-family:var(--font-hand);font-size:1.4rem;line-height:1.45;color:var(--ink)}.entry .mood{font-size:1.1rem;margin-left:6px}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.photo{border-radius:14px;overflow:hidden;position:relative;aspect-ratio:1;background:#cfe7e6}.photo img{width:100%;height:100%;object-fit:cover;display:block}.photo .cap{position:absolute;left:0;bottom:0;width:100%;padding:8px 10px;color:#fff;font-family:var(--font-hand);font-size:1.1rem;line-height:1.2;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent)}.composer{border-radius:14px;padding:16px 18px;margin-bottom:18px;box-shadow:0 6px 22px #1f6f7814;border:1px solid var(--rule);background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 30px,var(--rule) 30px 31px);background-position:0 44px}.composer input[type=text],.composer textarea{width:100%;border:none;background:transparent;padding:2px;margin-bottom:8px;font-family:var(--font-hand);font-size:1.45rem;line-height:30px;color:var(--ink);caret-color:var(--sea)}.composer input[type=text]:focus,.composer textarea:focus{outline:none}.composer textarea{min-height:90px;resize:vertical}.composer input[type=text]::placeholder,.composer textarea::placeholder{color:#a8a08e}.row{display:flex;gap:10px;align-items:center}.btn{background:var(--sea);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-size:.95rem;font-weight:600;cursor:pointer}.btn.ghost{background:transparent;color:var(--sea);border:1px solid var(--sea)}.who-chip{font-family:var(--font-ui);font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tom);margin-bottom:8px}.who-chip.val{color:var(--val)}.wish{display:flex;align-items:center;gap:10px;background:var(--paper);border-radius:12px;padding:10px 14px;margin-bottom:8px;border:1px solid rgba(31,111,120,.07)}.wish input{width:20px;height:20px}.wish .t{flex:1;font-family:var(--font-hand);font-size:1.3rem;line-height:1.3}.wish.done .t{text-decoration:line-through;color:var(--soft)}.wish .by{font-size:.7rem;color:var(--soft)}.empty{text-align:center;color:var(--soft);padding:30px 10px;font-size:.95rem}.gate{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;background:linear-gradient(180deg,#7ec8c8,#1f6f78);color:#fff}.gate h1{font-size:2.4rem;font-weight:800;margin-bottom:10px}.gate input{margin:18px 0;padding:12px 16px;border-radius:12px;border:none;font-size:1rem;text-align:center}.gate p{font-size:1rem;opacity:.92}.gate-btn{background:#fff;color:var(--sea);border:none;border-radius:12px;padding:12px 26px;font-size:1rem;font-weight:700;cursor:pointer}.gate-btn:disabled{opacity:.6;cursor:default}.gate-who{display:flex;gap:12px;margin-top:18px}.gate-err{margin-top:18px;background:#0000002e;padding:8px 16px;border-radius:10px;font-size:.9rem}.gate-links{margin-top:22px;display:flex;gap:10px;align-items:center;font-size:.82rem;opacity:.85}.gate-links button{background:none;border:none;color:#fff;text-decoration:underline;cursor:pointer;font-size:.82rem}.gate-note{margin-top:14px;font-size:.78rem;opacity:.8;max-width:300px}.gate-lang{position:absolute;top:16px;right:16px;display:flex;gap:6px}.gate-lang button{background:#ffffff29;border:none;color:#fff;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:700;cursor:pointer;opacity:.8}.gate-lang button.on{background:#fff;color:var(--sea);opacity:1}.gate input+input{margin-top:0}.daycard{border-radius:18px;margin-bottom:14px;overflow:hidden;position:relative;min-height:120px;box-shadow:0 6px 22px #1f6f781a;border:1px solid rgba(31,111,120,.08);transition:transform .15s ease}.daycard.ready{cursor:pointer}.daycard.ready:active{transform:scale(.98)}.dc-kicker{position:absolute;top:12px;left:16px;z-index:2;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:#ffd87a}.dc-cover{padding:34px 18px 20px;text-align:center;color:#fff;background:linear-gradient(135deg,#3a9aa0,#13474d);min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.daycard.locked .dc-cover{filter:blur(1px) brightness(.85)}.daycard.locked{opacity:.85}.dc-emoji{font-size:2rem;opacity:.92}.dc-teaser{font-family:var(--font-hand);font-size:1.5rem;line-height:1.3;max-width:320px}.dc-action{margin-top:6px;font-size:.78rem;font-weight:700;background:#ffffff2e;padding:6px 14px;border-radius:20px}.dc-real{background:var(--shell)}.dc-img{width:100%;height:170px;object-fit:cover;display:block}.dc-img.placeholder{background:linear-gradient(135deg,#7ec8c8,#1f6f78)}.dc-body{padding:14px 18px 18px;background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 28px,var(--rule) 28px 29px);background-position:0 46px}.dc-body h3{font-family:var(--font-hand);font-size:1.8rem;line-height:1.15;color:var(--sea-deep);margin-bottom:2px}.dc-body h3 span{font-size:1.2rem}.dc-body p{font-family:var(--font-hand);font-size:1.4rem;line-height:1.45;color:var(--ink)}@keyframes pop{0%{transform:scale(.96);opacity:.4}to{transform:scale(1);opacity:1}}.daycard.revealed .dc-real{animation:pop .35s ease}.dc-together{margin-top:10px;width:100%}.dc-together-hint{font-size:.8rem;opacity:.92;margin-bottom:8px}.dc-ready-row{display:flex;gap:8px}.dc-ready{flex:1;padding:9px;border-radius:10px;border:1px solid rgba(255,255,255,.5);background:#ffffff24;color:#fff;font-weight:700;font-size:.85rem;cursor:pointer}.dc-ready.on{background:#fff;color:var(--sea-deep);border-color:#fff}.dc-ready.val.on{color:var(--val)}.dc-ready:disabled{cursor:default}.dc-waiting{margin-top:8px;font-size:.76rem;opacity:.85;font-style:italic}.sealed{background:var(--paper);border-radius:18px;padding:18px;margin-bottom:16px;box-shadow:0 6px 22px #1f6f781a;border:1px solid rgba(216,166,87,.4)}.sealed-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sealed-occ{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--gold)}.sealed-lock{font-size:.78rem;color:var(--soft)}.sealed-prompt{font-family:var(--font-hand);font-size:1.6rem;font-weight:600;color:var(--sea-deep);margin-bottom:14px;line-height:1.25}.sealed-mine-done{background:var(--foam);border-radius:12px;padding:14px;color:var(--sea-deep);font-size:.95rem}.sealed-partner{margin-top:10px;font-size:.82rem;color:var(--soft)}.sealed-reveal{display:flex;flex-direction:column;gap:12px}.sealed-ans{background:var(--foam);border-radius:12px;padding:14px 16px;border-left:4px solid var(--sea)}.sealed-ans.by-val{border-left-color:var(--val)}.sealed-ans .who{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sea);margin-bottom:4px}.sealed-ans.by-val .who{color:var(--val)}.sealed-ans p{font-family:var(--font-hand);color:var(--ink);font-size:1.35rem;line-height:1.4;white-space:pre-wrap}.letter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px 16px;overflow-y:auto;background:linear-gradient(180deg,#3a9aa0eb,#13474df0)}.letter{background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 30px,var(--rule) 30px 31px);background-position:0 14px;border-radius:14px;max-width:380px;width:100%;padding:30px 28px 26px;margin:auto;box-shadow:0 24px 60px #00000047;position:relative}.letter .seal{position:absolute;top:-14px;left:50%;transform:translate(-50%);width:30px;height:30px;border-radius:50%;background:var(--gold);box-shadow:0 3px 10px #00000040;display:flex;align-items:center;justify-content:center;font-size:.9rem}.letter .to{font-family:var(--font-hand);font-size:1.7rem;color:var(--sea-deep);font-weight:700;margin-bottom:6px}.letter p{font-family:var(--font-hand);font-size:1.32rem;color:var(--ink);line-height:1.5;margin-bottom:12px}.letter .sign{font-family:var(--font-hand);font-size:1.32rem;color:var(--ink);margin-top:14px}.letter .sign .name{display:block;font-size:1.6rem;color:var(--tom);font-weight:700}.letter .dismiss{font-family:var(--font-ui);margin-top:20px;width:100%;background:var(--sea);color:#fff;border:none;border-radius:10px;padding:11px;font-size:.92rem;font-weight:600;cursor:pointer}.letter .reread{font-family:var(--font-ui);text-align:center;font-size:.72rem;color:var(--soft);margin-top:10px}.letter-link{display:block;margin:30px auto 0;background:none;border:none;color:var(--soft);font-size:.78rem;cursor:pointer;text-decoration:none;opacity:.75}.letter-link:hover{opacity:1;color:var(--sea)}.logout{position:absolute;top:14px;right:16px;background:#ffffff24;color:#fff;border:none;border-radius:16px;padding:5px 12px;font-size:.72rem;cursor:pointer;opacity:.85}.logout:hover{opacity:1}
