:root{color:#333;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:400;line-height:1.5}body{background-color:#f8f9fa;min-height:100vh}button{background-color:#f9f9f9}.login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{background:#fff;border-radius:16px;width:100%;max-width:440px;padding:48px 40px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:40px}.logo{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:48px;font-weight:700}.tagline{color:#666;margin:0;font-size:16px}.login-content{text-align:center}.login-content h2{color:#333;margin:0 0 12px;font-size:28px;font-weight:600}.description{color:#666;margin:0 0 32px;font-size:15px;line-height:1.6}.google-login-btn{color:#333;cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:8px;justify-content:center;align-items:center;gap:12px;width:100%;padding:14px 24px;font-size:16px;font-weight:500;transition:all .2s;display:flex}.google-login-btn:hover:not(:disabled){background:#f8f9fa;border-color:#999;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.google-login-btn:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px}.loading{animation:1.5s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.divider{text-align:center;margin:32px 0;position:relative}.divider:before{content:"";background:#ddd;height:1px;position:absolute;top:50%;left:0;right:0}.divider span{color:#999;background:#fff;padding:0 16px;font-size:14px;position:relative}.guest-login{margin-top:24px}.guest-login p{color:#666;margin:0 0 12px;font-size:14px}.guest-btn{color:#333;cursor:pointer;background:#f0f0f0;border:1px solid #ddd;border-radius:6px;padding:10px 24px;font-size:15px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.guest-btn:hover{background:#e0e0e0;border-color:#999;transform:translateY(-1px)}.login-footer{text-align:center;border-top:1px solid #eee;margin-top:40px;padding-top:24px}.login-footer p{color:#999;margin:0;font-size:12px;line-height:1.6}.login-footer a{color:#667eea;text-decoration:none}.login-footer a:hover{text-decoration:underline}@media (max-width:480px){.login-container{padding:32px 24px}.logo{font-size:36px}.login-content h2{font-size:24px}}.sidebar{z-index:100;background-color:#f9fafb;border-right:1px solid #e5e7eb;flex-direction:column;width:208px;height:100vh;padding:20px;display:flex;position:relative;top:0;left:0}.logo{color:#111827;margin-bottom:32px;font-size:24px;font-weight:700}.nav-menu{margin:0;padding:0;list-style:none}.nav-item{cursor:pointer;color:#4b5563;border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:12px 16px;transition:all .2s;display:flex}.nav-item.active{color:#fff;background-color:#4a8bf4}.nav-item span:first-of-type{font-size:18px}.logout-btn{color:#fff;cursor:pointer;background-color:#ff6b6b;border:none;border-radius:4px;width:100%;margin-top:auto;padding:10px;font-size:14px;font-weight:600}.logout-btn:hover{background-color:#ee5a52}.logout-btn.login-btn{background-color:#10b981}.logout-btn.login-btn:hover{background-color:#0e9f6e}.right-panel{z-index:100;background-color:#ffdeff;border-top-left-radius:20px;border-bottom-left-radius:20px;flex-direction:column;width:400px;min-width:360px;height:100vh;transition:transform .3s cubic-bezier(.25,1,.5,1),opacity .3s;display:flex;position:fixed;top:0;right:0;box-shadow:-5px 0 20px #0000000d}.right-panel.open{opacity:1;pointer-events:auto;transform:translate(0)}.right-panel.closed{opacity:0;pointer-events:none;transform:translate(100%)}.chat-header{z-index:2;background-color:#0000;align-items:flex-end;height:60px;padding:10px 10px 0;display:flex;position:relative}.tab-buttons{flex:1;gap:4px;display:flex}.tab-button{color:#8d7b68;cursor:pointer;opacity:.8;background:#e6dab3;border:none;border-top-left-radius:16px;border-top-right-radius:16px;flex:1;justify-content:center;align-items:center;height:44px;font-size:16px;font-weight:600;transition:all .2s;display:flex}.tab-button:hover{opacity:1;background:#eddcb9}.tab-button.active{color:#000;opacity:1;z-index:3;background-color:#fff;height:50px;font-weight:800;box-shadow:0 -3px 6px #0000000d}.close-btn{color:#5d4037;cursor:pointer;background-color:#0000;border:none;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:5px;margin-left:10px;font-size:24px;display:flex}.close-btn:hover{background-color:#0000000d;border-radius:50%}.panel-content-wrapper{z-index:1;background-color:#fff;border-top-left-radius:24px;border-top-right-radius:0;flex-direction:column;flex:1;margin-top:-1px;display:flex;position:relative;overflow:hidden}.chat-body,.edit-body{background-color:#fff;flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.message-row{width:100%;margin-bottom:8px;display:flex}.message-row.is-user{justify-content:flex-end}.message-row.is-bot{justify-content:flex-start}.message-bubble{border-radius:20px;max-width:80%;padding:12px 18px;font-size:15px;line-height:1.5;position:relative;box-shadow:0 2px 5px #00000008}.message-user{color:#5d4037;background-color:#e495e4;border-bottom-right-radius:4px;font-weight:500}.message-bot{color:#333;background-color:#f5f5f5;border:1px solid #eee;border-bottom-left-radius:4px}.streaming-cursor{color:#ffd54f;margin-left:4px;animation:1s infinite blink;display:inline-block}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.chat-input-area{background-color:#fff;padding:20px}.chat-input{color:#333;background-color:#fff;border:2px solid #f0f0f0;border-radius:30px;outline:none;width:100%;padding:18px 60px 18px 24px;font-size:15px;transition:border-color .2s}.chat-input:focus{border-color:#e495e4}.send-btn{color:#5d4037;cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600;position:absolute;top:50%;right:20px;transform:translateY(-50%)}.edit-preview-area{background-color:#fafafa;border:2px dashed #eee;border-radius:16px;justify-content:center;align-items:center;min-height:200px;display:flex;overflow:hidden}.edit-controls{justify-content:center;gap:10px;padding:10px 0;display:flex}.control-btn{cursor:pointer;color:#555;background:#fff;border:1px solid #eee;border-radius:12px;justify-content:center;align-items:center;padding:10px 14px;transition:all .2s;display:flex;box-shadow:0 2px 5px #00000008}.control-btn:hover{color:#5d4037;background-color:#ffdeff;border-color:#e495e4;transform:translateY(-2px)}.apply-btn{color:#5d4037;cursor:pointer;background:#e495e4;border:none;border-radius:14px;width:100%;margin-top:10px;padding:16px;font-size:15px;font-weight:800;transition:background .2s,transform .1s}.apply-btn:hover{background:#e495e4;transform:translateY(-1px)}.image-msg-wrapper{flex-direction:column;align-items:center;display:flex}.chat-image-preview{border-radius:8px;max-width:150px;margin-bottom:4px;box-shadow:0 4px 10px #0000001a}.chat-text{white-space:pre-wrap;word-break:break-word}.photo-card{cursor:pointer;background:#fff;border-radius:12px;transition:all .3s;overflow:hidden;box-shadow:0 2px 8px #00000014}.photo-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f}.photo-card-image{background:#f0f0f0;width:100%;padding-bottom:100%;position:relative;overflow:hidden}.photo-card-image img{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.photo-card-info{background:#fff;padding:12px}.photo-card-title{color:#333;white-space:nowrap;text-overflow:ellipsis;margin:0 0 8px;font-size:14px;font-weight:600;overflow:hidden}.photo-card-meta{color:#999;align-items:center;gap:6px;font-size:12px;display:flex}.photo-card-meta .icon{width:14px;height:14px}.photo-card-image{position:relative;overflow:hidden}.photo-card-actions{opacity:0;z-index:2;gap:6px;transition:opacity .2s ease-in-out;display:flex;position:absolute;top:10px;right:10px}.photo-card:hover .photo-card-actions{opacity:1}.action-btn{color:#fff;cursor:pointer;background-color:#00000080;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:background-color .2s;display:flex}.action-btn:hover{background-color:#000c}.action-btn.delete:hover{background-color:#ef4444}.feed-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:30px;display:grid}.loading-item{grid-column:1/-1;justify-content:center;padding:40px 0;display:flex}.spinner{border:3px solid #f0f0f0;border-top-color:#e495e4;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:1400px){.feed-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:1000px){.feed-grid{grid-template-columns:repeat(2,1fr)}}.main-feed{background-color:#f8f9fa;flex:1;margin:0;padding:0 40px;transition:margin-right .3s;overflow-y:auto}.main-feed.with-panel{margin-right:360px}.feed-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.feed-header h2{color:#333;margin:0;font-size:26px;font-weight:800}.feed-content{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;display:grid}.feed-placeholder{color:#4b5563}.feed-error{color:#c33;text-align:center;background:#fee;border:1px solid #fcc;border-radius:8px;margin-bottom:20px;padding:16px}.retry-btn{color:#fff;cursor:pointer;background:#e495e4;border:none;border-radius:6px;margin-top:10px;padding:8px 16px;font-weight:600;transition:background .2s}.retry-btn:hover{background:#e495e4}.feed-observer{visibility:hidden;height:100px}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-container{background:#fff;border-radius:16px;grid-template-columns:1fr 1fr;gap:0;width:100%;max-width:900px;max-height:90vh;display:grid;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-close-btn{cursor:pointer;z-index:10;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;top:20px;right:20px}.modal-close-btn:hover{background:#fff;box-shadow:0 4px 12px #00000026}.modal-close-btn .icon{color:#333;width:24px;height:24px}.modal-content{display:contents}.photo-viewer{background:#000;border-radius:16px 0 0 16px;justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.photo-image{object-fit:contain;width:100%;height:100%}.photo-meta{background:#fff;border-radius:0 16px 16px 0;flex-direction:column;gap:24px;padding:40px;display:flex;overflow-y:auto}.meta-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.photo-title{color:#333;flex:1;margin:0;font-size:24px;font-weight:800}.like-btn{cursor:pointer;color:#999;white-space:nowrap;background:#f5f5f5;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-weight:600;transition:all .2s;display:flex}.like-btn:hover{color:#ff6b6b;background:#ffe0e0}.like-btn.liked{color:#fff;background:#ffd54f}.like-btn .icon{width:18px;height:18px}.photo-description{color:#666;margin:0;font-size:14px;line-height:1.6}.meta-info{border-top:1px solid #eee;border-bottom:1px solid #eee;flex-direction:column;gap:12px;padding:16px 0;display:flex}.meta-item{gap:8px;font-size:13px;display:flex}.meta-label{color:#999;font-weight:600}.meta-value{color:#333}.meta-author-btn{color:#06c;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:500;text-decoration:none;transition:color .2s}.meta-author-btn:hover{color:#0052a3;text-decoration:underline}.action-buttons{grid-template-columns:1fr 1fr;gap:12px;display:grid}.action-buttons.action-buttons--three{grid-template-columns:1fr 1fr 1fr}.save-btn{color:#111;background:#f5f5f5}.save-btn:hover{background:#eaeaea;transform:translateY(-2px)}.action-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.action-btn .icon{width:18px;height:18px}.ai-edit-btn{color:#fff;background:#e495e4}.ai-edit-btn:hover{background:#e495e4;transform:translateY(-2px)}.ai-search-btn{color:#fff;background:#4a8bf4}.ai-search-btn:hover{background:#3a7be4;transform:translateY(-2px)}@media (max-width:768px){.modal-container{grid-template-columns:1fr;max-height:95vh}.photo-viewer{border-radius:16px 16px 0 0;min-height:400px}.photo-meta{border-radius:0 0 16px 16px;padding:24px}.meta-header{flex-direction:column}.action-buttons{grid-template-columns:1fr}}.profile-page-container{background-color:#fff;flex:1;height:100%;transition:margin-right .3s;display:flex;overflow:hidden}.profile-page-container.with-panel{margin-right:360px}.profile-sidebar{background-color:#fdfdfd;border-right:1px solid #eee;flex-direction:column;flex:3;justify-content:center;align-items:center;min-width:300px;padding:40px;display:flex}.profile-image-container{background-color:#eee;border:4px solid #fff;border-radius:50%;width:180px;height:180px;margin-bottom:24px;overflow:hidden;box-shadow:0 8px 24px #00000014}.profile-image{object-fit:cover;width:100%;height:100%}.profile-text-info{text-align:center;margin-bottom:24px}.profile-text-info h2{color:#333;margin-bottom:10px;font-size:26px;font-weight:700}.profile-text-info p{color:#666;font-size:15px}.profile-actions{color:#888;align-items:center;gap:12px;font-size:14px;display:flex}.action-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:20px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.action-btn:hover{color:#333;background-color:#f5f5f5;border-color:#ccc}.divider{color:#eee;font-size:12px}.profile-gallery{background-color:#fafafa;flex:5;padding:40px;overflow-y:auto}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;display:grid}.profile-header-nav{justify-content:flex-start;width:100%;margin-bottom:20px;display:flex}.back-btn{cursor:pointer;color:#555;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:background-color .2s;display:flex}.back-btn:hover{color:#333;background-color:#f0f0f0}.follow-page{background-color:#fff;flex-direction:column;flex:1;height:100%;padding:40px;display:flex;overflow-y:auto}.follow-header{border-bottom:1px solid #eee;align-items:center;gap:16px;margin-bottom:40px;padding-bottom:20px;display:flex}.follow-header h2{color:#333;margin:0;font-size:24px;font-weight:700}.back-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:background-color .2s;display:flex}.back-btn:hover{background-color:#f5f5f5}.follow-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:30px;display:grid}.follow-user-card{border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:20px;transition:transform .2s,background-color .2s;display:flex}.follow-user-card:hover{background-color:#fafafa;transform:translateY(-5px)}.user-avatar-wrapper{border:3px solid #fff;border-radius:50%;width:100px;height:100px;overflow:hidden;box-shadow:0 4px 10px #0000001a}.user-avatar{object-fit:cover;width:100%;height:100%}.user-name{color:#333;font-size:16px;font-weight:600}.follow-btn{color:#666;cursor:pointer;background-color:#fff;border:1px solid #ddd;border-radius:20px;padding:6px 16px;font-size:12px}.upload-page{background-color:#fff;flex-direction:column;flex:1;height:100vh;padding:40px;transition:margin-right .3s;display:flex;overflow:hidden}.upload-page.with-panel{margin-right:360px}.upload-page-title{color:#333;margin-bottom:30px;font-size:28px;font-weight:800}.upload-flex-content{flex:1;align-items:flex-start;gap:60px;display:flex}.upload-left{aspect-ratio:1;cursor:pointer;background-color:#f0f0f0;border:2px dashed #ccc;border-radius:20px;flex:1;justify-content:center;align-items:center;max-height:600px;transition:all .3s;display:flex;position:relative;overflow:hidden}.upload-left:hover{background-color:#e8e8e8;border-color:#aaa}.upload-left.has-image{cursor:default;background-color:#000;border:none}.upload-right{flex-direction:column;flex:1;min-width:400px;height:100%;display:flex}.form-group{margin-bottom:24px}.form-group.grow{flex:1;display:flex}.input-title{color:#333;background:0 0;border:none;border-bottom:2px solid #eee;outline:none;width:100%;padding-bottom:10px;font-size:42px;font-weight:800}.input-title:focus{border-color:#e495e4}.input-date{color:#999;margin-top:8px;font-size:14px}.input-desc{resize:none;color:#555;border:none;outline:none;width:100%;min-height:200px;font-size:18px;line-height:1.6}.form-actions{justify-content:flex-end;gap:12px;margin-top:auto;padding-top:20px;display:flex}.submit-btn{color:#fff;cursor:pointer;background-color:#333;border:none;border-radius:30px;padding:14px 40px;font-size:18px;font-weight:700}.cancel-btn{color:#666;cursor:pointer;background-color:#eee;border:none;border-radius:30px;padding:14px 30px;font-size:18px;font-weight:600}.placeholder-container{color:#888;flex-direction:column;align-items:center;gap:16px;display:flex}.image-preview{object-fit:contain;width:100%;height:100%}#root{text-align:left;width:100%;max-width:100%;margin:0;padding:0}*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background-color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow:hidden}.app-container{width:100vw;height:100vh;display:flex}.sidebar{background-color:#fff;border-right:1px solid #eee;flex-direction:column;width:240px;min-width:240px;padding:30px 20px;display:flex}.logo{color:#444;letter-spacing:-.5px;margin-bottom:50px;padding-left:10px;font-size:24px;font-weight:900}.nav-menu{flex-direction:column;gap:10px;list-style:none;display:flex}.nav-item{cursor:pointer;color:#999;border-radius:14px;align-items:center;gap:12px;padding:14px 16px;font-weight:600;transition:all .2s;display:flex}.nav-item:hover{color:#fbc02d;background-color:#fff9c4}.nav-item.active{color:#fff;background-color:#ffd54f;box-shadow:0 4px 12px #ffd54f66}.main-feed{background-color:#f8f9fa;flex:1;padding:40px;overflow-y:auto}.feed-header h2{color:#333;margin-bottom:30px;font-size:26px;font-weight:800}.right-panel{z-index:10;background-color:#fff;border-left:1px solid #eee;flex-direction:column;width:360px;min-width:360px;display:flex;box-shadow:-5px 0 20px #00000005}.chat-header{border-bottom:1px solid #f0f0f0;height:64px;display:flex}.chat-tab{color:#aaa;cursor:pointer;flex:1;justify-content:center;align-items:center;font-size:15px;font-weight:600;transition:color .2s;display:flex}.chat-tab:hover{color:#666}.chat-tab.active{color:#333;box-shadow:inset 0 -3px #333}.close-btn-area{cursor:pointer;color:#fff;background-color:#ffd54f;justify-content:center;align-items:center;width:64px;font-size:18px;transition:background-color .2s;display:flex}.close-btn-area:hover{background-color:#fbc02d}.chat-body{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.message-bubble{border-radius:18px;max-width:85%;padding:14px 18px;font-size:14px;line-height:1.6;position:relative}.message-bot{color:#444;background-color:#f5f5f5;border-top-left-radius:4px;align-self:flex-start}.message-user{color:#fff;background-color:#ffd54f;border-top-right-radius:4px;align-self:flex-end}.action-button{color:#fff;cursor:pointer;background-color:#ffd54f;border:none;border-radius:100px;align-self:flex-end;padding:10px 24px;font-size:13px;font-weight:700;transition:transform .1s;box-shadow:0 4px 10px #ffd54f4d}.action-button:hover{transform:scale(1.05)}.chat-input-area{background-color:#fff;border-top:1px solid #f9f9f9;padding:24px}.input-wrapper{width:100%;position:relative}.chat-input{background-color:#fff;border:1px solid #e0e0e0;border-radius:30px;outline:none;width:100%;padding:16px 60px 16px 20px;font-size:14px;transition:border-color .2s}.chat-input:focus{border-color:#ffd54f;box-shadow:0 0 0 3px #ffd54f1a}.send-btn{color:#ccc;cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:700;transition:color .2s;position:absolute;top:50%;right:20px;transform:translateY(-50%)}.send-btn:hover{color:#ffd54f}.floating-chat-btn{z-index:20;color:#fff;cursor:pointer;background:#ffd54f;border:none;border-radius:999px;padding:12px 16px;font-weight:700;transition:transform .15s,box-shadow .15s,right .2s;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 18px #ffd54f59}.floating-chat-btn:hover{transform:translateY(-1px);box-shadow:0 12px 20px #ffd54f73}.floating-chat-btn.with-panel{right:400px}
