@import "https://fonts.googleapis.com/css2?family=Prompt:wght@300;400;500;600;700&display=swap";:root{--gold:#d4a843;--gold-light:#f5e6c8;--gold-dark:#b8912e;--bg:#fafafa;--bg-card:#fff;--text:#1a1a1a;--text-secondary:#6b7280;--text-gold:#c49a2a;--border:#e5e7eb;--shadow:0 2px 12px #00000014;--shadow-lg:0 8px 32px #0000001f;--radius:14px;--radius-sm:10px;--radius-full:9999px;--transition:all .25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Prompt,sans-serif;overflow-x:hidden}#root{background:var(--bg);max-width:480px;min-height:100dvh;margin:0 auto;position:relative}.app-header{background:var(--bg);z-index:50;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex;position:sticky;top:0}.app-header h1{font-size:1.6rem;font-weight:700}.btn-add{background:var(--gold);color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:.95rem;font-weight:600;display:flex;box-shadow:0 4px 14px #d4a84359}.btn-add:active{transform:scale(.96)}.search-bar{align-items:center;gap:10px;margin-bottom:8px;padding:0 20px;display:flex}.search-input-wrap{border-radius:var(--radius-full);background:#f3f4f6;flex:1;align-items:center;gap:8px;padding:10px 16px;display:flex}.search-input-wrap svg{color:#9ca3af;flex-shrink:0}.search-input-wrap input{width:100%;color:var(--text);background:0 0;border:none;outline:none;font-family:inherit;font-size:.9rem}.search-input-wrap input::placeholder{color:#9ca3af}.btn-filter{border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;width:44px;height:44px;transition:var(--transition);background:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.btn-filter.active{border-color:var(--gold);background:var(--gold-light)}.activity-list{padding:4px 20px 100px}.activity-item{border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition);align-items:center;gap:14px;padding:14px 0;animation:.35s both fadeInUp;display:flex}.activity-item:active{background:#f9f9f9}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.activity-thumb{border-radius:var(--radius-sm);object-fit:cover;background:#e5e7eb;flex-shrink:0;width:72px;height:72px}.activity-thumb-placeholder{border-radius:var(--radius-sm);color:#bbb;background:#e5e7eb;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.activity-info{flex:1;min-width:0}.activity-date{color:var(--text);font-size:.95rem;font-weight:600}.activity-age{color:var(--text-secondary);margin-top:2px;font-size:.82rem}.activity-category{background:var(--gold-light);color:var(--gold-dark);border-radius:var(--radius-full);margin-top:4px;padding:2px 10px;font-size:.72rem;font-weight:500;display:inline-block}.btn-more{cursor:pointer;width:36px;height:36px;transition:var(--transition);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.btn-more:active{background:#f0f0f0}.popup-menu{border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:100;background:#fff;min-width:140px;padding:6px 0;animation:.2s popIn;position:absolute;right:20px}@keyframes popIn{0%{opacity:0;transform:scale(.9)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}.popup-menu button{cursor:pointer;width:100%;transition:var(--transition);background:0 0;border:none;align-items:center;gap:10px;padding:12px 18px;font-family:inherit;font-size:.9rem;display:flex}.popup-menu button:active{background:#f5f5f5}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:90dvh;padding:0 24px 24px;animation:.3s cubic-bezier(.22,1,.36,1) slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{background:#d1d5db;border-radius:2px;width:40px;height:4px;margin:12px auto 16px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{font-size:1.15rem;font-weight:600}.modal-close{border:1.5px solid var(--border);cursor:pointer;color:#666;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1rem;display:flex}.form-group{margin-bottom:20px}.form-label{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.9rem;font-weight:500;display:flex}.form-label .required{color:var(--text-gold);font-size:.8rem;font-weight:400}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;transition:var(--transition);background:#f9fafb;outline:none;padding:12px 16px;font-family:inherit;font-size:.9rem}.form-input:focus{border-color:var(--gold);background:#fff}.form-input-icon{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:#f9fafb;align-items:center;gap:10px;padding:12px 16px;display:flex}.form-input-icon span{color:var(--text-secondary);font-size:.9rem}textarea.form-input{resize:vertical;min-height:120px}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{border-radius:var(--radius-full);border:1.5px solid var(--border);cursor:pointer;transition:var(--transition);background:#fff;padding:8px 18px;font-family:inherit;font-size:.85rem;font-weight:400}.chip.active{border-color:var(--gold);background:var(--gold-light);color:var(--gold-dark);font-weight:500}.image-upload-area{flex-wrap:wrap;gap:10px;display:flex}.image-upload-btn{border:2px dashed var(--border);border-radius:var(--radius-sm);cursor:pointer;width:80px;height:80px;transition:var(--transition);color:#9ca3af;background:#f9fafb;flex-direction:column;justify-content:center;align-items:center;font-size:.7rem;display:flex}.image-upload-btn svg{margin-bottom:2px;font-size:24px}.image-preview{border-radius:var(--radius-sm);width:80px;height:80px;position:relative;overflow:hidden}.image-preview img{object-fit:cover;width:100%;height:100%}.image-preview .remove-img{color:#fff;cursor:pointer;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;display:flex;position:absolute;top:4px;right:4px}.btn-row{gap:12px;margin-top:24px;display:flex}.btn-cancel{border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;transition:var(--transition);background:#fff;flex:1;padding:14px;font-family:inherit;font-size:.95rem;font-weight:500}.btn-submit{border-radius:var(--radius-sm);background:var(--gold);color:#fff;cursor:pointer;transition:var(--transition);border:none;flex:1;padding:14px;font-family:inherit;font-size:.95rem;font-weight:600;box-shadow:0 4px 14px #d4a8434d}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-submit:not(:disabled):active{transform:scale(.97)}.detail-page{background:#fff;min-height:100dvh}.detail-nav{justify-content:center;align-items:center;padding:16px 20px;display:flex;position:relative}.detail-nav h2{font-size:1.05rem;font-weight:600}.btn-back{cursor:pointer;width:40px;height:40px;transition:var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;left:16px}.btn-back:active{background:#f0f0f0}.detail-images{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;width:100%;display:flex;overflow-x:auto}.detail-images img{object-fit:contain;scroll-snap-align:center;background:#f5f5f5;flex-shrink:0;width:100%;max-height:400px}.detail-body{padding:20px 24px}.detail-date{color:var(--text-gold);font-size:.95rem;font-weight:500}.detail-age{margin:6px 0 20px;font-size:1.5rem;font-weight:700}.detail-note-label{color:var(--text-secondary);margin-bottom:8px;font-weight:500}.detail-note{border-radius:var(--radius-sm);border:1px solid var(--border);background:#f9fafb;min-height:80px;padding:16px;font-size:.9rem;line-height:1.6}.btn-edit-full{background:var(--gold);color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding:16px;font-family:inherit;font-size:1rem;font-weight:600;display:flex;box-shadow:0 4px 14px #d4a8434d}.btn-edit-full:active{transform:scale(.97)}.edit-page{background:#fff;min-height:100dvh}.edit-nav{justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.edit-nav button{cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.95rem;font-weight:500}.edit-nav .cancel-btn{color:var(--text-gold)}.edit-nav .submit-btn{color:var(--text-gold);font-weight:600}.edit-nav h2{font-size:1.05rem;font-weight:600}.edit-body{padding:8px 24px 40px}.filter-section{margin-bottom:24px}.filter-section-header{cursor:pointer;justify-content:space-between;align-items:center;padding:8px 0;font-size:.95rem;font-weight:600;display:flex}.filter-option{justify-content:space-between;align-items:center;padding:10px 0;font-size:.9rem;display:flex}.filter-option label{cursor:pointer;flex:1}.filter-checkbox{border:2px solid var(--border);appearance:none;cursor:pointer;width:22px;height:22px;transition:var(--transition);border-radius:4px;position:relative}.filter-checkbox:checked{background:var(--gold);border-color:var(--gold)}.filter-checkbox:checked:after{content:"✓";color:#fff;font-size:.8rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.filter-divider{background:var(--border);height:1px;margin:8px 0}.pin-page{background:linear-gradient(165deg,#fff8e7 0%,#fffcf5 40%,#fff 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:40px 24px;display:flex}.pin-logo{margin-bottom:8px;font-size:3rem}.pin-title{margin-bottom:6px;font-size:1.4rem;font-weight:700}.pin-subtitle{color:var(--text-secondary);margin-bottom:40px;font-size:.9rem}.pin-dots{gap:16px;margin-bottom:36px;display:flex}.pin-dot{border:2px solid var(--gold);width:18px;height:18px;transition:var(--transition);border-radius:50%}.pin-dot.filled{background:var(--gold);transform:scale(1.1)}.pin-dot.error{background:#ef4444;border-color:#ef4444;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.pin-pad{grid-template-columns:repeat(3,1fr);gap:14px;width:100%;max-width:280px;display:grid}.pin-key{cursor:pointer;width:72px;height:72px;transition:var(--transition);background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;margin:0 auto;font-family:inherit;font-size:1.5rem;font-weight:500;display:flex;box-shadow:0 2px 8px #0000000f}.pin-key:active{background:var(--gold-light);transform:scale(.93)}.pin-key.empty{box-shadow:none;cursor:default;background:0 0}.pin-key.delete{font-size:1.2rem}.pin-error{color:#ef4444;min-height:20px;margin-top:16px;font-size:.85rem}.settings-page{background:var(--bg);min-height:100dvh}.settings-header{background:var(--bg);z-index:50;align-items:center;gap:12px;padding:16px 20px;display:flex;position:sticky;top:0}.settings-header h2{font-size:1.15rem;font-weight:600}.settings-section{margin-bottom:24px;padding:0 20px}.settings-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.8rem;font-weight:600}.settings-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;overflow:hidden}.settings-item{border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.settings-item:last-child{border-bottom:none}.settings-item:active{background:#f9f9f9}.settings-item-left{align-items:center;gap:12px;display:flex}.settings-item-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.settings-item-label{font-size:.92rem;font-weight:400}.settings-item-value{color:var(--text-secondary);font-size:.85rem}.settings-item-arrow{color:#ccc;font-size:.9rem}.bottom-nav{border-top:1px solid var(--border);z-index:100;width:100%;max-width:480px;padding-bottom:env(safe-area-inset-bottom,0);background:#fff;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 0 8px;font-family:inherit;font-size:.7rem;display:flex}.nav-item.active{color:var(--gold-dark)}.nav-item svg{font-size:1.3rem}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{opacity:.6;margin-bottom:16px;font-size:4rem}.empty-state-text{color:var(--text-secondary);font-size:.95rem}.toast{color:#fff;border-radius:var(--radius-full);z-index:500;box-shadow:var(--shadow-lg);background:#1f2937;padding:12px 24px;font-size:.85rem;animation:.3s toastIn;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.member-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.member-item:last-child{border-bottom:none}.member-info{align-items:center;gap:12px;display:flex}.member-avatar{background:var(--gold-light);width:40px;height:40px;color:var(--gold-dark);border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.member-role{color:var(--text-secondary);border-radius:var(--radius-full);background:#f3f4f6;padding:2px 8px;font-size:.75rem}.member-actions{gap:8px;display:flex}.member-actions button{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;transition:var(--transition);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;display:flex}::-webkit-scrollbar{width:0;height:0}.loading{color:var(--text-secondary);justify-content:center;align-items:center;padding:40px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.image-dots{justify-content:center;gap:6px;padding:10px 0;display:flex}.image-dot{width:8px;height:8px;transition:var(--transition);background:#d1d5db;border-radius:50%}.image-dot.active{background:var(--gold);border-radius:4px;width:20px}.full-overlay{z-index:300;background:#fff;max-width:480px;margin:0 auto;animation:.3s slideInRight;position:fixed;inset:0;overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.log-item{border-bottom:1px solid var(--border);padding:14px 18px}.log-item-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.log-member{font-size:.9rem;font-weight:600}.log-time{color:var(--text-secondary);font-size:.75rem}.log-action{border-radius:var(--radius-full);padding:2px 10px;font-size:.75rem;font-weight:500;display:inline-block}.log-action.add{color:#065f46;background:#d1fae5}.log-action.edit{color:#92400e;background:#fef3c7}.log-action.delete{color:#991b1b;background:#fee2e2}.log-detail{color:var(--text-secondary);margin-top:4px;font-size:.82rem}
