@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400;1,600&family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap";:root{--ink: #1a1510;--ink-60: rgba(26,21,16,.6);--ink-30: rgba(26,21,16,.3);--ink-10: rgba(26,21,16,.1);--cream: #f5f0e8;--cream-dark: #ede6d8;--terra: #c2714f;--terra-soft: #e8b4a0;--terra-pale: #fdf0ea;--sage: #6b7c5e;--sage-pale: #e8ede4;--gold: #c8a878;--gold-pale: #f5ede0;--paper: #faf7f0;--f-display: "Space Grotesk", -apple-system, sans-serif;--f-content: "Cormorant Garamond", Georgia, serif;--f-body: "DM Sans", -apple-system, sans-serif;--f-mono: "DM Mono", "Courier New", monospace;--s1: 4px;--s2: 8px;--s3: 12px;--s4: 16px;--s5: 20px;--s6: 24px;--s7: 32px;--s8: 40px;--s9: 56px;--r-sm: 6px;--r-md: 12px;--r-lg: 20px;--r-xl: 32px;--t-fast: .15s ease;--t-mid: .28s cubic-bezier(.4, 0, .2, 1);--t-slow: .45s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 4px rgba(26,21,16,.08), 0 0 1px rgba(26,21,16,.06);--shadow-md: 0 4px 16px rgba(26,21,16,.1), 0 1px 4px rgba(26,21,16,.06);--shadow-lg: 0 12px 40px rgba(26,21,16,.14), 0 2px 8px rgba(26,21,16,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--f-body);background:var(--cream);color:var(--ink);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}.screen{display:none;min-height:100dvh}.screen.active{display:flex;flex-direction:column}#screen-onboard{background:var(--ink);color:var(--cream);align-items:center;justify-content:flex-end;padding:env(safe-area-inset-top,20px) var(--s6) env(safe-area-inset-bottom,20px);padding-bottom:max(env(safe-area-inset-bottom,20px),var(--s7));position:relative;overflow:hidden}.onboard-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 70% 20%,rgba(194,113,79,.25) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 20% 80%,rgba(107,124,94,.2) 0%,transparent 60%),var(--ink)}.onboard-content{position:relative;z-index:1;width:100%;max-width:440px}.onboard-logo{display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s9)}.onboard-wordmark{font-family:var(--f-display);font-size:clamp(28px,6vw,36px);font-weight:400;letter-spacing:-.02em;line-height:1;color:var(--cream)}.onboard-tagline{font-size:13px;font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:#f5f0e880;margin-top:var(--s1);font-family:var(--f-mono)}.onboard-headline{font-family:var(--f-display);font-size:clamp(30px,8vw,48px);font-weight:400;line-height:1.15;letter-spacing:-.02em;margin-bottom:var(--s5)}.onboard-headline em{font-style:italic;color:var(--terra)}.onboard-body{font-size:15px;font-weight:300;line-height:1.7;color:#f5f0e8b3;margin-bottom:var(--s8);max-width:38ch}.onboard-steps{display:flex;flex-direction:column;gap:var(--s4);margin-bottom:var(--s8)}.onboard-step{display:flex;align-items:flex-start;gap:var(--s4)}.step-num{font-family:var(--f-mono);font-size:11px;color:var(--terra);min-width:20px;padding-top:3px;letter-spacing:.1em}.step-text{font-size:14px;font-weight:300;color:#f5f0e8bf;line-height:1.5}.step-text strong{font-weight:500;color:var(--cream)}.btn-primary{display:block;width:100%;background:var(--terra);color:var(--cream);border:none;border-radius:var(--r-md);padding:18px var(--s6);font-family:var(--f-body);font-size:15px;font-weight:500;letter-spacing:.02em;cursor:pointer;transition:background var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);-webkit-tap-highlight-color:transparent;min-height:56px}.btn-primary:hover{background:#b5634a;box-shadow:var(--shadow-md)}.btn-primary:active{transform:scale(.98)}.btn-secondary{display:block;width:100%;background:transparent;color:#f5f0e899;border:1px solid rgba(245,240,232,.2);border-radius:var(--r-md);padding:16px var(--s6);font-family:var(--f-body);font-size:14px;font-weight:400;letter-spacing:.02em;cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent;min-height:52px;margin-top:var(--s3)}.btn-secondary:hover{border-color:#f5f0e880;color:#f5f0e8e6}#screen-setup{background:var(--paper);padding:0}.setup-header{background:var(--ink);padding:max(env(safe-area-inset-top,20px),var(--s6)) var(--s6) var(--s7);color:var(--cream)}.setup-back{display:flex;align-items:center;gap:var(--s2);font-size:13px;color:#f5f0e899;cursor:pointer;margin-bottom:var(--s6);width:fit-content;background:none;border:none;-webkit-tap-highlight-color:transparent;transition:color var(--t-fast);font-family:var(--f-body)}.setup-back:hover{color:var(--cream)}.setup-title{font-family:var(--f-display);font-size:clamp(22px,5vw,28px);font-weight:400;line-height:1.25}.setup-subtitle{font-size:13px;font-weight:300;color:#f5f0e88c;margin-top:var(--s2);font-family:var(--f-mono);letter-spacing:.05em}.setup-body{flex:1;padding:var(--s7) var(--s6);overflow-y:auto}.setup-step{display:none}.setup-step.active{display:block;animation:fadeUp .3s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:var(--s6)}.form-label{display:block;font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-60);font-family:var(--f-mono);margin-bottom:var(--s2)}.form-input{display:block;width:100%;background:#fff;border:1.5px solid var(--ink-10);border-radius:var(--r-md);padding:14px var(--s5);font-family:var(--f-body);font-size:16px;color:var(--ink);transition:border-color var(--t-fast),box-shadow var(--t-fast);-webkit-appearance:none;min-height:52px}.form-input:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px #c2714f1f}.form-input::placeholder{color:var(--ink-30)}.color-picker{display:flex;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s3)}.color-swatch{width:44px;height:44px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.color-swatch.selected{border-color:var(--ink);transform:scale(1.1)}.setup-hint{font-size:13px;font-weight:300;color:var(--ink-60);line-height:1.6;margin-top:var(--s3);padding:var(--s4);background:var(--gold-pale);border-radius:var(--r-sm);border-left:2px solid var(--gold)}.progress-dots{display:flex;gap:var(--s2);justify-content:center;padding:var(--s5) var(--s6)}.progress-dot{width:6px;height:6px;border-radius:50%;background:var(--ink-10);transition:all var(--t-mid)}.progress-dot.active{background:var(--terra);width:20px;border-radius:3px}.progress-dot.done{background:var(--ink-30)}.setup-footer{padding:var(--s5) var(--s6) max(env(safe-area-inset-bottom,20px),var(--s6));background:var(--paper);border-top:1px solid var(--ink-10)}.btn-dark{display:block;width:100%;background:var(--ink);color:var(--cream);border:none;border-radius:var(--r-md);padding:18px var(--s6);font-family:var(--f-body);font-size:15px;font-weight:500;cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent;min-height:56px}.btn-dark:hover{background:#2a2520}.btn-dark:active{transform:scale(.98)}.btn-dark:disabled{opacity:.4;pointer-events:none}#screen-app{background:var(--paper);padding-bottom:max(env(safe-area-inset-bottom,0px),80px)}.app-topbar{position:sticky;top:0;z-index:100;background:#faf7f2eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--ink-10);padding:max(env(safe-area-inset-top,12px),12px) var(--s6) var(--s3);display:flex;align-items:center;justify-content:space-between}.topbar-wordmark{font-family:var(--f-display);font-size:20px;font-weight:400;letter-spacing:-.02em;color:var(--ink)}.topbar-actions{display:flex;gap:var(--s2)}.icon-btn{width:40px;height:40px;border-radius:50%;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-60);transition:background var(--t-fast),color var(--t-fast);-webkit-tap-highlight-color:transparent}.icon-btn:hover{background:var(--ink-10);color:var(--ink)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#faf7f2f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--ink-10);padding:var(--s2) var(--s4) max(env(safe-area-inset-bottom,0px),var(--s3));display:grid;grid-template-columns:repeat(4,1fr);max-width:600px;margin:0 auto}.nav-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--s2) var(--s2);border:none;background:none;cursor:pointer;border-radius:var(--r-sm);transition:all var(--t-fast);-webkit-tap-highlight-color:transparent;min-height:56px;justify-content:center}.nav-label{font-size:10px;font-weight:500;letter-spacing:.06em;color:var(--ink-30);font-family:var(--f-mono);transition:color var(--t-fast)}.nav-btn.active .nav-label{color:var(--terra)}.nav-icon{transition:all var(--t-fast)}.nav-btn.active .nav-icon{color:var(--terra)}.nav-btn:not(.active) .nav-icon{color:var(--ink-30)}.scroll-area{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.tab-view{display:none;padding:var(--s6) var(--s5);max-width:600px}.tab-view.active{display:block;animation:fadeUp .25s ease}.home-greeting{margin-bottom:var(--s7)}.greeting-date{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-30);margin-bottom:var(--s2)}.greeting-headline{font-family:var(--f-display);font-size:clamp(22px,5vw,28px);font-weight:400;line-height:1.25;letter-spacing:-.01em}.greeting-headline em{font-style:italic;color:var(--terra)}.prompt-card{background:var(--ink);border-radius:var(--r-xl);padding:var(--s7) var(--s6);color:var(--cream);margin-bottom:var(--s5);position:relative;overflow:hidden;cursor:pointer;transition:transform var(--t-mid),box-shadow var(--t-mid)}.prompt-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.prompt-card:active{transform:scale(.99)}.prompt-card-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 80% 0%,rgba(194,113,79,.2) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 10% 100%,rgba(107,124,94,.15) 0%,transparent 60%)}.prompt-card-eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);margin-bottom:var(--s4);display:flex;align-items:center;gap:var(--s3)}.pulse-dot{width:6px;height:6px;border-radius:50%;background:var(--terra);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.prompt-card-question{font-family:var(--f-content);font-size:clamp(20px,5.5vw,28px);font-weight:300;line-height:1.35;letter-spacing:-.01em;margin-bottom:var(--s5)}.prompt-card-question em{font-style:italic;color:var(--terra)}.prompt-card-meta{display:flex;align-items:center;justify-content:space-between}.prompt-card-participants{display:flex;gap:-4px}.participant-avatar{width:28px;height:28px;border-radius:50%;border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;font-family:var(--f-mono)}.participant-avatar:not(:first-child){margin-left:-8px}.prompt-card-cta{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:#f5f0e880;display:flex;align-items:center;gap:var(--s2)}.prompt-responded{background:var(--sage);border-radius:var(--r-sm);padding:3px var(--s2);font-size:10px;letter-spacing:.1em;color:#fff;font-family:var(--f-mono);text-transform:uppercase}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--s4);margin-top:var(--s6)}.section-title{font-family:var(--f-display);font-size:18px;font-weight:500;letter-spacing:-.01em}.section-link{font-size:12px;font-weight:400;color:var(--terra);font-family:var(--f-mono);letter-spacing:.05em;cursor:pointer;background:none;border:none;-webkit-tap-highlight-color:transparent;transition:opacity var(--t-fast)}.section-link:hover{opacity:.7}.circle-list{display:flex;flex-direction:column;gap:var(--s3)}.circle-card{background:#fff;border-radius:var(--r-lg);padding:var(--s5);display:flex;align-items:center;gap:var(--s4);cursor:pointer;transition:all var(--t-fast);box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent}.circle-card:hover{transform:translate(3px);box-shadow:var(--shadow-md)}.circle-avatar{width:52px;height:52px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:18px;font-weight:400;flex-shrink:0;color:#fff}.circle-info{flex:1;min-width:0}.circle-name{font-family:var(--f-display);font-size:16px;font-weight:500;letter-spacing:-.01em;margin-bottom:2px}.circle-last-response{font-size:12px;font-weight:300;color:var(--ink-60);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.circle-badge{width:10px;height:10px;border-radius:50%;background:var(--terra);flex-shrink:0}.moments-list{display:flex;flex-direction:column;gap:var(--s3)}.moment-card{background:#fff;border-radius:var(--r-lg);padding:var(--s5);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.moment-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.moment-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--s3)}.moment-author-row{display:flex;align-items:center;gap:var(--s2)}.moment-avatar-sm{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:500;font-family:var(--f-mono);color:#fff;flex-shrink:0}.moment-author{font-size:12px;font-weight:500;color:var(--ink-60)}.moment-via{font-size:12px;font-weight:300;color:var(--ink-30)}.moment-date{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;color:var(--ink-30)}.moment-type-badge{display:inline-flex;align-items:center;gap:var(--s1);background:var(--terra-pale);color:var(--terra);border-radius:4px;padding:2px var(--s2);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;font-family:var(--f-mono);margin-bottom:var(--s3)}.moment-type-badge.voice{background:var(--sage-pale);color:var(--sage)}.moment-type-badge.place{background:var(--gold-pale);color:var(--gold)}.moment-text{font-family:var(--f-content);font-size:18px;font-weight:300;line-height:1.5;color:var(--ink)}.moment-text.truncate{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.moment-voice-player{display:flex;align-items:center;gap:var(--s3);background:var(--sage-pale);border-radius:var(--r-sm);padding:var(--s3) var(--s4);margin-top:var(--s3)}.play-btn{width:36px;height:36px;border-radius:50%;background:var(--sage);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.play-btn:hover{background:#5a6b4e}.waveform{flex:1;height:28px;display:flex;align-items:center;gap:2px}.wave-bar{flex:1;background:var(--sage);border-radius:2px;opacity:.4;animation:wave-idle 1.5s ease-in-out infinite}.wave-bar:nth-child(odd){animation-delay:-.3s}.wave-bar:nth-child(3n){animation-delay:-.6s}@keyframes wave-idle{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.voice-duration{font-family:var(--f-mono);font-size:11px;color:var(--sage);flex-shrink:0}.moment-location{display:flex;align-items:center;gap:var(--s2);background:var(--gold-pale);border-radius:var(--r-sm);padding:var(--s3) var(--s4);margin-top:var(--s3);font-size:13px;font-weight:400;color:var(--gold)}.add-moment-btn{position:fixed;right:var(--s5);bottom:max(env(safe-area-inset-bottom,0px),80px);margin-bottom:var(--s4);width:60px;height:60px;border-radius:50%;background:var(--terra);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 20px #c2714f66;transition:all var(--t-mid);z-index:99;-webkit-tap-highlight-color:transparent}.add-moment-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px #c2714f80}.add-moment-btn:active{transform:scale(.95)}.prompt-this-week{background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--s6)}.prompt-week-header{background:var(--ink);padding:var(--s6);color:var(--cream);position:relative;overflow:hidden}.prompt-week-header:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 90% 10%,rgba(194,113,79,.2),transparent);pointer-events:none}.prompt-week-eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);margin-bottom:var(--s3)}.prompt-week-question{font-family:var(--f-content);font-size:clamp(22px,5.5vw,30px);font-weight:300;line-height:1.3;letter-spacing:-.01em}.prompt-week-question em{font-style:italic;color:var(--terra)}.prompt-edit-area{padding:var(--s5) var(--s5) var(--s2)}.prompt-edit-label{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-30);font-family:var(--f-mono);margin-bottom:var(--s2)}.prompt-edit-toggle{display:flex;align-items:center;gap:var(--s2);cursor:pointer;width:fit-content;-webkit-tap-highlight-color:transparent}.toggle-switch{width:36px;height:20px;border-radius:10px;background:var(--ink-10);position:relative;transition:background var(--t-fast);flex-shrink:0}.toggle-switch.on{background:var(--terra)}.toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--t-fast);box-shadow:var(--shadow-sm)}.toggle-switch.on .toggle-knob{transform:translate(16px)}.toggle-label{font-size:13px;font-weight:400;color:var(--ink-60)}.prompt-custom-input{display:none;margin-top:var(--s4)}.prompt-custom-input.visible{display:block}.textarea-input{display:block;width:100%;background:var(--cream);border:1.5px solid var(--ink-10);border-radius:var(--r-md);padding:var(--s4);font-family:var(--f-body);font-size:16px;font-weight:300;color:var(--ink);line-height:1.6;resize:none;min-height:100px;transition:border-color var(--t-fast)}.textarea-input:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px #c2714f1a}.response-section{background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm)}.response-section-header{padding:var(--s5) var(--s5) var(--s3);border-bottom:1px solid var(--ink-10);display:flex;align-items:center;justify-content:space-between}.response-section-title{font-family:var(--f-display);font-size:16px;font-weight:500}.response-count{font-family:var(--f-mono);font-size:11px;color:var(--ink-30);letter-spacing:.08em}.response-list{padding:var(--s4) var(--s5)}.response-item{padding:var(--s4) 0;border-bottom:1px solid var(--ink-10)}.response-item:last-child{border-bottom:none}.response-author-row{display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s3)}.response-author-name{font-size:13px;font-weight:500;color:var(--ink)}.response-author-date{font-family:var(--f-mono);font-size:10px;color:var(--ink-30);letter-spacing:.06em}.response-empty{padding:var(--s7) var(--s5);text-align:center;color:var(--ink-30);font-size:14px;font-weight:300;font-style:italic;font-family:var(--f-content);font-size:18px}.record-area{padding:var(--s5);border-top:1px solid var(--ink-10)}.record-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--s3);background:var(--sage);color:#fff;border:none;border-radius:var(--r-md);padding:16px var(--s5);font-family:var(--f-body);font-size:14px;font-weight:500;cursor:pointer;min-height:52px;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.record-btn:hover{background:#5a6b4e}.record-btn.recording{background:#c24f4f;animation:record-pulse 1s ease-in-out infinite}@keyframes record-pulse{0%,to{box-shadow:0 0 #c24f4f66}50%{box-shadow:0 0 0 8px #c24f4f00}}.circle-detail{display:none}.circle-detail.active{display:block;animation:fadeUp .25s ease}.add-circle-card{background:#fff;border-radius:var(--r-lg);border:1.5px dashed var(--ink-10);padding:var(--s5);display:flex;align-items:center;gap:var(--s4);cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.add-circle-card:hover{border-color:var(--terra)}.add-circle-icon{width:52px;height:52px;border-radius:var(--r-md);background:var(--terra-pale);display:flex;align-items:center;justify-content:center;color:var(--terra);flex-shrink:0}.add-circle-text .label{font-weight:500;font-size:15px;color:var(--terra)}.add-circle-text .sub{font-size:12px;font-weight:300;color:var(--ink-30);margin-top:2px}.map-placeholder{background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--s5)}.map-canvas{width:100%;height:220px;background:linear-gradient(135deg,var(--sage-pale) 0%,var(--gold-pale) 50%,var(--terra-pale) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.map-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(26,21,16,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(26,21,16,.06) 1px,transparent 1px);background-size:32px 32px}.map-pin{position:absolute;cursor:pointer;transition:transform var(--t-fast);-webkit-tap-highlight-color:transparent}.map-pin:hover{transform:scale(1.2) translateY(-2px)}.pin-dot{width:14px;height:14px;border-radius:50%;border:2.5px solid white;box-shadow:var(--shadow-md)}.pin-label{position:absolute;top:-28px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--cream);font-size:10px;font-family:var(--f-mono);letter-spacing:.06em;padding:3px var(--s2);border-radius:4px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--t-fast)}.map-pin:hover .pin-label{opacity:1}.map-legend{padding:var(--s4) var(--s5);border-top:1px solid var(--ink-10);display:flex;gap:var(--s4);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--s2);font-size:11px;font-weight:400;color:var(--ink-60);font-family:var(--f-mono)}.legend-dot{width:8px;height:8px;border-radius:50%}.almanac-year-header{text-align:center;margin-bottom:var(--s7)}.almanac-year{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-30);margin-bottom:var(--s2)}.almanac-headline{font-family:var(--f-display);font-size:clamp(28px,7vw,40px);font-weight:400;letter-spacing:-.02em;line-height:1.1}.almanac-headline em{font-style:italic;color:var(--terra)}.almanac-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3);margin-bottom:var(--s6)}.stat-card{background:#fff;border-radius:var(--r-md);padding:var(--s4);text-align:center;box-shadow:var(--shadow-sm)}.stat-num{font-family:var(--f-display);font-size:clamp(22px,5vw,28px);font-weight:400;line-height:1;margin-bottom:var(--s1)}.stat-label{font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-30)}.almanac-chapters{display:flex;flex-direction:column;gap:var(--s4)}.chapter-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.chapter-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.chapter-header{padding:var(--s5) var(--s5) var(--s4);display:flex;align-items:flex-start;gap:var(--s4);border-bottom:1px solid var(--ink-10)}.chapter-month-badge{background:var(--terra);color:#fff;border-radius:var(--r-sm);padding:var(--s1) var(--s3);font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;margin-top:3px}.chapter-title{font-family:var(--f-display);font-size:16px;font-weight:500;letter-spacing:-.01em;line-height:1.3}.chapter-subtitle{font-size:12px;font-weight:300;color:var(--ink-60);margin-top:2px}.chapter-preview{padding:var(--s4) var(--s5);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2)}.chapter-thumbnail{border-radius:var(--r-sm);aspect-ratio:1;overflow:hidden;background:var(--cream-dark);display:flex;align-items:center;justify-content:center}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#1a151000;pointer-events:none;transition:background var(--t-slow)}.sheet-overlay.visible{background:#1a151080;pointer-events:all}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:201;background:var(--paper);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:var(--s4) var(--s6) max(env(safe-area-inset-bottom,20px),var(--s7));transform:translateY(110%);transition:transform var(--t-slow);max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.bottom-sheet.open{transform:translateY(0)}.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--ink-10);margin:0 auto var(--s6)}.sheet-title{font-family:var(--f-display);font-size:22px;font-weight:400;letter-spacing:-.01em;margin-bottom:var(--s2)}.sheet-subtitle{font-size:13px;font-weight:300;color:var(--ink-60);line-height:1.6;margin-bottom:var(--s6)}.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3);margin-bottom:var(--s6)}.type-card{background:#fff;border-radius:var(--r-lg);padding:var(--s5);text-align:center;cursor:pointer;border:2px solid transparent;transition:all var(--t-fast);box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent}.type-card:hover{border-color:var(--terra)}.type-card.selected{border-color:var(--terra);background:var(--terra-pale)}.type-icon{width:44px;height:44px;margin:0 auto var(--s3);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}.type-label{font-size:14px;font-weight:500;margin-bottom:2px}.type-desc{font-size:11px;font-weight:300;color:var(--ink-60)}.circle-selector{display:flex;flex-direction:column;gap:var(--s2);margin-bottom:var(--s6)}.circle-selector-item{display:flex;align-items:center;gap:var(--s4);padding:var(--s4);background:#fff;border-radius:var(--r-md);cursor:pointer;border:2px solid transparent;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.circle-selector-item:hover{border-color:var(--ink-10)}.circle-selector-item.selected{border-color:var(--terra);background:var(--terra-pale)}.circle-selector-name{font-size:14px;font-weight:500}.circle-selector-sub{font-size:12px;font-weight:300;color:var(--ink-60)}.checkmark{width:22px;height:22px;border-radius:50%;border:2px solid var(--ink-10);margin-left:auto;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}.circle-selector-item.selected .checkmark{background:var(--terra);border-color:var(--terra)}.empty-state{text-align:center;padding:var(--s9) var(--s6);display:flex;flex-direction:column;align-items:center;gap:var(--s4)}.empty-icon{width:64px;height:64px;opacity:.3}.empty-title{font-family:var(--f-display);font-size:20px;font-weight:400;color:var(--ink-60)}.empty-body{font-size:14px;font-weight:300;color:var(--ink-30);line-height:1.7;max-width:30ch}.toast{position:fixed;top:max(env(safe-area-inset-top,20px),20px);left:50%;transform:translate(-50%) translateY(-80px);background:var(--ink);color:var(--cream);padding:var(--s3) var(--s6);border-radius:100px;font-size:13px;font-weight:400;box-shadow:var(--shadow-lg);z-index:300;transition:transform var(--t-mid);white-space:nowrap;pointer-events:none}.toast.show{transform:translate(-50%) translateY(0)}@media (min-width: 640px){.bottom-nav{left:50%;right:auto;transform:translate(-50%);min-width:400px}.tab-view{padding:var(--s7) var(--s7);margin:0 auto}.add-moment-btn{right:calc(50% - 300px + var(--s5))}.prompt-card{padding:var(--s8) var(--s7)}.prompt-card-question{font-size:26px}.almanac-stats{grid-template-columns:repeat(3,1fr);gap:var(--s4)}}@media (min-width: 900px){#screen-app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:auto 1fr;max-width:1200px;margin:0 auto;min-height:100dvh}.app-topbar{grid-column:1 / -1}.bottom-nav{position:static;grid-column:1;grid-row:2;flex-direction:column;border-top:none;border-right:1px solid var(--ink-10);padding:var(--s7) var(--s4);background:var(--paper);-webkit-backdrop-filter:none;backdrop-filter:none;align-items:flex-start;display:flex;transform:none;left:auto;right:auto;bottom:auto;min-width:unset}.bottom-nav{grid-template-columns:unset}.nav-btn{width:100%;flex-direction:row;justify-content:flex-start;gap:var(--s3);padding:var(--s3) var(--s4);min-height:48px;border-radius:var(--r-md)}.nav-label{font-size:13px;letter-spacing:.05em}.nav-btn.active{background:var(--terra-pale)}.scroll-area{grid-column:2;grid-row:2}.tab-view{max-width:720px}.add-moment-btn{position:fixed;right:var(--s7);bottom:var(--s7)}}.fade-in{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .4s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.stagger>*{animation:fadeUp .35s ease both}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.15s}.stagger>*:nth-child(4){animation-delay:.2s}.stagger>*:nth-child(5){animation-delay:.25s}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.mt1{margin-top:var(--s3)}.mt2{margin-top:var(--s5)}.mt3{margin-top:var(--s7)}#mapbox-container{width:100%;height:260px;border-radius:var(--r-xl) var(--r-xl) 0 0;overflow:hidden;position:relative}#mapbox-container .mapboxgl-canvas{border-radius:var(--r-xl) var(--r-xl) 0 0}.mapbox-token-prompt{width:100%;height:260px;background:linear-gradient(135deg,var(--cream-dark) 0%,var(--terra-pale) 60%,var(--gold-pale) 100%);border-radius:var(--r-xl) var(--r-xl) 0 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);padding:var(--s6);text-align:center}.mapbox-token-prompt svg{opacity:.4}.mapbox-token-prompt .prompt-title{font-family:var(--f-display);font-size:18px;font-weight:500;color:var(--ink)}.mapbox-token-prompt .prompt-body{font-size:13px;font-weight:300;color:var(--ink-60);line-height:1.6;max-width:30ch}.mapbox-token-prompt .prompt-code{font-family:var(--f-mono);font-size:11px;background:#1a151014;padding:var(--s2) var(--s3);border-radius:var(--r-sm);color:var(--ink);letter-spacing:.04em}.dd-marker{width:32px;height:32px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:3px solid white;box-shadow:0 2px 8px #00000040;cursor:pointer;transition:transform var(--t-fast)}.dd-marker:hover{transform:rotate(-45deg) scale(1.15)}.dd-marker-inner{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;transform:rotate(45deg);font-family:var(--f-mono)}.mapboxgl-popup-content{font-family:var(--f-body);border-radius:var(--r-md)!important;padding:var(--s4) var(--s5)!important;box-shadow:var(--shadow-lg)!important;background:var(--ink)!important;color:var(--cream)!important;max-width:200px}.mapboxgl-popup-tip{border-top-color:var(--ink)!important}.mapboxgl-popup-close-button{color:#f5f0e899!important;font-size:18px!important}.map-popup-name{font-weight:500;font-size:14px;margin-bottom:3px}.map-popup-note{font-size:12px;font-weight:300;opacity:.7}.map-popup-by{font-family:var(--f-mono);font-size:10px;opacity:.5;margin-top:4px;letter-spacing:.06em}.photo-capture-area{margin-bottom:var(--s5)}.photo-preview{width:100%;aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden;position:relative;background:var(--cream-dark);display:flex;align-items:center;justify-content:center}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-preview-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--s2);color:var(--ink-30)}.photo-preview-placeholder svg{opacity:.4}.photo-preview-placeholder span{font-size:12px;font-weight:300;font-family:var(--f-mono);letter-spacing:.06em}.photo-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3);margin-top:var(--s3)}.photo-action-btn{display:flex;align-items:center;justify-content:center;gap:var(--s2);padding:14px var(--s4);border-radius:var(--r-md);border:1.5px solid var(--ink-10);background:#fff;font-family:var(--f-body);font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent;min-height:48px}.photo-action-btn:hover{border-color:var(--terra);color:var(--terra)}.photo-action-btn.primary{background:var(--terra);border-color:var(--terra);color:#fff}.photo-action-btn.primary:hover{background:#b5634a}.moment-photo{width:100%;border-radius:var(--r-md);margin-top:var(--s3);overflow:hidden;aspect-ratio:4/3}.moment-photo img{width:100%;height:100%;object-fit:cover;display:block}.profile-avatar{position:relative;width:72px;height:72px;flex-shrink:0}.profile-avatar-img{width:72px;height:72px;border-radius:var(--r-lg);object-fit:cover;display:block}.profile-avatar-initials{width:72px;height:72px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:24px;font-weight:400;color:#fff}.profile-avatar-edit{position:absolute;bottom:-4px;right:-4px;width:24px;height:24px;border-radius:50%;background:var(--terra);color:#fff;border:2px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--t-fast);-webkit-tap-highlight-color:transparent}.profile-avatar-edit:hover{transform:scale(1.1)}.settings-section{margin-bottom:var(--s6)}.settings-section-title{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-30);margin-bottom:var(--s3)}.settings-row{background:#fff;border-radius:var(--r-md);padding:var(--s4) var(--s5);display:flex;align-items:center;gap:var(--s4);margin-bottom:var(--s2);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--t-fast);-webkit-tap-highlight-color:transparent}.settings-row:hover{box-shadow:var(--shadow-md)}.settings-row-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-row-label{font-size:14px;font-weight:500;flex:1}.settings-row-value{font-size:13px;font-weight:300;color:var(--ink-60);font-family:var(--f-mono)}.settings-row-arrow{color:var(--ink-30)}.settings-profile-header{display:flex;align-items:center;gap:var(--s5);background:#fff;border-radius:var(--r-xl);padding:var(--s5);margin-bottom:var(--s6);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--t-fast)}.settings-profile-header:hover{box-shadow:var(--shadow-md)}.settings-profile-info{flex:1}.settings-profile-name{font-family:var(--f-display);font-size:20px;font-weight:500;letter-spacing:-.01em}.settings-profile-couple{font-size:13px;font-weight:300;color:var(--ink-60);margin-top:2px}.settings-profile-sub{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;color:var(--terra);margin-top:var(--s1)}.token-input-row{display:flex;gap:var(--s2);align-items:center}.token-input-row .form-input{flex:1;font-size:13px;font-family:var(--f-mono)}.token-save-btn{padding:14px var(--s5);background:var(--terra);color:#fff;border:none;border-radius:var(--r-md);font-family:var(--f-body);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;min-height:52px;transition:background var(--t-fast);-webkit-tap-highlight-color:transparent}.token-save-btn:hover{background:#b5634a}.place-search-row{display:flex;gap:var(--s2);margin-bottom:var(--s4)}.place-search-row .form-input{flex:1}.geocode-btn{padding:14px var(--s4);background:var(--ink);color:#fff;border:none;border-radius:var(--r-md);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;min-height:52px;min-width:80px;font-family:var(--f-body);transition:background var(--t-fast);-webkit-tap-highlight-color:transparent}.geocode-btn:hover{background:#2a2520}
