:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:#000;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#1a1a1a;color:#fff}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#0003;border-radius:10px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#fff9,#fff6,#ffffff80);border-radius:10px;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:all .3s ease;box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff4d}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#fffc,#fff9,#ffffffb3);border-color:#fff6;transform:scale(1.05);box-shadow:0 4px 12px #0006,inset 0 1px #ffffff80}::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,#ffffffe6,#ffffffb3,#fffc);box-shadow:0 2px 6px #00000080,inset 0 1px #fff9}::-webkit-scrollbar-corner{background:#0003;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.6) rgba(0,0,0,.2)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#fff;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1f1f1f,#333,#0f0f0f);background-size:400% 400%;animation:gradientShift 20s ease infinite;min-height:100vh}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.app{min-height:100vh;display:flex;flex-direction:column}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top:4px solid #fff;border-radius:50%;animation:spin 1s linear infinite}.loading-container p{color:#fffc;font-size:16px}.notification{position:fixed;top:100px;right:20px;z-index:10000;max-width:400px;background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:1px solid rgba(255,255,255,.3);border-radius:16px;box-shadow:0 8px 32px #0000001f,inset 0 1px #fff6,0 0 0 1px #ffffff1a;transform:translate(100%);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.notification.show{transform:translate(0)}.notification.hide{transform:translate(100%)}.notification-content{display:flex;align-items:center;padding:16px 20px;gap:12px}.notification-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;flex-shrink:0}.notification.success .notification-icon{background:#22c55e33;color:#22c55e}.notification.error .notification-icon{background:#ef444433;color:#ef4444}.notification.info .notification-icon{background:#3b82f633;color:#3b82f6}.notification-message{flex:1;color:#fff;font-size:14px;font-weight:500;line-height:1.4}.notification-close{background:none;border:none;color:#fff9;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.notification-close:hover{color:#ffffffe6;background:#ffffff1a}.notification:after{content:"";position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:notificationProgress 4s linear forwards}.notification.success:after{background:linear-gradient(90deg,transparent,#22c55e,transparent)}.notification.error:after{background:linear-gradient(90deg,transparent,#ef4444,transparent)}.notification.info:after{background:linear-gradient(90deg,transparent,#3b82f6,transparent)}@keyframes notificationProgress{0%{width:100%}to{width:0%}}.header{position:fixed;top:20px;left:50%;transform:translate(-50%);width:480px;background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:1px solid rgba(255,255,255,.3);border-radius:20px;box-shadow:0 8px 32px #0000001f,inset 0 1px #fff6,inset 0 -1px #ffffff1a;z-index:1000;transition:all .4s cubic-bezier(.25,.46,.45,.94);overflow:hidden}.header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent)}.header:hover{background:#ffffff40;backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);-webkit-backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);box-shadow:0 12px 40px #00000026,inset 0 1px #ffffff80,inset 0 -1px #ffffff26;transform:translate(-50%) translateY(-2px)}.nav{padding:.75rem 1rem;display:flex;justify-content:center;align-items:center}.search-container{position:relative;width:450px;display:flex;align-items:center;justify-content:center}.search-input{width:100%;padding:.75rem 3.5rem .75rem 1rem;border:1px solid rgba(255,255,255,.15);border-radius:12px;background:#0000004d;backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);font-size:.9rem;color:#fff;transition:all .3s cubic-bezier(.25,.46,.45,.94);outline:none;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff1a}.search-input::placeholder{color:#fff6;font-weight:400}.search-input:focus{background:#00000080;border-color:#fff6;backdrop-filter:blur(25px) saturate(130%) contrast(1.2);-webkit-backdrop-filter:blur(25px) saturate(130%) contrast(1.2);box-shadow:0 4px 16px #0003,0 0 0 2px #667eea33,inset 0 1px #fff3;transform:translateY(-1px)}.search-button{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border:none;border-radius:10px;background:transparent;color:#fffc;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.search-button:hover:not(:disabled){color:#fff;transform:translateY(-50%) scale(1.1)}.search-button:active:not(:disabled){transform:translateY(-50%) scale(.9)}.search-button:disabled{opacity:.3;cursor:not-allowed;transform:translateY(-50%)}.search-button svg{width:20px;height:20px;stroke-width:2}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#fff9;font-size:1rem;pointer-events:none;transition:color .3s ease}.logo{height:3rem;width:auto;transition:transform .3s ease}.logo:hover{transform:scale(1.05)}.floating-logo{position:fixed;top:20px;left:20px;z-index:1001;background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:1px solid rgba(255,255,255,.3);border-radius:16px;padding:.75rem;box-shadow:0 8px 32px #0000001f,inset 0 1px #fff6,inset 0 -1px #ffffff1a;transition:all .4s cubic-bezier(.25,.46,.45,.94);cursor:pointer}.floating-logo:hover{background:#ffffff40;backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);-webkit-backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);box-shadow:0 12px 40px #00000026,inset 0 1px #ffffff80,inset 0 -1px #ffffff26;transform:translateY(-2px) scale(1.05)}.floating-logo .logo{height:2.5rem;width:auto;display:block}.nav-buttons-top-right{position:fixed;top:20px;right:20px;display:flex;gap:.5rem;z-index:1001;align-items:center;background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:1px solid rgba(255,255,255,.3);border-radius:16px;box-shadow:0 8px 32px #0000001f,inset 0 1px #fff6,inset 0 -1px #ffffff1a;padding:.5rem;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.nav-buttons-top-right:hover{background:#ffffff40;backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);-webkit-backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);box-shadow:0 12px 40px #00000026,inset 0 1px #ffffff80,inset 0 -1px #ffffff26;transform:translateY(-2px)}.nav-icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:10px;background:transparent;color:#ffffffb3;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.nav-icon-btn:hover{color:#fff;background:#ffffff40;backdrop-filter:blur(20px) saturate(110%) contrast(1.05);-webkit-backdrop-filter:blur(20px) saturate(110%) contrast(1.05);box-shadow:0 4px 12px #0000001a,inset 0 1px #ffffff4d;transform:translateY(-1px)}.nav-icon-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0000001a,inset 0 1px #fff3}@media(max-width:768px){.nav{padding:1rem}.search-container{width:calc(100vw - 100px);max-width:450px}.nav-buttons-top-right{top:15px;right:15px;gap:.5rem}.floating-logo{top:15px;left:15px;padding:.5rem}.floating-logo .logo{height:2rem}}.graph-container{width:100vw;height:100vh;position:fixed;top:0;left:0;z-index:1}.post-card-node{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:16px;box-shadow:0 8px 32px #0000001f,inset 0 1px #fff6,inset 0 -1px #ffffff1a;padding:1.5rem;width:320px;max-width:320px;height:auto;min-height:200px;transition:all .3s cubic-bezier(.25,.46,.45,.94);cursor:pointer;-webkit-user-select:none;user-select:none}.post-card-node:hover{background:#ffffff40;backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);-webkit-backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px #0003,inset 0 1px #ffffff80,inset 0 -1px #ffffff26;border-color:#fff9}.post-title{font-size:1.1rem;font-weight:600;color:#fffffff2;margin-bottom:.75rem;line-height:1.3;word-wrap:break-word}.post-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.post-avatar{width:48px;height:48px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;overflow:hidden}.post-avatar img{display:block;width:100%;height:100%;object-fit:cover}.post-user-info{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.post-user-info strong{font-size:.95rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.post-username{font-size:.85rem;color:#fff9}.post-content{font-size:.95rem;line-height:1.5;color:#ffffffe6;margin-bottom:1rem;word-wrap:break-word}.post-image{border-radius:12px;overflow:hidden;margin-bottom:1rem}.post-image img{width:100%;height:auto;display:block}.post-footer{display:flex;gap:1.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.post-action{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:#fff9;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;font-size:.9rem}.post-action:hover{background:#ffffff1a;color:#ffffffe6}.post-action svg{width:16px;height:16px}.react-flow__renderer{overflow:visible!important}.react-flow__node{border-radius:12px}.react-flow__handle{background:#ffffffe6;border:3px solid rgba(255,255,255,.5);width:14px;height:14px;opacity:.6;transition:opacity .2s ease;pointer-events:none}.react-flow__node:hover .react-flow__handle{opacity:1}.react-flow__edge-path{stroke:#fff!important;stroke-width:4!important;filter:drop-shadow(0 0 3px rgba(255,255,255,.8));opacity:1!important}.react-flow__edge.selected .react-flow__edge-path{stroke:#fff!important;stroke-width:5!important;filter:drop-shadow(0 0 5px rgba(255,255,255,1))}.react-flow__edge-arrowhead{fill:#fff!important;opacity:1!important}.react-flow__edge.selected .react-flow__edge-arrowhead{fill:#fff!important;filter:drop-shadow(0 0 5px rgba(255,255,255,1))}.react-flow__controls{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:12px}.react-flow__controls-button{background:transparent;border:none;color:#fffc;transition:all .2s ease}.react-flow__controls-button:hover{background:#ffffff1a;color:#fff}.react-flow__minimap{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;overflow:hidden}.react-flow__background-pattern{stroke:#fff3;stroke-width:1}.react-flow__edges{z-index:2}.react-flow__edge{z-index:2;pointer-events:all}.react-flow__attribution{display:none!important}.modal-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px #fff6,inset 0 -1px #ffffff1a;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;overflow-x:hidden;position:relative;animation:none}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:none;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10}.modal-close:hover{background:#fff3;color:#fff;transform:scale(1.1)}.modal-post{padding:2rem}.modal-post-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.modal-post-avatar{width:60px;height:60px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.modal-post-user-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.modal-post-user-info strong{font-size:1.25rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-post-username{font-size:1rem;color:#fff9}.modal-post-content{font-size:1.125rem;line-height:1.6;color:#ffffffe6;margin-bottom:1.5rem;word-wrap:break-word;position:relative;z-index:1}.modal-post-image{border-radius:16px;overflow:hidden;margin-bottom:2rem;background:#0003;width:100%;position:relative;z-index:1;clear:both}.modal-post-image img{width:100%;height:auto;max-height:70vh;object-fit:contain;display:block;position:relative;z-index:1}.modal-post-footer{display:flex;gap:2rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:2}.modal-post-action{display:flex;align-items:center;gap:.75rem;background:transparent;border:none;color:#fff9;cursor:pointer;padding:.75rem 1rem;border-radius:12px;transition:all .3s ease;font-size:1rem;font-weight:500}.modal-post-action:hover{background:#ffffff1a;color:#ffffffe6;transform:translateY(-1px)}.modal-post-action svg{width:20px;height:20px}@media(max-width:768px){.modal-overlay{padding:1rem}.modal-content{max-height:90vh}.modal-post{padding:1.5rem}.modal-post-header{gap:.75rem;margin-bottom:1rem}.modal-post-avatar{width:50px;height:50px;font-size:1.5rem}.modal-post-user-info strong{font-size:1.125rem}.modal-post-username{font-size:.9rem}.modal-post-content{font-size:1rem;margin-bottom:1rem}.modal-post-footer{gap:1.5rem;flex-wrap:wrap}.modal-post-action{padding:.5rem .75rem;font-size:.9rem}.modal-post-image{border-radius:12px;margin-bottom:1rem}.modal-post-image img{max-height:50vh}}.signup-page{min-height:100vh;display:flex;flex-direction:column;position:relative}.signup-nav-btn{padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:12px;background:#ffffff1a;backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);color:#ffffffe6;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);white-space:nowrap}.signup-nav-btn:hover{background:#fff3;border-color:#ffffff80;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a,inset 0 1px #ffffff4d}.back-button{position:fixed;top:20px;right:20px;z-index:1001;display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:12px;background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);color:#ffffffe6;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);box-shadow:0 8px 32px #0000001f,inset 0 1px #fff6,inset 0 -1px #ffffff1a}.back-button:hover{background:#ffffff40;backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);-webkit-backdrop-filter:blur(50px) saturate(140%) brightness(1.15) contrast(1.15);color:#fff;transform:translateY(-2px);box-shadow:0 12px 40px #00000026,inset 0 1px #ffffff80,inset 0 -1px #ffffff26}.signup-container{flex:1;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 4rem;min-height:100vh}.signup-card{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px #fff6,inset 0 -1px #ffffff1a;padding:2.5rem;width:100%;max-width:500px;margin:0 auto;animation:signupSlideIn .5s ease-out}@keyframes signupSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.signup-header{text-align:center;margin-bottom:1.5rem}.signup-header h1{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem}.signup-header p{font-size:1rem;color:#ffffffb3}.signup-form{display:flex;flex-direction:column;gap:1.25rem;margin:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;margin:0}.form-group{display:flex;flex-direction:column;gap:.5rem;width:100%;margin:0}.form-group label{font-size:.9rem;font-weight:500;color:#ffffffe6}.form-group input{width:100%;padding:.875rem 1rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:#0000004d;backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);font-size:.95rem;color:#fff;transition:all .3s cubic-bezier(.25,.46,.45,.94);outline:none;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff1a;box-sizing:border-box}.form-group input::placeholder{color:#fff6;font-weight:400}.form-group input:focus{background:#00000080;border-color:#fff6;backdrop-filter:blur(25px) saturate(130%) contrast(1.2);-webkit-backdrop-filter:blur(25px) saturate(130%) contrast(1.2);box-shadow:0 4px 16px #0003,0 0 0 2px #ffffff1a,inset 0 1px #fff3;transform:translateY(-1px)}.form-group input.error{border-color:#ff636399;background:#ff63631a}.form-group input.error:focus{border-color:#ff6363cc;box-shadow:0 4px 16px #ff636333,0 0 0 2px #ff63631a,inset 0 1px #fff3}.error-message{font-size:.75rem;color:#ff6363e6;margin-top:.125rem;margin-bottom:0}.signup-button{padding:.875rem 2rem;border:none;border-radius:12px;background:linear-gradient(135deg,#fff3,#ffffff1a);backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);box-shadow:0 4px 16px #0000001a,inset 0 1px #ffffff4d;margin-top:.75rem}.signup-button:hover{background:linear-gradient(135deg,#ffffff4d,#fff3);backdrop-filter:blur(25px) saturate(130%) contrast(1.2);-webkit-backdrop-filter:blur(25px) saturate(130%) contrast(1.2);border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 8px 24px #00000026,inset 0 1px #fff6}.signup-button:active{transform:translateY(0);box-shadow:0 2px 8px #0000001a,inset 0 1px #fff3}.signup-footer{text-align:center;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.1)}.signup-footer p{font-size:.9rem;color:#ffffffb3}.login-link{background:none;border:none;color:#ffffffe6;font-weight:500;cursor:pointer;text-decoration:underline;margin-left:.5rem;transition:color .3s ease}.login-link:hover{color:#fff}@media(max-width:768px){.signup-container{padding:4.5rem 1rem 3rem}.signup-card{padding:1.5rem}.signup-header{margin-bottom:1.25rem}.signup-header h1{font-size:1.75rem;margin-bottom:.375rem}.signup-form{gap:1rem}.form-row{grid-template-columns:1fr;gap:1rem}.form-group input{padding:.75rem .875rem;font-size:.9rem}.error-message{font-size:.7rem;margin-top:.125rem}.signup-button{padding:.75rem 1.5rem;font-size:.95rem;margin-top:.5rem}.signup-footer{margin-top:1.25rem;padding-top:1rem}.back-button{top:15px;right:15px;padding:.5rem .75rem;font-size:.8rem}.signup-nav-btn{padding:.4rem .8rem;font-size:.8rem}}@media(max-width:640px){.signup-container{padding:4rem 1rem 2rem}.signup-card{padding:1.25rem;border-radius:16px}.signup-header{margin-bottom:1rem}.signup-header h1{font-size:1.5rem;margin-bottom:.25rem}.signup-header p{font-size:.9rem}.signup-form{gap:.875rem}.form-group label{font-size:.85rem}.form-group input{padding:.625rem .75rem;font-size:.875rem}.error-message{font-size:.65rem}.signup-button{padding:.625rem 1.25rem;font-size:.9rem;margin-top:.25rem}.signup-footer{margin-top:1rem;padding-top:.875rem}.signup-footer p{font-size:.85rem}}.profile-page{min-height:100vh;display:flex;flex-direction:column;position:relative;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1f1f1f,#333,#0f0f0f);background-size:400% 400%;animation:gradientShift 20s ease infinite}.profile-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:6rem 2rem 4rem;min-height:100vh;max-width:1600px;margin:0 auto;width:100%}.profile-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:2rem;width:100%;max-width:1400px;align-items:stretch}.profile-card{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px #fff6,inset 0 -1px #ffffff1a;padding:2.5rem;width:100%;max-width:600px;margin:0 auto;animation:profileSlideIn .5s ease-out;height:87vh;max-height:87vh;overflow-y:auto;overflow-x:hidden}@keyframes profileSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.profile-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.profile-header h1{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-header p{font-size:1.1rem;color:#ffffffb3;font-weight:400}.profile-picture-section{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.profile-avatar{width:100px;height:100px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;overflow:hidden;border:3px solid rgba(255,255,255,.2);transition:all .3s ease;position:relative}.profile-avatar:hover{border-color:#fff6;transform:scale(1.05)}.profile-img{width:100%;height:100%;object-fit:cover}.profile-placeholder{font-size:2.5rem;color:#ffffffb3;font-weight:600}.upload-overlay{position:absolute;inset:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:50%;display:flex;align-items:center;justify-content:center}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff}.upload-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.progress-bar{width:60px;height:4px;background:#ffffff4d;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:2px;transition:width .3s ease}.progress-text{font-size:.75rem;font-weight:600;color:#fff}.edit-picture-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fffc;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease}.edit-picture-btn:hover{background:#fff3;border-color:#ffffff80;color:#fff;transform:translateY(-1px)}.profile-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center}.logout-button{padding:.75rem 1.5rem;border:1px solid rgba(255,99,99,.3);border-radius:12px;background:#ff63631a;backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);color:#ff6363e6;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);box-shadow:0 4px 16px #ff63631a,inset 0 1px #ffffff1a;min-width:120px}.logout-button:hover{background:#ff636333;border-color:#ff636380;color:#ff6363;transform:translateY(-2px);box-shadow:0 8px 24px #ff636326,inset 0 1px #fff3}.cancel-button{padding:.75rem 1.5rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:#ffffff0d;backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);color:#ffffffb3;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);box-shadow:0 4px 16px #0000001a,inset 0 1px #ffffff1a;min-width:120px}.cancel-button:hover{background:#ffffff1a;border-color:#fff6;color:#ffffffe6;transform:translateY(-2px);box-shadow:0 8px 24px #00000026,inset 0 1px #fff3}.profile-info{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.info-item:last-child{border-bottom:none}.info-label{font-size:.9rem;color:#ffffffb3;font-weight:500}.info-value{font-size:.9rem;color:#ffffffe6;font-weight:400;font-family:Courier New,monospace}.form-group input:disabled{background:#0003;border-color:#ffffff1a;color:#fff9;cursor:not-allowed}.form-group input:disabled::placeholder{color:#ffffff4d}@media(max-width:768px){.profile-picture-section{margin-bottom:1.5rem;padding-bottom:1rem}.profile-avatar{width:80px;height:80px;margin-bottom:.75rem}.profile-placeholder{font-size:2rem}.edit-picture-btn{padding:.4rem .8rem;font-size:.8rem}.profile-actions{flex-direction:column;gap:.75rem;margin-top:1rem}.logout-button,.cancel-button{padding:.7rem 1.25rem;font-size:.85rem;min-width:100px}.profile-info{margin-top:1.5rem;padding-top:1rem}.info-item{padding:.5rem 0;flex-direction:column;align-items:flex-start;gap:.25rem}.info-label,.info-value{font-size:.85rem}}@media(max-width:640px){.profile-avatar{width:70px;height:70px}.profile-placeholder{font-size:1.75rem}.edit-picture-btn{padding:.375rem .75rem;font-size:.75rem}.logout-button,.cancel-button{padding:.6rem 1rem;font-size:.8rem;min-width:90px}}.profile-field-display{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 16px;color:#fff;font-size:16px;min-height:48px;display:flex;align-items:center;transition:all .3s ease}.profile-field-display:hover{background:#ffffff26;border-color:#ffffff4d}.profile-field-display:empty:before{content:"Not set";color:#fff9;font-style:italic}.create-post-page{min-height:100vh;display:flex;flex-direction:column;position:relative;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1f1f1f,#333,#0f0f0f);background-size:400% 400%;animation:gradientShift 20s ease infinite}.create-post-container{flex:1;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 4rem;min-height:100vh}.create-post-card{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px #fff6,inset 0 -1px #ffffff1a;padding:2.5rem;width:100%;max-width:600px;margin:0 auto;animation:createPostSlideIn .5s ease-out}@keyframes createPostSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.create-post-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.create-post-header h1{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.create-post-header p{font-size:1.1rem;color:#ffffffb3;font-weight:400}.create-post-form{display:flex;flex-direction:column;gap:1.5rem;margin:0}.create-post-form .form-group{display:flex;flex-direction:column;gap:.5rem;width:100%;margin:0}.create-post-form .form-group label{font-size:.9rem;font-weight:500;color:#ffffffe6}.create-post-form .form-group input,.create-post-form .form-group textarea{width:100%;padding:.875rem 1rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:#0000004d;backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);font-size:.95rem;color:#fff;transition:all .3s cubic-bezier(.25,.46,.45,.94);outline:none;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff1a;box-sizing:border-box;font-family:inherit}.create-post-form .form-group textarea{resize:vertical;min-height:120px;line-height:1.5}.create-post-form .form-group input::placeholder,.create-post-form .form-group textarea::placeholder{color:#fff6;font-weight:400}.create-post-form .form-group input:focus,.create-post-form .form-group textarea:focus{background:#00000080;border-color:#fff6;backdrop-filter:blur(25px) saturate(130%) contrast(1.2);-webkit-backdrop-filter:blur(25px) saturate(130%) contrast(1.2);box-shadow:0 4px 16px #0003,0 0 0 2px #ffffff1a,inset 0 1px #fff3;transform:translateY(-1px)}.create-post-form .form-group input:disabled,.create-post-form .form-group textarea:disabled{background:#0003;border-color:#ffffff1a;color:#fff9;cursor:not-allowed}.character-count{font-size:.75rem;color:#fff9;text-align:right;margin-top:.25rem}.image-upload-section{display:flex;flex-direction:column;gap:1rem}.image-upload-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:2px dashed rgba(255,255,255,.3);border-radius:12px;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fffc;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;min-height:80px}.image-upload-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80;color:#fff;transform:translateY(-1px)}.image-upload-btn:disabled{opacity:.6;cursor:not-allowed}.image-preview-container{position:relative;border-radius:12px;overflow:hidden;background:#0000004d;border:1px solid rgba(255,255,255,.2)}.image-preview{width:100%;height:200px;object-fit:cover;display:block}.remove-image-btn{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;border:none;border-radius:50%;background:#000000b3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#ffffffe6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.remove-image-btn:hover:not(:disabled){background:#ff6363cc;color:#fff;transform:scale(1.1)}.remove-image-btn:disabled{opacity:.6;cursor:not-allowed}.image-help-text{font-size:.75rem;color:#fff9;margin-top:.25rem}.form-actions{display:flex;gap:1rem;margin-top:1rem;justify-content:flex-end}.create-post-button{padding:.875rem 2rem;border:none;border-radius:12px;background:linear-gradient(135deg,#fff3,#ffffff1a);backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);box-shadow:0 4px 16px #0000001a,inset 0 1px #ffffff4d;display:flex;align-items:center;gap:.5rem;min-width:140px;justify-content:center}.create-post-button:hover:not(:disabled){background:linear-gradient(135deg,#ffffff4d,#fff3);backdrop-filter:blur(25px) saturate(130%) contrast(1.2);-webkit-backdrop-filter:blur(25px) saturate(130%) contrast(1.2);border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 8px 24px #00000026,inset 0 1px #fff6}.create-post-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #0000001a,inset 0 1px #fff3}.create-post-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.button-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid #fff;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.create-post-container{padding:4.5rem 1rem 3rem}.create-post-card{padding:1.5rem;max-width:100%}.create-post-header{margin-bottom:1.5rem;padding-bottom:1rem}.create-post-header h1{font-size:2rem;margin-bottom:.375rem}.create-post-header p{font-size:1rem}.create-post-form{gap:1.25rem}.form-actions{flex-direction:column;gap:.75rem;margin-top:.75rem}.create-post-button,.cancel-button{padding:.75rem 1.5rem;font-size:.95rem;min-width:100px}.image-preview{height:150px}}@media(max-width:640px){.create-post-container{padding:4rem 1rem 2rem}.create-post-card{padding:1.25rem;border-radius:16px}.create-post-header{margin-bottom:1rem;padding-bottom:.875rem}.create-post-header h1{font-size:1.75rem;margin-bottom:.25rem}.create-post-header p{font-size:.9rem}.create-post-form{gap:1rem}.create-post-form .form-group input,.create-post-form .form-group textarea{padding:.75rem .875rem;font-size:.9rem}.form-actions{margin-top:.5rem}.create-post-button,.cancel-button{padding:.625rem 1.25rem;font-size:.9rem;min-width:90px}.image-preview{height:120px}}@media(max-width:768px){.profile-container{padding:4.5rem 1rem 3rem}.profile-card{padding:1.5rem;max-width:100%}.profile-header{margin-bottom:1.5rem;padding-bottom:1rem}.profile-header h1{font-size:2rem;margin-bottom:.375rem}.profile-header p{font-size:1rem}.profile-picture-section{margin-bottom:1.5rem;padding-bottom:1rem}.profile-avatar{width:80px;height:80px;margin-bottom:.75rem}.profile-placeholder{font-size:2rem}.edit-picture-btn{padding:.4rem .8rem;font-size:.8rem}.profile-actions{flex-direction:column;gap:.75rem;margin-top:1rem}.logout-button,.cancel-button{padding:.7rem 1.25rem;font-size:.85rem;min-width:100px}.profile-info{margin-top:1.5rem;padding-top:1rem}.info-item{padding:.5rem 0;flex-direction:column;align-items:flex-start;gap:.25rem}.info-label,.info-value{font-size:.85rem}}@media(max-width:640px){.profile-container{padding:4rem 1rem 2rem}.profile-card{padding:1.25rem;border-radius:16px}.profile-header{margin-bottom:1rem;padding-bottom:.875rem}.profile-header h1{font-size:1.75rem;margin-bottom:.25rem}.profile-header p{font-size:.9rem}.profile-avatar{width:70px;height:70px}.profile-placeholder{font-size:1.75rem}.edit-picture-btn{padding:.375rem .75rem;font-size:.75rem}.logout-button,.cancel-button{padding:.6rem 1rem;font-size:.8rem;min-width:90px}}.profile-posts-card{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px #fff6,inset 0 -1px #ffffff1a;padding:1.5rem;width:100%;animation:profileSlideIn .5s ease-out;display:flex;flex-direction:column;height:87vh;max-height:87vh;overflow-y:auto;overflow-x:hidden}.posts-feed-title{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:1rem;text-align:center;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex-shrink:0}.posts-feed{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;overflow:visible;padding-right:.5rem;flex:1}.posts-feed::-webkit-scrollbar{width:8px}.posts-feed::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.posts-feed::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:10px}.posts-feed::-webkit-scrollbar-thumb:hover{background:#ffffff80}.post-feed-item{background:#ffffff1a;backdrop-filter:blur(20px) saturate(120%);-webkit-backdrop-filter:blur(20px) saturate(120%);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1rem;transition:all .3s ease;flex-shrink:0;aspect-ratio:1;display:flex;flex-direction:column;overflow:hidden}.post-feed-image{width:100%;height:200px;margin-bottom:.75rem;border-radius:8px;overflow:hidden;background:#0003;flex-shrink:0}.post-feed-image img{width:100%;height:100%;object-fit:cover;display:block}.post-feed-content{display:flex;flex-direction:column;gap:.5rem;flex:1;min-height:0;overflow:hidden}.post-feed-item-title{font-size:1rem;font-weight:700;color:#fff;margin:0;word-wrap:break-word;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex-shrink:0}.post-feed-text{font-size:.85rem;line-height:1.4;color:#ffffffd9;margin:0;word-wrap:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1}.post-feed-date{font-size:.75rem;color:#fff9;font-weight:500;margin-top:.25rem}.no-posts{text-align:center;padding:3rem 1rem;color:#ffffffb3}.no-posts p{font-size:1.1rem;margin:0}@media(max-width:1200px){.profile-layout{grid-template-columns:1fr;gap:2rem}}@media(max-width:768px){.profile-card{height:80vh;max-height:80vh;padding:1.5rem}.profile-posts-card{padding:1.5rem;height:80vh;max-height:80vh}.posts-feed-title{font-size:1.5rem;margin-bottom:1rem}.post-feed-item{padding:.875rem}.post-feed-item-title{font-size:1.1rem}.post-feed-text{font-size:.85rem}}@media(max-width:640px){.profile-card{height:75vh;max-height:75vh;padding:1.25rem}.profile-posts-card{padding:1rem;height:75vh;max-height:75vh}.posts-feed-title{font-size:1.25rem;margin-bottom:.75rem}.post-feed-item-title{font-size:1rem}.post-feed-text{font-size:.85rem}}.post-detail-modal-overlay{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease-out;overflow:hidden}.post-detail-modal-overlay .post-detail-modal{overflow-y:auto;overflow-x:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.post-detail-modal{background:#ffffff26;backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);-webkit-backdrop-filter:blur(40px) saturate(120%) brightness(1.1) contrast(1.1);border:2px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px #fff6,inset 0 -1px #ffffff1a;max-width:800px;width:100%;max-height:98vh;overflow-y:auto;overflow-x:hidden;animation:slideIn .3s ease-out;display:flex;flex-direction:column;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}.post-detail-modal::-webkit-scrollbar{width:8px}.post-detail-modal::-webkit-scrollbar-track{background:transparent}.post-detail-modal::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.post-detail-modal::-webkit-scrollbar-thumb:hover{background:#ffffff80}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.post-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.2)}.post-detail-title{font-size:1.75rem;font-weight:700;color:#fff;margin:0}.post-detail-close-btn{background:none;border:none;color:#fffc;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.post-detail-close-btn:hover{background:#ffffff1a;color:#fff;transform:rotate(90deg)}.post-detail-user-info{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.post-detail-avatar{width:48px;height:48px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.post-detail-user-info strong{display:block;font-size:1rem;font-weight:700;color:#fff}.post-detail-username{display:block;font-size:.875rem;color:#fff9;margin-top:.25rem}.post-detail-image{width:100%;overflow:visible;margin:0;padding:0;background:#0000001a;border-radius:0;display:flex;align-items:center;justify-content:center}.post-detail-image img{max-width:100%;height:auto;object-fit:contain;display:block;transition:transform .3s ease;width:auto;max-height:70vh}.post-detail-image img:hover{transform:scale(1.01)}.post-detail-content{padding:1.5rem}.post-detail-text{font-size:1.1rem;line-height:1.7;color:#ffffffe6;margin-bottom:1.5rem;white-space:pre-wrap;word-wrap:break-word}.post-detail-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2);gap:1rem}.post-detail-actions,.post-detail-meta{display:flex;align-items:center;gap:1rem}.post-like-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.post-like-btn:hover{color:#ff6b6b;background:#ff6b6b1a}.post-like-btn.liked{color:#ff6b6b}.post-like-btn.liked:hover{color:#ff5252;background:#ff6b6b26}.comments-section{padding:1.5rem;border-top:1px solid rgba(255,255,255,.2)}.comments-title{font-size:1.25rem;font-weight:600;color:#fff;margin:0 0 1.5rem;display:flex;align-items:center;gap:.5rem}.add-comment-form{margin-bottom:2rem}.comment-input{width:100%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1rem;color:#fff;font-size:1rem;line-height:1.5;resize:vertical;min-height:80px;margin-bottom:1rem;transition:all .2s ease}.comment-input::placeholder{color:#fff9}.comment-input:focus{outline:none;border-color:#fff6;background:#ffffff26;box-shadow:0 0 0 3px #ffffff1a}.comment-input:disabled{opacity:.6;cursor:not-allowed}.comment-submit-btn{padding:.75rem 1.5rem;border:1px solid rgba(255,255,255,.3);border-radius:12px;background:linear-gradient(135deg,#fff3,#ffffff1a);backdrop-filter:blur(20px) saturate(120%) contrast(1.1);-webkit-backdrop-filter:blur(20px) saturate(120%) contrast(1.1);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;box-shadow:0 4px 16px #0000001a,inset 0 1px #fff3}.comment-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#ffffff4d,#fff3);backdrop-filter:blur(25px) saturate(130%) contrast(1.2);-webkit-backdrop-filter:blur(25px) saturate(130%) contrast(1.2);border-color:#ffffff80;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #00000026,inset 0 1px #ffffff4d}.comment-submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #0000001a,inset 0 1px #fff3}.comment-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.comments-list{display:flex;flex-direction:column;gap:1rem;max-height:400px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.comments-list::-webkit-scrollbar{width:6px}.comments-list::-webkit-scrollbar-track{background:transparent}.comments-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.comments-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.comment-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;transition:all .2s ease}.comment-item:hover{background:#ffffff14;border-color:#ffffff26}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:1rem}.comment-author{font-weight:600;color:#667eea;font-size:.9rem}.comment-date{color:#fff9;font-size:.8rem;white-space:nowrap}.comment-delete-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.comment-delete-btn:hover{color:#ff6b6b;background:#ff6b6b1a}.comment-content{color:#ffffffe6;line-height:1.6;margin:0;white-space:pre-wrap;word-wrap:break-word}.comment-actions{display:flex;align-items:center;gap:1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.comment-like-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.comment-like-btn:hover{color:#ff6b6b;background:#ff6b6b1a}.comment-like-btn.liked{color:#ff6b6b}.comment-like-btn.liked:hover{color:#ff5252;background:#ff6b6b26}.comments-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#ffffffb3}.comments-loading .loading-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:.5rem}.no-comments{text-align:center;padding:2rem;color:#fff9;font-style:italic}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.post-detail-modal-overlay{padding:2rem 1rem 1rem;align-items:flex-start}.post-detail-modal{max-height:calc(100vh - 4rem);max-width:100%;margin:0}.post-detail-image img{height:auto}.post-detail-footer{flex-direction:column;align-items:flex-start;gap:1rem}.post-detail-meta{width:100%;justify-content:space-between}.comments-list{max-height:300px}.comment-input{min-height:60px}}@media(max-width:480px){.post-detail-modal-overlay{padding:1rem .5rem .5rem}.post-detail-modal{max-height:calc(100vh - 2rem);border-radius:16px}.post-detail-header,.post-detail-content,.comments-section{padding:1rem}.comments-list{max-height:250px}}.post-detail-date{font-size:.9rem;color:#fff9;font-weight:500}.post-delete-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#dc354533;border:1px solid rgba(220,53,69,.5);border-radius:8px;color:#ff6b6b;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.post-delete-btn:hover:not(:disabled){background:#dc35454d;border-color:#dc3545b3;color:#ff5252;transform:translateY(-1px)}.post-delete-btn:disabled{opacity:.6;cursor:not-allowed}.post-delete-btn svg{flex-shrink:0}.post-feed-item{cursor:pointer}.post-feed-item:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 8px 24px #0003}.relationship-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.relationship-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.relationship-subtitle{font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 .75rem}.relationship-text{font-size:1rem;line-height:1.6;color:#ffffffe6;margin:0;white-space:pre-wrap;word-wrap:break-word}.similarity-badge{display:inline-block;padding:.5rem 1rem;background:#667eea33;border:1px solid rgba(102,126,234,.5);border-radius:8px;color:#667eea;font-size:.9rem;font-weight:600}.relationship-posts-preview{display:flex;align-items:center;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.2)}.relationship-post-card{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem}.relationship-post-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.relationship-post-avatar{width:32px;height:32px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.relationship-post-info strong{font-size:.9rem;font-weight:600;color:#fff}.relationship-post-title{font-size:.95rem;font-weight:600;color:#fffffff2;margin:0 0 .5rem;line-height:1.3}.relationship-post-content-preview{font-size:.85rem;line-height:1.5;color:#fffc;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.relationship-posts-connector{font-size:1.5rem;color:#fff6;font-weight:700}@media(max-width:768px){.relationship-posts-preview{flex-direction:column;gap:1rem}.relationship-posts-connector{transform:rotate(90deg)}.relationship-post-card{min-width:100%}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}
