:root{--primary-purple: #5D2CE8;--icon-gray: #A9A9A9;--text-gray: #898A8D;--text-dark: #454545;--text-black: #000000;--background-gray: #F5F5F5;--white: #FFFFFF;--divider-gray: #E0E0E0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;background-color:var(--background-gray);color:var(--text-dark);font-size:14px;line-height:1.5;min-height:100vh}a{color:var(--primary-purple);text-decoration:none}a:hover{opacity:.8}button{font-family:inherit;cursor:pointer;border:none;background:none;padding:0}button:disabled{cursor:not-allowed;opacity:.5}.post-item{background:var(--white);border-radius:24px;padding:10px;margin:8px 10px}.post-header-row{display:flex;gap:10px;align-items:flex-start}.post-profile-image{flex-shrink:0;width:33.3px;height:33.3px;border-radius:50%;overflow:hidden}.post-profile-image img{width:100%;height:100%;object-fit:cover}.post-profile-placeholder{width:100%;height:100%;background-color:var(--primary-purple)}.post-content-wrapper{flex:1;min-width:0}.post-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.post-header-left{flex:1;min-width:0}.post-club-name{display:flex;align-items:center;gap:0px;margin-bottom:2px;font-size:10px;font-weight:400;color:var(--primary-purple)}.post-author-name{font-size:10px;font-weight:400;color:var(--text-black)}.author-prefix{color:var(--text-gray)}.author-rest{color:var(--text-black)}.post-header-right{display:flex;align-items:center;gap:12px;transform:translate(-6px,6px)}.post-time{font-size:10px;font-weight:400;color:var(--text-gray)}.post-body{margin-bottom:12px}.post-text{font-size:14px;font-weight:400;line-height:1.5;color:var(--text-dark);white-space:pre-wrap;word-wrap:break-word}.post-footer{display:flex;justify-content:space-around;gap:8px;padding-left:16px}.post-action-button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 4px;background:none;border:none;cursor:pointer;font-size:12px;font-weight:400;color:var(--icon-gray);transition:opacity .2s}.post-action-button:hover{opacity:.7}.post-action-button svg{color:var(--icon-gray)}.post-action-button.liked{color:var(--primary-purple)}.post-action-button.liked svg{color:var(--primary-purple);fill:var(--primary-purple)}@media(max-width:768px){.post-item{margin:8px 0;border-radius:0}}.post-list-page{width:100%;min-height:100vh;background-color:var(--background-gray)}.page-header{background:var(--white);padding:20px 16px;box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:100}.header-content{max-width:600px;margin:0 auto}.page-header h1{font-size:24px;font-weight:700;color:var(--primary-purple);margin:0 0 4px}.page-subtitle{font-size:14px;font-weight:400;color:var(--text-gray);margin:0}.post-list-container{max-width:600px;margin:0 auto;padding:16px 0}.post-list{display:flex;flex-direction:column;gap:0}.loading-container,.error-container,.empty-state{max-width:600px;margin:80px auto;text-align:center;padding:40px 20px}.loading-spinner{width:40px;height:40px;margin:0 auto 20px;border:3px solid var(--divider-gray);border-top-color:var(--primary-purple);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p,.error-container p,.empty-state p{font-size:16px;color:var(--text-gray)}.error-container p{color:#ff3b30}@media(max-width:768px){.page-header{padding:16px}.page-header h1{font-size:20px}.post-list-container{padding:0}}.public-post-page{min-height:100vh;background-color:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-bar{background-color:#5d2ce8;padding:16px 20px;color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000001a}.app-bar-title{display:flex;align-items:center;justify-content:center;gap:8px}.feed-group-avatar{width:26px;height:26px;border-radius:50%;background-color:#ffffff4d;overflow:hidden;display:flex;align-items:center;justify-content:center}.feed-group-avatar img{width:100%;height:100%;object-fit:cover}.feed-group-icon{font-size:13px}.feed-group-name{font-size:16px;font-weight:700;color:#fff}.content-container{background-color:#fff;border-radius:30px 30px 0 0;margin-top:0;min-height:calc(100vh - 60px);padding-bottom:120px;padding-top:16px}.post-content{padding:16px;background-color:#fff}.post-header{display:flex;gap:10px;align-items:flex-start}.avatar{width:37px;height:37px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:22px}.post-main{flex:1;min-width:0}.post-info{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-top:8px}.author-name{font-size:12px;font-weight:400;color:#474747;line-height:1.3}.author-prefix{color:#898a8d}.author-main{color:#474747}.post-time{font-size:10px;font-weight:400;color:#898a8d;white-space:nowrap}.post-text{font-size:14px;font-weight:400;line-height:1.5;color:#454545;word-wrap:break-word;white-space:pre-wrap}.post-actions{display:flex;justify-content:space-around;margin-top:24px;padding-left:16px}.action-button{display:flex;align-items:center;gap:6px;padding:8px 12px;cursor:not-allowed;opacity:.7;font-size:12px;font-weight:400;color:#a9a9a9}.action-icon{font-size:16px;filter:grayscale(100%)}.action-label{color:#a9a9a9}.comments-section{margin-top:32px;padding:0 16px}.comment-item{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}.comment-item.child-comment{margin-left:42px;margin-top:12px}.comment-avatar{width:30px;height:30px;border-radius:50%;background-color:#dadada;flex-shrink:0}.comment-content{flex:1;min-width:0}.comment-card{background-color:#f4f4f4;border-radius:20px;padding:12px}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.comment-author{font-size:12px;font-weight:600;color:#474747}.comment-time{font-size:10px;font-weight:400;color:#898a8d;white-space:nowrap}.comment-text{font-size:12px;font-weight:400;line-height:1.5;color:#454545;word-wrap:break-word;white-space:pre-wrap}.comment-image{width:100%;border-radius:12px;margin-top:8px}.child-comments{margin-top:12px}.no-comments{text-align:center;padding:48px 32px;color:#666}.no-comments-icon{font-size:48px;margin-bottom:16px;filter:grayscale(50%);opacity:.5}.no-comments-title{font-size:16px;font-weight:400;color:#666;margin-bottom:8px}.no-comments-subtitle{font-size:14px;font-weight:400;color:#999}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:32px;text-align:center;background-color:#fff}.error-icon{font-size:64px;margin-bottom:24px;filter:grayscale(30%)}.error-container h2{font-size:24px;font-weight:700;color:#333;margin-bottom:12px}.error-container p{font-size:16px;font-weight:400;color:#666;max-width:400px;line-height:1.5;margin-bottom:24px}.error-details{width:100%;max-width:600px;margin-top:32px;padding:24px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:12px;text-align:left}.error-detail-item{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e9ecef}.error-detail-item:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.error-detail-item strong{display:block;font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.error-detail-item code,.error-url{display:block;font-family:Monaco,Courier New,monospace;font-size:13px;color:#333;background-color:#fff;padding:8px 12px;border-radius:6px;border:1px solid #dee2e6;word-break:break-all;margin-top:6px}.error-stack,.error-raw{margin-top:16px;border:1px solid #dee2e6;border-radius:8px;background-color:#fff}.error-stack summary,.error-raw summary{cursor:pointer;padding:12px 16px;font-size:13px;font-weight:600;color:#495057;-webkit-user-select:none;user-select:none;background-color:#f8f9fa;border-radius:8px;transition:background-color .2s}.error-stack summary:hover,.error-raw summary:hover{background-color:#e9ecef}.error-stack[open] summary,.error-raw[open] summary{border-bottom:1px solid #dee2e6;border-radius:8px 8px 0 0}.error-stack pre,.error-raw pre{margin:0;padding:16px;font-family:Monaco,Courier New,monospace;font-size:12px;line-height:1.6;color:#212529;overflow-x:auto;background-color:#fff;border-radius:0 0 8px 8px}.error-actions{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap;justify-content:center}.error-retry-button,.error-copy-button{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.error-retry-button{background-color:#5d2ce8;color:#fff;box-shadow:0 2px 8px #5d2ce84d}.error-retry-button:hover{background-color:#4a23b8;transform:translateY(-1px);box-shadow:0 4px 12px #5d2ce866}.error-copy-button{background-color:#6c757d;color:#fff;box-shadow:0 2px 8px #6c757d4d}.error-copy-button:hover{background-color:#5a6268;transform:translateY(-1px);box-shadow:0 4px 12px #6c757d66}.error-retry-button:active,.error-copy-button:active{transform:scale(.98)}.bottom-cta{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:16px 20px;box-shadow:0 -4px 20px #00000026;text-align:center;z-index:99}.bottom-cta p{font-size:14px;font-weight:500;color:#666;margin-bottom:12px}.cta-button{background-color:#5d2ce8;color:#fff;border:none;padding:14px 48px;border-radius:100px;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s;box-shadow:0 2px 8px #5d2ce84d;text-decoration:none;display:inline-block}.cta-button:hover{background-color:#4a23b8}.cta-button:active{transform:scale(.98)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-title{width:150px;height:20px;border-radius:10px}.skeleton-avatar{width:37px;height:37px;border-radius:50%}.skeleton-avatar-small{width:30px;height:30px;border-radius:50%}.skeleton-name{width:120px;height:12px;margin-bottom:16px}.skeleton-text{width:100%;height:14px;margin-bottom:8px}.skeleton-comment{width:100%;height:80px;border-radius:20px}@media(max-width:768px){.app-bar{padding:12px 16px}.content-container{margin-top:-20px;border-radius:20px 20px 0 0}.post-content{padding:12px}.comments-section{padding:0 12px}.comment-item.child-comment{margin-left:32px}}@media(min-width:769px){.public-post-page{max-width:600px;margin:0 auto;box-shadow:0 0 40px #0000001a}}#root{width:100%;min-height:100vh}
