:root{--bg: #0f0f1a;--bg-card: #1a1a2e;--bg-input: #16213e;--text: #e0e0e0;--text-muted: #8888aa;--primary: #6c63ff;--primary-hover: #5a52e0;--danger: #e74c3c;--warning: #f39c12;--border: #2a2a4a;--nav-height: 60px}*{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;overscroll-behavior:none}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.app-content{flex:1;padding:16px;padding-bottom:calc(var(--nav-height) + 16px);max-width:600px;margin:0 auto;width:100%}.app-loading{display:flex;align-items:center;justify-content:center;height:100dvh;color:var(--text-muted);font-size:1.1rem}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:var(--bg-card);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--text-muted);font-size:.7rem;padding:6px 12px;transition:color .2s}.nav-tab.active{color:var(--primary)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px}.login-card{width:100%;max-width:360px;text-align:center}.login-card h1{font-size:2.5rem;color:var(--primary);margin-bottom:4px}.login-card h2{font-size:1.5rem;margin-bottom:8px}.subtitle{color:var(--text-muted);margin-bottom:32px}.btn{display:block;width:100%;padding:12px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-google{background:#fff;color:#333;font-weight:500;margin-bottom:16px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff;margin-top:24px}.btn-icon{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-back{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:4px;font-size:.9rem;margin-bottom:12px;padding:4px 0}.divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-muted);font-size:.85rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}input[type=email],input[type=text]{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text);font-size:1rem;margin-bottom:12px;outline:none}input:focus{border-color:var(--primary)}input[readonly]{opacity:.8;cursor:text}.error{color:var(--danger);margin-top:12px;font-size:.9rem}.otp-msg{color:var(--primary);font-size:.95rem;padding:16px 0}.page{padding-top:8px}.page h2{font-size:1.4rem;margin-bottom:16px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.page-header h2{margin-bottom:0}.header-actions{display:flex;gap:8px}.page-loading,.page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50dvh;color:var(--text-muted);text-align:center}.page-placeholder{color:var(--text-muted);padding:24px 0;text-align:center}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:400px}.modal-card h3{margin-bottom:16px;font-size:1.2rem}.modal-actions{display:flex;gap:8px;margin-top:8px}.modal-actions .btn{flex:1}.family-list{list-style:none}.family-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;cursor:pointer;position:relative;transition:border-color .2s}.family-card:hover{border-color:var(--primary)}.family-card h3{font-size:1.1rem;margin-bottom:4px}.family-card p{color:var(--text-muted);font-size:.9rem}.card-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1.2rem}.family-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:16px}.tab-bar{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:8px}.tab{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px 12px;font-size:.85rem;border-radius:6px;display:flex;align-items:center;gap:4px;transition:all .2s}.tab.active{background:var(--bg-input);color:var(--primary)}.members-list{display:flex;flex-direction:column;gap:8px}.member-card{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.member-info{flex:1;display:flex;align-items:center;justify-content:space-between}.member-name{font-size:.95rem;display:flex;align-items:center;gap:6px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;color:#fff;text-transform:capitalize}.badge-muted{background:var(--text-muted)!important}.relations-list{display:flex;flex-direction:column;gap:8px}.relation-card{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:.9rem}.rel-from,.rel-to{font-weight:500}.rel-type{color:var(--primary);font-size:.8rem;background:var(--bg-input);padding:2px 8px;border-radius:8px}.invite-panel{padding:8px 0}.invite-panel p{color:var(--text-muted);font-size:.9rem}.invite-result{display:flex;gap:8px;margin-top:12px}.invite-result input{flex:1;margin-bottom:0}.invite-result .btn{width:auto;padding:12px 20px;flex-shrink:0}.profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.profile-card p{margin-bottom:8px;font-size:.9rem;word-break:break-all}.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.media-thumb{aspect-ratio:1;background:var(--bg-card);border-radius:4px;overflow:hidden}.media-thumb{cursor:pointer}.thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-muted);padding:4px;text-align:center}.upload-bar{background:var(--primary);color:#fff;text-align:center;padding:8px;border-radius:8px;margin-bottom:12px;font-size:.9rem}.photo-view{border-radius:12px;overflow:hidden;margin-bottom:16px;background:var(--bg-card)}.photo-view img{width:100%;display:block}.photo-actions{margin-bottom:16px}.photo-meta{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.photo-meta h3{font-size:1rem;margin-bottom:12px}.meta-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:.85rem}.meta-row:last-child{border-bottom:none}.meta-label{color:var(--text-muted);display:flex;align-items:center;gap:4px}.meta-value{color:var(--text)}.share-group-list{display:flex;flex-direction:column;gap:8px}.share-group-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:12px;cursor:pointer;color:var(--text);font-size:.95rem;transition:border-color .2s}.share-group-item:hover{border-color:var(--primary)}.share-group-item:disabled{opacity:.6}.post-form{display:flex;gap:8px;margin-bottom:16px}.post-form input{flex:1;margin-bottom:0}.feed-list{display:flex;flex-direction:column;gap:12px}.feed-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.feed-card.pinned{border-color:var(--warning)}.pin-label{display:inline-block;font-size:.7rem;color:var(--warning);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.feed-body{font-size:.95rem;line-height:1.4;margin-bottom:8px}.feed-time{font-size:.75rem;color:var(--text-muted)}.feed-image{width:100%;border-radius:8px;margin-bottom:8px}.feed-share{padding:12px}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--text-muted);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.select-input,.date-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text);font-size:1rem;margin-bottom:12px;outline:none;appearance:none}.select-input:focus,.date-input:focus{border-color:var(--primary)}.section{margin-top:24px}.section-title{font-size:1rem;margin-bottom:12px;display:flex;align-items:center;gap:6px}.section-muted{color:var(--text-muted)}.event-card{display:flex;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:10px}.event-card.event-past{opacity:.5}.event-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:48px;background:var(--bg-input);border-radius:8px;padding:6px}.event-month{font-size:.65rem;text-transform:uppercase;color:var(--primary);letter-spacing:.5px}.event-day{font-size:1.3rem;font-weight:700;line-height:1}.event-info{flex:1;min-width:0}.event-title{font-weight:600;margin-bottom:4px}.event-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.event-group-name{font-size:.75rem;color:var(--text-muted)}.event-location,.event-time{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:4px;margin-top:2px}.group-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;transition:border-color .2s}.group-card:hover{border-color:var(--primary)}.consent-card{background:var(--bg-card);border:1px solid var(--warning);border-radius:10px;padding:12px;margin-bottom:8px}.consent-card p{font-size:.9rem;margin-bottom:8px}.consent-actions{display:flex;gap:8px}.btn-sm{padding:6px 16px;font-size:.85rem;width:auto}
