@import"https://unpkg.com/leaflet@1.9.4/dist/leaflet.css";:root{--brand: #E8435A;--brand-light: #ff6b7f;--brand-dark: #c4293f;--bg: #fafafa;--card-bg: #ffffff;--text: #1a1a1a;--text-muted: #666;--radius: 16px;--shadow: 0 4px 20px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}.app-layout{min-height:100dvh;display:flex;flex-direction:column}.app-main{flex:1;padding:20px 16px 90px;max-width:600px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--card-bg);border-top:1px solid rgba(0,0,0,.06);display:flex;justify-content:space-around;align-items:center;padding:8px 0 calc(8px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--text-muted);font-size:10px;gap:2px;transition:color .2s,transform .2s}.nav-item.active{color:var(--brand)}.nav-icon{font-size:22px;transition:transform .2s}.nav-item.active .nav-icon{transform:scale(1.15)}.nav-icon.add-btn{width:40px;height:40px;background:var(--brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:300;box-shadow:0 4px 12px #e8435a66;margin-top:-10px}.nav-label{font-weight:500}.loading-screen{height:100dvh;display:flex;align-items:center;justify-content:center}.loading-heart{font-size:48px;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.login-page{height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff5f6,#ffe0e4);padding:20px}.login-card{background:var(--card-bg);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow-lg);max-width:360px;width:100%}.login-heart{font-size:56px;margin-bottom:16px}.login-card h1{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text)}.login-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:15px}.google-btn{display:inline-flex;align-items:center;gap:12px;padding:14px 28px;border:1px solid #ddd;border-radius:50px;background:#fff;font-size:15px;font-weight:500;cursor:pointer;transition:box-shadow .2s,border-color .2s}.google-btn:hover{box-shadow:0 2px 12px #0000001a;border-color:#bbb}.home-page{display:flex;flex-direction:column;align-items:center;padding-top:40px;gap:32px}.days-counter{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.days-heart{font-size:40px}.days-number{font-size:72px;font-weight:800;color:var(--brand);line-height:1;letter-spacing:-2px}.days-label{font-size:16px;color:var(--text-muted);font-weight:500}.today-memory-card{background:var(--card-bg);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);width:100%;max-width:400px}.memory-card-image img{width:100%;height:220px;object-fit:cover}.memory-card-info{padding:16px 20px}.memory-card-info h3{font-size:17px;margin-bottom:6px}.memory-card-location{color:var(--text-muted);font-size:13px}.memory-card-date{color:var(--text-muted);font-size:12px;margin-top:4px}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:15px}.memory-book-page h2{font-size:24px;margin-bottom:20px}.memory-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.memory-tile{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:1;cursor:pointer;box-shadow:var(--shadow)}.memory-tile img{width:100%;height:100%;object-fit:cover}.memory-tile-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px 10px 10px;background:linear-gradient(transparent,#0009);color:#fff;font-size:12px;font-weight:500}.memory-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.memory-modal{background:var(--card-bg);border-radius:var(--radius);overflow:hidden;max-width:420px;width:100%;position:relative;box-shadow:var(--shadow-lg)}.memory-modal img{width:100%;height:300px;object-fit:cover}.memory-modal-info{padding:20px}.memory-modal-info h3{font-size:18px;margin-bottom:8px}.memory-modal-location{color:var(--text-muted);font-size:14px}.memory-modal-date{color:var(--text-muted);font-size:13px;margin-top:4px}.modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.add-memory-page{padding-top:10px}.add-memory-page h2{font-size:24px;margin-bottom:20px}.add-memory-form{display:flex;flex-direction:column;gap:20px}.photo-picker{width:100%;aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;border:2px dashed #ddd;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#f9f9f9;transition:border-color .2s}.photo-picker:hover{border-color:var(--brand)}.photo-placeholder{text-align:center;color:var(--text-muted)}.photo-placeholder span{font-size:40px;display:block;margin-bottom:8px}.photo-preview{width:100%;height:100%;object-fit:cover}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.form-field input[type=text],.form-field input[type=date]{padding:14px 16px;border:1px solid #e0e0e0;border-radius:12px;font-size:15px;background:#fff;transition:border-color .2s,box-shadow .2s;outline:none}.form-field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #e8435a1a}.form-hint{display:block;margin-top:6px;font-size:.78rem;color:var(--muted, #888);line-height:1.35}.location-row{display:flex;gap:8px}.location-row input{flex:1;padding:14px 16px;border:1px solid #e0e0e0;border-radius:12px;font-size:15px;outline:none;transition:border-color .2s}.location-row input:focus{border-color:var(--brand)}.geo-btn{width:48px;height:48px;border-radius:12px;border:1px solid #e0e0e0;background:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.geo-btn:hover{background:#f5f5f5}.submit-btn{padding:16px;border:none;border-radius:12px;background:var(--brand);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s}.submit-btn:hover{background:var(--brand-dark)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.map-page{position:fixed;top:0;right:0;left:0;bottom:66px}.memory-map{width:100%;height:100%}.heart-icon-wrapper{background:none!important;border:none!important}.map-heart-pin{font-size:24px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));animation:bounce-in .4s ease-out}@keyframes bounce-in{0%{transform:scale(0) translateY(-10px)}60%{transform:scale(1.2) translateY(0)}to{transform:scale(1) translateY(0)}}.memory-popup img{width:100%;max-width:200px;border-radius:8px;margin-bottom:8px}.memory-popup strong{display:block;margin-bottom:4px}@media (min-width: 768px){.memory-grid{grid-template-columns:repeat(3,1fr)}}.onboarding-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff5f6,#ffe0e4);padding:20px}.onboarding-card{background:var(--card-bg);border-radius:var(--radius);padding:40px 28px;text-align:center;box-shadow:var(--shadow-lg);max-width:380px;width:100%}.onboarding-card h1{font-size:26px;margin-bottom:4px}.onboarding-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:15px}.onboarding-form{display:flex;flex-direction:column;align-items:center;gap:20px}.avatar-picker{width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid var(--brand);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;background:#f9f9f9}.avatar-preview{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:32px}.avatar-edit-badge{position:absolute;bottom:2px;right:2px;width:26px;height:26px;border-radius:50%;background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:12px}.onboarding-form .form-field{width:100%}.pairing-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff5f6,#ffe0e4);padding:20px}.pairing-card{background:var(--card-bg);border-radius:var(--radius);padding:40px 28px;text-align:center;box-shadow:var(--shadow-lg);max-width:400px;width:100%}.pairing-card h1{font-size:22px;margin-bottom:8px}.pairing-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:14px}.pairing-options{display:flex;flex-direction:column;gap:14px}.pairing-option-btn{display:flex;flex-direction:column;align-items:center;padding:20px;border:2px solid #eee;border-radius:14px;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s}.pairing-option-btn:hover{border-color:var(--brand);box-shadow:0 2px 12px #e8435a1a}.option-icon{font-size:28px;margin-bottom:8px}.option-text{font-size:16px;font-weight:600;color:var(--text)}.option-desc{font-size:13px;color:var(--text-muted);margin-top:4px}.code-display,.code-enter{display:flex;flex-direction:column;align-items:center;gap:12px}.code-instruction{font-size:14px;color:var(--text-muted)}.code-value{font-size:36px;font-weight:800;letter-spacing:6px;color:var(--brand);background:#fff0f2;padding:16px 28px;border-radius:12px}.code-expiry{font-size:12px;color:var(--text-muted)}.code-waiting{font-size:14px;color:var(--text-muted);animation:pulse 1.5s ease-in-out infinite}.code-input{text-align:center;font-size:24px!important;letter-spacing:4px;font-weight:700}.code-enter .form-field{width:100%}.pairing-error{color:#dc3545;font-size:13px;font-weight:500}.text-btn{background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:8px;margin-top:4px}.text-btn:hover{color:var(--brand)}.home-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.home-avatars{display:flex;align-items:center}.home-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid #fff;box-shadow:0 1px 4px #0000001f}.home-avatar-overlap{margin-left:-10px}.home-names{font-size:.95rem;font-weight:500;color:#444}.settings-page{padding:1.25rem;max-width:520px;margin:0 auto}.settings-page h2{margin:0 0 1.25rem}.settings-section{background:#fff;border-radius:16px;padding:1rem 1.1rem;margin-bottom:1rem;box-shadow:0 1px 6px #0000000d}.settings-section h3{margin:0 0 .75rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:#888;font-weight:600}.settings-row{display:flex;align-items:center;gap:.85rem}.settings-row-text{display:flex;flex-direction:column}.settings-row-text strong{font-size:1rem;color:#222}.settings-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.settings-muted{color:#888;font-size:.85rem;margin-top:2px}.settings-danger .text-btn{display:block;width:100%;text-align:left;padding:.6rem 0}.text-btn.danger{color:#d23a4d}.confirm-block{margin-top:.5rem;padding:.75rem;background:#fff5f5;border-radius:10px}.confirm-block p{margin:0 0 .75rem;font-size:.9rem;color:#6a2a32}.confirm-actions{display:flex;gap:.5rem;justify-content:flex-end}
