*,:before,:after{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{color:#262626;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fafafa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}#root{background:#fff;flex-direction:column;max-width:430px;min-height:100svh;margin:0 auto;display:flex;position:relative}h1,h2,h3,h4,h5,h6,p{margin:0}.app-shell{flex-direction:column;min-height:100svh;display:flex}.app-content{flex:1;padding-bottom:64px;overflow-y:auto}.app-loading{justify-content:center;align-items:center;min-height:100svh;display:flex}.app-loading-logo{color:#262626;letter-spacing:-.5px;font-family:Georgia,Times New Roman,serif;font-size:2rem;font-weight:700}.screen-placeholder{color:#8e8e8e;justify-content:center;align-items:center;min-height:calc(100svh - 64px);font-size:1.1rem;display:flex}.join-screen{background:#fff;justify-content:center;align-items:center;min-height:100svh;padding:24px 16px;display:flex}.join-card{flex-direction:column;align-items:center;gap:0;width:100%;max-width:360px;display:flex}.join-logo{color:#262626;letter-spacing:-1px;margin-bottom:4px;font-family:Georgia,Times New Roman,serif;font-size:2.5rem;font-weight:700}.join-tagline{color:#8e8e8e;margin-bottom:28px;font-size:.9rem}.join-toggle{border:1px solid #dbdbdb;border-radius:10px;width:100%;margin-bottom:24px;display:flex;overflow:hidden}.toggle-btn{color:#8e8e8e;cursor:pointer;background:0 0;border:none;flex:1;padding:10px;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.toggle-btn.active{color:#fff;background:#262626}.join-form{flex-direction:column;gap:14px;width:100%;display:flex}.input-group{flex-direction:column;gap:5px;display:flex}.input-label{color:#262626;letter-spacing:.02em;font-size:.8rem;font-weight:600}.optional{color:#8e8e8e;font-weight:400}.input-field{color:#262626;appearance:none;background:#fafafa;border:1px solid #dbdbdb;border-radius:8px;outline:none;width:100%;padding:12px 14px;font-size:.95rem;transition:border-color .15s,background .15s}.input-field:focus{background:#fff;border-color:#a8a8a8}.input-file{color:#262626;padding:2px 0;font-size:.85rem}.join-error{color:#ed4956;text-align:center;padding:2px 0;font-size:.85rem}.join-btn{color:#fff;cursor:pointer;background:#0095f6;border:none;border-radius:8px;width:100%;margin-top:4px;padding:13px;font-size:.95rem;font-weight:600;transition:opacity .15s}.join-btn:disabled{opacity:.6;cursor:not-allowed}.join-btn:not(:disabled):active{opacity:.85}.join-switch{color:#8e8e8e;text-align:center;margin-top:20px;font-size:.85rem}.link-btn{color:#0095f6;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:600}.bottom-nav{z-index:100;background:#fff;border-top:1px solid #dbdbdb;align-items:stretch;width:100%;max-width:430px;height:64px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-tab{cursor:pointer;color:#8e8e8e;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;transition:color .15s;display:flex}.nav-tab--active{color:#262626}.nav-label{letter-spacing:.02em;font-size:.6rem;font-weight:500}.nav-tab--post{color:#262626}.post-btn-circle{color:#fff;background:#0095f6;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.nav-tab--post.nav-tab--active .post-btn-circle{background:#0077d4}.feed-screen{flex-direction:column;min-height:calc(100svh - 64px);display:flex}.feed-header{z-index:10;background:#fff;border-bottom:1px solid #dbdbdb;justify-content:center;align-items:center;height:48px;display:flex;position:sticky;top:0}.feed-logo{color:#262626;letter-spacing:-.5px;font-family:Georgia,Times New Roman,serif;font-size:1.5rem;font-weight:700}.feed-loading{flex:1;justify-content:center;align-items:center;display:flex}.feed-spinner{border:2.5px solid #dbdbdb;border-top-color:#0095f6;border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.feed-empty{flex:1;justify-content:center;align-items:center;padding:40px 24px;display:flex}.feed-empty-text{color:#8e8e8e;text-align:center;font-size:.95rem}.feed-list{flex-direction:column;display:flex}.post-card{background:#fff;flex-direction:column;display:flex}.post-card-author{align-items:center;gap:10px;padding:10px 12px;display:flex}.post-card-avatar{border:1px solid #dbdbdb;border-radius:50%;flex-shrink:0;width:32px;height:32px;overflow:hidden}.avatar-img,.avatar-img--sm{object-fit:cover;width:100%;height:100%}.avatar-fallback{color:#8e8e8e;background:#dbdbdb;justify-content:center;align-items:center;width:100%;height:100%;font-size:.8rem;font-weight:600;display:flex}.avatar-fallback--sm{font-size:.65rem}.post-card-username{color:#262626;flex:1;font-size:.88rem;font-weight:600}.post-card-time{color:#8e8e8e;font-size:.78rem}.post-card-photo-btn{cursor:pointer;background:0 0;border:none;width:100%;padding:0;display:block}.post-card-photo{aspect-ratio:1;object-fit:cover;background:#fafafa;width:100%;display:block}.post-card-actions{align-items:center;gap:12px;padding:8px 12px 4px;display:flex}.post-card-like-btn,.post-card-comment-btn{cursor:pointer;color:#262626;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;padding:4px;transition:transform .1s;display:flex}.post-card-like-btn:active,.post-card-comment-btn:active{transform:scale(.88)}.post-card-like-btn--liked{color:#ed4956}.post-card-like-count{color:#262626;margin-bottom:2px;padding:0 12px;font-size:.88rem;font-weight:600}.post-card-caption{color:#262626;padding:2px 12px;font-size:.88rem;line-height:1.4}.post-card-caption-username{font-weight:600}.post-card-comments{padding:4px 12px 0}.post-card-view-comments{color:#8e8e8e;cursor:pointer;background:0 0;border:none;margin-bottom:2px;padding:0;font-size:.82rem;display:block}.post-card-latest-comment{color:#262626;font-size:.85rem;line-height:1.4}.post-card-add-comment{color:#8e8e8e;cursor:pointer;text-align:left;background:0 0;border:none;width:100%;padding:4px 12px 6px;font-size:.82rem;display:block}.post-card-divider{background:#efefef;height:1px;margin:6px 0 0}.composer-screen{flex-direction:column;min-height:calc(100svh - 64px);display:flex}.composer-header{z-index:10;background:#fff;border-bottom:1px solid #dbdbdb;justify-content:center;align-items:center;height:48px;display:flex;position:sticky;top:0}.composer-title{color:#262626;font-size:1rem;font-weight:600}.composer-body{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex}.composer-photo-area{aspect-ratio:1;cursor:pointer;background:#fafafa;border:2px dashed #dbdbdb;border-radius:12px;justify-content:center;align-items:center;width:100%;transition:border-color .15s;display:flex;overflow:hidden}.composer-photo-area--filled{border-style:solid;border-color:#dbdbdb}.composer-photo-area:active{border-color:#0095f6}.composer-placeholder{flex-direction:column;align-items:center;gap:10px;display:flex}.composer-placeholder-text{color:#8e8e8e;font-size:.88rem}.composer-preview{object-fit:cover;width:100%;height:100%}.composer-change-photo{color:#0095f6;cursor:pointer;background:0 0;border:none;align-self:center;padding:0;font-size:.88rem;font-weight:500}.composer-caption-row{flex-direction:column;display:flex}.composer-caption{color:#262626;resize:none;background:#fafafa;border:1px solid #dbdbdb;border-radius:8px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:border-color .15s}.composer-caption:focus{background:#fff;border-color:#a8a8a8}.composer-error{color:#ed4956;text-align:center;font-size:.85rem}.composer-share-btn{color:#fff;cursor:pointer;background:#0095f6;border:none;border-radius:8px;width:100%;padding:13px;font-size:.95rem;font-weight:600;transition:opacity .15s}.composer-share-btn:disabled{opacity:.5;cursor:not-allowed}.composer-share-btn:not(:disabled):active{opacity:.85}.post-detail-screen{flex-direction:column;min-height:calc(100svh - 64px);display:flex}.post-detail-header{z-index:10;background:#fff;border-bottom:1px solid #dbdbdb;align-items:center;gap:8px;height:48px;padding:0 8px;display:flex;position:sticky;top:0}.back-btn{cursor:pointer;color:#262626;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;padding:8px;display:flex}.post-detail-header-title{color:#262626;font-size:1rem;font-weight:600}.post-detail-scroll{flex:1;overflow-y:auto}.post-detail-loading,.post-detail-not-found{color:#8e8e8e;flex:1;justify-content:center;align-items:center;padding:40px;font-size:.95rem;display:flex}.post-detail-photo{aspect-ratio:1;object-fit:cover;background:#fafafa;width:100%;display:block}.post-detail-comments{flex-direction:column;gap:10px;padding:8px 12px 4px;display:flex}.post-detail-no-comments{color:#8e8e8e;text-align:center;padding:8px 0;font-size:.85rem}.comment-row{align-items:flex-start;gap:10px;display:flex}.comment-avatar{border:1px solid #dbdbdb;border-radius:50%;flex-shrink:0;width:28px;height:28px;overflow:hidden}.comment-body{flex-direction:column;flex:1;gap:2px;display:flex}.comment-text{color:#262626;font-size:.86rem;line-height:1.4}.comment-time{color:#8e8e8e;font-size:.75rem}.post-detail-comment-bar{z-index:10;background:#fff;border-top:1px solid #dbdbdb;align-items:center;gap:8px;padding:10px 12px;display:flex;position:sticky;bottom:0}.post-detail-comment-input{color:#262626;background:#fafafa;border:1px solid #dbdbdb;border-radius:20px;outline:none;flex:1;padding:9px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.post-detail-comment-input:focus{background:#fff;border-color:#a8a8a8}.post-detail-comment-post-btn{color:#0095f6;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:.9rem;font-weight:600;transition:opacity .15s}.post-detail-comment-post-btn:disabled{opacity:.4;cursor:not-allowed}.photo-grid{grid-template-columns:repeat(3,1fr);gap:2px;display:grid}.photo-grid-cell{aspect-ratio:1;position:relative;overflow:hidden}.photo-grid-img{object-fit:cover;width:100%;height:100%;display:block}.photo-grid-btn{aspect-ratio:1;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;width:100%;padding:0;display:block}.profile-screen{flex-direction:column;min-height:calc(100svh - 64px);display:flex}.profile-header{z-index:10;background:#fff;border-bottom:1px solid #dbdbdb;align-items:center;gap:8px;height:48px;padding:0 12px;display:flex;position:sticky;top:0}.profile-header-title{font-size:1rem;font-weight:600}.profile-header-back-btn{cursor:pointer;color:#262626;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;padding:8px;display:flex}.profile-hero{flex-direction:column;align-items:center;gap:8px;padding:20px 16px;display:flex}.profile-avatar-wrap{width:72px;height:72px;position:relative}.profile-avatar{border:1px solid #dbdbdb;border-radius:50%;width:72px;height:72px;overflow:hidden}.profile-avatar-edit-btn{cursor:pointer;color:#fff;background:#0095f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;display:flex;position:absolute;bottom:0;right:0}.profile-username{color:#262626;font-size:1.1rem;font-weight:700}.profile-bio{color:#8e8e8e;text-align:center;max-width:240px;font-size:.88rem;line-height:1.4}.profile-edit-bio-btn{color:#0095f6;cursor:pointer;background:0 0;border:none;padding:0;font-size:.82rem}.profile-bio-edit{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.profile-bio-input{border:1px solid #dbdbdb;border-radius:8px;outline:none;width:100%;max-width:280px;padding:8px 12px;font-family:inherit;font-size:.9rem}.profile-bio-actions{gap:8px;display:flex}.profile-bio-save-btn{color:#fff;cursor:pointer;background:#0095f6;border:none;border-radius:6px;padding:6px 16px;font-size:.85rem;font-weight:600}.profile-bio-cancel-btn{color:#262626;cursor:pointer;background:0 0;border:1px solid #dbdbdb;border-radius:6px;padding:6px 16px;font-size:.85rem}.profile-stats{color:#262626;padding:4px 0 16px;font-size:.88rem;font-weight:600}.profile-grid-section{width:100%}.profile-logout-wrap{padding:24px 16px}.profile-logout-btn{color:#8e8e8e;cursor:pointer;background:0 0;border:1px solid #dbdbdb;border-radius:8px;width:100%;padding:12px;font-size:.9rem}.albums-screen{flex-direction:column;min-height:calc(100svh - 64px);display:flex}.albums-header{z-index:10;background:#fff;border-bottom:1px solid #dbdbdb;align-items:center;gap:8px;height:48px;padding:0 12px;display:flex;position:sticky;top:0}.albums-header-title{flex:1;font-size:1rem;font-weight:600}.albums-new-btn{color:#fff;cursor:pointer;background:#0095f6;border:none;border-radius:6px;padding:6px 12px;font-size:.82rem;font-weight:600}.albums-list{flex-direction:column;display:flex}.album-row{cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;background:0 0;border:none;border-bottom:1px solid #efefef;align-items:center;gap:12px;width:100%;padding:12px 16px;display:flex}.album-row-name{color:#262626;flex:1;font-size:.95rem;font-weight:500}.albums-empty{color:#8e8e8e;text-align:center;flex:1;justify-content:center;align-items:center;padding:40px 24px;font-size:.9rem;display:flex}.album-detail-screen{flex-direction:column;min-height:calc(100svh - 64px);display:flex}.album-detail-header{z-index:10;background:#fff;border-bottom:1px solid #dbdbdb;align-items:center;gap:8px;height:48px;padding:0 8px;display:flex;position:sticky;top:0}.album-detail-title{flex:1;font-size:1rem;font-weight:600}.modal-overlay{z-index:200;background:#00000080;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-sheet{background:#fff;border-radius:16px 16px 0 0;flex-direction:column;gap:12px;width:100%;max-height:80svh;padding:20px 16px;display:flex;overflow-y:auto}.modal-title{font-size:1rem;font-weight:700}.modal-close-btn{cursor:pointer;color:#8e8e8e;background:0 0;border:none;font-size:1.2rem}.modal-album-list{flex-direction:column;gap:8px;display:flex}.modal-album-row{cursor:pointer;align-items:center;gap:10px;padding:6px 0;display:flex}.modal-album-label{flex:1;font-size:.9rem}.modal-done-btn{color:#fff;cursor:pointer;background:#0095f6;border:none;border-radius:8px;width:100%;margin-top:8px;padding:12px;font-size:.95rem;font-weight:600}.modal-form{flex-direction:column;gap:12px;display:flex}.modal-input{color:#262626;background:#fafafa;border:1px solid #dbdbdb;border-radius:8px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:.95rem}.modal-member-list{flex-direction:column;gap:6px;max-height:200px;display:flex;overflow-y:auto}.modal-member-row{cursor:pointer;align-items:center;gap:10px;display:flex}.modal-create-btn{color:#fff;cursor:pointer;background:#0095f6;border:none;border-radius:8px;width:100%;margin-top:8px;padding:12px;font-size:.95rem;font-weight:600}.modal-create-btn:disabled{opacity:.5;cursor:not-allowed}.modal-cancel-btn{color:#8e8e8e;cursor:pointer;background:0 0;border:1px solid #dbdbdb;border-radius:8px;width:100%;padding:11px;font-size:.95rem}.modal-thumb{object-fit:cover;border-radius:8px;align-self:center;width:80px;height:80px}.chat-screen{background:#fff;flex-direction:column;height:calc(100svh - 64px);display:flex}.chat-header{border-bottom:1px solid #efefef;flex-shrink:0;align-items:center;padding:14px 16px 12px;display:flex}.chat-header-title{color:#262626;font-size:1rem;font-weight:700}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:12px 12px 8px;display:flex;overflow-y:auto}.chat-loading{flex:1;justify-content:center;align-items:center;padding:40px 0;display:flex}.chat-empty{text-align:center;color:#8e8e8e;padding:40px 0;font-size:.9rem}.chat-row{align-items:flex-end;gap:8px;display:flex}.chat-row--mine{flex-direction:row-reverse}.chat-row--theirs{flex-direction:row}.chat-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:30px;height:30px}.chat-avatar-placeholder{color:#8e8e8e;background:#dbdbdb;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.chat-bubble-group{flex-direction:column;max-width:70%;display:flex}.chat-row--mine .chat-bubble-group{align-items:flex-end}.chat-row--theirs .chat-bubble-group{align-items:flex-start}.chat-sender-name{color:#8e8e8e;margin-bottom:2px;padding-left:4px;font-size:.7rem;font-weight:600}.chat-bubble{word-break:break-word;border-radius:18px;padding:8px 12px;line-height:1.4}.chat-bubble--mine{color:#fff;background:#0095f6;border-bottom-right-radius:4px}.chat-bubble--theirs{color:#262626;background:#efefef;border-bottom-left-radius:4px}.chat-bubble-text{font-size:.9rem}.chat-time{color:#a8a8a8;margin-top:3px;padding:0 4px;font-size:.65rem}.chat-input-bar{background:#fff;border-top:1px solid #efefef;flex-shrink:0;align-items:center;gap:8px;padding:8px 12px 12px;display:flex}.chat-input{color:#262626;background:#fafafa;border:1px solid #dbdbdb;border-radius:22px;outline:none;flex:1;padding:9px 14px;font-family:inherit;font-size:.9rem}.chat-input:focus{border-color:#a8a8a8}.chat-send-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#0095f6;border:none;border-radius:22px;padding:9px 16px;font-size:.9rem;font-weight:600}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.confetti-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.confetti-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:360px;padding:36px 28px 28px;box-shadow:0 20px 60px #00000040}.confetti-emoji{margin-bottom:12px;font-size:3rem}.confetti-heading{color:#262626;margin-bottom:10px;font-size:1.6rem;font-weight:700;line-height:1.3}.confetti-subtext{color:#8e8e8e;margin-bottom:28px;font-size:1rem;line-height:1.5}.confetti-btn{color:#fff;cursor:pointer;letter-spacing:.3px;background:#0095f6;border:none;border-radius:10px;width:100%;padding:14px;font-size:1rem;font-weight:600}.confetti-btn:hover{background:#1877f2}
